mirror of
https://github.com/hathach/tinyusb.git
synced 2025-03-23 22:43:49 +00:00
add class flags
change keyboard_info_pool to keyboard_data
This commit is contained in:
parent
92c137243d
commit
a1b17be681
@ -55,4 +55,11 @@
|
||||
void keyboard_app_task(void)
|
||||
{
|
||||
|
||||
for (uint8_t dev_addr = 1; dev_addr <= TUSB_CFG_HOST_DEVICE_MAX; dev_addr++)
|
||||
{
|
||||
if ( tusbh_device_is_configured(dev_addr) )
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -41,7 +41,7 @@
|
||||
#include "mock_osal.h"
|
||||
#include "mock_usbh.h"
|
||||
|
||||
extern class_hid_keyboard_info_t keyboard_info_pool[TUSB_CFG_HOST_DEVICE_MAX];
|
||||
extern class_hid_keyboard_info_t keyboard_data[TUSB_CFG_HOST_DEVICE_MAX];
|
||||
|
||||
tusb_keyboard_report_t sample_key[2] =
|
||||
{
|
||||
@ -66,9 +66,9 @@ void setUp(void)
|
||||
instance_num = 0;
|
||||
memset(&report, 0, sizeof(tusb_keyboard_report_t));
|
||||
|
||||
keyboard_info_pool[0].instance_count = 0;
|
||||
keyboard_info_pool[0].instance[0].pipe_in = (pipe_handle_t) { .dev_addr = 1, .xfer_type = TUSB_XFER_INTERRUPT, .index = 1};
|
||||
keyboard_info_pool[0].instance[0].report_size = sizeof(tusb_keyboard_report_t);
|
||||
keyboard_data[0].instance_count = 0;
|
||||
keyboard_data[0].instance[0].pipe_in = (pipe_handle_t) { .dev_addr = 1, .xfer_type = TUSB_XFER_INTERRUPT, .index = 1};
|
||||
keyboard_data[0].instance[0].report_size = sizeof(tusb_keyboard_report_t);
|
||||
|
||||
kbd_descriptor = ((tusb_descriptor_interface_t)
|
||||
{
|
||||
@ -115,7 +115,7 @@ void test_keyboard_init(void)
|
||||
|
||||
hidh_keyboard_init();
|
||||
|
||||
TEST_ASSERT_EQUAL_MEMORY(keyboard_info_zero, keyboard_info_pool, sizeof(class_hid_keyboard_info_t)*TUSB_CFG_HOST_DEVICE_MAX);
|
||||
TEST_ASSERT_EQUAL_MEMORY(keyboard_info_zero, keyboard_data, sizeof(class_hid_keyboard_info_t)*TUSB_CFG_HOST_DEVICE_MAX);
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------+
|
||||
@ -126,7 +126,7 @@ pipe_status_t pipe_status_get_stub(pipe_handle_t pipe_hdl, int num_call)
|
||||
switch (num_call)
|
||||
{
|
||||
case 0:
|
||||
memcpy(keyboard_info_pool[0].instance[0].buffer, &sample_key[0], sizeof(tusb_keyboard_report_t));
|
||||
memcpy(keyboard_data[0].instance[0].buffer, &sample_key[0], sizeof(tusb_keyboard_report_t));
|
||||
return PIPE_STATUS_COMPLETE;
|
||||
break;
|
||||
|
||||
@ -139,7 +139,7 @@ pipe_status_t pipe_status_get_stub(pipe_handle_t pipe_hdl, int num_call)
|
||||
break;
|
||||
|
||||
case 3:
|
||||
memcpy(keyboard_info_pool[0].instance[0].buffer, &sample_key[1], sizeof(tusb_keyboard_report_t));
|
||||
memcpy(keyboard_data[0].instance[0].buffer, &sample_key[1], sizeof(tusb_keyboard_report_t));
|
||||
return PIPE_STATUS_COMPLETE;
|
||||
break;
|
||||
|
||||
@ -163,7 +163,7 @@ void test_keyboard_get_invalid_para()
|
||||
void test_keyboard_get_class_not_supported()
|
||||
{
|
||||
tusbh_device_get_state_IgnoreAndReturn(TUSB_DEVICE_STATE_CONFIGURED);
|
||||
keyboard_info_pool[dev_addr].instance[0].pipe_in = (pipe_handle_t) { 0 };
|
||||
keyboard_data[dev_addr].instance[0].pipe_in = (pipe_handle_t) { 0 };
|
||||
TEST_ASSERT_EQUAL(TUSB_ERROR_CLASS_DEVICE_DONT_SUPPORT, tusbh_hid_keyboard_get(dev_addr, instance_num, &report));
|
||||
}
|
||||
|
||||
|
@ -55,7 +55,7 @@
|
||||
//--------------------------------------------------------------------+
|
||||
// INTERNAL OBJECT & FUNCTION DECLARATION
|
||||
//--------------------------------------------------------------------+
|
||||
STATIC_ class_hid_keyboard_info_t keyboard_info_pool[TUSB_CFG_HOST_DEVICE_MAX];
|
||||
STATIC_ class_hid_keyboard_info_t keyboard_data[TUSB_CFG_HOST_DEVICE_MAX];
|
||||
|
||||
|
||||
//--------------------------------------------------------------------+
|
||||
@ -69,7 +69,7 @@ tusb_error_t tusbh_hid_keyboard_get(uint8_t const dev_addr, uint8_t instance_num
|
||||
ASSERT_PTR(report, TUSB_ERROR_INVALID_PARA);
|
||||
ASSERT(instance_num < TUSB_CFG_HOST_HID_KEYBOARD_NO_INSTANCES_PER_DEVICE, TUSB_ERROR_INVALID_PARA);
|
||||
|
||||
p_kbd = &keyboard_info_pool[dev_addr].instance[instance_num];
|
||||
p_kbd = &keyboard_data[dev_addr].instance[instance_num];
|
||||
|
||||
ASSERT(0 != p_kbd->pipe_in.dev_addr, TUSB_ERROR_CLASS_DEVICE_DONT_SUPPORT);
|
||||
|
||||
@ -84,7 +84,7 @@ uint8_t tusbh_hid_keyboard_no_instances(uint8_t const dev_addr)
|
||||
{
|
||||
ASSERT_INT(TUSB_DEVICE_STATE_CONFIGURED, tusbh_device_get_state(dev_addr), 0);
|
||||
|
||||
return keyboard_info_pool[dev_addr].instance_count;
|
||||
return keyboard_data[dev_addr].instance_count;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------+
|
||||
@ -99,12 +99,12 @@ void hidh_init(void)
|
||||
|
||||
void hidh_keyboard_init(void)
|
||||
{
|
||||
memclr_(&keyboard_info_pool, sizeof(class_hid_keyboard_info_t)*TUSB_CFG_HOST_DEVICE_MAX);
|
||||
memclr_(&keyboard_data, sizeof(class_hid_keyboard_info_t)*TUSB_CFG_HOST_DEVICE_MAX);
|
||||
}
|
||||
|
||||
tusb_error_t hidh_keyboard_install(uint8_t const dev_addr, uint8_t const *descriptor)
|
||||
{
|
||||
keyboard_info_pool[dev_addr].instance_count++;
|
||||
keyboard_data[dev_addr].instance_count++;
|
||||
|
||||
return TUSB_ERROR_NONE;
|
||||
}
|
||||
|
@ -62,9 +62,9 @@
|
||||
//--------------------------------------------------------------------+
|
||||
// APPLICATION API
|
||||
//--------------------------------------------------------------------+
|
||||
uint8_t tusbh_hid_keyboard_no_instances(uint8_t const dev_addr) ATTR_WARN_UNUSED_RESULT;
|
||||
tusb_error_t tusbh_hid_keyboard_get(uint8_t const handle, uint8_t const instance_num, tusb_keyboard_report_t * const report) ATTR_WARN_UNUSED_RESULT;
|
||||
pipe_status_t tusbh_hid_keyboard_pipe_status(uint8_t const handle, uint8_t const instance_num);
|
||||
uint8_t tusbh_hid_keyboard_no_instances(uint8_t const dev_addr) ATTR_WARN_UNUSED_RESULT;
|
||||
tusb_error_t tusbh_hid_keyboard_get(uint8_t const handle, uint8_t const instance_num, tusb_keyboard_report_t * const report) ATTR_WARN_UNUSED_RESULT;
|
||||
pipe_status_t tusbh_hid_keyboard_pipe_status(uint8_t const handle, uint8_t const instance_num) ATTR_WARN_UNUSED_RESULT;
|
||||
|
||||
//--------------------------------------------------------------------+
|
||||
// INTERNAL API
|
||||
|
@ -125,16 +125,16 @@ typedef enum {
|
||||
TUSB_CLASS_RESERVED_4 = 4 , ///< 4
|
||||
TUSB_CLASS_PHYSICAL = 5 , ///< 5
|
||||
TUSB_CLASS_IMAGE = 6 , ///< 6
|
||||
TUSB_CLASS_PRINTER = 7 , ///< 7
|
||||
TUSB_CLASS_MSC = 8 , ///< 8
|
||||
TUSB_CLASS_HUB = 9 , ///< 9
|
||||
TUSB_CLASS_CDC_DATA = 10 , ///< 10
|
||||
TUSB_CLASS_SMART_CARD = 11 , ///< 11
|
||||
TUSB_CLASS_PRINTER = 7 , ///< 7
|
||||
TUSB_CLASS_MSC = 8 , ///< 8
|
||||
TUSB_CLASS_HUB = 9 , ///< 9
|
||||
TUSB_CLASS_CDC_DATA = 10 , ///< 10
|
||||
TUSB_CLASS_SMART_CARD = 11 , ///< 11
|
||||
TUSB_CLASS_RESERVED_12 = 12 , ///< 12
|
||||
TUSB_CLASS_CONTENT_SECURITY = 13 , ///< 13
|
||||
TUSB_CLASS_VIDEO = 14 , ///< 14
|
||||
TUSB_CLASS_PERSONAL_HEALTHCARE = 15 , ///< 15
|
||||
TUSB_CLASS_AUDIO_VIDEO = 16 , ///< 16
|
||||
TUSB_CLASS_CONTENT_SECURITY = 13 , ///< 13
|
||||
TUSB_CLASS_VIDEO = 14 , ///< 14
|
||||
TUSB_CLASS_PERSONAL_HEALTHCARE = 15 , ///< 15
|
||||
TUSB_CLASS_AUDIO_VIDEO = 16 , ///< 16
|
||||
|
||||
TUSB_CLASS_MAX_CONSEC_NUMBER = 17 , // TODO compact & minimize this number
|
||||
|
||||
@ -145,6 +145,29 @@ typedef enum {
|
||||
TUSB_CLASS_VENDOR_SPECIFIC = 0xFF
|
||||
}tusb_std_class_code_t;
|
||||
|
||||
typedef enum tusb_std_class_flag_{
|
||||
TUSB_CLASS_FLAG_AUDIO = BIT_(TUSB_CLASS_AUDIO) , ///< 1
|
||||
TUSB_CLASS_FLAG_CDC = BIT_(TUSB_CLASS_CDC) , ///< 2
|
||||
TUSB_CLASS_FLAG_HID = BIT_(TUSB_CLASS_HID) , ///< 3
|
||||
TUSB_CLASS_FLAG_PHYSICAL = BIT_(TUSB_CLASS_PHYSICAL) , ///< 5
|
||||
TUSB_CLASS_FLAG_IMAGE = BIT_(TUSB_CLASS_IMAGE) , ///< 6
|
||||
TUSB_CLASS_FLAG_PRINTER = BIT_(TUSB_CLASS_PRINTER) , ///< 7
|
||||
TUSB_CLASS_FLAG_MSC = BIT_(TUSB_CLASS_MSC) , ///< 8
|
||||
TUSB_CLASS_FLAG_HUB = BIT_(TUSB_CLASS_HUB) , ///< 9
|
||||
TUSB_CLASS_FLAG_CDC_DATA = BIT_(TUSB_CLASS_CDC_DATA) , ///< 10
|
||||
TUSB_CLASS_FLAG_SMART_CARD = BIT_(TUSB_CLASS_SMART_CARD) , ///< 11
|
||||
TUSB_CLASS_FLAG_CONTENT_SECURITY = BIT_(TUSB_CLASS_CONTENT_SECURITY) , ///< 13
|
||||
TUSB_CLASS_FLAG_VIDEO = BIT_(TUSB_CLASS_VIDEO) , ///< 14
|
||||
TUSB_CLASS_FLAG_PERSONAL_HEALTHCARE = BIT_(TUSB_CLASS_PERSONAL_HEALTHCARE) , ///< 15
|
||||
TUSB_CLASS_FLAG_AUDIO_VIDEO = BIT_(TUSB_CLASS_AUDIO_VIDEO) , ///< 16
|
||||
|
||||
TUSB_CLASS_FLAG_DIAGNOSTIC = BIT_(27) ,
|
||||
TUSB_CLASS_FLAG_WIRELESS_CONTROLLER = BIT_(28) ,
|
||||
TUSB_CLASS_FLAG_MISC = BIT_(29) ,
|
||||
TUSB_CLASS_FLAG_APPLICATION_SPECIFIC = BIT_(30) ,
|
||||
TUSB_CLASS_FLAG_VENDOR_SPECIFIC = BIT_(31)
|
||||
} tusb_std_class_flag_t;
|
||||
|
||||
enum {
|
||||
TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP = BIT_(5),
|
||||
TUSB_DESC_CONFIG_ATT_SELF_POWER = BIT_(6),
|
||||
|
@ -70,8 +70,6 @@ typedef enum pipe_status_{
|
||||
PIPE_STATUS_ERROR
|
||||
} pipe_status_t;
|
||||
|
||||
typedef uint32_t tusbh_flag_class_t;
|
||||
|
||||
typedef struct {
|
||||
void (* const init) (void);
|
||||
tusb_error_t (* const open_subtask)(uint8_t, uint8_t const *, uint16_t*);
|
||||
@ -86,7 +84,12 @@ typedef struct {
|
||||
// APPLICATION API
|
||||
//--------------------------------------------------------------------+
|
||||
tusb_error_t tusbh_configuration_set (uint8_t dev_addr, uint8_t configure_number) ATTR_WARN_UNUSED_RESULT;
|
||||
tusb_device_state_t tusbh_device_get_state (uint8_t const dev_addr) ATTR_WARN_UNUSED_RESULT;
|
||||
tusb_device_state_t tusbh_device_get_state (uint8_t const dev_addr) ATTR_WARN_UNUSED_RESULT ATTR_PURE;
|
||||
static inline bool tusbh_device_is_configured(uint8_t const dev_addr) ATTR_ALWAYS_INLINE ATTR_WARN_UNUSED_RESULT ATTR_PURE;
|
||||
static inline bool tusbh_device_is_configured(uint8_t const dev_addr)
|
||||
{
|
||||
return tusbh_device_get_state(dev_addr) == TUSB_DEVICE_STATE_CONFIGURED;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------+
|
||||
// APPLICATION CALLBACK
|
||||
|
@ -103,6 +103,7 @@ typedef struct { // TODO internal structure, re-order members
|
||||
|
||||
extern usbh_device_info_t usbh_devices[TUSB_CFG_HOST_DEVICE_MAX+1]; // including zero-address
|
||||
|
||||
//------------- callback from HCD ISR-------------//
|
||||
void usbh_isr(pipe_handle_t pipe_hdl, uint8_t class_code, tusb_bus_event_t event);
|
||||
void usbh_device_plugged_isr(uint8_t hostid, tusb_speed_t speed);
|
||||
void usbh_device_unplugged_isr(uint8_t hostid);
|
||||
|
Loading…
x
Reference in New Issue
Block a user