Changeset 733a9a8 in mainline
- Timestamp:
- 2011-02-19T19:45:18Z (14 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 7e7f0f5
- Parents:
- e221ca0
- Location:
- uspace/drv/uhci-hcd
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/drv/uhci-hcd/main.c
re221ca0 r733a9a8 34 34 #include <driver.h> 35 35 #include <usb_iface.h> 36 #include <ipc/irc.h> 37 #include <ipc/ns.h> 38 #include <ipc/services.h> 39 #include <sysinfo.h> 36 40 37 41 #include <errno.h> … … 76 80 }; 77 81 /*----------------------------------------------------------------------------*/ 82 static irq_cmd_t uhci_cmds[] = { 83 { 84 .cmd = CMD_PIO_READ_16, 85 .addr = (void*)0xc022, 86 .dstarg = 1 87 }, 88 { 89 .cmd = CMD_PIO_WRITE_16, 90 .addr = (void*)0xc022, 91 .value = 0x1f 92 }, 93 { 94 .cmd = CMD_ACCEPT 95 } 96 }; 97 /*----------------------------------------------------------------------------*/ 98 static irq_code_t uhci_code = { 99 sizeof(uhci_cmds) / sizeof(irq_cmd_t), 100 uhci_cmds 101 }; 102 /*----------------------------------------------------------------------------*/ 78 103 static void irq_handler(device_t *device, ipc_callid_t iid, ipc_call_t *call) 79 104 { … … 81 106 uhci_t *hc = dev_to_uhci(device); 82 107 usb_log_info("LOL HARDWARE INTERRUPT: %p.\n", hc); 108 uint16_t status = IPC_GET_ARG1(*call); 83 109 assert(hc); 84 uhci_interrupt(hc );110 uhci_interrupt(hc, status); 85 111 } 86 112 /*----------------------------------------------------------------------------*/ … … 109 135 io_reg_base, io_reg_size, irq); 110 136 111 ret = register_interrupt_handler(device, irq, irq_handler, NULL); 137 138 sysarg_t apic; 139 sysarg_t i8259; 140 int irc_phone = -1; 141 int irc_service = 0; 142 143 if ((sysinfo_get_value("apic", &apic) == EOK) && (apic)) { 144 irc_service = SERVICE_APIC; 145 usb_log_debug("SERVICE_APIC\n"); 146 } else if ((sysinfo_get_value("i8259", &i8259) == EOK) && (i8259)) { 147 irc_service = SERVICE_I8259; 148 usb_log_debug("SERVICE_I8259\n"); 149 } 150 151 if (irc_service) { 152 while (irc_phone < 0) 153 irc_phone = service_connect_blocking(irc_service, 0, 0); 154 } 155 usb_log_debug("Interrupt conttroller phone: %d\n", irc_phone); 156 157 async_msg_1(irc_phone, IRC_ENABLE_INTERRUPT, irq); 158 // async_hangup(irc_phone); 159 160 ret = register_interrupt_handler(device, irq, irq_handler, &uhci_code); 112 161 usb_log_debug("Registered interrupt handler %d.\n", ret); 113 162 -
uspace/drv/uhci-hcd/uhci.c
re221ca0 r733a9a8 58 58 int uhci_init(uhci_t *instance, void *regs, size_t reg_size) 59 59 { 60 int ret = uhci_init_mem_structures(instance); 61 CHECK_RET_RETURN(ret, "Failed to initialize memory structures.\n"); 60 assert(reg_size >= sizeof(regs_t)); 62 61 63 62 /* allow access to hc control registers */ 64 63 regs_t *io; 65 assert(reg_size >= sizeof(regs_t)); 66 ret = pio_enable(regs, reg_size, (void**)&io); 64 int ret = pio_enable(regs, reg_size, (void**)&io); 67 65 CHECK_RET_RETURN(ret, "Failed to gain access to registers at %p.\n", io); 68 66 instance->registers = io; 69 67 usb_log_debug("Device registers accessible.\n"); 70 68 69 ret = uhci_init_mem_structures(instance); 70 CHECK_RET_RETURN(ret, "Failed to initialize memory structures.\n"); 71 72 uhci_init_hw(instance); 73 71 74 instance->cleaner = fibril_create(uhci_interrupt_emulator, instance); 72 fibril_add_ready(instance->cleaner);75 // fibril_add_ready(instance->cleaner); 73 76 74 77 instance->debug_checker = fibril_create(uhci_debug_checker, instance); 75 78 fibril_add_ready(instance->debug_checker); 76 79 77 uhci_init_hw(instance);78 79 80 return EOK; 80 81 } … … 82 83 void uhci_init_hw(uhci_t *instance) 83 84 { 85 86 /* set framelist pointer */ 84 87 const uint32_t pa = addr_to_phys(instance->frame_list); 85 88 pio_write_32(&instance->registers->flbaseadd, pa); 86 89 87 /* enable all interrupts */90 /* enable all interrupts, but resume interrupt */ 88 91 pio_write_16(&instance->registers->usbintr, 89 92 UHCI_INTR_CRC | UHCI_INTR_COMPLETE | UHCI_INTR_SHORT_PACKET); … … 91 94 /* Start the hc with large(64B) packet FSBR */ 92 95 pio_write_16(&instance->registers->usbcmd, 93 UHCI_CMD_RUN_STOP | UHCI_CMD_MAX_PACKET );96 UHCI_CMD_RUN_STOP | UHCI_CMD_MAX_PACKET | UHCI_CMD_CONFIGURE); 94 97 usb_log_debug("Started UHCI HC.\n"); 95 98 } … … 189 192 } 190 193 /*----------------------------------------------------------------------------*/ 191 void uhci_interrupt(uhci_t *instance) 192 { 193 assert(instance); 194 const uint16_t sts = pio_read_16(&instance->registers->usbsts); 195 if ((sts & (UHCI_STATUS_INTERRUPT | UHCI_STATUS_ERROR_INTERRUPT)) == 0) 194 void uhci_interrupt(uhci_t *instance, uint16_t status) 195 { 196 assert(instance); 197 if ((status & (UHCI_STATUS_INTERRUPT | UHCI_STATUS_ERROR_INTERRUPT)) == 0) 196 198 return; 197 usb_log_debug("UHCI interrupt: %X.\n", st s);199 usb_log_debug("UHCI interrupt: %X.\n", status); 198 200 transfer_list_check(&instance->transfers_interrupt); 199 201 transfer_list_check(&instance->transfers_control_slow); 200 202 transfer_list_check(&instance->transfers_control_full); 201 203 transfer_list_check(&instance->transfers_bulk_full); 202 pio_write_16(&instance->registers->usbsts, 0xf);203 204 } 204 205 /*----------------------------------------------------------------------------*/ 205 206 int uhci_interrupt_emulator(void* arg) 206 207 { 207 return EOK;208 208 usb_log_debug("Started interrupt emulator.\n"); 209 209 uhci_t *instance = (uhci_t*)arg; … … 211 211 212 212 while(1) { 213 uhci_interrupt(instance); 213 uint16_t status = pio_read_16(&instance->registers->usbsts); 214 uhci_interrupt(instance, status); 214 215 async_usleep(UHCI_CLEANER_TIMEOUT); 215 216 } … … 229 230 230 231 uintptr_t frame_list = pio_read_32(&instance->registers->flbaseadd); 231 if (frame_list != (uintptr_t)addr_to_phys(instance->frame_list)) {232 if (frame_list != addr_to_phys(instance->frame_list)) { 232 233 usb_log_debug("Framelist address: %p vs. %p.\n", 233 234 frame_list, addr_to_phys(instance->frame_list)); -
uspace/drv/uhci-hcd/uhci.h
re221ca0 r733a9a8 117 117 int uhci_schedule(uhci_t *instance, batch_t *batch); 118 118 119 void uhci_interrupt(uhci_t *instance );119 void uhci_interrupt(uhci_t *instance, uint16_t status); 120 120 121 121 static inline uhci_t * dev_to_uhci(device_t *dev)
Note:
See TracChangeset
for help on using the changeset viewer.