Fixed possible buffer overrun in the XPLAINBridge project when in serial bridge mode.
authorDean Camera <dean@fourwalledcubicle.com>
Thu, 15 Jul 2010 04:45:31 +0000 (04:45 +0000)
committerDean Camera <dean@fourwalledcubicle.com>
Thu, 15 Jul 2010 04:45:31 +0000 (04:45 +0000)
Projects/Benito/Lib/LightweightRingBuff.h
Projects/USBtoSerial/Lib/LightweightRingBuff.h
Projects/USBtoSerial/USBtoSerial.c
Projects/XPLAINBridge/Lib/LightweightRingBuff.h
Projects/XPLAINBridge/XPLAINBridge.c

index 9c25707..0ffe792 100644 (file)
                        Buffer->Count = 0;
                }
                
+               /** Atomically determines if the specified ring buffer contains any free space. This should
+                *  be tested before storing data to the buffer, to ensure that no data is lost due to a
+                *  buffer overrun.
+                *
+                *  \param[in,out] Buffer  Pointer to a ring buffer structure to insert into
+                *
+                *  \return Boolean true if the buffer contains no free space, false otherwise
+                */              
+               static inline bool RingBuffer_IsFull(RingBuff_t* const Buffer)
+               {
+                       bool IsFull;
+                       
+                       ATOMIC_BLOCK(ATOMIC_RESTORESTATE)
+                       {
+                               IsFull = (Buffer->Count == BUFFER_SIZE);
+                       }
+                       
+                       return IsFull;
+               }
+               
                /** Atomically inserts an element into the ring buffer.
                 *
                 *  \param[in,out] Buffer  Pointer to a ring buffer structure to insert into
index 9c25707..0ffe792 100644 (file)
                        Buffer->Count = 0;
                }
                
+               /** Atomically determines if the specified ring buffer contains any free space. This should
+                *  be tested before storing data to the buffer, to ensure that no data is lost due to a
+                *  buffer overrun.
+                *
+                *  \param[in,out] Buffer  Pointer to a ring buffer structure to insert into
+                *
+                *  \return Boolean true if the buffer contains no free space, false otherwise
+                */              
+               static inline bool RingBuffer_IsFull(RingBuff_t* const Buffer)
+               {
+                       bool IsFull;
+                       
+                       ATOMIC_BLOCK(ATOMIC_RESTORESTATE)
+                       {
+                               IsFull = (Buffer->Count == BUFFER_SIZE);
+                       }
+                       
+                       return IsFull;
+               }
+               
                /** Atomically inserts an element into the ring buffer.
                 *
                 *  \param[in,out] Buffer  Pointer to a ring buffer structure to insert into
index 145047c..1cd6f55 100644 (file)
@@ -84,7 +84,7 @@ int main(void)
                /* Read bytes from the USB OUT endpoint into the USART transmit buffer */
                for (uint8_t DataBytesRem = CDC_Device_BytesReceived(&VirtualSerial_CDC_Interface); DataBytesRem != 0; DataBytesRem--)
                {
-                       if (!(BUFFER_SIZE - USBtoUSART_Buffer.Count))
+                       if (RingBuffer_IsFull(&USBtoUSART_Buffer))
                          break;
                          
                        RingBuffer_AtomicInsert(&USBtoUSART_Buffer, CDC_Device_ReceiveByte(&VirtualSerial_CDC_Interface));
index 9c25707..0ffe792 100644 (file)
                        Buffer->Count = 0;
                }
                
+               /** Atomically determines if the specified ring buffer contains any free space. This should
+                *  be tested before storing data to the buffer, to ensure that no data is lost due to a
+                *  buffer overrun.
+                *
+                *  \param[in,out] Buffer  Pointer to a ring buffer structure to insert into
+                *
+                *  \return Boolean true if the buffer contains no free space, false otherwise
+                */              
+               static inline bool RingBuffer_IsFull(RingBuff_t* const Buffer)
+               {
+                       bool IsFull;
+                       
+                       ATOMIC_BLOCK(ATOMIC_RESTORESTATE)
+                       {
+                               IsFull = (Buffer->Count == BUFFER_SIZE);
+                       }
+                       
+                       return IsFull;
+               }
+               
                /** Atomically inserts an element into the ring buffer.
                 *
                 *  \param[in,out] Buffer  Pointer to a ring buffer structure to insert into
index f08dfc5..3bbc0bc 100644 (file)
@@ -120,7 +120,7 @@ void UARTBridge_Task(void)
          return;
 
        /* Read bytes from the USB OUT endpoint into the UART transmit buffer */
-       if (CDC_Device_BytesReceived(&VirtualSerial_CDC_Interface))
+       if (CDC_Device_BytesReceived(&VirtualSerial_CDC_Interface) && !(RingBuffer_IsFull(&USBtoUART_Buffer)))
          RingBuffer_AtomicInsert(&USBtoUART_Buffer, CDC_Device_ReceiveByte(&VirtualSerial_CDC_Interface));
        
        /* Check if the software UART flush timer has expired */