Changeset 733a9a8 in mainline for uspace/drv/uhci-hcd/uhci.c
- 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
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
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));
Note:
See TracChangeset
for help on using the changeset viewer.