mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-18 11:21:11 +00:00
refactor(core/embed): remove global deps from usb class drivers
[no changelog]
This commit is contained in:
parent
baff1691a0
commit
d8d6410284
@ -324,13 +324,13 @@ void usb_set_iface_class(uint8_t iface_num, const USBD_ClassTypeDef *class) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
USBD_HandleTypeDef *usb_get_dev_handle(void) {
|
USBD_HandleTypeDef *usb_get_dev_handle(void) {
|
||||||
usb_driver_t *usb = &g_usb_driver;
|
usb_driver_t *drv = &g_usb_driver;
|
||||||
|
|
||||||
return &usb->dev_handle;
|
return &drv->dev_handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
void *usb_alloc_class_descriptors(size_t desc_len) {
|
void *usb_alloc_class_descriptors(size_t desc_len) {
|
||||||
usb_driver_t *usb = &g_usb_driver;
|
usb_driver_t *drv = &g_usb_driver;
|
||||||
|
|
||||||
if (drv->config_desc->wTotalLength + desc_len < USB_MAX_CONFIG_DESC_SIZE) {
|
if (drv->config_desc->wTotalLength + desc_len < USB_MAX_CONFIG_DESC_SIZE) {
|
||||||
void *retval = &drv->desc_buffer[drv->config_desc->wTotalLength];
|
void *retval = &drv->desc_buffer[drv->config_desc->wTotalLength];
|
||||||
|
@ -146,7 +146,6 @@ secbool usb_hid_add(const usb_hid_info_t *info) {
|
|||||||
d->ep_out.bInterval = info->polling_interval;
|
d->ep_out.bInterval = info->polling_interval;
|
||||||
|
|
||||||
// Interface state
|
// Interface state
|
||||||
state->dev_handle = usb_get_dev_handle();
|
|
||||||
state->desc_block = d;
|
state->desc_block = d;
|
||||||
state->report_desc = info->report_desc;
|
state->report_desc = info->report_desc;
|
||||||
state->rx_buffer = info->rx_buffer;
|
state->rx_buffer = info->rx_buffer;
|
||||||
@ -171,10 +170,12 @@ secbool usb_hid_can_read(uint8_t iface_num) {
|
|||||||
if (state == NULL) {
|
if (state == NULL) {
|
||||||
return secfalse; // Invalid interface number
|
return secfalse; // Invalid interface number
|
||||||
}
|
}
|
||||||
|
if (state->dev_handle == NULL) {
|
||||||
|
return secfalse; // Class driver not initialized
|
||||||
|
}
|
||||||
if (state->last_read_len == 0) {
|
if (state->last_read_len == 0) {
|
||||||
return secfalse; // Nothing in the receiving buffer
|
return secfalse; // Nothing in the receiving buffer
|
||||||
}
|
}
|
||||||
|
|
||||||
if (state->dev_handle->dev_state != USBD_STATE_CONFIGURED) {
|
if (state->dev_handle->dev_state != USBD_STATE_CONFIGURED) {
|
||||||
return secfalse; // Device is not configured
|
return secfalse; // Device is not configured
|
||||||
}
|
}
|
||||||
@ -186,6 +187,9 @@ secbool usb_hid_can_write(uint8_t iface_num) {
|
|||||||
if (state == NULL) {
|
if (state == NULL) {
|
||||||
return secfalse; // Invalid interface number
|
return secfalse; // Invalid interface number
|
||||||
}
|
}
|
||||||
|
if (state->dev_handle == NULL) {
|
||||||
|
return secfalse; // Class driver not initialized
|
||||||
|
}
|
||||||
if (state->ep_in_is_idle == 0) {
|
if (state->ep_in_is_idle == 0) {
|
||||||
return secfalse; // Last transmission is not over yet
|
return secfalse; // Last transmission is not over yet
|
||||||
}
|
}
|
||||||
@ -202,6 +206,10 @@ int usb_hid_read(uint8_t iface_num, uint8_t *buf, uint32_t len) {
|
|||||||
return -1; // Invalid interface number
|
return -1; // Invalid interface number
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (state->dev_handle == NULL) {
|
||||||
|
return -1; // Class driver not initialized
|
||||||
|
}
|
||||||
|
|
||||||
// Copy maximum possible amount of data
|
// Copy maximum possible amount of data
|
||||||
uint32_t last_read_len = state->last_read_len;
|
uint32_t last_read_len = state->last_read_len;
|
||||||
if (len < last_read_len) {
|
if (len < last_read_len) {
|
||||||
@ -226,6 +234,10 @@ int usb_hid_write(uint8_t iface_num, const uint8_t *buf, uint32_t len) {
|
|||||||
return -1; // Invalid interface number
|
return -1; // Invalid interface number
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (state->dev_handle == NULL) {
|
||||||
|
return -1; // Class driver not initialized
|
||||||
|
}
|
||||||
|
|
||||||
if (state->ep_in_is_idle == 0) {
|
if (state->ep_in_is_idle == 0) {
|
||||||
return 0; // Last transmission is not over yet
|
return 0; // Last transmission is not over yet
|
||||||
}
|
}
|
||||||
@ -280,6 +292,8 @@ int usb_hid_write_blocking(uint8_t iface_num, const uint8_t *buf, uint32_t len,
|
|||||||
static uint8_t usb_hid_class_init(USBD_HandleTypeDef *dev, uint8_t cfg_idx) {
|
static uint8_t usb_hid_class_init(USBD_HandleTypeDef *dev, uint8_t cfg_idx) {
|
||||||
usb_hid_state_t *state = (usb_hid_state_t *)dev->pUserData;
|
usb_hid_state_t *state = (usb_hid_state_t *)dev->pUserData;
|
||||||
|
|
||||||
|
state->dev_handle = dev;
|
||||||
|
|
||||||
// Open endpoints
|
// Open endpoints
|
||||||
USBD_LL_OpenEP(dev, state->ep_in, USBD_EP_TYPE_INTR, state->max_packet_len);
|
USBD_LL_OpenEP(dev, state->ep_in, USBD_EP_TYPE_INTR, state->max_packet_len);
|
||||||
USBD_LL_OpenEP(dev, state->ep_out, USBD_EP_TYPE_INTR, state->max_packet_len);
|
USBD_LL_OpenEP(dev, state->ep_out, USBD_EP_TYPE_INTR, state->max_packet_len);
|
||||||
@ -308,6 +322,8 @@ static uint8_t usb_hid_class_deinit(USBD_HandleTypeDef *dev, uint8_t cfg_idx) {
|
|||||||
USBD_LL_CloseEP(dev, state->ep_in);
|
USBD_LL_CloseEP(dev, state->ep_in);
|
||||||
USBD_LL_CloseEP(dev, state->ep_out);
|
USBD_LL_CloseEP(dev, state->ep_out);
|
||||||
|
|
||||||
|
state->dev_handle = NULL;
|
||||||
|
|
||||||
return USBD_OK;
|
return USBD_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -297,7 +297,6 @@ secbool usb_vcp_add(const usb_vcp_info_t *info) {
|
|||||||
d->ep_in.bInterval = 0;
|
d->ep_in.bInterval = 0;
|
||||||
|
|
||||||
// Interface state
|
// Interface state
|
||||||
state->dev_handle = usb_get_dev_handle();
|
|
||||||
state->desc_block = d;
|
state->desc_block = d;
|
||||||
|
|
||||||
state->rx_ring.buf = info->rx_buffer;
|
state->rx_ring.buf = info->rx_buffer;
|
||||||
@ -428,6 +427,8 @@ int usb_vcp_write_blocking(uint8_t iface_num, const uint8_t *buf, uint32_t len,
|
|||||||
static uint8_t usb_vcp_class_init(USBD_HandleTypeDef *dev, uint8_t cfg_idx) {
|
static uint8_t usb_vcp_class_init(USBD_HandleTypeDef *dev, uint8_t cfg_idx) {
|
||||||
usb_vcp_state_t *state = (usb_vcp_state_t *)dev->pUserData;
|
usb_vcp_state_t *state = (usb_vcp_state_t *)dev->pUserData;
|
||||||
|
|
||||||
|
state->dev_handle = dev;
|
||||||
|
|
||||||
// Open endpoints
|
// Open endpoints
|
||||||
USBD_LL_OpenEP(dev, state->ep_in, USBD_EP_TYPE_BULK, state->max_packet_len);
|
USBD_LL_OpenEP(dev, state->ep_in, USBD_EP_TYPE_BULK, state->max_packet_len);
|
||||||
USBD_LL_OpenEP(dev, state->ep_out, USBD_EP_TYPE_BULK, state->max_packet_len);
|
USBD_LL_OpenEP(dev, state->ep_out, USBD_EP_TYPE_BULK, state->max_packet_len);
|
||||||
@ -460,6 +461,8 @@ static uint8_t usb_vcp_class_deinit(USBD_HandleTypeDef *dev, uint8_t cfg_idx) {
|
|||||||
USBD_LL_CloseEP(dev, state->ep_out);
|
USBD_LL_CloseEP(dev, state->ep_out);
|
||||||
USBD_LL_CloseEP(dev, state->ep_cmd);
|
USBD_LL_CloseEP(dev, state->ep_cmd);
|
||||||
|
|
||||||
|
state->dev_handle = NULL;
|
||||||
|
|
||||||
return USBD_OK;
|
return USBD_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -111,7 +111,6 @@ secbool usb_webusb_add(const usb_webusb_info_t *info) {
|
|||||||
d->ep_out.bInterval = info->polling_interval;
|
d->ep_out.bInterval = info->polling_interval;
|
||||||
|
|
||||||
// Interface state
|
// Interface state
|
||||||
state->dev_handle = usb_get_dev_handle();
|
|
||||||
state->desc_block = d;
|
state->desc_block = d;
|
||||||
state->rx_buffer = info->rx_buffer;
|
state->rx_buffer = info->rx_buffer;
|
||||||
state->ep_in = info->ep_in | USB_EP_DIR_IN;
|
state->ep_in = info->ep_in | USB_EP_DIR_IN;
|
||||||
@ -128,9 +127,13 @@ secbool usb_webusb_add(const usb_webusb_info_t *info) {
|
|||||||
|
|
||||||
secbool usb_webusb_can_read(uint8_t iface_num) {
|
secbool usb_webusb_can_read(uint8_t iface_num) {
|
||||||
usb_webusb_state_t *state = usb_get_webusb_state(iface_num);
|
usb_webusb_state_t *state = usb_get_webusb_state(iface_num);
|
||||||
|
|
||||||
if (state == NULL) {
|
if (state == NULL) {
|
||||||
return secfalse; // Invalid interface number
|
return secfalse; // Invalid interface number
|
||||||
}
|
}
|
||||||
|
if (state->dev_handle == NULL) {
|
||||||
|
return secfalse; // Class driver not initialized
|
||||||
|
}
|
||||||
if (state->last_read_len == 0) {
|
if (state->last_read_len == 0) {
|
||||||
return secfalse; // Nothing in the receiving buffer
|
return secfalse; // Nothing in the receiving buffer
|
||||||
}
|
}
|
||||||
@ -145,6 +148,9 @@ secbool usb_webusb_can_write(uint8_t iface_num) {
|
|||||||
if (state == NULL) {
|
if (state == NULL) {
|
||||||
return secfalse; // Invalid interface number
|
return secfalse; // Invalid interface number
|
||||||
}
|
}
|
||||||
|
if (state->dev_handle == NULL) {
|
||||||
|
return secfalse; // Class driver not initialized
|
||||||
|
}
|
||||||
if (state->ep_in_is_idle == 0) {
|
if (state->ep_in_is_idle == 0) {
|
||||||
return secfalse; // Last transmission is not over yet
|
return secfalse; // Last transmission is not over yet
|
||||||
}
|
}
|
||||||
@ -160,6 +166,10 @@ int usb_webusb_read(uint8_t iface_num, uint8_t *buf, uint32_t len) {
|
|||||||
return -1; // Invalid interface number
|
return -1; // Invalid interface number
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (state->dev_handle == NULL) {
|
||||||
|
return -1; // Class driver not initialized
|
||||||
|
}
|
||||||
|
|
||||||
// Copy maximum possible amount of data
|
// Copy maximum possible amount of data
|
||||||
uint32_t last_read_len = state->last_read_len;
|
uint32_t last_read_len = state->last_read_len;
|
||||||
if (len < last_read_len) {
|
if (len < last_read_len) {
|
||||||
@ -183,6 +193,10 @@ int usb_webusb_write(uint8_t iface_num, const uint8_t *buf, uint32_t len) {
|
|||||||
return -1; // Invalid interface number
|
return -1; // Invalid interface number
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (state->dev_handle == NULL) {
|
||||||
|
return -1; // Class driver not initialized
|
||||||
|
}
|
||||||
|
|
||||||
state->ep_in_is_idle = 0;
|
state->ep_in_is_idle = 0;
|
||||||
USBD_LL_Transmit(state->dev_handle, state->ep_in, UNCONST(buf),
|
USBD_LL_Transmit(state->dev_handle, state->ep_in, UNCONST(buf),
|
||||||
(uint16_t)len);
|
(uint16_t)len);
|
||||||
@ -233,6 +247,8 @@ int usb_webusb_write_blocking(uint8_t iface_num, const uint8_t *buf,
|
|||||||
static uint8_t usb_webusb_class_init(USBD_HandleTypeDef *dev, uint8_t cfg_idx) {
|
static uint8_t usb_webusb_class_init(USBD_HandleTypeDef *dev, uint8_t cfg_idx) {
|
||||||
usb_webusb_state_t *state = (usb_webusb_state_t *)dev->pUserData;
|
usb_webusb_state_t *state = (usb_webusb_state_t *)dev->pUserData;
|
||||||
|
|
||||||
|
state->dev_handle = dev;
|
||||||
|
|
||||||
// Open endpoints
|
// Open endpoints
|
||||||
USBD_LL_OpenEP(dev, state->ep_in, USBD_EP_TYPE_INTR, state->max_packet_len);
|
USBD_LL_OpenEP(dev, state->ep_in, USBD_EP_TYPE_INTR, state->max_packet_len);
|
||||||
USBD_LL_OpenEP(dev, state->ep_out, USBD_EP_TYPE_INTR, state->max_packet_len);
|
USBD_LL_OpenEP(dev, state->ep_out, USBD_EP_TYPE_INTR, state->max_packet_len);
|
||||||
@ -260,6 +276,8 @@ static uint8_t usb_webusb_class_deinit(USBD_HandleTypeDef *dev,
|
|||||||
USBD_LL_CloseEP(dev, state->ep_in);
|
USBD_LL_CloseEP(dev, state->ep_in);
|
||||||
USBD_LL_CloseEP(dev, state->ep_out);
|
USBD_LL_CloseEP(dev, state->ep_out);
|
||||||
|
|
||||||
|
state->dev_handle = NULL;
|
||||||
|
|
||||||
return USBD_OK;
|
return USBD_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -126,7 +126,4 @@ void usb_set_iface_class(uint8_t iface_num, const USBD_ClassTypeDef *class);
|
|||||||
// returns NULL if not.
|
// returns NULL if not.
|
||||||
void *usb_alloc_class_descriptors(size_t desc_len);
|
void *usb_alloc_class_descriptors(size_t desc_len);
|
||||||
|
|
||||||
// Returns the global handle to the USB device.
|
|
||||||
USBD_HandleTypeDef *usb_get_dev_handle(void);
|
|
||||||
|
|
||||||
#endif // TREZORHAL_USBD_INTERNAL_H
|
#endif // TREZORHAL_USBD_INTERNAL_H
|
||||||
|
Loading…
Reference in New Issue
Block a user