Changeset 71ed4849 in mainline
- Timestamp:
- 2010-12-28T14:00:36Z (14 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 8f8a0cd6
- Parents:
- de2c901
- Location:
- uspace
- Files:
-
- 9 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/drv/uhci/main.c
rde2c901 r71ed4849 27 27 */ 28 28 #include <usb/hcdhubd.h> 29 #include <usb_iface.h> 29 30 #include <usb/debug.h> 30 31 #include <errno.h> … … 32 33 #include "uhci.h" 33 34 35 static int usb_iface_get_hc_handle(device_t *dev, devman_handle_t *handle) 36 { 37 /* This shall be called only for the UHCI itself. */ 38 assert(dev->parent == NULL); 39 40 *handle = dev->handle; 41 return EOK; 42 } 43 44 static usb_iface_t hc_usb_iface = { 45 .get_hc_handle = usb_iface_get_hc_handle 46 }; 47 34 48 static device_ops_t uhci_ops = { 35 .interfaces[USBHC_DEV_IFACE] = &uhci_iface, 49 .interfaces[USB_DEV_IFACE] = &hc_usb_iface, 50 .interfaces[USBHC_DEV_IFACE] = &uhci_iface 36 51 }; 37 52 -
uspace/drv/usbhub/usbhub.c
rde2c901 r71ed4849 37 37 #include <errno.h> 38 38 39 #include <usb hc_iface.h>39 #include <usb_iface.h> 40 40 #include <usb/usbdrv.h> 41 41 #include <usb/descriptor.h> … … 46 46 #include "usbhub_private.h" 47 47 #include "port_status.h" 48 49 static usb_iface_t hub_usb_iface = { 50 .get_hc_handle = usb_drv_find_hc 51 }; 52 53 static device_ops_t hub_device_ops = { 54 .interfaces[USB_DEV_IFACE] = &hub_usb_iface 55 }; 48 56 49 57 //********************************************* … … 135 143 * connected devices. 136 144 */ 145 dev->ops = &hub_device_ops; 137 146 138 147 //create the hub structure 139 148 //get hc connection 140 int hc = usb_drv_hc_connect(dev, 0); 149 int hc = usb_drv_hc_connect_auto(dev, 0); 150 if (hc < 0) { 151 return hc; 152 } 141 153 142 154 usb_hub_info_t * hub_info = usb_create_hub_info(dev, hc); … … 464 476 * Connect to respective HC. 465 477 */ 466 int hc = usb_drv_hc_connect (hub_info->device, 0);478 int hc = usb_drv_hc_connect_auto(hub_info->device, 0); 467 479 if (hc < 0) { 468 480 continue; -
uspace/drv/usbkbd/main.c
rde2c901 r71ed4849 190 190 // get phone to my HC and save it as my parent's phone 191 191 // TODO: maybe not a good idea if DDF will use parent_phone 192 kbd_dev->device->parent_phone = usb_drv_hc_connect (dev, 0);192 kbd_dev->device->parent_phone = usb_drv_hc_connect_auto(dev, 0); 193 193 194 194 kbd_dev->address = usb_drv_get_my_address(dev->parent_phone, … … 325 325 * Not supported yet, skip.. 326 326 */ 327 // int phone = usb_drv_hc_connect (dev, 0);327 // int phone = usb_drv_hc_connect_auto(dev, 0); 328 328 // if (phone < 0) { 329 329 // /* -
uspace/drv/vhc/hcd.c
rde2c901 r71ed4849 46 46 47 47 #include <usb/usb.h> 48 #include <usb_iface.h> 48 49 #include "vhcd.h" 49 50 #include "hc.h" … … 52 53 #include "conn.h" 53 54 55 static int usb_iface_get_hc_handle(device_t *dev, devman_handle_t *handle) 56 { 57 /* This shall be called only for VHC device. */ 58 assert(dev->parent == NULL); 59 60 *handle = dev->handle; 61 return EOK; 62 } 63 64 static usb_iface_t hc_usb_iface = { 65 .get_hc_handle = usb_iface_get_hc_handle 66 }; 67 54 68 static device_ops_t vhc_ops = { 55 69 .interfaces[USBHC_DEV_IFACE] = &vhc_iface, 70 .interfaces[USB_DEV_IFACE] = &hc_usb_iface, 56 71 .default_handler = default_connection_handler 57 72 }; -
uspace/drv/vhc/hub.c
rde2c901 r71ed4849 79 79 device_t *hc_dev = (device_t *) arg; 80 80 81 int hc = usb_drv_hc_connect(hc_dev, IPC_FLAG_BLOCKING);81 int hc = usb_drv_hc_connect(hc_dev, hc_dev->handle, IPC_FLAG_BLOCKING); 82 82 if (hc < 0) { 83 83 printf(NAME ": failed to register root hub\n"); -
uspace/lib/usb/include/usb/usbdrv.h
rde2c901 r71ed4849 42 42 43 43 int usb_drv_find_hc(device_t *, devman_handle_t *); 44 int usb_drv_hc_connect(device_t *, unsigned int); 44 int usb_drv_hc_connect(device_t *, devman_handle_t, unsigned int); 45 int usb_drv_hc_connect_auto(device_t *, unsigned int); 45 46 46 47 int usb_drv_reserve_default_address(int); -
uspace/lib/usb/src/hcdhubd.c
rde2c901 r71ed4849 36 36 #include <usb/devreq.h> 37 37 #include <usbhc_iface.h> 38 #include <usb_iface.h> 38 39 #include <usb/descriptor.h> 39 40 #include <driver.h> … … 45 46 #include "hcdhubd_private.h" 46 47 48 49 static int usb_iface_get_hc_handle(device_t *dev, devman_handle_t *handle) 50 { 51 assert(dev); 52 assert(dev->parent != NULL); 53 54 device_t *parent = dev->parent; 55 56 if (parent->ops && parent->ops->interfaces[USB_DEV_IFACE]) { 57 usb_iface_t *usb_iface 58 = (usb_iface_t *) parent->ops->interfaces[USB_DEV_IFACE]; 59 assert(usb_iface != NULL); 60 if (usb_iface->get_hc_handle) { 61 int rc = usb_iface->get_hc_handle(parent, handle); 62 return rc; 63 } 64 } 65 66 return ENOTSUP; 67 } 68 69 static usb_iface_t usb_iface = { 70 .get_hc_handle = usb_iface_get_hc_handle 71 }; 72 73 static device_ops_t child_ops = { 74 .interfaces[USB_DEV_IFACE] = &usb_iface 75 }; 76 47 77 /** Callback when new device is detected and must be handled by this driver. 48 78 * … … 129 159 } 130 160 child->name = child_info->name; 161 child->parent = child_info->parent; 162 child->ops = &child_ops; 131 163 132 164 match_id = create_match_id(); -
uspace/lib/usb/src/recognise.c
rde2c901 r71ed4849 33 33 * @brief Functions for recognising kind of attached devices. 34 34 */ 35 #include <usb_iface.h> 35 36 #include <usb/usbdrv.h> 36 37 #include <usb/classes/classes.h> … … 38 39 #include <errno.h> 39 40 41 static int usb_iface_get_hc_handle(device_t *dev, devman_handle_t *handle) 42 { 43 assert(dev); 44 assert(dev->parent != NULL); 45 46 device_t *parent = dev->parent; 47 48 if (parent->ops && parent->ops->interfaces[USB_DEV_IFACE]) { 49 usb_iface_t *usb_iface 50 = (usb_iface_t *) parent->ops->interfaces[USB_DEV_IFACE]; 51 assert(usb_iface != NULL); 52 if (usb_iface->get_hc_handle) { 53 int rc = usb_iface->get_hc_handle(parent, handle); 54 return rc; 55 } 56 } 57 58 return ENOTSUP; 59 } 60 61 static usb_iface_t usb_iface = { 62 .get_hc_handle = usb_iface_get_hc_handle 63 }; 64 65 static device_ops_t child_ops = { 66 .interfaces[USB_DEV_IFACE] = &usb_iface 67 }; 40 68 41 69 #define BCD_INT(a) (((unsigned int)(a)) / 256) … … 285 313 goto failure; 286 314 } 315 child->parent = parent; 287 316 child->name = child_name; 317 child->ops = &child_ops; 288 318 289 319 rc = usb_drv_create_device_match_ids(hc, &child->match_ids, address); -
uspace/lib/usb/src/usbdrv.c
rde2c901 r71ed4849 70 70 } 71 71 72 int parent_phone = devman_parent_device_connect(dev->handle, 0); 72 int parent_phone = devman_parent_device_connect(dev->handle, 73 IPC_FLAG_BLOCKING); 73 74 if (parent_phone < 0) { 74 75 return parent_phone; … … 78 79 int rc = async_req_1_1(parent_phone, DEV_IFACE_ID(USB_DEV_IFACE), 79 80 IPC_M_USB_GET_HOST_CONTROLLER_HANDLE, &h); 81 82 ipc_hangup(parent_phone); 83 80 84 if (rc != EOK) { 81 85 return rc; … … 85 89 86 90 return EOK; 91 } 92 93 /** Connect to host controller the device is physically attached to. 94 * 95 * @param dev Device asking for connection. 96 * @param hc_handle Devman handle of the host controller. 97 * @param flags Connection flags (blocking connection). 98 * @return Phone to the HC or error code. 99 */ 100 int usb_drv_hc_connect(device_t *dev, devman_handle_t hc_handle, 101 unsigned int flags) 102 { 103 return devman_device_connect(hc_handle, flags); 87 104 } 88 105 … … 93 110 * @return Phone to corresponding HC or error code. 94 111 */ 95 int usb_drv_hc_connect(device_t *dev, unsigned int flags) 96 { 112 int usb_drv_hc_connect_auto(device_t *dev, unsigned int flags) 113 { 114 int rc; 115 devman_handle_t hc_handle; 116 97 117 /* 98 118 * Call parent hub to obtain device handle of respective HC. 99 119 */ 100 101 /* 102 * FIXME: currently we connect always to virtual host controller. 103 */ 104 int rc; 105 devman_handle_t handle; 106 107 rc = devman_device_get_handle("/virt/usbhc", &handle, flags); 120 rc = usb_drv_find_hc(dev, &hc_handle); 108 121 if (rc != EOK) { 109 122 return rc; 110 123 } 111 124 112 int phone = devman_device_connect(handle, flags); 113 114 return phone; 125 return usb_drv_hc_connect(dev, hc_handle, flags); 115 126 } 116 127
Note:
See TracChangeset
for help on using the changeset viewer.