Add some limited support for low-speed devices to SL811 USB controller
authorwdenk <wdenk>
Tue, 11 May 2004 21:53:55 +0000 (21:53 +0000)
committerwdenk <wdenk>
Tue, 11 May 2004 21:53:55 +0000 (21:53 +0000)
(at least "usb reset" now passes successfully and "usb info" displays
correct information)

CHANGELOG
drivers/sl811_usb.c

index 0ddcc612dd67b880ba2c2c3bc515b684efc5eea1..5e9c5e508dad0fba3ba75c6bcaeaff32457d66e8 100644 (file)
--- a/CHANGELOG
+++ b/CHANGELOG
@@ -2,6 +2,10 @@
 Changes since U-Boot 1.1.1:
 ======================================================================
 
+* Add some limited support for low-speed devices to SL811 USB controller
+  (at least "usb reset" now passes successfully and "usb info" displays
+  correct information)
+
 * Change init sequence for multiple network interfaces: initialize
   on-chip interfaces before external cards.
 
index 5136cdc68d313d439df640b1ba117280b40ed0e9..61604e55ccbea012237d7f93c715dfa1bcd0990d 100644 (file)
@@ -228,7 +228,7 @@ int usb_lowlevel_stop(void)
 
 static int calc_needed_buswidth(int bytes, int low_speed)
 {
-       return bytes * 8 + 512;
+       return low_speed ? 0 : bytes * 8 + 512;
 }
 
 static int sl811_send_packet(int dir_to_host, int data1, __u8 *buffer, int len)
@@ -253,7 +253,8 @@ static int sl811_send_packet(int dir_to_host, int data1, __u8 *buffer, int len)
                if (!dir_to_host && len)
                        sl811_write_buf(0x10, buffer, len);
 
-               if (sl811_read(SL811_SOFCNTDIV)*64 < calc_needed_buswidth(len, 0))
+               if (sl811_read(SL811_SOFCNTDIV)*64 < 
+                   calc_needed_buswidth(len, rh_status.wPortStatus & USB_PORT_STAT_LOW_SPEED))
                        ctrl |= SL811_USB_CTRL_SOF;
                else
                        ctrl &= ~SL811_USB_CTRL_SOF;