projects
/
pub
/
USBasp.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (from parent 1:
8f9b5ae
)
Fixed USBtoSerial and XPLAINBridge demos discarding data from the PC if the send...
author
Dean Camera
<dean@fourwalledcubicle.com>
Wed, 3 Nov 2010 11:24:34 +0000
(11:24 +0000)
committer
Dean Camera
<dean@fourwalledcubicle.com>
Wed, 3 Nov 2010 11:24:34 +0000
(11:24 +0000)
LUFA/Drivers/USB/HighLevel/EndpointStream.h
patch
|
blob
|
blame
|
history
LUFA/Drivers/USB/HighLevel/PipeStream.h
patch
|
blob
|
blame
|
history
LUFA/ManPages/ChangeLog.txt
patch
|
blob
|
blame
|
history
LUFA/ManPages/LibraryResources.txt
patch
|
blob
|
blame
|
history
Projects/USBtoSerial/USBtoSerial.c
patch
|
blob
|
blame
|
history
Projects/XPLAINBridge/XPLAINBridge.c
patch
|
blob
|
blame
|
history
diff --git
a/LUFA/Drivers/USB/HighLevel/EndpointStream.h
b/LUFA/Drivers/USB/HighLevel/EndpointStream.h
index
5c3c957
..
a8b9021
100644
(file)
--- a/
LUFA/Drivers/USB/HighLevel/EndpointStream.h
+++ b/
LUFA/Drivers/USB/HighLevel/EndpointStream.h
@@
-51,7
+51,6
@@
#define __ENDPOINT_STREAM_H__
\r
\r
/* Includes: */
\r
#define __ENDPOINT_STREAM_H__
\r
\r
/* Includes: */
\r
- #include <avr/io.h>
\r
#include <avr/pgmspace.h>
\r
#include <avr/eeprom.h>
\r
#include <stdbool.h>
\r
#include <avr/pgmspace.h>
\r
#include <avr/eeprom.h>
\r
#include <stdbool.h>
\r
diff --git
a/LUFA/Drivers/USB/HighLevel/PipeStream.h
b/LUFA/Drivers/USB/HighLevel/PipeStream.h
index
1279a71
..
730a338
100644
(file)
--- a/
LUFA/Drivers/USB/HighLevel/PipeStream.h
+++ b/
LUFA/Drivers/USB/HighLevel/PipeStream.h
@@
-51,7
+51,6
@@
#define __PIPE_STREAM_H__
\r
\r
/* Includes: */
\r
#define __PIPE_STREAM_H__
\r
\r
/* Includes: */
\r
- #include <avr/io.h>
\r
#include <avr/pgmspace.h>
\r
#include <avr/eeprom.h>
\r
#include <stdbool.h>
\r
#include <avr/pgmspace.h>
\r
#include <avr/eeprom.h>
\r
#include <stdbool.h>
\r
diff --git
a/LUFA/ManPages/ChangeLog.txt
b/LUFA/ManPages/ChangeLog.txt
index
69b129d
..
86aac5c
100644
(file)
--- a/
LUFA/ManPages/ChangeLog.txt
+++ b/
LUFA/ManPages/ChangeLog.txt
@@
-93,6
+93,7
@@
* - Fixed random enumeration failure while in device mode due to interrupts causing the Set Address request to exceed maximum timings
* - Fixed MIDI_Host_Flush() not aborting early when the specified MIDI host interface was not configured
* - Fixed MIDI class driver send routines silently discarding packets if the endpoint or pipe is busy (thanks to Robin Green)
* - Fixed random enumeration failure while in device mode due to interrupts causing the Set Address request to exceed maximum timings
* - Fixed MIDI_Host_Flush() not aborting early when the specified MIDI host interface was not configured
* - Fixed MIDI class driver send routines silently discarding packets if the endpoint or pipe is busy (thanks to Robin Green)
+ * - Fixed USBtoSerial and XPLAINBridge demos discarding data from the PC if the send buffer becomes full
*
* \section Sec_ChangeLog100807 Version 100807
* <b>New:</b>
*
* \section Sec_ChangeLog100807 Version 100807
* <b>New:</b>
diff --git
a/LUFA/ManPages/LibraryResources.txt
b/LUFA/ManPages/LibraryResources.txt
index
062702b
..
7f67739
100644
(file)
--- a/
LUFA/ManPages/LibraryResources.txt
+++ b/
LUFA/ManPages/LibraryResources.txt
@@
-20,6
+20,7
@@
*
* \section Sec_InDevelopment Latest In-Development Source Code
* Issue Tracker: http://www.lufa-lib.org/tracker \n
*
* \section Sec_InDevelopment Latest In-Development Source Code
* Issue Tracker: http://www.lufa-lib.org/tracker \n
+ * Bazaar Access: http://www.lufa-lib.org/bzr \n
* SVN Access: http://www.lufa-lib.org/svn \n
* Git Access: http://www.lufa-lib.org/git \n
* Mercurial Access: http://www.lufa-lib.org/hg \n
* SVN Access: http://www.lufa-lib.org/svn \n
* Git Access: http://www.lufa-lib.org/git \n
* Mercurial Access: http://www.lufa-lib.org/hg \n
diff --git
a/Projects/USBtoSerial/USBtoSerial.c
b/Projects/USBtoSerial/USBtoSerial.c
index
3f06acd
..
c26667d
100644
(file)
--- a/
Projects/USBtoSerial/USBtoSerial.c
+++ b/
Projects/USBtoSerial/USBtoSerial.c
@@
-81,15
+81,21
@@
int main(void)
for (;;)
{
for (;;)
{
- /*
Read bytes from the USB OUT endpoint into the USART transmit buffer
*/
- i
nt16_t ReceivedByte = CDC_Device_ReceiveByte(&VirtualSerial_CDC_Interface);
- if (!(ReceivedByte < 0) && !(RingBuffer_IsFull(&USBtoUSART_Buffer)))
-
RingBuffer_Insert(&USBtoUSART_Buffer, ReceivedByt
e);
+ /*
Only try to read in bytes from the CDC interface if the transmit buffer is not full
*/
+ i
f (!(RingBuffer_IsFull(&USBtoUSART_Buffer)))
+ {
+
int16_t ReceivedByte = CDC_Device_ReceiveByte(&VirtualSerial_CDC_Interfac
e);
+ /* Read bytes from the USB OUT endpoint into the USART transmit buffer */
+ if (!(ReceivedByte < 0))
+ RingBuffer_Insert(&USBtoUSART_Buffer, ReceivedByte);
+ }
+
/* Check if the UART receive buffer flush timer has expired or the buffer is nearly full */
RingBuff_Count_t BufferCount = RingBuffer_GetCount(&USARTtoUSB_Buffer);
if ((TIFR0 & (1 << TOV0)) || (BufferCount > 200))
{
/* Check if the UART receive buffer flush timer has expired or the buffer is nearly full */
RingBuff_Count_t BufferCount = RingBuffer_GetCount(&USARTtoUSB_Buffer);
if ((TIFR0 & (1 << TOV0)) || (BufferCount > 200))
{
+ /* Clear flush timer expiry flag */
TIFR0 |= (1 << TOV0);
/* Read bytes from the USART receive buffer into the USB IN endpoint */
TIFR0 |= (1 << TOV0);
/* Read bytes from the USART receive buffer into the USB IN endpoint */
diff --git
a/Projects/XPLAINBridge/XPLAINBridge.c
b/Projects/XPLAINBridge/XPLAINBridge.c
index
8cd1b2d
..
d645ebe
100644
(file)
--- a/
Projects/XPLAINBridge/XPLAINBridge.c
+++ b/
Projects/XPLAINBridge/XPLAINBridge.c
@@
-119,15
+119,21
@@
void UARTBridge_Task(void)
if (USB_DeviceState != DEVICE_STATE_Configured)
return;
if (USB_DeviceState != DEVICE_STATE_Configured)
return;
- /*
Read bytes from the USB OUT endpoint into the UART transmit buffer
*/
- i
nt16_t ReceivedByte = CDC_Device_ReceiveByte(&VirtualSerial_CDC_Interface);
- if (!(ReceivedByte < 0) && !(RingBuffer_IsFull(&USBtoUART_Buffer)))
-
RingBuffer_Insert(&USBtoUART_Buffer, ReceivedByt
e);
+ /*
Only try to read in bytes from the CDC interface if the transmit buffer is not full
*/
+ i
f (!(RingBuffer_IsFull(&USBtoUART_Buffer)))
+ {
+
int16_t ReceivedByte = CDC_Device_ReceiveByte(&VirtualSerial_CDC_Interfac
e);
+ /* Read bytes from the USB OUT endpoint into the UART transmit buffer */
+ if (!(ReceivedByte < 0))
+ RingBuffer_Insert(&USBtoUART_Buffer, ReceivedByte);
+ }
+
/* Check if the UART receive buffer flush timer has expired or buffer is nearly full */
RingBuff_Count_t BufferCount = RingBuffer_GetCount(&UARTtoUSB_Buffer);
if ((TIFR0 & (1 << TOV0)) || (BufferCount > 200))
{
/* Check if the UART receive buffer flush timer has expired or buffer is nearly full */
RingBuff_Count_t BufferCount = RingBuffer_GetCount(&UARTtoUSB_Buffer);
if ((TIFR0 & (1 << TOV0)) || (BufferCount > 200))
{
+ /* Clear flush timer expiry flag */
TIFR0 |= (1 << TOV0);
/* Read bytes from the UART receive buffer into the USB IN endpoint */
TIFR0 |= (1 << TOV0);
/* Read bytes from the UART receive buffer into the USB IN endpoint */