mirror of
https://github.com/hathach/tinyusb.git
synced 2025-01-31 05:52:55 +08:00
enhance device hid
- add CFG_TUD_HID_ASCII_TO_KEYCODE_LOOKUP - add tud_hid_keyboard_send_keycode(), tud_hid_keyboard_send_char(), tud_hid_keyboard_send_string() - add timeout_blocking_wait()
This commit is contained in:
parent
262be103e0
commit
3e209f9c20
@ -76,6 +76,9 @@ int main(void)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------+
|
||||||
|
// USB CDC
|
||||||
|
//--------------------------------------------------------------------+
|
||||||
void virtual_com_task(void)
|
void virtual_com_task(void)
|
||||||
{
|
{
|
||||||
// connected and there are data available
|
// connected and there are data available
|
||||||
@ -91,6 +94,30 @@ void virtual_com_task(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------+
|
||||||
|
// USB CDC
|
||||||
|
//--------------------------------------------------------------------+
|
||||||
|
void usb_hid_task(void)
|
||||||
|
{
|
||||||
|
if ( tud_mounted() )
|
||||||
|
{
|
||||||
|
if ( !tud_hid_keyboard_busy() )
|
||||||
|
{
|
||||||
|
static bool toggle = false; // send either A or B
|
||||||
|
|
||||||
|
tud_hid_keyboard_send_char( toggle ? 'A' : 'B' );
|
||||||
|
toggle = !toggle;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( !tud_hid_mouse_busy() )
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
// tinyusb callbacks
|
// tinyusb callbacks
|
||||||
|
@ -126,6 +126,13 @@
|
|||||||
*/
|
*/
|
||||||
#define CFG_TUD_HID_BOOT_PROTOCOL 1
|
#define CFG_TUD_HID_BOOT_PROTOCOL 1
|
||||||
|
|
||||||
|
/* Use the HID_ASCII_TO_KEYCODE lookup if CFG_TUD_HID_KEYBOARD is enabled.
|
||||||
|
* This will occupies 256 bytes of ROM. It will also enable the use of 2 extra APIs
|
||||||
|
* - tud_hid_keyboard_send_char()
|
||||||
|
* - tud_hid_keyboard_send_string()
|
||||||
|
*/
|
||||||
|
#define CFG_TUD_HID_ASCII_TO_KEYCODE_LOOKUP 1
|
||||||
|
|
||||||
//--------------------------------------------------------------------
|
//--------------------------------------------------------------------
|
||||||
// USB RAM PLACEMENT
|
// USB RAM PLACEMENT
|
||||||
//--------------------------------------------------------------------
|
//--------------------------------------------------------------------
|
||||||
|
@ -217,102 +217,123 @@ typedef enum
|
|||||||
|
|
||||||
/// @}
|
/// @}
|
||||||
|
|
||||||
#define HID_KEYCODE_TABLE(ENTRY) \
|
//--------------------------------------------------------------------+
|
||||||
ENTRY( 0x04, 'a' , 'A' )\
|
// HID KEYCODE
|
||||||
ENTRY( 0x05, 'b' , 'B' )\
|
//--------------------------------------------------------------------+
|
||||||
ENTRY( 0x06, 'c' , 'C' )\
|
#define HID_KEY_NONE 0x00
|
||||||
ENTRY( 0x07, 'd' , 'D' )\
|
#define HID_KEY_A 0x04
|
||||||
ENTRY( 0x08, 'e' , 'E' )\
|
#define HID_KEY_B 0x05
|
||||||
ENTRY( 0x09, 'f' , 'F' )\
|
#define HID_KEY_C 0x06
|
||||||
ENTRY( 0x0a, 'g' , 'G' )\
|
#define HID_KEY_D 0x07
|
||||||
ENTRY( 0x0b, 'h' , 'H' )\
|
#define HID_KEY_E 0x08
|
||||||
ENTRY( 0x0c, 'i' , 'I' )\
|
#define HID_KEY_F 0x09
|
||||||
ENTRY( 0x0d, 'j' , 'J' )\
|
#define HID_KEY_G 0x0A
|
||||||
ENTRY( 0x0e, 'k' , 'K' )\
|
#define HID_KEY_H 0x0B
|
||||||
ENTRY( 0x0f, 'l' , 'L' )\
|
#define HID_KEY_I 0x0C
|
||||||
ENTRY( 0x10, 'm' , 'M' )\
|
#define HID_KEY_J 0x0D
|
||||||
ENTRY( 0x11, 'n' , 'N' )\
|
#define HID_KEY_K 0x0E
|
||||||
ENTRY( 0x12, 'o' , 'O' )\
|
#define HID_KEY_L 0x0F
|
||||||
ENTRY( 0x13, 'p' , 'P' )\
|
#define HID_KEY_M 0x10
|
||||||
ENTRY( 0x14, 'q' , 'Q' )\
|
#define HID_KEY_N 0x11
|
||||||
ENTRY( 0x15, 'r' , 'R' )\
|
#define HID_KEY_O 0x12
|
||||||
ENTRY( 0x16, 's' , 'S' )\
|
#define HID_KEY_P 0x13
|
||||||
ENTRY( 0x17, 't' , 'T' )\
|
#define HID_KEY_Q 0x14
|
||||||
ENTRY( 0x18, 'u' , 'U' )\
|
#define HID_KEY_R 0x15
|
||||||
ENTRY( 0x19, 'v' , 'V' )\
|
#define HID_KEY_S 0x16
|
||||||
ENTRY( 0x1a, 'w' , 'W' )\
|
#define HID_KEY_T 0x17
|
||||||
ENTRY( 0x1b, 'x' , 'X' )\
|
#define HID_KEY_U 0x18
|
||||||
ENTRY( 0x1c, 'y' , 'Y' )\
|
#define HID_KEY_V 0x19
|
||||||
ENTRY( 0x1d, 'z' , 'Z' )\
|
#define HID_KEY_W 0x1A
|
||||||
\
|
#define HID_KEY_X 0x1B
|
||||||
ENTRY( 0x1e, '1' , '!' )\
|
#define HID_KEY_Y 0x1C
|
||||||
ENTRY( 0x1f, '2' , '@' )\
|
#define HID_KEY_Z 0x1D
|
||||||
ENTRY( 0x20, '3' , '#' )\
|
#define HID_KEY_1 0x1E
|
||||||
ENTRY( 0x21, '4' , '$' )\
|
#define HID_KEY_2 0x1F
|
||||||
ENTRY( 0x22, '5' , '%' )\
|
#define HID_KEY_3 0x20
|
||||||
ENTRY( 0x23, '6' , '^' )\
|
#define HID_KEY_4 0x21
|
||||||
ENTRY( 0x24, '7' , '&' )\
|
#define HID_KEY_5 0x22
|
||||||
ENTRY( 0x25, '8' , '*' )\
|
#define HID_KEY_6 0x23
|
||||||
ENTRY( 0x26, '9' , '(' )\
|
#define HID_KEY_7 0x24
|
||||||
ENTRY( 0x27, '0' , ')' )\
|
#define HID_KEY_8 0x25
|
||||||
\
|
#define HID_KEY_9 0x26
|
||||||
ENTRY( 0x28, '\r' , '\r' )\
|
#define HID_KEY_0 0x27
|
||||||
ENTRY( 0x29, '\x1b', '\x1b' )\
|
#define HID_KEY_RETURN 0x28
|
||||||
ENTRY( 0x2a, '\b' , '\b' )\
|
#define HID_KEY_ESCAPE 0x29
|
||||||
ENTRY( 0x2b, '\t' , '\t' )\
|
#define HID_KEY_BACKSPACE 0x2A
|
||||||
ENTRY( 0x2c, ' ' , ' ' )\
|
#define HID_KEY_TAB 0x2B
|
||||||
ENTRY( 0x2d, '-' , '_' )\
|
#define HID_KEY_SPACE 0x2C
|
||||||
ENTRY( 0x2e, '=' , '+' )\
|
#define HID_KEY_MINUS 0x2D
|
||||||
ENTRY( 0x2f, '[' , '{' )\
|
#define HID_KEY_EQUAL 0x2E
|
||||||
ENTRY( 0x30, ']' , '}' )\
|
#define HID_KEY_BRACKET_LEFT 0x2F
|
||||||
ENTRY( 0x31, '\\' , '|' )\
|
#define HID_KEY_BRACKET_RIGHT 0x30
|
||||||
ENTRY( 0x32, '#' , '~' ) /* TODO non-US keyboard */ \
|
#define HID_KEY_BACKSLASH 0x31
|
||||||
ENTRY( 0x33, ';' , ':' )\
|
#define HID_KEY_EUROPE_1 0x32
|
||||||
ENTRY( 0x34, '\'' , '\"' )\
|
#define HID_KEY_SEMICOLON 0x33
|
||||||
ENTRY( 0x35, 0 , 0 )\
|
#define HID_KEY_APOSTROPHE 0x34
|
||||||
ENTRY( 0x36, ',' , '<' )\
|
#define HID_KEY_GRAVE 0x35
|
||||||
ENTRY( 0x37, '.' , '>' )\
|
#define HID_KEY_COMMA 0x36
|
||||||
ENTRY( 0x38, '/' , '?' )\
|
#define HID_KEY_PERIOD 0x37
|
||||||
ENTRY( 0x39, 0 , 0 ) /* TODO CapsLock, non-locking key implementation*/ \
|
#define HID_KEY_SLASH 0x38
|
||||||
\
|
#define HID_KEY_CAPS_LOCK 0x39
|
||||||
ENTRY( 0x54, '/' , '/' )\
|
#define HID_KEY_F1 0x3A
|
||||||
ENTRY( 0x55, '*' , '*' )\
|
#define HID_KEY_F2 0x3B
|
||||||
ENTRY( 0x56, '-' , '-' )\
|
#define HID_KEY_F3 0x3C
|
||||||
ENTRY( 0x57, '+' , '+' )\
|
#define HID_KEY_F4 0x3D
|
||||||
ENTRY( 0x58, '\r' , '\r' )\
|
#define HID_KEY_F5 0x3E
|
||||||
ENTRY( 0x59, '1' , 0 ) /* numpad1 & end */ \
|
#define HID_KEY_F6 0x3F
|
||||||
ENTRY( 0x5a, '2' , 0 )\
|
#define HID_KEY_F7 0x40
|
||||||
ENTRY( 0x5b, '3' , 0 )\
|
#define HID_KEY_F8 0x41
|
||||||
ENTRY( 0x5c, '4' , 0 )\
|
#define HID_KEY_F9 0x42
|
||||||
ENTRY( 0x5d, '5' , '5' )\
|
#define HID_KEY_F10 0x43
|
||||||
ENTRY( 0x5e, '6' , 0 )\
|
#define HID_KEY_F11 0x44
|
||||||
ENTRY( 0x5f, '7' , 0 )\
|
#define HID_KEY_F12 0x45
|
||||||
ENTRY( 0x60, '8' , 0 )\
|
#define HID_KEY_PRINT_SCREEN 0x46
|
||||||
ENTRY( 0x61, '9' , 0 )\
|
#define HID_KEY_SCROLL_LOCK 0x47
|
||||||
ENTRY( 0x62, '0' , 0 )\
|
#define HID_KEY_PAUSE 0x48
|
||||||
ENTRY( 0x63, '0' , 0 )\
|
#define HID_KEY_INSERT 0x49
|
||||||
ENTRY( 0x67, '=' , '=' )\
|
#define HID_KEY_HOME 0x4A
|
||||||
|
#define HID_KEY_PAGE_UP 0x4B
|
||||||
|
#define HID_KEY_DELETE 0x4C
|
||||||
|
#define HID_KEY_END 0x4D
|
||||||
|
#define HID_KEY_PAGE_DOWN 0x4E
|
||||||
|
#define HID_KEY_ARROW_RIGHT 0x4F
|
||||||
|
#define HID_KEY_ARROW_LEFT 0x50
|
||||||
|
#define HID_KEY_ARROW_DOWN 0x51
|
||||||
|
#define HID_KEY_ARROW_UP 0x52
|
||||||
|
#define HID_KEY_NUM_LOCK 0x53
|
||||||
|
#define HID_KEY_KEYPAD_DIVIDE 0x54
|
||||||
|
#define HID_KEY_KEYPAD_MULTIPLY 0x55
|
||||||
|
#define HID_KEY_KEYPAD_SUBTRACT 0x56
|
||||||
|
#define HID_KEY_KEYPAD_ADD 0x57
|
||||||
|
#define HID_KEY_KEYPAD_ENTER 0x58
|
||||||
|
#define HID_KEY_KEYPAD_1 0x59
|
||||||
|
#define HID_KEY_KEYPAD_2 0x5A
|
||||||
|
#define HID_KEY_KEYPAD_3 0x5B
|
||||||
|
#define HID_KEY_KEYPAD_4 0x5C
|
||||||
|
#define HID_KEY_KEYPAD_5 0x5D
|
||||||
|
#define HID_KEY_KEYPAD_6 0x5E
|
||||||
|
#define HID_KEY_KEYPAD_7 0x5F
|
||||||
|
#define HID_KEY_KEYPAD_8 0x60
|
||||||
|
#define HID_KEY_KEYPAD_9 0x61
|
||||||
|
#define HID_KEY_KEYPAD_0 0x62
|
||||||
|
#define HID_KEY_KEYPAD_DECIMAL 0x63
|
||||||
|
#define HID_KEY_EUROPE_2 0x64
|
||||||
|
#define HID_KEY_APPLICATION 0x65
|
||||||
|
#define HID_KEY_POWER 0x66
|
||||||
|
#define HID_KEY_KEYPAD_EQUAL 0x67
|
||||||
|
#define HID_KEY_F13 0x68
|
||||||
|
#define HID_KEY_F14 0x69
|
||||||
|
#define HID_KEY_F15 0x6A
|
||||||
|
#define HID_KEY_CONTROL_LEFT 0xE0
|
||||||
|
#define HID_KEY_SHIFT_LEFT 0xE1
|
||||||
|
#define HID_KEY_ALT_LEFT 0xE2
|
||||||
|
#define HID_KEY_GUI_LEFT 0xE3
|
||||||
|
#define HID_KEY_CONTROL_RIGHT 0xE4
|
||||||
|
#define HID_KEY_SHIFT_RIGHT 0xE5
|
||||||
|
#define HID_KEY_ALT_RIGHT 0xE6
|
||||||
|
#define HID_KEY_GUI_RIGHT 0xE7
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// TODO HID complete keycode table
|
|
||||||
|
|
||||||
//enum
|
|
||||||
//{
|
|
||||||
// KEYBOARD_KEYCODE_A = 0x04,
|
|
||||||
// KEYBOARD_KEYCODE_Z = 0x1d,
|
|
||||||
//
|
|
||||||
// KEYBOARD_KEYCODE_1 = 0x1e,
|
|
||||||
// KEYBOARD_KEYCODE_0 = 0x27,
|
|
||||||
//
|
|
||||||
// KEYBOARD_KEYCODE_ENTER = 0x28,
|
|
||||||
// KEYBOARD_KEYCODE_ESCAPE = 0x29,
|
|
||||||
// KEYBOARD_KEYCODE_BACKSPACE = 0x2a,
|
|
||||||
// KEYBOARD_KEYCODE_TAB = 0x2b,
|
|
||||||
// KEYBOARD_KEYCODE_SPACEBAR = 0x2c,
|
|
||||||
//
|
|
||||||
//};
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
// REPORT DESCRIPTOR
|
// REPORT DESCRIPTOR
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
|
@ -45,6 +45,7 @@
|
|||||||
// INCLUDE
|
// INCLUDE
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
#include "common/tusb_common.h"
|
#include "common/tusb_common.h"
|
||||||
|
#include "common/timeout_timer.h"
|
||||||
#include "hid_device.h"
|
#include "hid_device.h"
|
||||||
#include "device/usbd_pvt.h"
|
#include "device/usbd_pvt.h"
|
||||||
|
|
||||||
@ -91,16 +92,71 @@ bool tud_hid_keyboard_busy(void)
|
|||||||
return dcd_edpt_busy(TUD_OPT_RHPORT, _kbd_itf.ep_in);
|
return dcd_edpt_busy(TUD_OPT_RHPORT, _kbd_itf.ep_in);
|
||||||
}
|
}
|
||||||
|
|
||||||
tusb_error_t tud_hid_keyboard_send(hid_keyboard_report_t const *p_report)
|
bool tud_hid_keyboard_send_report(hid_keyboard_report_t const *p_report)
|
||||||
{
|
{
|
||||||
VERIFY(tud_mounted(), TUSB_ERROR_USBD_DEVICE_NOT_CONFIGURED);
|
VERIFY( tud_mounted() && !tud_hid_keyboard_busy() );
|
||||||
|
|
||||||
hidd_interface_t * p_kbd = &_kbd_itf;
|
hidd_interface_t * p_hid = &_kbd_itf;
|
||||||
|
|
||||||
TU_ASSERT( dcd_edpt_xfer(TUD_OPT_RHPORT, p_kbd->ep_in, (void*) p_report, sizeof(hid_keyboard_report_t)), TUSB_ERROR_DCD_EDPT_XFER ) ;
|
if ( p_report )
|
||||||
|
{
|
||||||
|
memcpy(p_hid->report_buf, p_report, sizeof(hid_keyboard_report_t));
|
||||||
|
}else
|
||||||
|
{
|
||||||
|
// empty report
|
||||||
|
arrclr_(p_hid->report_buf);
|
||||||
|
}
|
||||||
|
|
||||||
return TUSB_ERROR_NONE;
|
return dcd_edpt_xfer(TUD_OPT_RHPORT, p_hid->ep_in, p_hid->report_buf, sizeof(hid_keyboard_report_t));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool tud_hid_keyboard_send_keycode(uint8_t modifier, uint8_t keycode[6])
|
||||||
|
{
|
||||||
|
hid_keyboard_report_t report = { .modifier = modifier };
|
||||||
|
memcpy(report.keycode, keycode, 6);
|
||||||
|
|
||||||
|
return tud_hid_keyboard_send_report(&report);
|
||||||
|
}
|
||||||
|
|
||||||
|
#if CFG_TUD_HID_ASCII_TO_KEYCODE_LOOKUP
|
||||||
|
|
||||||
|
bool tud_hid_keyboard_send_char(char ch)
|
||||||
|
{
|
||||||
|
hid_keyboard_report_t report;
|
||||||
|
varclr_(&report);
|
||||||
|
|
||||||
|
report.modifier = ( HID_ASCII_TO_KEYCODE[(uint8_t)ch].shift ) ? KEYBOARD_MODIFIER_LEFTSHIFT : 0;
|
||||||
|
report.keycode[0] = HID_ASCII_TO_KEYCODE[(uint8_t)ch].keycode;
|
||||||
|
|
||||||
|
return tud_hid_keyboard_send_report(&report);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool tud_hid_keyboard_send_string(const char* str, uint32_t interval_ms)
|
||||||
|
{
|
||||||
|
// Send each key in string
|
||||||
|
char ch;
|
||||||
|
while( (ch = *str++) != 0 )
|
||||||
|
{
|
||||||
|
char lookahead = *str;
|
||||||
|
|
||||||
|
tud_hid_keyboard_send_char(ch);
|
||||||
|
|
||||||
|
// Blocking delay
|
||||||
|
timeout_blocking_wait(interval_ms);
|
||||||
|
|
||||||
|
/* Only need to empty report if the next character is NULL or the same with
|
||||||
|
* the current one, else no need to send */
|
||||||
|
if ( lookahead == ch || lookahead == 0 )
|
||||||
|
{
|
||||||
|
tud_hid_keyboard_send_report(NULL);
|
||||||
|
timeout_blocking_wait(interval_ms);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // CFG_TUD_HID_ASCII_TO_KEYCODE_LOOKUP
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
@ -112,15 +168,14 @@ bool tud_hid_mouse_is_busy(void)
|
|||||||
return dcd_edpt_busy(TUD_OPT_RHPORT, _mse_itf.ep_in);
|
return dcd_edpt_busy(TUD_OPT_RHPORT, _mse_itf.ep_in);
|
||||||
}
|
}
|
||||||
|
|
||||||
tusb_error_t tud_hid_mouse_send(hid_mouse_report_t const *p_report)
|
bool tud_hid_mouse_send(hid_mouse_report_t const *p_report)
|
||||||
{
|
{
|
||||||
VERIFY(tud_mounted(), TUSB_ERROR_USBD_DEVICE_NOT_CONFIGURED);
|
VERIFY( tud_mounted() && !tud_hid_mouse_is_busy() );
|
||||||
|
|
||||||
hidd_interface_t * p_mouse = &_mse_itf;
|
hidd_interface_t * p_hid = &_mse_itf;
|
||||||
|
memcpy(p_hid->report_buf, p_report, sizeof(hid_mouse_report_t));
|
||||||
|
|
||||||
TU_ASSERT( dcd_edpt_xfer(TUD_OPT_RHPORT, p_mouse->ep_in, (void*) p_report, sizeof(hid_mouse_report_t)), TUSB_ERROR_DCD_EDPT_XFER ) ;
|
return dcd_edpt_xfer(TUD_OPT_RHPORT, p_hid->ep_in, p_hid->report_buf, sizeof(hid_mouse_report_t));
|
||||||
|
|
||||||
return TUSB_ERROR_NONE;
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -327,4 +382,143 @@ tusb_error_t hidd_xfer_cb(uint8_t rhport, uint8_t edpt_addr, tusb_event_t event,
|
|||||||
return TUSB_ERROR_NONE;
|
return TUSB_ERROR_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*------------------------------------------------------------------*/
|
||||||
|
/* Ascii to Keycode
|
||||||
|
*------------------------------------------------------------------*/
|
||||||
|
const hid_ascii_to_keycode_entry_t HID_ASCII_TO_KEYCODE[128] =
|
||||||
|
{
|
||||||
|
{0, 0 }, // 0x00 Null
|
||||||
|
{0, 0 }, // 0x01
|
||||||
|
{0, 0 }, // 0x02
|
||||||
|
{0, 0 }, // 0x03
|
||||||
|
{0, 0 }, // 0x04
|
||||||
|
{0, 0 }, // 0x05
|
||||||
|
{0, 0 }, // 0x06
|
||||||
|
{0, 0 }, // 0x07
|
||||||
|
{0, HID_KEY_BACKSPACE }, // 0x08 Backspace
|
||||||
|
{0, HID_KEY_TAB }, // 0x09 Horizontal Tab
|
||||||
|
{0, HID_KEY_RETURN }, // 0x0A Line Feed
|
||||||
|
{0, 0 }, // 0x0B
|
||||||
|
{0, 0 }, // 0x0C
|
||||||
|
{0, HID_KEY_RETURN }, // 0x0D Carriage return
|
||||||
|
{0, 0 }, // 0x0E
|
||||||
|
{0, 0 }, // 0x0F
|
||||||
|
{0, 0 }, // 0x10
|
||||||
|
{0, 0 }, // 0x11
|
||||||
|
{0, 0 }, // 0x12
|
||||||
|
{0, 0 }, // 0x13
|
||||||
|
{0, 0 }, // 0x14
|
||||||
|
{0, 0 }, // 0x15
|
||||||
|
{0, 0 }, // 0x16
|
||||||
|
{0, 0 }, // 0x17
|
||||||
|
{0, 0 }, // 0x18
|
||||||
|
{0, 0 }, // 0x19
|
||||||
|
{0, 0 }, // 0x1A
|
||||||
|
{0, HID_KEY_ESCAPE }, // 0x1B Escape
|
||||||
|
{0, 0 }, // 0x1C
|
||||||
|
{0, 0 }, // 0x1D
|
||||||
|
{0, 0 }, // 0x1E
|
||||||
|
{0, 0 }, // 0x1F
|
||||||
|
|
||||||
|
{0, HID_KEY_SPACE }, // 0x20
|
||||||
|
{1, HID_KEY_1 }, // 0x21 !
|
||||||
|
{1, HID_KEY_APOSTROPHE }, // 0x22 "
|
||||||
|
{1, HID_KEY_3 }, // 0x23 #
|
||||||
|
{1, HID_KEY_4 }, // 0x24 $
|
||||||
|
{1, HID_KEY_5 }, // 0x25 %
|
||||||
|
{1, HID_KEY_7 }, // 0x26 &
|
||||||
|
{0, HID_KEY_APOSTROPHE }, // 0x27 '
|
||||||
|
{1, HID_KEY_9 }, // 0x28 (
|
||||||
|
{1, HID_KEY_0 }, // 0x29 )
|
||||||
|
{1, HID_KEY_8 }, // 0x2A *
|
||||||
|
{1, HID_KEY_EQUAL }, // 0x2B +
|
||||||
|
{0, HID_KEY_COMMA }, // 0x2C ,
|
||||||
|
{0, HID_KEY_MINUS }, // 0x2D -
|
||||||
|
{0, HID_KEY_PERIOD }, // 0x2E .
|
||||||
|
{0, HID_KEY_SLASH }, // 0x2F /
|
||||||
|
{0, HID_KEY_0 }, // 0x30 0
|
||||||
|
{0, HID_KEY_1 }, // 0x31 1
|
||||||
|
{0, HID_KEY_2 }, // 0x32 2
|
||||||
|
{0, HID_KEY_3 }, // 0x33 3
|
||||||
|
{0, HID_KEY_4 }, // 0x34 4
|
||||||
|
{0, HID_KEY_5 }, // 0x35 5
|
||||||
|
{0, HID_KEY_6 }, // 0x36 6
|
||||||
|
{0, HID_KEY_7 }, // 0x37 7
|
||||||
|
{0, HID_KEY_8 }, // 0x38 8
|
||||||
|
{0, HID_KEY_9 }, // 0x39 9
|
||||||
|
{1, HID_KEY_SEMICOLON }, // 0x3A :
|
||||||
|
{0, HID_KEY_SEMICOLON }, // 0x3B ;
|
||||||
|
{1, HID_KEY_COMMA }, // 0x3C <
|
||||||
|
{0, HID_KEY_EQUAL }, // 0x3D =
|
||||||
|
{1, HID_KEY_PERIOD }, // 0x3E >
|
||||||
|
{1, HID_KEY_SLASH }, // 0x3F ?
|
||||||
|
|
||||||
|
{1, HID_KEY_2 }, // 0x40 @
|
||||||
|
{1, HID_KEY_A }, // 0x41 A
|
||||||
|
{1, HID_KEY_B }, // 0x42 B
|
||||||
|
{1, HID_KEY_C }, // 0x43 C
|
||||||
|
{1, HID_KEY_D }, // 0x44 D
|
||||||
|
{1, HID_KEY_E }, // 0x45 E
|
||||||
|
{1, HID_KEY_F }, // 0x46 F
|
||||||
|
{1, HID_KEY_G }, // 0x47 G
|
||||||
|
{1, HID_KEY_H }, // 0x48 H
|
||||||
|
{1, HID_KEY_I }, // 0x49 I
|
||||||
|
{1, HID_KEY_J }, // 0x4A J
|
||||||
|
{1, HID_KEY_K }, // 0x4B K
|
||||||
|
{1, HID_KEY_L }, // 0x4C L
|
||||||
|
{1, HID_KEY_M }, // 0x4D M
|
||||||
|
{1, HID_KEY_N }, // 0x4E N
|
||||||
|
{1, HID_KEY_O }, // 0x4F O
|
||||||
|
{1, HID_KEY_P }, // 0x50 P
|
||||||
|
{1, HID_KEY_Q }, // 0x51 Q
|
||||||
|
{1, HID_KEY_R }, // 0x52 R
|
||||||
|
{1, HID_KEY_S }, // 0x53 S
|
||||||
|
{1, HID_KEY_T }, // 0x55 T
|
||||||
|
{1, HID_KEY_U }, // 0x55 U
|
||||||
|
{1, HID_KEY_V }, // 0x56 V
|
||||||
|
{1, HID_KEY_W }, // 0x57 W
|
||||||
|
{1, HID_KEY_X }, // 0x58 X
|
||||||
|
{1, HID_KEY_Y }, // 0x59 Y
|
||||||
|
{1, HID_KEY_Z }, // 0x5A Z
|
||||||
|
{0, HID_KEY_BRACKET_LEFT }, // 0x5B [
|
||||||
|
{0, HID_KEY_BACKSLASH }, // 0x5C '\'
|
||||||
|
{0, HID_KEY_BRACKET_RIGHT }, // 0x5D ]
|
||||||
|
{1, HID_KEY_6 }, // 0x5E ^
|
||||||
|
{1, HID_KEY_MINUS }, // 0x5F _
|
||||||
|
|
||||||
|
{0, HID_KEY_GRAVE }, // 0x60 `
|
||||||
|
{0, HID_KEY_A }, // 0x61 a
|
||||||
|
{0, HID_KEY_B }, // 0x62 b
|
||||||
|
{0, HID_KEY_C }, // 0x63 c
|
||||||
|
{0, HID_KEY_D }, // 0x66 d
|
||||||
|
{0, HID_KEY_E }, // 0x65 e
|
||||||
|
{0, HID_KEY_F }, // 0x66 f
|
||||||
|
{0, HID_KEY_G }, // 0x67 g
|
||||||
|
{0, HID_KEY_H }, // 0x68 h
|
||||||
|
{0, HID_KEY_I }, // 0x69 i
|
||||||
|
{0, HID_KEY_J }, // 0x6A j
|
||||||
|
{0, HID_KEY_K }, // 0x6B k
|
||||||
|
{0, HID_KEY_L }, // 0x6C l
|
||||||
|
{0, HID_KEY_M }, // 0x6D m
|
||||||
|
{0, HID_KEY_N }, // 0x6E n
|
||||||
|
{0, HID_KEY_O }, // 0x6F o
|
||||||
|
{0, HID_KEY_P }, // 0x70 p
|
||||||
|
{0, HID_KEY_Q }, // 0x71 q
|
||||||
|
{0, HID_KEY_R }, // 0x72 r
|
||||||
|
{0, HID_KEY_S }, // 0x73 s
|
||||||
|
{0, HID_KEY_T }, // 0x75 t
|
||||||
|
{0, HID_KEY_U }, // 0x75 u
|
||||||
|
{0, HID_KEY_V }, // 0x76 v
|
||||||
|
{0, HID_KEY_W }, // 0x77 w
|
||||||
|
{0, HID_KEY_X }, // 0x78 x
|
||||||
|
{0, HID_KEY_Y }, // 0x79 y
|
||||||
|
{0, HID_KEY_Z }, // 0x7A z
|
||||||
|
{1, HID_KEY_BRACKET_LEFT }, // 0x7B {
|
||||||
|
{1, HID_KEY_BACKSLASH }, // 0x7C |
|
||||||
|
{1, HID_KEY_BRACKET_RIGHT }, // 0x7D }
|
||||||
|
{1, HID_KEY_GRAVE }, // 0x7E ~
|
||||||
|
{0, HID_KEY_DELETE } // 0x7F Delete
|
||||||
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -63,22 +63,26 @@
|
|||||||
*/
|
*/
|
||||||
bool tud_hid_keyboard_busy(void);
|
bool tud_hid_keyboard_busy(void);
|
||||||
|
|
||||||
/** \brief Submit USB transfer
|
/** \brief Send a keyboard report
|
||||||
* \param[in] rhport USB Controller ID
|
* \param[in,out] p_report Report data, if NULL, an empty report (all zeroes) is used
|
||||||
* \param[in,out] p_report address that is used to store data from device. Must be accessible by usb controller (see \ref CFG_TUSB_ATTR_USBRAM)
|
* \returns true on success, false otherwise (not mounted or busy)
|
||||||
* \returns \ref tusb_error_t type to indicate success or error condition.
|
|
||||||
* \retval TUSB_ERROR_NONE on success
|
|
||||||
* \retval TUSB_ERROR_INTERFACE_IS_BUSY if the interface is already transferring data with device
|
|
||||||
* \retval TUSB_ERROR_DEVICE_NOT_READY if device is not yet configured (by SET CONFIGURED request)
|
|
||||||
* \retval TUSB_ERROR_INVALID_PARA if input parameters are not correct
|
|
||||||
* \note This function is non-blocking and returns immediately. Data will be transferred when USB Host work with this interface.
|
|
||||||
* The result of usb transfer will be reported by the interface's callback function
|
|
||||||
*/
|
*/
|
||||||
tusb_error_t tud_hid_keyboard_send(hid_keyboard_report_t const *p_report);
|
bool tud_hid_keyboard_send_report(hid_keyboard_report_t const *p_report);
|
||||||
|
|
||||||
//--------------------------------------------------------------------+
|
bool tud_hid_keyboard_send_keycode(uint8_t modifier, uint8_t keycode[6]);
|
||||||
// APPLICATION CALLBACK API
|
|
||||||
//--------------------------------------------------------------------+
|
#if CFG_TUD_HID_ASCII_TO_KEYCODE_LOOKUP
|
||||||
|
bool tud_hid_keyboard_send_char(char ch);
|
||||||
|
bool tud_hid_keyboard_send_string(const char* str, uint32_t interval_ms);
|
||||||
|
|
||||||
|
typedef struct{
|
||||||
|
uint8_t shift;
|
||||||
|
uint8_t keycode;
|
||||||
|
}hid_ascii_to_keycode_entry_t;
|
||||||
|
extern const hid_ascii_to_keycode_entry_t HID_ASCII_TO_KEYCODE[128];
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*------------- Callbacks -------------*/
|
||||||
|
|
||||||
/** \brief Callback function that is invoked when USB host request \ref HID_REQUEST_CONTROL_GET_REPORT
|
/** \brief Callback function that is invoked when USB host request \ref HID_REQUEST_CONTROL_GET_REPORT
|
||||||
* via control endpoint.
|
* via control endpoint.
|
||||||
@ -120,23 +124,15 @@ ATTR_WEAK void tud_hid_keyboard_set_report_cb(hid_report_type_t report_type, uin
|
|||||||
* \retval false if the interface is not busy meaning the stack successfully transferred data from/to host
|
* \retval false if the interface is not busy meaning the stack successfully transferred data from/to host
|
||||||
* \note This function is primarily used for polling/waiting result after \ref tusbd_hid_mouse_send.
|
* \note This function is primarily used for polling/waiting result after \ref tusbd_hid_mouse_send.
|
||||||
*/
|
*/
|
||||||
bool tud_hid_mouse_is_busy(void);
|
bool tud_hid_mouse_busy(void);
|
||||||
|
|
||||||
/** \brief Perform transfer queuing
|
/** \brief Perform transfer queuing
|
||||||
* \param[in,out] p_report address that is used to store data from device. Must be accessible by usb controller (see \ref CFG_TUSB_ATTR_USBRAM)
|
* \param[in,out] p_report address that is used to store data from device. Must be accessible by usb controller (see \ref CFG_TUSB_ATTR_USBRAM)
|
||||||
* \returns \ref tusb_error_t type to indicate success or error condition.
|
* \returns true on success, false otherwise (not mounted or busy)
|
||||||
* \retval TUSB_ERROR_NONE on success
|
|
||||||
* \retval TUSB_ERROR_INTERFACE_IS_BUSY if the interface is already transferring data with device
|
|
||||||
* \retval TUSB_ERROR_DEVICE_NOT_READY if device is not yet configured (by SET CONFIGURED request)
|
|
||||||
* \retval TUSB_ERROR_INVALID_PARA if input parameters are not correct
|
|
||||||
* \note This function is non-blocking and returns immediately. Data will be transferred when USB Host work with this interface.
|
|
||||||
* The result of usb transfer will be reported by the interface's callback function
|
|
||||||
*/
|
*/
|
||||||
tusb_error_t tud_hid_mouse_send(hid_mouse_report_t const *p_report);
|
bool tud_hid_mouse_send(hid_mouse_report_t const *p_report);
|
||||||
|
|
||||||
//--------------------------------------------------------------------+
|
/*------------- Callbacks -------------*/
|
||||||
// APPLICATION CALLBACK API
|
|
||||||
//--------------------------------------------------------------------+
|
|
||||||
|
|
||||||
/** \brief Callback function that is invoked when USB host request \ref HID_REQUEST_CONTROL_GET_REPORT
|
/** \brief Callback function that is invoked when USB host request \ref HID_REQUEST_CONTROL_GET_REPORT
|
||||||
* via control endpoint.
|
* via control endpoint.
|
||||||
|
@ -67,6 +67,15 @@ static inline bool timeout_expired(timeout_timer_t* tt)
|
|||||||
return ( tusb_hal_millis() - tt->start ) >= tt->interval;
|
return ( tusb_hal_millis() - tt->start ) >= tt->interval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline void timeout_blocking_wait(uint32_t msec)
|
||||||
|
{
|
||||||
|
timeout_timer_t tt;
|
||||||
|
timeout_set(&tt, msec);
|
||||||
|
|
||||||
|
// blocking delay
|
||||||
|
while ( !timeout_expired(&tt) ) { }
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user