Changes in uspace/drv/bus/usb/ehci/main.c [7de1988c:972e8a9] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/drv/bus/usb/ehci/main.c
r7de1988c r972e8a9 33 33 * Main routines of EHCI driver. 34 34 */ 35 36 35 #include <ddf/driver.h> 37 36 #include <ddf/interrupt.h> 38 37 #include <device/hw_res.h> 39 38 #include <errno.h> 40 #include <stdbool.h>41 39 #include <str_error.h> 42 40 43 41 #include <usb_iface.h> 44 #include <usb/ddfiface.h>45 42 #include <usb/debug.h> 46 #include <usb/host/ hcd.h>43 #include <usb/host/ddf_helpers.h> 47 44 48 45 #include "res.h" 46 #include "hc.h" 49 47 50 48 #define NAME "ehci" 49 // TODO: This should be merged to hc_interrupt 50 static void ehci_interrupt(hcd_t *hcd, uint32_t status) 51 { 52 assert(hcd); 53 if (hcd->driver.data) 54 hc_interrupt(hcd->driver.data, status); 55 } 56 57 static int ehci_driver_init(hcd_t *hcd, const hw_res_list_parsed_t *res, bool irq) 58 { 59 assert(hcd); 60 assert(hcd->driver.data == NULL); 61 62 hc_t *instance = malloc(sizeof(hc_t)); 63 if (!instance) 64 return ENOMEM; 65 66 const int ret = hc_init(instance, res, irq); 67 if (ret == EOK) 68 hcd_set_implementation(hcd, instance, hc_schedule, 69 NULL, NULL, ehci_interrupt); 70 return ret; 71 } 72 73 static void ehci_driver_fini(hcd_t *hcd) 74 { 75 assert(hcd); 76 if (hcd->driver.data) 77 hc_fini(hcd->driver.data); 78 79 free(hcd->driver.data); 80 hcd_set_implementation(hcd, NULL, NULL, NULL, NULL, NULL); 81 } 51 82 52 83 static int ehci_dev_add(ddf_dev_t *device); … … 60 91 .driver_ops = &ehci_driver_ops 61 92 }; 62 static ddf_dev_ops_t hc_ops = {63 .interfaces[USBHC_DEV_IFACE] = &hcd_iface,64 };65 93 66 94 … … 72 100 static int ehci_dev_add(ddf_dev_t *device) 73 101 { 74 ddf_fun_t *hc_fun = NULL; 75 bool fun_bound = false; 76 102 usb_log_debug("ehci_dev_add() called\n"); 77 103 assert(device); 78 104 79 addr_range_t reg_range; 80 int irq = 0; 81 82 int rc = get_my_registers(device, ®_range, &irq); 83 if (rc != EOK) { 84 usb_log_error("Failed to get memory addresses for %" PRIun 85 ": %s.\n", ddf_dev_get_handle(device), str_error(rc)); 86 goto error; 105 const int ret = ddf_hcd_device_setup_all(device, USB_SPEED_HIGH, 106 BANDWIDTH_AVAILABLE_USB20, bandwidth_count_usb11, 107 ddf_hcd_gen_irq_handler, hc_gen_irq_code, 108 ehci_driver_init, ehci_driver_fini); 109 if (ret != EOK) { 110 usb_log_error("Failed to initialize EHCI driver: %s.\n", 111 str_error(ret)); 87 112 } 88 89 usb_log_info("Memory mapped regs at %p (size %zu), IRQ %d.\n", 90 RNGABSPTR(reg_range), RNGSZ(reg_range), irq); 91 92 rc = disable_legacy(device, ®_range); 93 if (rc != EOK) { 94 usb_log_error("Failed to disable legacy USB: %s.\n", 95 str_error(rc)); 96 goto error; 97 } 98 99 hc_fun = ddf_fun_create(device, fun_exposed, "ehci_hc"); 100 if (hc_fun == NULL) { 101 usb_log_error("Failed to create EHCI function.\n"); 102 rc = ENOMEM; 103 goto error; 104 } 105 106 hcd_t *ehci_hc = ddf_fun_data_alloc(hc_fun, sizeof(hcd_t)); 107 if (ehci_hc == NULL) { 108 usb_log_error("Failed to alloc generic HC driver.\n"); 109 rc = ENOMEM; 110 goto error; 111 } 112 113 /* High Speed, no bandwidth */ 114 hcd_init(ehci_hc, USB_SPEED_HIGH, 0, NULL); 115 ddf_fun_set_ops(hc_fun, &hc_ops); 116 117 rc = ddf_fun_bind(hc_fun); 118 if (rc != EOK) { 119 usb_log_error("Failed to bind EHCI function: %s.\n", 120 str_error(rc)); 121 goto error; 122 } 123 124 fun_bound = true; 125 126 rc = ddf_fun_add_to_category(hc_fun, USB_HC_CATEGORY); 127 if (rc != EOK) { 128 usb_log_error("Failed to add EHCI to HC class: %s.\n", 129 str_error(rc)); 130 goto error; 131 } 132 133 usb_log_info("Controlling new EHCI device `%s' (handle %" PRIun ").\n", 134 ddf_dev_get_name(device), ddf_dev_get_handle(device)); 113 usb_log_info("Controlling new EHCI device '%s'.\n", 114 ddf_dev_get_name(device)); 135 115 136 116 return EOK; 137 error:138 if (fun_bound)139 ddf_fun_unbind(hc_fun);140 if (hc_fun != NULL)141 ddf_fun_destroy(hc_fun);142 return rc;143 117 } 144 118
Note:
See TracChangeset
for help on using the changeset viewer.