stm32/usbdev: Put all state for the USB device driver in a struct.
This commit is contained in:
parent
35e3435f6e
commit
f8f17f48c5
@ -111,7 +111,7 @@ bool pyb_usb_dev_init(uint16_t vid, uint16_t pid, usb_device_mode_t mode, USBD_H
|
||||
|
||||
// configure the VID, PID and the USBD mode (interfaces it will expose)
|
||||
USBD_SetVIDPIDRelease(vid, pid, 0x0200, mode == USBD_MODE_CDC);
|
||||
if (USBD_SelectMode(mode, hid_info) != 0) {
|
||||
if (USBD_SelectMode(&usbd_cdc_msc_hid_state, mode, hid_info) != 0) {
|
||||
return false;
|
||||
}
|
||||
|
||||
@ -121,6 +121,7 @@ bool pyb_usb_dev_init(uint16_t vid, uint16_t pid, usb_device_mode_t mode, USBD_H
|
||||
usbd->dev_state = USBD_STATE_DEFAULT;
|
||||
usbd->pDesc = (USBD_DescriptorsTypeDef*)&USBD_Descriptors;
|
||||
usbd->pClass = &USBD_CDC_MSC_HID;
|
||||
usbd_cdc_msc_hid_state.pdev = usbd;
|
||||
usbd_cdc_msc_hid_state.cdc = &usbd_cdc_itf;
|
||||
usbd_cdc_msc_hid_state.hid = &usbd_hid_itf;
|
||||
usbd->pClassData = &usbd_cdc_msc_hid_state;
|
||||
@ -128,11 +129,11 @@ bool pyb_usb_dev_init(uint16_t vid, uint16_t pid, usb_device_mode_t mode, USBD_H
|
||||
switch (pyb_usb_storage_medium) {
|
||||
#if MICROPY_HW_HAS_SDCARD
|
||||
case PYB_USB_STORAGE_MEDIUM_SDCARD:
|
||||
USBD_MSC_RegisterStorage(usbd, (USBD_StorageTypeDef*)&USBD_SDCARD_STORAGE_fops);
|
||||
USBD_MSC_RegisterStorage(&usbd_cdc_msc_hid_state, (USBD_StorageTypeDef*)&USBD_SDCARD_STORAGE_fops);
|
||||
break;
|
||||
#endif
|
||||
default:
|
||||
USBD_MSC_RegisterStorage(usbd, (USBD_StorageTypeDef*)&USBD_FLASH_STORAGE_fops);
|
||||
USBD_MSC_RegisterStorage(&usbd_cdc_msc_hid_state, (USBD_StorageTypeDef*)&USBD_FLASH_STORAGE_fops);
|
||||
break;
|
||||
}
|
||||
|
||||
@ -225,7 +226,7 @@ STATIC mp_obj_t pyb_usb_mode(size_t n_args, const mp_obj_t *pos_args, mp_map_t *
|
||||
#if defined(USE_HOST_MODE)
|
||||
return MP_OBJ_NEW_QSTR(MP_QSTR_host);
|
||||
#elif defined(USE_DEVICE_MODE)
|
||||
uint8_t mode = USBD_GetMode();
|
||||
uint8_t mode = USBD_GetMode(&usbd_cdc_msc_hid_state);
|
||||
switch (mode) {
|
||||
case USBD_MODE_CDC:
|
||||
return MP_OBJ_NEW_QSTR(MP_QSTR_VCP);
|
||||
@ -614,7 +615,7 @@ STATIC mp_obj_t pyb_usb_hid_send(mp_obj_t self_in, mp_obj_t report_in) {
|
||||
}
|
||||
|
||||
// send the data
|
||||
if (USBD_OK == USBD_HID_SendReport(&hUSBDDevice, bufinfo.buf, bufinfo.len)) {
|
||||
if (USBD_OK == USBD_HID_SendReport(&usbd_cdc_msc_hid_state, bufinfo.buf, bufinfo.len)) {
|
||||
return mp_obj_new_int(bufinfo.len);
|
||||
} else {
|
||||
return mp_obj_new_int(0);
|
||||
@ -646,7 +647,7 @@ STATIC mp_uint_t pyb_usb_hid_ioctl(mp_obj_t self_in, mp_uint_t request, mp_uint_
|
||||
if ((flags & MP_STREAM_POLL_RD) && usbd_hid_rx_num(&usbd_hid_itf) > 0) {
|
||||
ret |= MP_STREAM_POLL_RD;
|
||||
}
|
||||
if ((flags & MP_STREAM_POLL_WR) && USBD_HID_CanSendReport(&hUSBDDevice)) {
|
||||
if ((flags & MP_STREAM_POLL_WR) && USBD_HID_CanSendReport(&usbd_cdc_msc_hid_state)) {
|
||||
ret |= MP_STREAM_POLL_WR;
|
||||
}
|
||||
} else {
|
||||
|
@ -56,8 +56,8 @@
|
||||
#define CDC_SET_CONTROL_LINE_STATE 0x22
|
||||
#define CDC_SEND_BREAK 0x23
|
||||
|
||||
uint8_t *usbd_cdc_init(usbd_cdc_itf_t *cdc, USBD_HandleTypeDef *pdev) {
|
||||
cdc->usb = pdev;
|
||||
uint8_t *usbd_cdc_init(usbd_cdc_itf_t *cdc, usbd_cdc_msc_hid_state_t *usbd) {
|
||||
cdc->usbd = usbd;
|
||||
cdc->rx_buf_put = 0;
|
||||
cdc->rx_buf_get = 0;
|
||||
cdc->tx_buf_ptr_in = 0;
|
||||
@ -181,7 +181,7 @@ void HAL_PCD_SOFCallback(PCD_HandleTypeDef *hpcd) {
|
||||
|
||||
buffptr = cdc->tx_buf_ptr_out_shadow;
|
||||
|
||||
if (USBD_CDC_TransmitPacket(hpcd->pData, buffsize, &cdc->tx_buf[buffptr]) == USBD_OK) {
|
||||
if (USBD_CDC_TransmitPacket(cdc->usbd, buffsize, &cdc->tx_buf[buffptr]) == USBD_OK) {
|
||||
cdc->tx_buf_ptr_out_shadow += buffsize;
|
||||
if (cdc->tx_buf_ptr_out_shadow == USBD_CDC_TX_DATA_SIZE) {
|
||||
cdc->tx_buf_ptr_out_shadow = 0;
|
||||
@ -219,7 +219,7 @@ int8_t usbd_cdc_receive(usbd_cdc_itf_t *cdc, size_t len) {
|
||||
}
|
||||
|
||||
// initiate next USB packet transfer
|
||||
USBD_CDC_ReceivePacket(cdc->usb, cdc->rx_packet_buf);
|
||||
USBD_CDC_ReceivePacket(cdc->usbd, cdc->rx_packet_buf);
|
||||
|
||||
return USBD_OK;
|
||||
}
|
||||
|
@ -35,7 +35,7 @@
|
||||
#define USBD_CDC_TX_DATA_SIZE (1024) // I think this can be any value (was 2048)
|
||||
|
||||
typedef struct _usbd_cdc_itf_t {
|
||||
USBD_HandleTypeDef *usb; // the parent USB device
|
||||
usbd_cdc_msc_hid_state_t *usbd; // the parent USB device
|
||||
|
||||
uint8_t rx_packet_buf[CDC_DATA_FS_MAX_PACKET_SIZE]; // received data from USB OUT endpoint is stored in this buffer
|
||||
uint8_t rx_user_buf[USBD_CDC_RX_DATA_SIZE]; // received data is buffered here until the user reads it
|
||||
|
@ -42,8 +42,8 @@
|
||||
#include "irq.h"
|
||||
#include "usb.h"
|
||||
|
||||
uint8_t *usbd_hid_init(usbd_hid_itf_t *hid, USBD_HandleTypeDef *pdev) {
|
||||
hid->usb = pdev;
|
||||
uint8_t *usbd_hid_init(usbd_hid_itf_t *hid, usbd_cdc_msc_hid_state_t *usbd) {
|
||||
hid->usbd = usbd;
|
||||
hid->current_read_buffer = 0;
|
||||
hid->last_read_len = 0;
|
||||
hid->current_write_buffer = 0;
|
||||
@ -59,9 +59,9 @@ int8_t usbd_hid_receive(usbd_hid_itf_t *hid, size_t len) {
|
||||
hid->current_write_buffer = !hid->current_write_buffer;
|
||||
hid->last_read_len = len;
|
||||
// initiate next USB packet transfer, to append to existing data in buffer
|
||||
USBD_HID_ReceivePacket(hid->usb, hid->buffer[hid->current_write_buffer]);
|
||||
USBD_HID_ReceivePacket(hid->usbd, hid->buffer[hid->current_write_buffer]);
|
||||
// Set NAK to indicate we need to process read buffer
|
||||
USBD_HID_SetNAK(hid->usb);
|
||||
USBD_HID_SetNAK(hid->usbd);
|
||||
return USBD_OK;
|
||||
}
|
||||
|
||||
@ -98,7 +98,7 @@ int usbd_hid_rx(usbd_hid_itf_t *hid, size_t len, uint8_t *buf, uint32_t timeout)
|
||||
hid->current_read_buffer = !hid->current_read_buffer;
|
||||
|
||||
// Clear NAK to indicate we are ready to read more data
|
||||
USBD_HID_ClearNAK(hid->usb);
|
||||
USBD_HID_ClearNAK(hid->usbd);
|
||||
|
||||
// Success, return number of bytes read
|
||||
return hid->last_read_len;
|
||||
|
@ -7,7 +7,7 @@
|
||||
#include "usbd_cdc_msc_hid.h"
|
||||
|
||||
typedef struct _usbd_hid_itf_t {
|
||||
USBD_HandleTypeDef *usb; // the parent USB device
|
||||
usbd_cdc_msc_hid_state_t *usbd; // the parent USB device
|
||||
|
||||
uint8_t buffer[2][HID_DATA_FS_MAX_PACKET_SIZE]; // pair of buffers to read individual packets into
|
||||
int8_t current_read_buffer; // which buffer to read from
|
||||
|
@ -6,6 +6,10 @@
|
||||
#include "usbd_msc_scsi.h"
|
||||
#include "usbd_ioreq.h"
|
||||
|
||||
// Needed for the CDC+MSC+HID state and should be maximum of all template
|
||||
// config descriptors defined in usbd_cdc_msc_hid.c
|
||||
#define MAX_TEMPLATE_CONFIG_DESC_SIZE (107)
|
||||
|
||||
// CDC, MSC and HID packet sizes
|
||||
#define CDC_DATA_FS_MAX_PACKET_SIZE (64) // endpoint IN & OUT packet size
|
||||
#define MSC_MEDIA_PACKET (2048) // was 8192; how low can it go whilst still working?
|
||||
@ -70,7 +74,39 @@ typedef struct {
|
||||
uint32_t scsi_blk_len;
|
||||
} USBD_MSC_BOT_HandleTypeDef;
|
||||
|
||||
typedef enum {
|
||||
HID_IDLE = 0,
|
||||
HID_BUSY,
|
||||
} HID_StateTypeDef;
|
||||
|
||||
typedef struct {
|
||||
uint32_t Protocol;
|
||||
uint32_t IdleState;
|
||||
uint32_t AltSetting;
|
||||
HID_StateTypeDef state;
|
||||
} USBD_HID_HandleTypeDef;
|
||||
|
||||
typedef struct _usbd_cdc_msc_hid_state_t {
|
||||
USBD_HandleTypeDef *pdev;
|
||||
|
||||
uint8_t usbd_mode;
|
||||
uint8_t cdc_iface_num;
|
||||
uint8_t hid_in_ep;
|
||||
uint8_t hid_out_ep;
|
||||
uint8_t hid_iface_num;
|
||||
uint8_t usbd_config_desc_size;
|
||||
uint8_t *hid_desc;
|
||||
const uint8_t *hid_report_desc;
|
||||
|
||||
USBD_StorageTypeDef *MSC_fops;
|
||||
|
||||
USBD_CDC_HandleTypeDef CDC_ClassData;
|
||||
USBD_MSC_BOT_HandleTypeDef MSC_BOT_ClassData;
|
||||
USBD_HID_HandleTypeDef HID_ClassData;
|
||||
|
||||
// RAM to hold the current configuration descriptor, which we configure on the fly
|
||||
__ALIGN_BEGIN uint8_t usbd_config_desc[MAX_TEMPLATE_CONFIG_DESC_SIZE] __ALIGN_END;
|
||||
|
||||
void *cdc;
|
||||
void *msc;
|
||||
void *hid;
|
||||
@ -89,30 +125,30 @@ extern const uint8_t USBD_HID_KEYBOARD_ReportDesc[USBD_HID_KEYBOARD_REPORT_DESC_
|
||||
extern const USBD_ClassTypeDef USBD_CDC_MSC_HID;
|
||||
|
||||
// returns 0 on success, -1 on failure
|
||||
int USBD_SelectMode(uint32_t mode, USBD_HID_ModeInfoTypeDef *hid_info);
|
||||
int USBD_SelectMode(usbd_cdc_msc_hid_state_t *usbd, uint32_t mode, USBD_HID_ModeInfoTypeDef *hid_info);
|
||||
// returns the current usb mode
|
||||
uint8_t USBD_GetMode();
|
||||
uint8_t USBD_GetMode(usbd_cdc_msc_hid_state_t *usbd);
|
||||
|
||||
uint8_t USBD_CDC_ReceivePacket(USBD_HandleTypeDef *pdev, uint8_t *buf);
|
||||
uint8_t USBD_CDC_TransmitPacket(USBD_HandleTypeDef *pdev, size_t len, const uint8_t *buf);
|
||||
uint8_t USBD_CDC_ReceivePacket(usbd_cdc_msc_hid_state_t *usbd, uint8_t *buf);
|
||||
uint8_t USBD_CDC_TransmitPacket(usbd_cdc_msc_hid_state_t *usbd, size_t len, const uint8_t *buf);
|
||||
|
||||
uint8_t USBD_MSC_RegisterStorage(USBD_HandleTypeDef *pdev, USBD_StorageTypeDef *fops);
|
||||
uint8_t USBD_MSC_RegisterStorage(usbd_cdc_msc_hid_state_t *usbd, USBD_StorageTypeDef *fops);
|
||||
|
||||
uint8_t USBD_HID_ReceivePacket(USBD_HandleTypeDef *pdev, uint8_t *buf);
|
||||
int USBD_HID_CanSendReport(USBD_HandleTypeDef *pdev);
|
||||
uint8_t USBD_HID_SendReport(USBD_HandleTypeDef *pdev, uint8_t *report, uint16_t len);
|
||||
uint8_t USBD_HID_SetNAK(USBD_HandleTypeDef *pdev);
|
||||
uint8_t USBD_HID_ClearNAK(USBD_HandleTypeDef *pdev);
|
||||
uint8_t USBD_HID_ReceivePacket(usbd_cdc_msc_hid_state_t *usbd, uint8_t *buf);
|
||||
int USBD_HID_CanSendReport(usbd_cdc_msc_hid_state_t *usbd);
|
||||
uint8_t USBD_HID_SendReport(usbd_cdc_msc_hid_state_t *usbd, uint8_t *report, uint16_t len);
|
||||
uint8_t USBD_HID_SetNAK(usbd_cdc_msc_hid_state_t *usbd);
|
||||
uint8_t USBD_HID_ClearNAK(usbd_cdc_msc_hid_state_t *usbd);
|
||||
|
||||
// These are provided externally to implement the CDC interface
|
||||
struct _usbd_cdc_itf_t;
|
||||
uint8_t *usbd_cdc_init(struct _usbd_cdc_itf_t *cdc, USBD_HandleTypeDef *pdev);
|
||||
uint8_t *usbd_cdc_init(struct _usbd_cdc_itf_t *cdc, usbd_cdc_msc_hid_state_t *usbd);
|
||||
int8_t usbd_cdc_control(struct _usbd_cdc_itf_t *cdc, uint8_t cmd, uint8_t* pbuf, uint16_t length);
|
||||
int8_t usbd_cdc_receive(struct _usbd_cdc_itf_t *cdc, size_t len);
|
||||
|
||||
// These are provided externally to implement the HID interface
|
||||
struct _usbd_hid_itf_t;
|
||||
uint8_t *usbd_hid_init(struct _usbd_hid_itf_t *hid, USBD_HandleTypeDef *pdev);
|
||||
uint8_t *usbd_hid_init(struct _usbd_hid_itf_t *hid, usbd_cdc_msc_hid_state_t *usbd);
|
||||
int8_t usbd_hid_receive(struct _usbd_hid_itf_t *hid, size_t len);
|
||||
|
||||
#endif // _USB_CDC_MSC_CORE_H_
|
||||
|
@ -27,7 +27,6 @@
|
||||
#include "usbd_ioreq.h"
|
||||
#include "usbd_cdc_msc_hid.h"
|
||||
|
||||
#define MAX_TEMPLATE_CONFIG_DESC_SIZE (107) // should be maximum of all template config desc's
|
||||
#define CDC_TEMPLATE_CONFIG_DESC_SIZE (67)
|
||||
#define CDC_MSC_TEMPLATE_CONFIG_DESC_SIZE (98)
|
||||
#define CDC_HID_TEMPLATE_CONFIG_DESC_SIZE (107)
|
||||
@ -72,36 +71,6 @@
|
||||
#define HID_REQ_SET_IDLE (0x0a)
|
||||
#define HID_REQ_GET_IDLE (0x02)
|
||||
|
||||
typedef enum {
|
||||
HID_IDLE = 0,
|
||||
HID_BUSY,
|
||||
} HID_StateTypeDef;
|
||||
|
||||
typedef struct {
|
||||
uint32_t Protocol;
|
||||
uint32_t IdleState;
|
||||
uint32_t AltSetting;
|
||||
HID_StateTypeDef state;
|
||||
} USBD_HID_HandleTypeDef;
|
||||
|
||||
static uint8_t usbd_mode;
|
||||
static uint8_t cdc_iface_num;
|
||||
static uint8_t hid_in_ep;
|
||||
static uint8_t hid_out_ep;
|
||||
static uint8_t hid_iface_num;
|
||||
static uint8_t usbd_config_desc_size;
|
||||
static uint8_t *hid_desc;
|
||||
static const uint8_t *hid_report_desc;
|
||||
|
||||
static USBD_StorageTypeDef *MSC_fops;
|
||||
|
||||
static USBD_CDC_HandleTypeDef CDC_ClassData;
|
||||
static USBD_MSC_BOT_HandleTypeDef MSC_BOT_ClassData;
|
||||
static USBD_HID_HandleTypeDef HID_ClassData;
|
||||
|
||||
// RAM to hold the current configuration descriptor, which we configure on the fly
|
||||
__ALIGN_BEGIN static uint8_t usbd_config_desc[MAX_TEMPLATE_CONFIG_DESC_SIZE] __ALIGN_END;
|
||||
|
||||
/*
|
||||
// this is used only in high-speed mode, which we don't support
|
||||
// USB Standard Device Descriptor
|
||||
@ -574,36 +543,36 @@ __ALIGN_BEGIN const uint8_t USBD_HID_KEYBOARD_ReportDesc[USBD_HID_KEYBOARD_REPOR
|
||||
};
|
||||
|
||||
// return the saved usb mode
|
||||
uint8_t USBD_GetMode() {
|
||||
return usbd_mode;
|
||||
uint8_t USBD_GetMode(usbd_cdc_msc_hid_state_t *usbd) {
|
||||
return usbd->usbd_mode;
|
||||
}
|
||||
|
||||
int USBD_SelectMode(uint32_t mode, USBD_HID_ModeInfoTypeDef *hid_info) {
|
||||
int USBD_SelectMode(usbd_cdc_msc_hid_state_t *usbd, uint32_t mode, USBD_HID_ModeInfoTypeDef *hid_info) {
|
||||
// save mode
|
||||
usbd_mode = mode;
|
||||
usbd->usbd_mode = mode;
|
||||
|
||||
// construct config desc
|
||||
switch (usbd_mode) {
|
||||
switch (usbd->usbd_mode) {
|
||||
case USBD_MODE_CDC_MSC:
|
||||
usbd_config_desc_size = sizeof(cdc_msc_template_config_desc);
|
||||
memcpy(usbd_config_desc, cdc_msc_template_config_desc, sizeof(cdc_msc_template_config_desc));
|
||||
cdc_iface_num = CDC_IFACE_NUM_WITH_MSC;
|
||||
usbd->usbd_config_desc_size = sizeof(cdc_msc_template_config_desc);
|
||||
memcpy(usbd->usbd_config_desc, cdc_msc_template_config_desc, sizeof(cdc_msc_template_config_desc));
|
||||
usbd->cdc_iface_num = CDC_IFACE_NUM_WITH_MSC;
|
||||
break;
|
||||
|
||||
case USBD_MODE_CDC_HID:
|
||||
usbd_config_desc_size = sizeof(cdc_hid_template_config_desc);
|
||||
memcpy(usbd_config_desc, cdc_hid_template_config_desc, sizeof(cdc_hid_template_config_desc));
|
||||
cdc_iface_num = CDC_IFACE_NUM_WITH_HID;
|
||||
hid_in_ep = HID_IN_EP_WITH_CDC;
|
||||
hid_out_ep = HID_OUT_EP_WITH_CDC;
|
||||
hid_iface_num = HID_IFACE_NUM_WITH_CDC;
|
||||
hid_desc = usbd_config_desc + CDC_HID_TEMPLATE_HID_DESC_OFFSET;
|
||||
usbd->usbd_config_desc_size = sizeof(cdc_hid_template_config_desc);
|
||||
memcpy(usbd->usbd_config_desc, cdc_hid_template_config_desc, sizeof(cdc_hid_template_config_desc));
|
||||
usbd->cdc_iface_num = CDC_IFACE_NUM_WITH_HID;
|
||||
usbd->hid_in_ep = HID_IN_EP_WITH_CDC;
|
||||
usbd->hid_out_ep = HID_OUT_EP_WITH_CDC;
|
||||
usbd->hid_iface_num = HID_IFACE_NUM_WITH_CDC;
|
||||
usbd->hid_desc = usbd->usbd_config_desc + CDC_HID_TEMPLATE_HID_DESC_OFFSET;
|
||||
break;
|
||||
|
||||
case USBD_MODE_CDC:
|
||||
usbd_config_desc_size = sizeof(cdc_template_config_desc);
|
||||
memcpy(usbd_config_desc, cdc_template_config_desc, sizeof(cdc_template_config_desc));
|
||||
cdc_iface_num = CDC_IFACE_NUM_ALONE;
|
||||
usbd->usbd_config_desc_size = sizeof(cdc_template_config_desc);
|
||||
memcpy(usbd->usbd_config_desc, cdc_template_config_desc, sizeof(cdc_template_config_desc));
|
||||
usbd->cdc_iface_num = CDC_IFACE_NUM_ALONE;
|
||||
break;
|
||||
|
||||
/*
|
||||
@ -621,7 +590,8 @@ int USBD_SelectMode(uint32_t mode, USBD_HID_ModeInfoTypeDef *hid_info) {
|
||||
}
|
||||
|
||||
// configure the HID descriptor, if needed
|
||||
if (usbd_mode & USBD_MODE_HID) {
|
||||
if (usbd->usbd_mode & USBD_MODE_HID) {
|
||||
uint8_t *hid_desc = usbd->hid_desc;
|
||||
hid_desc[HID_DESC_OFFSET_SUBCLASS] = hid_info->subclass;
|
||||
hid_desc[HID_DESC_OFFSET_PROTOCOL] = hid_info->protocol;
|
||||
hid_desc[HID_DESC_OFFSET_REPORT_DESC_LEN] = hid_info->report_desc_len;
|
||||
@ -631,7 +601,7 @@ int USBD_SelectMode(uint32_t mode, USBD_HID_ModeInfoTypeDef *hid_info) {
|
||||
hid_desc[HID_DESC_OFFSET_MAX_PACKET_OUT_LO] = hid_info->max_packet_len;
|
||||
hid_desc[HID_DESC_OFFSET_MAX_PACKET_OUT_HI] = 0;
|
||||
hid_desc[HID_DESC_OFFSET_POLLING_INTERVAL_OUT] = hid_info->polling_interval;
|
||||
hid_report_desc = hid_info->report_desc;
|
||||
usbd->hid_report_desc = hid_info->report_desc;
|
||||
}
|
||||
|
||||
return 0;
|
||||
@ -643,9 +613,9 @@ static uint8_t USBD_CDC_MSC_HID_Init(USBD_HandleTypeDef *pdev, uint8_t cfgidx) {
|
||||
return 1;
|
||||
}
|
||||
|
||||
usbd_cdc_msc_hid_state_t *state = pdev->pClassData;
|
||||
usbd_cdc_msc_hid_state_t *usbd = pdev->pClassData;
|
||||
|
||||
if (usbd_mode & USBD_MODE_CDC) {
|
||||
if (usbd->usbd_mode & USBD_MODE_CDC) {
|
||||
// CDC VCP component
|
||||
|
||||
// Open EP IN
|
||||
@ -667,17 +637,17 @@ static uint8_t USBD_CDC_MSC_HID_Init(USBD_HandleTypeDef *pdev, uint8_t cfgidx) {
|
||||
CDC_CMD_PACKET_SIZE);
|
||||
|
||||
// Init physical Interface components
|
||||
uint8_t *buf = usbd_cdc_init(state->cdc, pdev);
|
||||
uint8_t *buf = usbd_cdc_init(usbd->cdc, usbd);
|
||||
|
||||
// Init Xfer states
|
||||
CDC_ClassData.TxState =0;
|
||||
CDC_ClassData.RxState =0;
|
||||
usbd->CDC_ClassData.TxState = 0;
|
||||
usbd->CDC_ClassData.RxState = 0;
|
||||
|
||||
// Prepare Out endpoint to receive next packet
|
||||
USBD_LL_PrepareReceive(pdev, CDC_OUT_EP, buf, CDC_DATA_OUT_PACKET_SIZE);
|
||||
}
|
||||
|
||||
if (usbd_mode & USBD_MODE_MSC) {
|
||||
if (usbd->usbd_mode & USBD_MODE_MSC) {
|
||||
// MSC component
|
||||
|
||||
// Open EP OUT
|
||||
@ -693,50 +663,50 @@ static uint8_t USBD_CDC_MSC_HID_Init(USBD_HandleTypeDef *pdev, uint8_t cfgidx) {
|
||||
MSC_MAX_PACKET);
|
||||
|
||||
// Set the MSC data for SCSI and BOT to reference it
|
||||
state->msc = &MSC_BOT_ClassData;
|
||||
usbd->msc = &usbd->MSC_BOT_ClassData;
|
||||
|
||||
// Init the BOT layer
|
||||
MSC_BOT_Init(pdev);
|
||||
}
|
||||
|
||||
if (usbd_mode & USBD_MODE_HID) {
|
||||
if (usbd->usbd_mode & USBD_MODE_HID) {
|
||||
// HID component
|
||||
|
||||
// get max packet lengths from descriptor
|
||||
uint16_t mps_in =
|
||||
hid_desc[HID_DESC_OFFSET_MAX_PACKET_LO]
|
||||
| (hid_desc[HID_DESC_OFFSET_MAX_PACKET_HI] << 8);
|
||||
usbd->hid_desc[HID_DESC_OFFSET_MAX_PACKET_LO]
|
||||
| (usbd->hid_desc[HID_DESC_OFFSET_MAX_PACKET_HI] << 8);
|
||||
uint16_t mps_out =
|
||||
hid_desc[HID_DESC_OFFSET_MAX_PACKET_OUT_LO]
|
||||
| (hid_desc[HID_DESC_OFFSET_MAX_PACKET_OUT_HI] << 8);
|
||||
usbd->hid_desc[HID_DESC_OFFSET_MAX_PACKET_OUT_LO]
|
||||
| (usbd->hid_desc[HID_DESC_OFFSET_MAX_PACKET_OUT_HI] << 8);
|
||||
|
||||
// Open EP IN
|
||||
USBD_LL_OpenEP(pdev,
|
||||
hid_in_ep,
|
||||
usbd->hid_in_ep,
|
||||
USBD_EP_TYPE_INTR,
|
||||
mps_in);
|
||||
|
||||
// Open EP OUT
|
||||
USBD_LL_OpenEP(pdev,
|
||||
hid_out_ep,
|
||||
usbd->hid_out_ep,
|
||||
USBD_EP_TYPE_INTR,
|
||||
mps_out);
|
||||
|
||||
uint8_t *buf = usbd_hid_init(state->hid, pdev);
|
||||
uint8_t *buf = usbd_hid_init(usbd->hid, usbd);
|
||||
|
||||
// Prepare Out endpoint to receive next packet
|
||||
USBD_LL_PrepareReceive(pdev, hid_out_ep, buf, mps_out);
|
||||
USBD_LL_PrepareReceive(pdev, usbd->hid_out_ep, buf, mps_out);
|
||||
|
||||
HID_ClassData.state = HID_IDLE;
|
||||
usbd->HID_ClassData.state = HID_IDLE;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static uint8_t USBD_CDC_MSC_HID_DeInit(USBD_HandleTypeDef *pdev, uint8_t cfgidx) {
|
||||
usbd_cdc_msc_hid_state_t *state = pdev->pClassData;
|
||||
usbd_cdc_msc_hid_state_t *usbd = pdev->pClassData;
|
||||
|
||||
if ((usbd_mode & USBD_MODE_CDC) && state->cdc) {
|
||||
if ((usbd->usbd_mode & USBD_MODE_CDC) && usbd->cdc) {
|
||||
// CDC VCP component
|
||||
|
||||
// close endpoints
|
||||
@ -745,7 +715,7 @@ static uint8_t USBD_CDC_MSC_HID_DeInit(USBD_HandleTypeDef *pdev, uint8_t cfgidx)
|
||||
USBD_LL_CloseEP(pdev, CDC_CMD_EP);
|
||||
}
|
||||
|
||||
if ((usbd_mode & USBD_MODE_MSC) && state->msc) {
|
||||
if ((usbd->usbd_mode & USBD_MODE_MSC) && usbd->msc) {
|
||||
// MSC component
|
||||
|
||||
// close endpoints
|
||||
@ -756,15 +726,15 @@ static uint8_t USBD_CDC_MSC_HID_DeInit(USBD_HandleTypeDef *pdev, uint8_t cfgidx)
|
||||
MSC_BOT_DeInit(pdev);
|
||||
|
||||
// clear the state pointer
|
||||
state->msc = NULL;
|
||||
usbd->msc = NULL;
|
||||
}
|
||||
|
||||
if (usbd_mode & USBD_MODE_HID) {
|
||||
if (usbd->usbd_mode & USBD_MODE_HID) {
|
||||
// HID component
|
||||
|
||||
// close endpoints
|
||||
USBD_LL_CloseEP(pdev, hid_in_ep);
|
||||
USBD_LL_CloseEP(pdev, hid_out_ep);
|
||||
USBD_LL_CloseEP(pdev, usbd->hid_in_ep);
|
||||
USBD_LL_CloseEP(pdev, usbd->hid_out_ep);
|
||||
}
|
||||
|
||||
return 0;
|
||||
@ -788,38 +758,38 @@ static uint8_t USBD_CDC_MSC_HID_Setup(USBD_HandleTypeDef *pdev, USBD_SetupReqTyp
|
||||
SU: 21 20 0 1
|
||||
*/
|
||||
|
||||
usbd_cdc_msc_hid_state_t *state = pdev->pClassData;
|
||||
usbd_cdc_msc_hid_state_t *usbd = pdev->pClassData;
|
||||
|
||||
switch (req->bmRequest & USB_REQ_TYPE_MASK) {
|
||||
|
||||
// Class request
|
||||
case USB_REQ_TYPE_CLASS:
|
||||
// req->wIndex is the recipient interface number
|
||||
if ((usbd_mode & USBD_MODE_CDC) && req->wIndex == cdc_iface_num) {
|
||||
if ((usbd->usbd_mode & USBD_MODE_CDC) && req->wIndex == usbd->cdc_iface_num) {
|
||||
// CDC component
|
||||
if (req->wLength) {
|
||||
if (req->bmRequest & 0x80) {
|
||||
// device-to-host request
|
||||
usbd_cdc_control(state->cdc, req->bRequest, (uint8_t*)CDC_ClassData.data, req->wLength);
|
||||
USBD_CtlSendData(pdev, (uint8_t*)CDC_ClassData.data, req->wLength);
|
||||
usbd_cdc_control(usbd->cdc, req->bRequest, (uint8_t*)usbd->CDC_ClassData.data, req->wLength);
|
||||
USBD_CtlSendData(pdev, (uint8_t*)usbd->CDC_ClassData.data, req->wLength);
|
||||
} else {
|
||||
// host-to-device request
|
||||
CDC_ClassData.CmdOpCode = req->bRequest;
|
||||
CDC_ClassData.CmdLength = req->wLength;
|
||||
USBD_CtlPrepareRx(pdev, (uint8_t*)CDC_ClassData.data, req->wLength);
|
||||
usbd->CDC_ClassData.CmdOpCode = req->bRequest;
|
||||
usbd->CDC_ClassData.CmdLength = req->wLength;
|
||||
USBD_CtlPrepareRx(pdev, (uint8_t*)usbd->CDC_ClassData.data, req->wLength);
|
||||
}
|
||||
} else {
|
||||
// Not a Data request
|
||||
// Transfer the command to the interface layer
|
||||
return usbd_cdc_control(state->cdc, req->bRequest, NULL, req->wValue);
|
||||
return usbd_cdc_control(usbd->cdc, req->bRequest, NULL, req->wValue);
|
||||
}
|
||||
} else if ((usbd_mode & USBD_MODE_MSC) && req->wIndex == MSC_IFACE_NUM_WITH_CDC) {
|
||||
} else if ((usbd->usbd_mode & USBD_MODE_MSC) && req->wIndex == MSC_IFACE_NUM_WITH_CDC) {
|
||||
// MSC component
|
||||
switch (req->bRequest) {
|
||||
case BOT_GET_MAX_LUN:
|
||||
if ((req->wValue == 0) && (req->wLength == 1) && ((req->bmRequest & 0x80) == 0x80)) {
|
||||
MSC_BOT_ClassData.max_lun = MSC_fops->GetMaxLun();
|
||||
USBD_CtlSendData(pdev, (uint8_t *)&MSC_BOT_ClassData.max_lun, 1);
|
||||
usbd->MSC_BOT_ClassData.max_lun = usbd->MSC_fops->GetMaxLun();
|
||||
USBD_CtlSendData(pdev, (uint8_t *)&usbd->MSC_BOT_ClassData.max_lun, 1);
|
||||
} else {
|
||||
USBD_CtlError(pdev, req);
|
||||
return USBD_FAIL;
|
||||
@ -839,22 +809,22 @@ static uint8_t USBD_CDC_MSC_HID_Setup(USBD_HandleTypeDef *pdev, USBD_SetupReqTyp
|
||||
USBD_CtlError(pdev, req);
|
||||
return USBD_FAIL;
|
||||
}
|
||||
} else if ((usbd_mode & USBD_MODE_HID) && req->wIndex == hid_iface_num) {
|
||||
} else if ((usbd->usbd_mode & USBD_MODE_HID) && req->wIndex == usbd->hid_iface_num) {
|
||||
switch (req->bRequest) {
|
||||
case HID_REQ_SET_PROTOCOL:
|
||||
HID_ClassData.Protocol = (uint8_t)(req->wValue);
|
||||
usbd->HID_ClassData.Protocol = (uint8_t)(req->wValue);
|
||||
break;
|
||||
|
||||
case HID_REQ_GET_PROTOCOL:
|
||||
USBD_CtlSendData (pdev, (uint8_t *)&HID_ClassData.Protocol, 1);
|
||||
USBD_CtlSendData(pdev, (uint8_t *)&usbd->HID_ClassData.Protocol, 1);
|
||||
break;
|
||||
|
||||
case HID_REQ_SET_IDLE:
|
||||
HID_ClassData.IdleState = (uint8_t)(req->wValue >> 8);
|
||||
usbd->HID_ClassData.IdleState = (uint8_t)(req->wValue >> 8);
|
||||
break;
|
||||
|
||||
case HID_REQ_GET_IDLE:
|
||||
USBD_CtlSendData (pdev, (uint8_t *)&HID_ClassData.IdleState, 1);
|
||||
USBD_CtlSendData(pdev, (uint8_t *)&usbd->HID_ClassData.IdleState, 1);
|
||||
break;
|
||||
|
||||
default:
|
||||
@ -866,14 +836,14 @@ static uint8_t USBD_CDC_MSC_HID_Setup(USBD_HandleTypeDef *pdev, USBD_SetupReqTyp
|
||||
|
||||
// Interface & Endpoint request
|
||||
case USB_REQ_TYPE_STANDARD:
|
||||
if ((usbd_mode & USBD_MODE_MSC) && req->wIndex == MSC_IFACE_NUM_WITH_CDC) {
|
||||
if ((usbd->usbd_mode & USBD_MODE_MSC) && req->wIndex == MSC_IFACE_NUM_WITH_CDC) {
|
||||
switch (req->bRequest) {
|
||||
case USB_REQ_GET_INTERFACE :
|
||||
USBD_CtlSendData(pdev, (uint8_t *)&MSC_BOT_ClassData.interface, 1);
|
||||
USBD_CtlSendData(pdev, (uint8_t *)&usbd->MSC_BOT_ClassData.interface, 1);
|
||||
break;
|
||||
|
||||
case USB_REQ_SET_INTERFACE :
|
||||
MSC_BOT_ClassData.interface = (uint8_t)(req->wValue);
|
||||
usbd->MSC_BOT_ClassData.interface = (uint8_t)(req->wValue);
|
||||
break;
|
||||
|
||||
case USB_REQ_CLEAR_FEATURE:
|
||||
@ -893,29 +863,29 @@ static uint8_t USBD_CDC_MSC_HID_Setup(USBD_HandleTypeDef *pdev, USBD_SetupReqTyp
|
||||
MSC_BOT_CplClrFeature(pdev, (uint8_t)req->wIndex);
|
||||
break;
|
||||
}
|
||||
} else if ((usbd_mode & USBD_MODE_HID) && req->wIndex == hid_iface_num) {
|
||||
} else if ((usbd->usbd_mode & USBD_MODE_HID) && req->wIndex == usbd->hid_iface_num) {
|
||||
switch (req->bRequest) {
|
||||
case USB_REQ_GET_DESCRIPTOR: {
|
||||
uint16_t len = 0;
|
||||
const uint8_t *pbuf = NULL;
|
||||
if (req->wValue >> 8 == HID_REPORT_DESC) {
|
||||
len = hid_desc[HID_DESC_OFFSET_REPORT_DESC_LEN];
|
||||
len = usbd->hid_desc[HID_DESC_OFFSET_REPORT_DESC_LEN];
|
||||
len = MIN(len, req->wLength);
|
||||
pbuf = hid_report_desc;
|
||||
pbuf = usbd->hid_report_desc;
|
||||
} else if (req->wValue >> 8 == HID_DESCRIPTOR_TYPE) {
|
||||
len = MIN(HID_SUBDESC_LEN, req->wLength);
|
||||
pbuf = hid_desc + HID_DESC_OFFSET_SUBDESC;
|
||||
pbuf = usbd->hid_desc + HID_DESC_OFFSET_SUBDESC;
|
||||
}
|
||||
USBD_CtlSendData(pdev, (uint8_t*)pbuf, len);
|
||||
break;
|
||||
}
|
||||
|
||||
case USB_REQ_GET_INTERFACE:
|
||||
USBD_CtlSendData (pdev, (uint8_t *)&HID_ClassData.AltSetting, 1);
|
||||
USBD_CtlSendData(pdev, (uint8_t *)&usbd->HID_ClassData.AltSetting, 1);
|
||||
break;
|
||||
|
||||
case USB_REQ_SET_INTERFACE:
|
||||
HID_ClassData.AltSetting = (uint8_t)(req->wValue);
|
||||
usbd->HID_ClassData.AltSetting = (uint8_t)(req->wValue);
|
||||
break;
|
||||
}
|
||||
}
|
||||
@ -930,26 +900,27 @@ static uint8_t EP0_TxSent(USBD_HandleTypeDef *pdev) {
|
||||
*/
|
||||
|
||||
static uint8_t USBD_CDC_MSC_HID_EP0_RxReady(USBD_HandleTypeDef *pdev) {
|
||||
usbd_cdc_msc_hid_state_t *state = pdev->pClassData;
|
||||
if (state->cdc != NULL && CDC_ClassData.CmdOpCode != 0xff) {
|
||||
usbd_cdc_control(state->cdc, CDC_ClassData.CmdOpCode, (uint8_t*)CDC_ClassData.data, CDC_ClassData.CmdLength);
|
||||
CDC_ClassData.CmdOpCode = 0xff;
|
||||
usbd_cdc_msc_hid_state_t *usbd = pdev->pClassData;
|
||||
if (usbd->cdc != NULL && usbd->CDC_ClassData.CmdOpCode != 0xff) {
|
||||
usbd_cdc_control(usbd->cdc, usbd->CDC_ClassData.CmdOpCode, (uint8_t*)usbd->CDC_ClassData.data, usbd->CDC_ClassData.CmdLength);
|
||||
usbd->CDC_ClassData.CmdOpCode = 0xff;
|
||||
}
|
||||
|
||||
return USBD_OK;
|
||||
}
|
||||
|
||||
static uint8_t USBD_CDC_MSC_HID_DataIn(USBD_HandleTypeDef *pdev, uint8_t epnum) {
|
||||
if ((usbd_mode & USBD_MODE_CDC) && (epnum == (CDC_IN_EP & 0x7f) || epnum == (CDC_CMD_EP & 0x7f))) {
|
||||
CDC_ClassData.TxState = 0;
|
||||
usbd_cdc_msc_hid_state_t *usbd = pdev->pClassData;
|
||||
if ((usbd->usbd_mode & USBD_MODE_CDC) && (epnum == (CDC_IN_EP & 0x7f) || epnum == (CDC_CMD_EP & 0x7f))) {
|
||||
usbd->CDC_ClassData.TxState = 0;
|
||||
return USBD_OK;
|
||||
} else if ((usbd_mode & USBD_MODE_MSC) && epnum == (MSC_IN_EP & 0x7f)) {
|
||||
} else if ((usbd->usbd_mode & USBD_MODE_MSC) && epnum == (MSC_IN_EP & 0x7f)) {
|
||||
MSC_BOT_DataIn(pdev, epnum);
|
||||
return USBD_OK;
|
||||
} else if ((usbd_mode & USBD_MODE_HID) && epnum == (hid_in_ep & 0x7f)) {
|
||||
} else if ((usbd->usbd_mode & USBD_MODE_HID) && epnum == (usbd->hid_in_ep & 0x7f)) {
|
||||
/* Ensure that the FIFO is empty before a new transfer, this condition could
|
||||
be caused by a new transfer before the end of the previous transfer */
|
||||
HID_ClassData.state = HID_IDLE;
|
||||
usbd->HID_ClassData.state = HID_IDLE;
|
||||
return USBD_OK;
|
||||
}
|
||||
|
||||
@ -957,34 +928,35 @@ static uint8_t USBD_CDC_MSC_HID_DataIn(USBD_HandleTypeDef *pdev, uint8_t epnum)
|
||||
}
|
||||
|
||||
static uint8_t USBD_CDC_MSC_HID_DataOut(USBD_HandleTypeDef *pdev, uint8_t epnum) {
|
||||
usbd_cdc_msc_hid_state_t *state = pdev->pClassData;
|
||||
if ((usbd_mode & USBD_MODE_CDC) && epnum == (CDC_OUT_EP & 0x7f)) {
|
||||
usbd_cdc_msc_hid_state_t *usbd = pdev->pClassData;
|
||||
if ((usbd->usbd_mode & USBD_MODE_CDC) && epnum == (CDC_OUT_EP & 0x7f)) {
|
||||
/* Get the received data length */
|
||||
size_t len = USBD_LL_GetRxDataSize (pdev, epnum);
|
||||
|
||||
/* USB data will be immediately processed, this allow next USB traffic being
|
||||
NAKed till the end of the application Xfer */
|
||||
usbd_cdc_receive(state->cdc, len);
|
||||
usbd_cdc_receive(usbd->cdc, len);
|
||||
|
||||
return USBD_OK;
|
||||
} else if ((usbd_mode & USBD_MODE_MSC) && epnum == (MSC_OUT_EP & 0x7f)) {
|
||||
} else if ((usbd->usbd_mode & USBD_MODE_MSC) && epnum == (MSC_OUT_EP & 0x7f)) {
|
||||
MSC_BOT_DataOut(pdev, epnum);
|
||||
return USBD_OK;
|
||||
} else if ((usbd_mode & USBD_MODE_HID) && epnum == (hid_out_ep & 0x7f)) {
|
||||
} else if ((usbd->usbd_mode & USBD_MODE_HID) && epnum == (usbd->hid_out_ep & 0x7f)) {
|
||||
size_t len = USBD_LL_GetRxDataSize(pdev, epnum);
|
||||
usbd_hid_receive(state->hid, len);
|
||||
usbd_hid_receive(usbd->hid, len);
|
||||
}
|
||||
|
||||
return USBD_OK;
|
||||
}
|
||||
|
||||
static uint8_t *USBD_CDC_MSC_HID_GetCfgDesc(uint16_t *length) {
|
||||
*length = usbd_config_desc_size;
|
||||
return usbd_config_desc;
|
||||
static uint8_t *USBD_CDC_MSC_HID_GetCfgDesc(USBD_HandleTypeDef *pdev, uint16_t *length) {
|
||||
usbd_cdc_msc_hid_state_t *usbd = pdev->pClassData;
|
||||
*length = usbd->usbd_config_desc_size;
|
||||
return usbd->usbd_config_desc;
|
||||
}
|
||||
|
||||
// this is used only in high-speed mode, which we don't support
|
||||
uint8_t *USBD_CDC_MSC_HID_GetDeviceQualifierDescriptor (uint16_t *length) {
|
||||
uint8_t *USBD_CDC_MSC_HID_GetDeviceQualifierDescriptor(USBD_HandleTypeDef *pdev, uint16_t *length) {
|
||||
/*
|
||||
*length = sizeof(USBD_CDC_MSC_HID_DeviceQualifierDesc);
|
||||
return USBD_CDC_MSC_HID_DeviceQualifierDesc;
|
||||
@ -994,13 +966,13 @@ uint8_t *USBD_CDC_MSC_HID_GetDeviceQualifierDescriptor (uint16_t *length) {
|
||||
}
|
||||
|
||||
// data received on non-control OUT endpoint
|
||||
uint8_t USBD_CDC_TransmitPacket(USBD_HandleTypeDef *pdev, size_t len, const uint8_t *buf) {
|
||||
if (CDC_ClassData.TxState == 0) {
|
||||
uint8_t USBD_CDC_TransmitPacket(usbd_cdc_msc_hid_state_t *usbd, size_t len, const uint8_t *buf) {
|
||||
if (usbd->CDC_ClassData.TxState == 0) {
|
||||
// transmit next packet
|
||||
USBD_LL_Transmit(pdev, CDC_IN_EP, (uint8_t*)buf, len);
|
||||
USBD_LL_Transmit(usbd->pdev, CDC_IN_EP, (uint8_t*)buf, len);
|
||||
|
||||
// Tx transfer in progress
|
||||
CDC_ClassData.TxState = 1;
|
||||
usbd->CDC_ClassData.TxState = 1;
|
||||
return USBD_OK;
|
||||
} else {
|
||||
return USBD_BUSY;
|
||||
@ -1008,70 +980,70 @@ uint8_t USBD_CDC_TransmitPacket(USBD_HandleTypeDef *pdev, size_t len, const uint
|
||||
}
|
||||
|
||||
// prepare OUT endpoint for reception
|
||||
uint8_t USBD_CDC_ReceivePacket(USBD_HandleTypeDef *pdev, uint8_t *buf) {
|
||||
uint8_t USBD_CDC_ReceivePacket(usbd_cdc_msc_hid_state_t *usbd, uint8_t *buf) {
|
||||
// Suspend or Resume USB Out process
|
||||
if (pdev->dev_speed == USBD_SPEED_HIGH) {
|
||||
if (usbd->pdev->dev_speed == USBD_SPEED_HIGH) {
|
||||
return USBD_FAIL;
|
||||
}
|
||||
|
||||
// Prepare Out endpoint to receive next packet
|
||||
USBD_LL_PrepareReceive(pdev, CDC_OUT_EP, buf, CDC_DATA_OUT_PACKET_SIZE);
|
||||
USBD_LL_PrepareReceive(usbd->pdev, CDC_OUT_EP, buf, CDC_DATA_OUT_PACKET_SIZE);
|
||||
|
||||
return USBD_OK;
|
||||
}
|
||||
|
||||
uint8_t USBD_MSC_RegisterStorage(USBD_HandleTypeDef *pdev, USBD_StorageTypeDef *fops) {
|
||||
uint8_t USBD_MSC_RegisterStorage(usbd_cdc_msc_hid_state_t *usbd, USBD_StorageTypeDef *fops) {
|
||||
if (fops == NULL) {
|
||||
return USBD_FAIL;
|
||||
} else {
|
||||
MSC_fops = fops;
|
||||
pdev->pUserData = fops; // MSC uses pUserData because SCSI and BOT reference it
|
||||
usbd->MSC_fops = fops;
|
||||
usbd->pdev->pUserData = fops; // MSC uses pUserData because SCSI and BOT reference it
|
||||
return USBD_OK;
|
||||
}
|
||||
}
|
||||
|
||||
// prepare OUT endpoint for reception
|
||||
uint8_t USBD_HID_ReceivePacket(USBD_HandleTypeDef *pdev, uint8_t *buf) {
|
||||
uint8_t USBD_HID_ReceivePacket(usbd_cdc_msc_hid_state_t *usbd, uint8_t *buf) {
|
||||
// Suspend or Resume USB Out process
|
||||
if (pdev->dev_speed == USBD_SPEED_HIGH) {
|
||||
if (usbd->pdev->dev_speed == USBD_SPEED_HIGH) {
|
||||
return USBD_FAIL;
|
||||
}
|
||||
|
||||
// Prepare Out endpoint to receive next packet
|
||||
uint16_t mps_out =
|
||||
hid_desc[HID_DESC_OFFSET_MAX_PACKET_OUT_LO]
|
||||
| (hid_desc[HID_DESC_OFFSET_MAX_PACKET_OUT_HI] << 8);
|
||||
USBD_LL_PrepareReceive(pdev, hid_out_ep, buf, mps_out);
|
||||
usbd->hid_desc[HID_DESC_OFFSET_MAX_PACKET_OUT_LO]
|
||||
| (usbd->hid_desc[HID_DESC_OFFSET_MAX_PACKET_OUT_HI] << 8);
|
||||
USBD_LL_PrepareReceive(usbd->pdev, usbd->hid_out_ep, buf, mps_out);
|
||||
|
||||
return USBD_OK;
|
||||
}
|
||||
|
||||
int USBD_HID_CanSendReport(USBD_HandleTypeDef *pdev) {
|
||||
return pdev->dev_state == USBD_STATE_CONFIGURED && HID_ClassData.state == HID_IDLE;
|
||||
int USBD_HID_CanSendReport(usbd_cdc_msc_hid_state_t *usbd) {
|
||||
return usbd->pdev->dev_state == USBD_STATE_CONFIGURED && usbd->HID_ClassData.state == HID_IDLE;
|
||||
}
|
||||
|
||||
uint8_t USBD_HID_SendReport(USBD_HandleTypeDef *pdev, uint8_t *report, uint16_t len) {
|
||||
if (pdev->dev_state == USBD_STATE_CONFIGURED) {
|
||||
if (HID_ClassData.state == HID_IDLE) {
|
||||
HID_ClassData.state = HID_BUSY;
|
||||
USBD_LL_Transmit(pdev, hid_in_ep, report, len);
|
||||
uint8_t USBD_HID_SendReport(usbd_cdc_msc_hid_state_t *usbd, uint8_t *report, uint16_t len) {
|
||||
if (usbd->pdev->dev_state == USBD_STATE_CONFIGURED) {
|
||||
if (usbd->HID_ClassData.state == HID_IDLE) {
|
||||
usbd->HID_ClassData.state = HID_BUSY;
|
||||
USBD_LL_Transmit(usbd->pdev, usbd->hid_in_ep, report, len);
|
||||
}
|
||||
}
|
||||
return USBD_OK;
|
||||
}
|
||||
|
||||
uint8_t USBD_HID_SetNAK(USBD_HandleTypeDef *pdev) {
|
||||
uint8_t USBD_HID_SetNAK(usbd_cdc_msc_hid_state_t *usbd) {
|
||||
// get USBx object from pdev (needed for USBx_OUTEP macro below)
|
||||
PCD_HandleTypeDef *hpcd = pdev->pData;
|
||||
PCD_HandleTypeDef *hpcd = usbd->pdev->pData;
|
||||
USB_OTG_GlobalTypeDef *USBx = hpcd->Instance;
|
||||
// set NAK on HID OUT endpoint
|
||||
USBx_OUTEP(HID_OUT_EP_WITH_CDC)->DOEPCTL |= USB_OTG_DOEPCTL_SNAK;
|
||||
return USBD_OK;
|
||||
}
|
||||
|
||||
uint8_t USBD_HID_ClearNAK(USBD_HandleTypeDef *pdev) {
|
||||
uint8_t USBD_HID_ClearNAK(usbd_cdc_msc_hid_state_t *usbd) {
|
||||
// get USBx object from pdev (needed for USBx_OUTEP macro below)
|
||||
PCD_HandleTypeDef *hpcd = pdev->pData;
|
||||
PCD_HandleTypeDef *hpcd = usbd->pdev->pData;
|
||||
USB_OTG_GlobalTypeDef *USBx = hpcd->Instance;
|
||||
// clear NAK on HID OUT endpoint
|
||||
USBx_OUTEP(HID_OUT_EP_WITH_CDC)->DOEPCTL |= USB_OTG_DOEPCTL_CNAK;
|
||||
|
Loading…
x
Reference in New Issue
Block a user