hog_mouse_demo/hog_keyboard_demo: handle set protocol mode = boot protocol mode

This commit is contained in:
Matthias Ringwald 2020-04-19 18:25:06 +02:00
parent 3035e4e529
commit 5030492178
3 changed files with 25 additions and 4 deletions

View File

@ -17,6 +17,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.
## Changes April 2020 ## Changes April 2020
### Fixed ### Fixed
- hog_mouse_demo/hog_keyboard_demo: handle set protocol mode = boot protocol mode
### Added ### Added
- GAP: gap_set_allow_role_switch allows to prevent role switch in outgoing classic ACL connections - GAP: gap_set_allow_role_switch allows to prevent role switch in outgoing classic ACL connections

View File

@ -166,6 +166,7 @@ static btstack_packet_callback_registration_t hci_event_callback_registration;
static btstack_packet_callback_registration_t sm_event_callback_registration; static btstack_packet_callback_registration_t sm_event_callback_registration;
static uint8_t battery = 100; static uint8_t battery = 100;
static hci_con_handle_t con_handle = HCI_CON_HANDLE_INVALID; static hci_con_handle_t con_handle = HCI_CON_HANDLE_INVALID;
static uint8_t protocol_mode = 1;
static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size); static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size);
@ -257,7 +258,16 @@ static int keycode_and_modifer_us_for_character(uint8_t character, uint8_t * key
static void send_report(int modifier, int keycode){ static void send_report(int modifier, int keycode){
uint8_t report[] = { /* 0xa1, */ modifier, 0, 0, keycode, 0, 0, 0, 0, 0}; uint8_t report[] = { /* 0xa1, */ modifier, 0, 0, keycode, 0, 0, 0, 0, 0};
hids_device_send_input_report(con_handle, report, sizeof(report)); switch (protocol_mode){
case 0:
hids_device_send_boot_keyboard_input_report(con_handle, report, sizeof(report));
break;
case 1:
hids_device_send_input_report(con_handle, report, sizeof(report));
break;
default:
break;
}
} }
// Demo Application // Demo Application
@ -426,6 +436,7 @@ static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *pack
printf("Boot Keyboard Characteristic Subscribed %u\n", hids_subevent_boot_keyboard_input_report_enable_get_enable(packet)); printf("Boot Keyboard Characteristic Subscribed %u\n", hids_subevent_boot_keyboard_input_report_enable_get_enable(packet));
break; break;
case HIDS_SUBEVENT_PROTOCOL_MODE: case HIDS_SUBEVENT_PROTOCOL_MODE:
protocol_mode = hids_subevent_protocol_mode_get_protocol_mode(packet);
printf("Protocol Mode: %s mode\n", hids_subevent_protocol_mode_get_protocol_mode(packet) ? "Report" : "Boot"); printf("Protocol Mode: %s mode\n", hids_subevent_protocol_mode_get_protocol_mode(packet) ? "Report" : "Boot");
break; break;
case HIDS_SUBEVENT_CAN_SEND_NOW: case HIDS_SUBEVENT_CAN_SEND_NOW:

View File

@ -101,6 +101,7 @@ static btstack_packet_callback_registration_t hci_event_callback_registration;
static btstack_packet_callback_registration_t sm_event_callback_registration; static btstack_packet_callback_registration_t sm_event_callback_registration;
static uint8_t battery = 100; static uint8_t battery = 100;
static hci_con_handle_t con_handle = HCI_CON_HANDLE_INVALID; static hci_con_handle_t con_handle = HCI_CON_HANDLE_INVALID;
static uint8_t protocol_mode = 1;
static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size); static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size);
@ -166,9 +167,16 @@ static void hog_mouse_setup(void){
// HID Report sending // HID Report sending
static void send_report(uint8_t buttons, int8_t dx, int8_t dy){ static void send_report(uint8_t buttons, int8_t dx, int8_t dy){
// uint8_t report[] = { (uint8_t) dx, (uint8_t) dy, buttons}; uint8_t report[] = { buttons, (uint8_t) dx, (uint8_t) dy, 0};
uint8_t report[] = { buttons, (uint8_t) dx, (uint8_t) dy}; switch (protocol_mode){
hids_device_send_input_report(con_handle, report, sizeof(report)); case 0:
hids_device_send_boot_mouse_input_report(con_handle, report, sizeof(report));
case 1:
hids_device_send_input_report(con_handle, report, sizeof(report));
break;
default:
break;
}
printf("Mouse: %d/%d - buttons: %02x\n", dx, dy, buttons); printf("Mouse: %d/%d - buttons: %02x\n", dx, dy, buttons);
} }
@ -366,6 +374,7 @@ static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *pack
printf("Boot Mouse Characteristic Subscribed %u\n", hids_subevent_boot_mouse_input_report_enable_get_enable(packet)); printf("Boot Mouse Characteristic Subscribed %u\n", hids_subevent_boot_mouse_input_report_enable_get_enable(packet));
break; break;
case HIDS_SUBEVENT_PROTOCOL_MODE: case HIDS_SUBEVENT_PROTOCOL_MODE:
protocol_mode = hids_subevent_protocol_mode_get_protocol_mode(packet);
printf("Protocol Mode: %s mode\n", hids_subevent_protocol_mode_get_protocol_mode(packet) ? "Report" : "Boot"); printf("Protocol Mode: %s mode\n", hids_subevent_protocol_mode_get_protocol_mode(packet) ? "Report" : "Boot");
break; break;
case HIDS_SUBEVENT_CAN_SEND_NOW: case HIDS_SUBEVENT_CAN_SEND_NOW: