fullspeed devices will be detected now
authorBernhard Urban <lewurm@gmx.net>
Wed, 23 Sep 2009 02:41:11 +0000 (04:41 +0200)
committerBernhard Urban <lewurm@gmx.net>
Wed, 23 Sep 2009 02:41:58 +0000 (04:41 +0200)
usb/core/core.c
usb/core/core.h
usb/core/usb.c
usb/host/ohci.c

index 0f30731bbb8a45f24fcfb69c92fbfc16d222395a..2028251f5726d68feb5ae3d84a61bef6b1de8f0a 100644 (file)
@@ -86,13 +86,16 @@ void usb_periodic()
  * for the core. usb_add_device expected that
  * the device answers to address zero.
  */
-struct usb_device *usb_add_device()
+struct usb_device *usb_add_device(u8 lowspeed)
 {
        struct usb_device *dev = (struct usb_device *) malloc(sizeof(struct usb_device));
        dev->conf = (struct usb_conf *) malloc(sizeof(struct usb_conf));
        dev->address = 0;
-       /* send at first time only 8 bytes */
-       dev->bMaxPacketSize0 = 8;
+       dev->fullspeed = lowspeed ? 0 : 1;
+       /* send at first time only 8 bytes for lowspeed devices
+        * 64 bytes for fullspeed
+        */
+       dev->bMaxPacketSize0 = lowspeed ? 8 : 64;
 
        dev->epSize[0] = 64;
        dev->epSize[1] = 64;
@@ -156,10 +159,12 @@ struct usb_device *usb_add_device()
        /* print device info */
        lsusb(dev);
 
+#if 0
        /* select configuration */
        ret = usb_set_configuration(dev, dev->conf->bConfigurationValue);
        printf("=============\nusb_set_configuration(ret: %d) %d\n", ret, dev->conf->bConfigurationValue);
        printf("=============\nusb_get_configuration: %d\n", usb_get_configuration(dev));
+#endif
 
 #if 0
        u8 buf[8];
@@ -202,7 +207,7 @@ void lsusb(struct usb_device *dev)
        printf("iProduct(0x%02X): \"%s\"\n", dev->iProduct, dev->iProduct ? usb_get_string_simple(dev, dev->iProduct) : "no String");
        printf("iSerialNumber(0x%02X): \"%s\"\n", dev->iSerialNumber, dev->iSerialNumber ? usb_get_string_simple(dev, dev->iSerialNumber) : "no String");
        printf("bNumConfigurations 0x%02X\n", dev->bNumConfigurations);
-       
+
        u8 c, i, e;
        struct usb_conf *conf = dev->conf;
        for(c=0; c <= dev->bNumConfigurations; c++) {
@@ -241,7 +246,7 @@ void lsusb(struct usb_device *dev)
 
                                ed = ed->next;
                        } //endpoint
-                       
+
                        ifs = ifs->next;
                } //interface
 
@@ -515,6 +520,7 @@ struct usb_transfer_descriptor *usb_create_transfer_descriptor(struct usb_irp *
        td->iso = 0;
        td->state = USB_TRANSFER_DESCR_NONE;
        td->maxp = irp->epsize;
+       td->fullspeed = irp->dev->fullspeed;
 
        return td;
 }
index b8149d3aef08230afb11d4918c0c1d92b7979883..b906bf2c6463b60e1831c49443e726db8b3e36e6 100644 (file)
@@ -165,6 +165,7 @@ struct usb_irp {
 struct usb_transfer_descriptor {
        u8 devaddress;
        u8 endpoint;
+       u8 fullspeed;
        
        // TODO: zusammenfassen!
        u8 pid;
@@ -192,7 +193,7 @@ void usb_periodic();
 u8 usb_next_address();
 
 
-struct usb_device *usb_add_device();
+struct usb_device *usb_add_device(u8 lowspeed);
 u8 usb_remove_device(struct usb_device *dev);
 u8 usb_register_driver(struct usb_driver *driver);
 void usb_probe_driver();
index c0ff3fb1820b863cfa19be899a824045b157516f..dd21166b838c7328543129e481c8186fbe9b6898 100644 (file)
@@ -111,7 +111,7 @@ s8 usb_control_msg(struct usb_device *dev, u8 requesttype, u8 request,
        struct usb_irp *irp = (struct usb_irp*)malloc(sizeof(struct usb_irp));
        irp->dev = dev;
        irp->endpoint = 0;
-       
+
        irp->epsize = dev->bMaxPacketSize0;
        irp->type = USB_CTRL;
 
index f18785ce5d4ced424db6d6ddc2f859ba327de487..db83e0f90e5f55609e9ae7edc82f147626c81d5a 100644 (file)
@@ -314,8 +314,12 @@ u8 hcdi_enqueue(const struct usb_transfer_descriptor *td) {
                memset(edhead, 0, sizeof(struct endpoint_descriptor));
                edhead->flags = LE(OHCI_ENDPOINT_GENERAL_FORMAT);
                edhead->headp = edhead->tailp = edhead->nexted = LE(0);
-               edhead->flags |= LE(OHCI_ENDPOINT_LOW_SPEED |
-                               OHCI_ENDPOINT_SET_DEVICE_ADDRESS(td->devaddress) |
+               if(td->fullspeed) {
+                       edhead->flags |= LE(OHCI_ENDPOINT_FULL_SPEED);
+               } else {
+                       edhead->flags |= LE(OHCI_ENDPOINT_LOW_SPEED);
+               }
+               edhead->flags |= LE(OHCI_ENDPOINT_SET_DEVICE_ADDRESS(td->devaddress) |
                                OHCI_ENDPOINT_SET_ENDPOINT_NUMBER(td->endpoint) |
                                OHCI_ENDPOINT_SET_MAX_PACKET_SIZE(td->maxp));
                edhead->tdcount = 0;
@@ -479,7 +483,8 @@ static void setup_port(u32 reg, u8 from_init)
                printf("loop done\n");
 #endif
 
-               (void) usb_add_device();
+               /* returns usb_device struct */
+               (void) usb_add_device((read32(reg) & RH_PS_LSDA) >> 8);
        }
 }