diff options
author | Frank Gevaerts <frank@gevaerts.be> | 2009-08-12 20:35:01 +0000 |
---|---|---|
committer | Frank Gevaerts <frank@gevaerts.be> | 2009-08-12 20:35:01 +0000 |
commit | f10a3c7bed9d7f0ba03cce37853aa7e9ecfc8bae (patch) | |
tree | eeb58519a718f710fbbfefabe6fe0bcc54096497 /firmware | |
parent | e783d0c82a6673d036a71f3eab3e69f95d4b0b37 (diff) | |
download | rockbox-f10a3c7bed9d7f0ba03cce37853aa7e9ecfc8bae.tar.gz rockbox-f10a3c7bed9d7f0ba03cce37853aa7e9ecfc8bae.zip |
Limit usb_serial packets to 32 bytes. It's unclear why this is needed, but usb serial packets larger than 96 bytes seem to never be sent.
Thanks to Amaury Pouly for investigating this
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@22285 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'firmware')
-rw-r--r-- | firmware/usbstack/usb_serial.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/firmware/usbstack/usb_serial.c b/firmware/usbstack/usb_serial.c index 6c654ad898..99b8bb2c3f 100644 --- a/firmware/usbstack/usb_serial.c +++ b/firmware/usbstack/usb_serial.c | |||
@@ -158,6 +158,9 @@ void usb_serial_disconnect(void) | |||
158 | static void sendout(void) | 158 | static void sendout(void) |
159 | { | 159 | { |
160 | buffer_transitlength = MIN(buffer_length,BUFFER_SIZE-buffer_start); | 160 | buffer_transitlength = MIN(buffer_length,BUFFER_SIZE-buffer_start); |
161 | /* For unknown reasons packets larger than 96 bytes are not sent. We play | ||
162 | * safe and limit to 32. TODO: find the real bug */ | ||
163 | buffer_transitlength = MIN(buffer_transitlength,32); | ||
161 | if(buffer_transitlength > 0) | 164 | if(buffer_transitlength > 0) |
162 | { | 165 | { |
163 | buffer_length -= buffer_transitlength; | 166 | buffer_length -= buffer_transitlength; |