mirror of
https://github.com/CTCaer/hekate
synced 2025-01-11 15:04:47 +00:00
usb: Refactor driver names and defines
This commit is contained in:
parent
c7fcea5f35
commit
604ec4416d
3 changed files with 74 additions and 88 deletions
bdk/usb
|
@ -198,7 +198,6 @@ typedef struct _usbd_gadget_ums_t {
|
||||||
u32 lun_idx; // lun index
|
u32 lun_idx; // lun index
|
||||||
logical_unit_t lun;
|
logical_unit_t lun;
|
||||||
|
|
||||||
u32 bulk_out_maxpacket; // 512
|
|
||||||
enum ums_state state; // For exception handling.
|
enum ums_state state; // For exception handling.
|
||||||
|
|
||||||
enum data_direction data_dir;
|
enum data_direction data_dir;
|
||||||
|
|
153
bdk/usb/usbd.c
153
bdk/usb/usbd.c
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Enhanced USB (EHCI) Device driver for Tegra X1
|
* Enhanced USB Device (EDCI) driver for Tegra X1
|
||||||
*
|
*
|
||||||
* Copyright (c) 2019-2020 CTCaer
|
* Copyright (c) 2019-2020 CTCaer
|
||||||
*
|
*
|
||||||
|
@ -93,16 +93,16 @@ typedef struct _usbd_controller_t
|
||||||
t210_usb2d_t *regs;
|
t210_usb2d_t *regs;
|
||||||
usb_ctrl_setup_t control_setup;
|
usb_ctrl_setup_t control_setup;
|
||||||
usb_desc_t *desc;
|
usb_desc_t *desc;
|
||||||
usb_gadget_type type;
|
usb_gadget_type gadget;
|
||||||
u8 configuration_set;
|
u8 config_num;
|
||||||
u8 usb_phy_ready;
|
u8 interface_num;
|
||||||
u8 configuration;
|
|
||||||
u8 interface;
|
|
||||||
u8 max_lun;
|
u8 max_lun;
|
||||||
u8 max_lun_set;
|
bool usb_phy_ready;
|
||||||
u8 bulk_reset_req;
|
bool configuration_set;
|
||||||
u8 hid_report_sent;
|
bool max_lun_set;
|
||||||
bool charger_detect;
|
bool bulk_reset_req;
|
||||||
|
bool hid_report_sent;
|
||||||
|
u32 charger_detect;
|
||||||
} usbd_controller_t;
|
} usbd_controller_t;
|
||||||
|
|
||||||
extern u8 hid_report_descriptor_jc[];
|
extern u8 hid_report_descriptor_jc[];
|
||||||
|
@ -125,7 +125,7 @@ u8 *usb_ep0_ctrl_buf = (u8 *)USB_EP_CONTROL_BUF_ADDR;
|
||||||
|
|
||||||
static int _usbd_reset_usb_otg_phy_device_mode()
|
static int _usbd_reset_usb_otg_phy_device_mode()
|
||||||
{
|
{
|
||||||
usbd_otg->usb_phy_ready = 0;
|
usbd_otg->usb_phy_ready = false;
|
||||||
|
|
||||||
// Clear UTMIP reset.
|
// Clear UTMIP reset.
|
||||||
USB(USB1_IF_USB_SUSP_CTRL) &= ~SUSP_CTRL_UTMIP_RESET;
|
USB(USB1_IF_USB_SUSP_CTRL) &= ~SUSP_CTRL_UTMIP_RESET;
|
||||||
|
@ -139,7 +139,7 @@ static int _usbd_reset_usb_otg_phy_device_mode()
|
||||||
return 1;
|
return 1;
|
||||||
usleep(1);
|
usleep(1);
|
||||||
}
|
}
|
||||||
usbd_otg->usb_phy_ready = 1;
|
usbd_otg->usb_phy_ready = true;
|
||||||
|
|
||||||
// Clear all device addresses, enabled setup requests and transmit events.
|
// Clear all device addresses, enabled setup requests and transmit events.
|
||||||
usbd_otg->regs->periodiclistbase = 0;
|
usbd_otg->regs->periodiclistbase = 0;
|
||||||
|
@ -488,7 +488,7 @@ void usb_device_stall_ep1_bulk_in()
|
||||||
_usbd_stall_reset_ep1(USB_DIR_IN, USB_EP_CFG_STALL);
|
_usbd_stall_reset_ep1(USB_DIR_IN, USB_EP_CFG_STALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
int usbd_get_max_pkt_length(int endpoint)
|
static int _usbd_get_max_pkt_length(int endpoint)
|
||||||
{
|
{
|
||||||
switch (endpoint)
|
switch (endpoint)
|
||||||
{
|
{
|
||||||
|
@ -497,7 +497,7 @@ int usbd_get_max_pkt_length(int endpoint)
|
||||||
return 64;
|
return 64;
|
||||||
case USB_EP_BULK_OUT:
|
case USB_EP_BULK_OUT:
|
||||||
case USB_EP_BULK_IN:
|
case USB_EP_BULK_IN:
|
||||||
if (usbd_otg->port_speed == 2)
|
if (usbd_otg->port_speed == USB_HIGH_SPEED)
|
||||||
return 512;
|
return 512;
|
||||||
else
|
else
|
||||||
return 64;
|
return 64;
|
||||||
|
@ -518,14 +518,14 @@ static void _usbd_initialize_ep_ctrl(u32 endpoint)
|
||||||
|
|
||||||
usbdaemon->qhs[endpoint].next_dTD_ptr = 1; // TERMINATE_SET
|
usbdaemon->qhs[endpoint].next_dTD_ptr = 1; // TERMINATE_SET
|
||||||
|
|
||||||
u32 max_packet_len = usbd_get_max_pkt_length(endpoint) & USB_QHD_EP_CAP_MAX_PKT_LEN_MASK;
|
u32 max_packet_len = _usbd_get_max_pkt_length(endpoint) & USB_QHD_EP_CAP_MAX_PKT_LEN_MASK;
|
||||||
usbdaemon->qhs[endpoint].ep_capabilities |= max_packet_len << 16;
|
usbdaemon->qhs[endpoint].ep_capabilities |= max_packet_len << 16;
|
||||||
|
|
||||||
if (direction == USB_DIR_IN)
|
if (direction == USB_DIR_IN)
|
||||||
{
|
{
|
||||||
u32 endpoint_type = usbd_otg->regs->endptctrl[actual_ep] & ~USB2D_ENDPTCTRL_TX_EP_TYPE_MASK;
|
u32 endpoint_type = usbd_otg->regs->endptctrl[actual_ep] & ~USB2D_ENDPTCTRL_TX_EP_TYPE_MASK;
|
||||||
if (actual_ep)
|
if (actual_ep)
|
||||||
endpoint_type |= usbd_otg->type ? USB2D_ENDPTCTRL_TX_EP_TYPE_INTR : USB2D_ENDPTCTRL_TX_EP_TYPE_BULK;
|
endpoint_type |= usbd_otg->gadget ? USB2D_ENDPTCTRL_TX_EP_TYPE_INTR : USB2D_ENDPTCTRL_TX_EP_TYPE_BULK;
|
||||||
else
|
else
|
||||||
endpoint_type |= USB2D_ENDPTCTRL_TX_EP_TYPE_CTRL;
|
endpoint_type |= USB2D_ENDPTCTRL_TX_EP_TYPE_CTRL;
|
||||||
|
|
||||||
|
@ -543,7 +543,7 @@ static void _usbd_initialize_ep_ctrl(u32 endpoint)
|
||||||
u32 endpoint_type = usbd_otg->regs->endptctrl[actual_ep] & ~USB2D_ENDPTCTRL_RX_EP_TYPE_MASK;
|
u32 endpoint_type = usbd_otg->regs->endptctrl[actual_ep] & ~USB2D_ENDPTCTRL_RX_EP_TYPE_MASK;
|
||||||
if (actual_ep)
|
if (actual_ep)
|
||||||
{
|
{
|
||||||
endpoint_type |= usbd_otg->type ? USB2D_ENDPTCTRL_RX_EP_TYPE_INTR : USB2D_ENDPTCTRL_RX_EP_TYPE_BULK;
|
endpoint_type |= usbd_otg->gadget ? USB2D_ENDPTCTRL_RX_EP_TYPE_INTR : USB2D_ENDPTCTRL_RX_EP_TYPE_BULK;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
endpoint_type |= USB2D_ENDPTCTRL_RX_EP_TYPE_CTRL;
|
endpoint_type |= USB2D_ENDPTCTRL_RX_EP_TYPE_CTRL;
|
||||||
|
@ -655,8 +655,8 @@ void usbd_end(bool reset_ep, bool only_controller)
|
||||||
_usbd_stall_reset_ep1(1, USB_EP_CFG_RESET); // EP1 Bulk OUT.
|
_usbd_stall_reset_ep1(1, USB_EP_CFG_RESET); // EP1 Bulk OUT.
|
||||||
//TODO: what about EP0 simultaneous in/out reset.
|
//TODO: what about EP0 simultaneous in/out reset.
|
||||||
|
|
||||||
usbd_otg->configuration = 0;
|
usbd_otg->config_num = 0;
|
||||||
usbd_otg->interface = 0;
|
usbd_otg->interface_num = 0;
|
||||||
usbd_otg->configuration_set = false;
|
usbd_otg->configuration_set = false;
|
||||||
usbd_otg->max_lun_set = false;
|
usbd_otg->max_lun_set = false;
|
||||||
}
|
}
|
||||||
|
@ -759,7 +759,7 @@ static int _usbd_ep_operation(usb_ep_t endpoint, u8 *buf, u32 len, bool sync)
|
||||||
if (endpoint == USB_EP_CTRL_OUT)
|
if (endpoint == USB_EP_CTRL_OUT)
|
||||||
usbdaemon->qhs[endpoint].ep_capabilities = USB_QHD_EP_CAP_IOS_ENABLE;
|
usbdaemon->qhs[endpoint].ep_capabilities = USB_QHD_EP_CAP_IOS_ENABLE;
|
||||||
|
|
||||||
u32 max_packet_len = usbd_get_max_pkt_length(endpoint) & USB_QHD_EP_CAP_MAX_PKT_LEN_MASK;
|
u32 max_packet_len = _usbd_get_max_pkt_length(endpoint) & USB_QHD_EP_CAP_MAX_PKT_LEN_MASK;
|
||||||
usbdaemon->qhs[endpoint].ep_capabilities |= (max_packet_len << 16) | USB_QHD_EP_CAP_ZERO_LEN_TERM_DIS;
|
usbdaemon->qhs[endpoint].ep_capabilities |= (max_packet_len << 16) | USB_QHD_EP_CAP_ZERO_LEN_TERM_DIS;
|
||||||
usbdaemon->qhs[endpoint].next_dTD_ptr = 0; // Clear terminate bit.
|
usbdaemon->qhs[endpoint].next_dTD_ptr = 0; // Clear terminate bit.
|
||||||
//usbdaemon->qhs[endpoint].ep_capabilities |= USB_QHD_TOKEN_IRQ_ON_COMPLETE;
|
//usbdaemon->qhs[endpoint].ep_capabilities |= USB_QHD_TOKEN_IRQ_ON_COMPLETE;
|
||||||
|
@ -894,8 +894,8 @@ static void _usbd_handle_get_class_request(bool *transmit_data, u8 *descriptor,
|
||||||
u16 _wValue = usbd_otg->control_setup.wValue;
|
u16 _wValue = usbd_otg->control_setup.wValue;
|
||||||
u16 _wLength = usbd_otg->control_setup.wLength;
|
u16 _wLength = usbd_otg->control_setup.wLength;
|
||||||
|
|
||||||
bool valid_interface = _wIndex == usbd_otg->interface;
|
bool valid_interface = _wIndex == usbd_otg->interface_num;
|
||||||
bool valid_len = _bRequest == USB_REQUEST_BULK_GET_MAX_LUN ? 1 : 0;
|
bool valid_len = (_bRequest == USB_REQUEST_BULK_GET_MAX_LUN) ? 1 : 0;
|
||||||
|
|
||||||
if (!valid_interface || _wValue != 0 || _wLength != valid_len)
|
if (!valid_interface || _wValue != 0 || _wLength != valid_len)
|
||||||
{
|
{
|
||||||
|
@ -907,12 +907,12 @@ static void _usbd_handle_get_class_request(bool *transmit_data, u8 *descriptor,
|
||||||
{
|
{
|
||||||
case USB_REQUEST_BULK_RESET:
|
case USB_REQUEST_BULK_RESET:
|
||||||
_usbd_ep_ack(USB_EP_CTRL_IN);
|
_usbd_ep_ack(USB_EP_CTRL_IN);
|
||||||
usbd_otg->bulk_reset_req = 1;
|
usbd_otg->bulk_reset_req = true;
|
||||||
break; // DELAYED_STATUS;
|
break; // DELAYED_STATUS;
|
||||||
case USB_REQUEST_BULK_GET_MAX_LUN:
|
case USB_REQUEST_BULK_GET_MAX_LUN:
|
||||||
*transmit_data = 1;
|
*transmit_data = true;
|
||||||
descriptor[0] = usbd_otg->max_lun; // Set 0 LUN for 1 drive supported.
|
descriptor[0] = usbd_otg->max_lun; // Set 0 LUN for 1 drive supported.
|
||||||
usbd_otg->max_lun_set = 1;
|
usbd_otg->max_lun_set = true;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
*ep_stall = 1;
|
*ep_stall = 1;
|
||||||
|
@ -938,13 +938,13 @@ static void _usbd_handle_get_descriptor(bool *transmit_data, void **descriptor,
|
||||||
*/
|
*/
|
||||||
*descriptor = usbd_otg->desc->dev;
|
*descriptor = usbd_otg->desc->dev;
|
||||||
*size = usbd_otg->desc->dev->bLength;
|
*size = usbd_otg->desc->dev->bLength;
|
||||||
*transmit_data = 1;
|
*transmit_data = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
case USB_DESCRIPTOR_CONFIGURATION:
|
case USB_DESCRIPTOR_CONFIGURATION:
|
||||||
if (usbd_otg->type == USB_GADGET_UMS)
|
if (usbd_otg->gadget == USB_GADGET_UMS)
|
||||||
{
|
{
|
||||||
if (usbd_otg->port_speed == 2) // High speed. 512 bytes.
|
if (usbd_otg->port_speed == USB_HIGH_SPEED) // High speed. 512 bytes.
|
||||||
{
|
{
|
||||||
usbd_otg->desc->cfg->endpoint[0].wMaxPacketSize = 0x200;
|
usbd_otg->desc->cfg->endpoint[0].wMaxPacketSize = 0x200;
|
||||||
usbd_otg->desc->cfg->endpoint[1].wMaxPacketSize = 0x200;
|
usbd_otg->desc->cfg->endpoint[1].wMaxPacketSize = 0x200;
|
||||||
|
@ -958,7 +958,7 @@ static void _usbd_handle_get_descriptor(bool *transmit_data, void **descriptor,
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
usb_cfg_hid_descr_t *tmp = (usb_cfg_hid_descr_t *)usbd_otg->desc->cfg;
|
usb_cfg_hid_descr_t *tmp = (usb_cfg_hid_descr_t *)usbd_otg->desc->cfg;
|
||||||
if (usbd_otg->port_speed == 2) // High speed. 512 bytes.
|
if (usbd_otg->port_speed == USB_HIGH_SPEED) // High speed. 512 bytes.
|
||||||
{
|
{
|
||||||
tmp->endpoint[0].wMaxPacketSize = 0x200;
|
tmp->endpoint[0].wMaxPacketSize = 0x200;
|
||||||
tmp->endpoint[1].wMaxPacketSize = 0x200;
|
tmp->endpoint[1].wMaxPacketSize = 0x200;
|
||||||
|
@ -971,7 +971,7 @@ static void _usbd_handle_get_descriptor(bool *transmit_data, void **descriptor,
|
||||||
}
|
}
|
||||||
*descriptor = usbd_otg->desc->cfg;
|
*descriptor = usbd_otg->desc->cfg;
|
||||||
*size = usbd_otg->desc->cfg->config.wTotalLength;
|
*size = usbd_otg->desc->cfg->config.wTotalLength;
|
||||||
*transmit_data = 1;
|
*transmit_data = true;
|
||||||
return;
|
return;
|
||||||
case USB_DESCRIPTOR_STRING:
|
case USB_DESCRIPTOR_STRING:
|
||||||
switch (descriptor_subtype)
|
switch (descriptor_subtype)
|
||||||
|
@ -997,19 +997,19 @@ static void _usbd_handle_get_descriptor(bool *transmit_data, void **descriptor,
|
||||||
*size = 4;
|
*size = 4;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
*transmit_data = 1;
|
*transmit_data = true;
|
||||||
return;
|
return;
|
||||||
case USB_DESCRIPTOR_DEVICE_QUALIFIER:
|
case USB_DESCRIPTOR_DEVICE_QUALIFIER:
|
||||||
if (!usbd_otg->desc->dev_qual)
|
if (!usbd_otg->desc->dev_qual)
|
||||||
goto exit;
|
goto exit;
|
||||||
*descriptor = usbd_otg->desc->dev_qual;
|
*descriptor = usbd_otg->desc->dev_qual;
|
||||||
*size = usbd_otg->desc->dev_qual->bLength;
|
*size = usbd_otg->desc->dev_qual->bLength;
|
||||||
*transmit_data = 1;
|
*transmit_data = true;
|
||||||
return;
|
return;
|
||||||
case USB_DESCRIPTOR_OTHER_SPEED_CONFIGURATION:
|
case USB_DESCRIPTOR_OTHER_SPEED_CONFIGURATION:
|
||||||
if (!usbd_otg->desc->cfg_other)
|
if (!usbd_otg->desc->cfg_other)
|
||||||
goto exit;
|
goto exit;
|
||||||
if (usbd_otg->port_speed == 2)
|
if (usbd_otg->port_speed == USB_HIGH_SPEED)
|
||||||
{
|
{
|
||||||
usbd_otg->desc->cfg_other->endpoint[0].wMaxPacketSize = 0x40;
|
usbd_otg->desc->cfg_other->endpoint[0].wMaxPacketSize = 0x40;
|
||||||
usbd_otg->desc->cfg_other->endpoint[1].wMaxPacketSize = 0x40;
|
usbd_otg->desc->cfg_other->endpoint[1].wMaxPacketSize = 0x40;
|
||||||
|
@ -1023,20 +1023,20 @@ static void _usbd_handle_get_descriptor(bool *transmit_data, void **descriptor,
|
||||||
usbd_otg->desc->cfg_other->config.bMaxPower = 500 / 2;
|
usbd_otg->desc->cfg_other->config.bMaxPower = 500 / 2;
|
||||||
*descriptor = usbd_otg->desc->cfg_other;
|
*descriptor = usbd_otg->desc->cfg_other;
|
||||||
*size = usbd_otg->desc->cfg_other->config.wTotalLength;
|
*size = usbd_otg->desc->cfg_other->config.wTotalLength;
|
||||||
*transmit_data = 1;
|
*transmit_data = true;
|
||||||
return;
|
return;
|
||||||
case USB_DESCRIPTOR_DEVICE_BINARY_OBJECT:
|
case USB_DESCRIPTOR_DEVICE_BINARY_OBJECT:
|
||||||
*descriptor = usbd_otg->desc->dev_bot;
|
*descriptor = usbd_otg->desc->dev_bot;
|
||||||
*size = usbd_otg->desc->dev_bot->wTotalLength;
|
*size = usbd_otg->desc->dev_bot->wTotalLength;
|
||||||
*transmit_data = 1;
|
*transmit_data = true;
|
||||||
return;
|
return;
|
||||||
default:
|
default:
|
||||||
*transmit_data = 0;
|
*transmit_data = false;
|
||||||
*ep_stall = 1;
|
*ep_stall = 1;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
exit:
|
exit:
|
||||||
*transmit_data = 0;
|
*transmit_data = false;
|
||||||
*ep_stall = 1;
|
*ep_stall = 1;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1058,10 +1058,10 @@ static int _usbd_handle_set_request(int *ep_stall)
|
||||||
ret = _usbd_ep_ack(USB_EP_CTRL_IN);
|
ret = _usbd_ep_ack(USB_EP_CTRL_IN);
|
||||||
if (!ret)
|
if (!ret)
|
||||||
{
|
{
|
||||||
usbd_otg->configuration = usbd_otg->control_setup.wValue;
|
usbd_otg->config_num = usbd_otg->control_setup.wValue;
|
||||||
_usbd_initialize_ep_ctrl(USB_EP_BULK_OUT);
|
_usbd_initialize_ep_ctrl(USB_EP_BULK_OUT);
|
||||||
_usbd_initialize_ep_ctrl(USB_EP_BULK_IN);
|
_usbd_initialize_ep_ctrl(USB_EP_BULK_IN);
|
||||||
usbd_otg->configuration_set = 1;
|
usbd_otg->configuration_set = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -1075,7 +1075,7 @@ static int _usbd_handle_ep0_control_transfer()
|
||||||
int direction;
|
int direction;
|
||||||
|
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
bool transmit_data = 0;
|
bool transmit_data = false;
|
||||||
u8 *descriptor = (u8 *)USB_DESCRIPTOR_ADDR;
|
u8 *descriptor = (u8 *)USB_DESCRIPTOR_ADDR;
|
||||||
int size = 0;
|
int size = 0;
|
||||||
int ep_stall = 0;
|
int ep_stall = 0;
|
||||||
|
@ -1097,7 +1097,7 @@ static int _usbd_handle_ep0_control_transfer()
|
||||||
case (USB_SETUP_HOST_TO_DEVICE | USB_SETUP_TYPE_STANDARD | USB_SETUP_RECIPIENT_INTERFACE):
|
case (USB_SETUP_HOST_TO_DEVICE | USB_SETUP_TYPE_STANDARD | USB_SETUP_RECIPIENT_INTERFACE):
|
||||||
ret = _usbd_ep_ack(USB_EP_CTRL_IN);
|
ret = _usbd_ep_ack(USB_EP_CTRL_IN);
|
||||||
if (!ret)
|
if (!ret)
|
||||||
usbd_otg->interface = _wValue;
|
usbd_otg->interface_num = _wValue;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case (USB_SETUP_HOST_TO_DEVICE | USB_SETUP_TYPE_STANDARD | USB_SETUP_RECIPIENT_ENDPOINT):
|
case (USB_SETUP_HOST_TO_DEVICE | USB_SETUP_TYPE_STANDARD | USB_SETUP_RECIPIENT_ENDPOINT):
|
||||||
|
@ -1153,16 +1153,16 @@ static int _usbd_handle_ep0_control_transfer()
|
||||||
case USB_REQUEST_GET_STATUS:
|
case USB_REQUEST_GET_STATUS:
|
||||||
descriptor[0] = USB_STATUS_DEV_SELF_POWERED;
|
descriptor[0] = USB_STATUS_DEV_SELF_POWERED;
|
||||||
descriptor[1] = 0; // No support for remove wake up.
|
descriptor[1] = 0; // No support for remove wake up.
|
||||||
transmit_data = 1;
|
transmit_data = true;
|
||||||
size = 2;
|
size = 2;
|
||||||
break;
|
break;
|
||||||
case USB_REQUEST_GET_DESCRIPTOR:
|
case USB_REQUEST_GET_DESCRIPTOR:
|
||||||
_usbd_handle_get_descriptor(&transmit_data, (void **)&descriptor, &size, &ep_stall);
|
_usbd_handle_get_descriptor(&transmit_data, (void **)&descriptor, &size, &ep_stall);
|
||||||
break;
|
break;
|
||||||
case USB_REQUEST_GET_CONFIGURATION:
|
case USB_REQUEST_GET_CONFIGURATION:
|
||||||
descriptor = (u8 *)&usbd_otg->configuration;
|
descriptor = (u8 *)&usbd_otg->config_num;
|
||||||
size = _wLength;
|
size = _wLength;
|
||||||
transmit_data = 1;
|
transmit_data = true;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
ep_stall = 1;
|
ep_stall = 1;
|
||||||
|
@ -1173,15 +1173,15 @@ static int _usbd_handle_ep0_control_transfer()
|
||||||
case (USB_SETUP_DEVICE_TO_HOST | USB_SETUP_TYPE_STANDARD | USB_SETUP_RECIPIENT_INTERFACE):
|
case (USB_SETUP_DEVICE_TO_HOST | USB_SETUP_TYPE_STANDARD | USB_SETUP_RECIPIENT_INTERFACE):
|
||||||
if (_bRequest == USB_REQUEST_GET_INTERFACE)
|
if (_bRequest == USB_REQUEST_GET_INTERFACE)
|
||||||
{
|
{
|
||||||
descriptor = (void *)&usbd_otg->interface;
|
descriptor = (void *)&usbd_otg->interface_num;
|
||||||
}
|
}
|
||||||
else if (_bRequest == USB_REQUEST_GET_STATUS)
|
else if (_bRequest == USB_REQUEST_GET_STATUS)
|
||||||
{
|
{
|
||||||
memset(descriptor, 0, _wLength);
|
memset(descriptor, 0, _wLength);
|
||||||
}
|
}
|
||||||
else if (_bRequest == USB_REQUEST_GET_DESCRIPTOR && (_wValue >> 8) == USB_DESCRIPTOR_HID_REPORT && usbd_otg->type > USB_GADGET_UMS)
|
else if (_bRequest == USB_REQUEST_GET_DESCRIPTOR && (_wValue >> 8) == USB_DESCRIPTOR_HID_REPORT && usbd_otg->gadget > USB_GADGET_UMS)
|
||||||
{
|
{
|
||||||
if (usbd_otg->type == USB_GADGET_HID_GAMEPAD)
|
if (usbd_otg->gadget == USB_GADGET_HID_GAMEPAD)
|
||||||
{
|
{
|
||||||
descriptor = (u8 *)&hid_report_descriptor_jc;
|
descriptor = (u8 *)&hid_report_descriptor_jc;
|
||||||
_wLength = hid_report_descriptor_jc_size;
|
_wLength = hid_report_descriptor_jc_size;
|
||||||
|
@ -1192,7 +1192,7 @@ static int _usbd_handle_ep0_control_transfer()
|
||||||
_wLength = hid_report_descriptor_touch_size;
|
_wLength = hid_report_descriptor_touch_size;
|
||||||
}
|
}
|
||||||
|
|
||||||
usbd_otg->hid_report_sent = 1;
|
usbd_otg->hid_report_sent = true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -1201,7 +1201,7 @@ static int _usbd_handle_ep0_control_transfer()
|
||||||
}
|
}
|
||||||
|
|
||||||
size = _wLength;
|
size = _wLength;
|
||||||
transmit_data = 1;
|
transmit_data = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case (USB_SETUP_DEVICE_TO_HOST | USB_SETUP_TYPE_STANDARD | USB_SETUP_RECIPIENT_ENDPOINT):
|
case (USB_SETUP_DEVICE_TO_HOST | USB_SETUP_TYPE_STANDARD | USB_SETUP_RECIPIENT_ENDPOINT):
|
||||||
|
@ -1235,7 +1235,7 @@ static int _usbd_handle_ep0_control_transfer()
|
||||||
else
|
else
|
||||||
descriptor[0] = USB_STATUS_EP_OK;
|
descriptor[0] = USB_STATUS_EP_OK;
|
||||||
|
|
||||||
transmit_data = 1;
|
transmit_data = true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
_usbd_stall_reset_ep1(3, USB_EP_CFG_STALL);
|
_usbd_stall_reset_ep1(3, USB_EP_CFG_STALL);
|
||||||
|
@ -1243,7 +1243,6 @@ static int _usbd_handle_ep0_control_transfer()
|
||||||
|
|
||||||
case (USB_SETUP_DEVICE_TO_HOST | USB_SETUP_TYPE_CLASS | USB_SETUP_RECIPIENT_INTERFACE):
|
case (USB_SETUP_DEVICE_TO_HOST | USB_SETUP_TYPE_CLASS | USB_SETUP_RECIPIENT_INTERFACE):
|
||||||
memset(descriptor, 0, _wLength);
|
memset(descriptor, 0, _wLength);
|
||||||
|
|
||||||
_usbd_handle_get_class_request(&transmit_data, descriptor, &size, &ep_stall);
|
_usbd_handle_get_class_request(&transmit_data, descriptor, &size, &ep_stall);
|
||||||
size = _wLength;
|
size = _wLength;
|
||||||
break;
|
break;
|
||||||
|
@ -1257,12 +1256,12 @@ static int _usbd_handle_ep0_control_transfer()
|
||||||
case USB_DESCRIPTOR_MS_COMPAT_ID:
|
case USB_DESCRIPTOR_MS_COMPAT_ID:
|
||||||
descriptor = (u8 *)usbd_otg->desc->ms_cid;
|
descriptor = (u8 *)usbd_otg->desc->ms_cid;
|
||||||
size = usbd_otg->desc->ms_cid->dLength;
|
size = usbd_otg->desc->ms_cid->dLength;
|
||||||
transmit_data = 1;
|
transmit_data = true;
|
||||||
break;
|
break;
|
||||||
case USB_DESCRIPTOR_MS_EXTENDED_PROPERTIES:
|
case USB_DESCRIPTOR_MS_EXTENDED_PROPERTIES:
|
||||||
descriptor = (u8 *)usbd_otg->desc->mx_ext;
|
descriptor = (u8 *)usbd_otg->desc->mx_ext;
|
||||||
size = usbd_otg->desc->mx_ext->dLength;
|
size = usbd_otg->desc->mx_ext->dLength;
|
||||||
transmit_data = 1;
|
transmit_data = true;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
ep_stall = 1;
|
ep_stall = 1;
|
||||||
|
@ -1312,8 +1311,8 @@ static int _usbd_ep0_initialize()
|
||||||
|
|
||||||
if (enter)
|
if (enter)
|
||||||
{
|
{
|
||||||
usbd_otg->configuration_set = 0;
|
usbd_otg->configuration_set = false;
|
||||||
usbd_otg->max_lun_set = 0;
|
usbd_otg->max_lun_set = false;
|
||||||
|
|
||||||
// Timeout if cable or communication isn't started in 1.5 minutes.
|
// Timeout if cable or communication isn't started in 1.5 minutes.
|
||||||
u32 timer = get_tmr_ms() + 90000;
|
u32 timer = get_tmr_ms() + 90000;
|
||||||
|
@ -1360,9 +1359,9 @@ static int _usbd_ep0_initialize()
|
||||||
return 3;
|
return 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
int usb_device_enumerate(usb_gadget_type type)
|
int usb_device_enumerate(usb_gadget_type gadget)
|
||||||
{
|
{
|
||||||
switch (type)
|
switch (gadget)
|
||||||
{
|
{
|
||||||
case USB_GADGET_UMS:
|
case USB_GADGET_UMS:
|
||||||
usbd_otg->desc = &usb_gadget_ums_descriptors;
|
usbd_otg->desc = &usb_gadget_ums_descriptors;
|
||||||
|
@ -1375,7 +1374,7 @@ int usb_device_enumerate(usb_gadget_type type)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
usbd_otg->type = type;
|
usbd_otg->gadget = gadget;
|
||||||
|
|
||||||
int result = _usbd_ep0_initialize();
|
int result = _usbd_ep0_initialize();
|
||||||
if (result)
|
if (result)
|
||||||
|
@ -1397,7 +1396,7 @@ int usbd_handle_ep0_ctrl_setup()
|
||||||
|
|
||||||
if (usbd_otg->bulk_reset_req)
|
if (usbd_otg->bulk_reset_req)
|
||||||
{
|
{
|
||||||
usbd_otg->bulk_reset_req = 0;
|
usbd_otg->bulk_reset_req = false;
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1422,12 +1421,7 @@ int usb_device_ep1_out_read(u8 *buf, u32 len, u32 *bytes_read, bool sync)
|
||||||
int result = _usbd_ep_operation(USB_EP_BULK_OUT, buf, len, sync);
|
int result = _usbd_ep_operation(USB_EP_BULK_OUT, buf, len, sync);
|
||||||
|
|
||||||
if (sync && bytes_read)
|
if (sync && bytes_read)
|
||||||
{
|
*bytes_read = result ? 0 : len;
|
||||||
if (result)
|
|
||||||
*bytes_read = 0;
|
|
||||||
else
|
|
||||||
*bytes_read = len;
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -1447,25 +1441,23 @@ int usb_device_ep1_out_read_big(u8 *buf, u32 len, u32 *bytes_read)
|
||||||
u32 len_ep = MIN(len, USB_EP_BUFFER_MAX_SIZE);
|
u32 len_ep = MIN(len, USB_EP_BUFFER_MAX_SIZE);
|
||||||
|
|
||||||
result = usb_device_ep1_out_read(buf_curr, len_ep, &bytes, USB_XFER_SYNCED);
|
result = usb_device_ep1_out_read(buf_curr, len_ep, &bytes, USB_XFER_SYNCED);
|
||||||
if (!result)
|
if (result)
|
||||||
{
|
return result;
|
||||||
|
|
||||||
len -= len_ep;
|
len -= len_ep;
|
||||||
buf_curr += len_ep;
|
buf_curr += len_ep;
|
||||||
*bytes_read = *bytes_read + bytes;
|
*bytes_read = *bytes_read + bytes;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int _usbd_get_ep1_out_bytes_read()
|
static int _usbd_get_ep1_out_bytes_read()
|
||||||
{
|
{
|
||||||
if (_usbd_get_ep_status(2) != USB_EP_STATUS_IDLE)
|
if (_usbd_get_ep_status(USB_EP_BULK_OUT) != USB_EP_STATUS_IDLE)
|
||||||
return 0;
|
return 0;
|
||||||
else
|
else
|
||||||
return (usbdaemon->ep_bytes_requested[2] - (usbdaemon->qhs[2].token >> 16));
|
return (usbdaemon->ep_bytes_requested[USB_EP_BULK_OUT] - (usbdaemon->qhs[USB_EP_BULK_OUT].token >> 16));
|
||||||
}
|
}
|
||||||
|
|
||||||
int usb_device_ep1_out_reading_finish(u32 *pending_bytes, int tries)
|
int usb_device_ep1_out_reading_finish(u32 *pending_bytes, int tries)
|
||||||
|
@ -1501,22 +1493,17 @@ int usb_device_ep1_in_write(u8 *buf, u32 len, u32 *bytes_written, bool sync)
|
||||||
int result = _usbd_ep_operation(USB_EP_BULK_IN, buf, len, sync);
|
int result = _usbd_ep_operation(USB_EP_BULK_IN, buf, len, sync);
|
||||||
|
|
||||||
if (sync && bytes_written)
|
if (sync && bytes_written)
|
||||||
{
|
*bytes_written = result ? 0 : len;
|
||||||
if (result)
|
|
||||||
*bytes_written = 0;
|
|
||||||
else
|
|
||||||
*bytes_written = len;
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int _usbd_get_ep1_in_bytes_written()
|
static int _usbd_get_ep1_in_bytes_written()
|
||||||
{
|
{
|
||||||
if (_usbd_get_ep_status(3) != USB_EP_STATUS_IDLE)
|
if (_usbd_get_ep_status(USB_EP_BULK_IN) != USB_EP_STATUS_IDLE)
|
||||||
return 0;
|
return 0;
|
||||||
else
|
else
|
||||||
return (usbdaemon->ep_bytes_requested[3] - (usbdaemon->qhs[3].token >> 16));
|
return (usbdaemon->ep_bytes_requested[USB_EP_BULK_IN] - (usbdaemon->qhs[USB_EP_BULK_IN].token >> 16));
|
||||||
}
|
}
|
||||||
|
|
||||||
int usb_device_ep1_in_writing_finish(u32 *pending_bytes)
|
int usb_device_ep1_in_writing_finish(u32 *pending_bytes)
|
||||||
|
@ -1545,8 +1532,8 @@ int usb_device_ep1_in_writing_finish(u32 *pending_bytes)
|
||||||
|
|
||||||
bool usb_device_get_suspended()
|
bool usb_device_get_suspended()
|
||||||
{
|
{
|
||||||
u32 suspended = usbd_otg->regs->portsc1 & USB2D_PORTSC1_SUSP;
|
bool suspended = (usbd_otg->regs->portsc1 & USB2D_PORTSC1_SUSP) == USB2D_PORTSC1_SUSP;
|
||||||
return (suspended ? true : false);
|
return suspended;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool usb_device_get_port_in_sleep()
|
bool usb_device_get_port_in_sleep()
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Enhanced USB (EHCI) Device driver for Tegra X1
|
* Enhanced USB Device (EDCI) driver for Tegra X1
|
||||||
*
|
*
|
||||||
* Copyright (c) 2019 CTCaer
|
* Copyright (c) 2019 CTCaer
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in a new issue