seperate control xfer to 3 tds for ohci

- ohci only work with 1st transfer with specific timing. TODO fix it
later
This commit is contained in:
hathach 2018-12-07 23:16:06 +07:00
parent 6c49848d59
commit e4fd9fbaf4
No known key found for this signature in database
GPG Key ID: 2FA891220FBFD581
2 changed files with 50 additions and 50 deletions

View File

@ -328,7 +328,6 @@ bool hcd_edpt_xfer(uint8_t rhport, uint8_t dev_addr, uint8_t ep_addr, uint8_t *
p_data->index = dev_addr; p_data->index = dev_addr;
p_data->pid = dir ? OHCI_PID_IN : OHCI_PID_OUT; p_data->pid = dir ? OHCI_PID_IN : OHCI_PID_OUT;
p_data->data_toggle = BIN8(11); // DATA1 p_data->data_toggle = BIN8(11); // DATA1
p_data->delay_interrupt = OHCI_INT_ON_COMPLETE_YES; p_data->delay_interrupt = OHCI_INT_ON_COMPLETE_YES;
p_ed->td_head.address = (uint32_t) p_data; p_ed->td_head.address = (uint32_t) p_data;
@ -336,7 +335,7 @@ bool hcd_edpt_xfer(uint8_t rhport, uint8_t dev_addr, uint8_t ep_addr, uint8_t *
OHCI_REG->command_status_bit.control_list_filled = 1; OHCI_REG->command_status_bit.control_list_filled = 1;
} }
return false; return true;
} }
tusb_error_t hcd_pipe_control_open(uint8_t dev_addr, uint8_t max_packet_size) tusb_error_t hcd_pipe_control_open(uint8_t dev_addr, uint8_t max_packet_size)
@ -356,48 +355,48 @@ tusb_error_t hcd_pipe_control_open(uint8_t dev_addr, uint8_t max_packet_size)
return TUSB_ERROR_NONE; return TUSB_ERROR_NONE;
} }
bool hcd_pipe_control_xfer(uint8_t dev_addr, tusb_control_request_t const * p_request, uint8_t data[]) //bool hcd_pipe_control_xfer(uint8_t dev_addr, tusb_control_request_t const * p_request, uint8_t data[])
{ //{
ohci_ed_t* const p_ed = &ohci_data.control[dev_addr].ed; // ohci_ed_t* const p_ed = &ohci_data.control[dev_addr].ed;
//
ohci_gtd_t *p_setup = &ohci_data.control[dev_addr].gtd[0]; // ohci_gtd_t *p_setup = &ohci_data.control[dev_addr].gtd[0];
ohci_gtd_t *p_data = p_setup + 1; // ohci_gtd_t *p_data = p_setup + 1;
ohci_gtd_t *p_status = p_setup + 2; // ohci_gtd_t *p_status = p_setup + 2;
//
//------------- SETUP Phase -------------// // //------------- SETUP Phase -------------//
gtd_init(p_setup, (void*) p_request, 8); // gtd_init(p_setup, (void*) p_request, 8);
p_setup->index = dev_addr; // p_setup->index = dev_addr;
p_setup->pid = OHCI_PID_SETUP; // p_setup->pid = OHCI_PID_SETUP;
p_setup->data_toggle = BIN8(10); // DATA0 // p_setup->data_toggle = BIN8(10); // DATA0
p_setup->next_td = (uint32_t) p_data; // p_setup->next_td = (uint32_t) p_data;
//
//------------- DATA Phase -------------// // //------------- DATA Phase -------------//
if (p_request->wLength > 0) // if (p_request->wLength > 0)
{ // {
gtd_init(p_data, data, p_request->wLength); // gtd_init(p_data, data, p_request->wLength);
p_data->index = dev_addr; // p_data->index = dev_addr;
p_data->pid = p_request->bmRequestType_bit.direction ? OHCI_PID_IN : OHCI_PID_OUT; // p_data->pid = p_request->bmRequestType_bit.direction ? OHCI_PID_IN : OHCI_PID_OUT;
p_data->data_toggle = BIN8(11); // DATA1 // p_data->data_toggle = BIN8(11); // DATA1
}else // }else
{ // {
p_data = p_setup; // p_data = p_setup;
} // }
p_data->next_td = (uint32_t) p_status; // p_data->next_td = (uint32_t) p_status;
//
//------------- STATUS Phase -------------// // //------------- STATUS Phase -------------//
gtd_init(p_status, NULL, 0); // zero-length data // gtd_init(p_status, NULL, 0); // zero-length data
p_status->index = dev_addr; // p_status->index = dev_addr;
p_status->pid = p_request->bmRequestType_bit.direction ? OHCI_PID_OUT : OHCI_PID_IN; // reverse direction of data phase // p_status->pid = p_request->bmRequestType_bit.direction ? OHCI_PID_OUT : OHCI_PID_IN; // reverse direction of data phase
p_status->data_toggle = BIN8(11); // DATA1 // p_status->data_toggle = BIN8(11); // DATA1
p_status->delay_interrupt = OHCI_INT_ON_COMPLETE_YES; // p_status->delay_interrupt = OHCI_INT_ON_COMPLETE_YES;
//
//------------- Attach TDs list to Control Endpoint -------------// // //------------- Attach TDs list to Control Endpoint -------------//
p_ed->td_head.address = (uint32_t) p_setup; // p_ed->td_head.address = (uint32_t) p_setup;
//
OHCI_REG->command_status_bit.control_list_filled = 1; // OHCI_REG->command_status_bit.control_list_filled = 1;
//
return true; // return true;
} //}
tusb_error_t hcd_pipe_control_close(uint8_t dev_addr) tusb_error_t hcd_pipe_control_close(uint8_t dev_addr)
{ {

View File

@ -200,10 +200,6 @@ bool usbh_control_xfer (uint8_t dev_addr, tusb_control_request_t* request, uint8
dev->control.request = *request; dev->control.request = *request;
dev->control.pipe_status = 0; dev->control.pipe_status = 0;
#if 0
TU_ASSERT(hcd_pipe_control_xfer(dev_addr, &dev->control.request, data));
TU_ASSERT(osal_semaphore_wait(dev->control.sem_hdl, OSAL_TIMEOUT_NORMAL));
#else
// Setup Stage // Setup Stage
hcd_setup_send(rhport, dev_addr, (uint8_t*) &dev->control.request); hcd_setup_send(rhport, dev_addr, (uint8_t*) &dev->control.request);
TU_VERIFY(osal_semaphore_wait(dev->control.sem_hdl, OSAL_TIMEOUT_NORMAL)); TU_VERIFY(osal_semaphore_wait(dev->control.sem_hdl, OSAL_TIMEOUT_NORMAL));
@ -218,7 +214,6 @@ bool usbh_control_xfer (uint8_t dev_addr, tusb_control_request_t* request, uint8
// Status : data toggle is always 1 // Status : data toggle is always 1
hcd_edpt_xfer(rhport, dev_addr, edpt_addr(0, 1-request->bmRequestType_bit.direction), NULL, 0); hcd_edpt_xfer(rhport, dev_addr, edpt_addr(0, 1-request->bmRequestType_bit.direction), NULL, 0);
TU_VERIFY(osal_semaphore_wait(dev->control.sem_hdl, OSAL_TIMEOUT_NORMAL)); TU_VERIFY(osal_semaphore_wait(dev->control.sem_hdl, OSAL_TIMEOUT_NORMAL));
#endif
osal_mutex_unlock(dev->control.mutex_hdl); osal_mutex_unlock(dev->control.mutex_hdl);
@ -395,8 +390,14 @@ void usbh_hcd_rhport_unplugged_isr(uint8_t hostid)
bool enum_task(hcd_event_t* event) bool enum_task(hcd_event_t* event)
{ {
enum { enum {
#if 1
// FIXME ohci LPC1769 xpresso + debugging to have 1st control xfer to work, some kind of timing or ohci driver issue !!!
POWER_STABLE_DELAY = 100,
RESET_DELAY = 500
#else
POWER_STABLE_DELAY = 500, POWER_STABLE_DELAY = 500,
RESET_DELAY = 200 // USB specs say only 50ms but many devices require much longer RESET_DELAY = 200, // USB specs say only 50ms but many devices require much longer
#endif
}; };
// for OSAL_NONE local variable won't retain value after blocking service sem_wait/queue_recv // for OSAL_NONE local variable won't retain value after blocking service sem_wait/queue_recv