2022-02-08 17:39:38 +08:00
|
|
|
/*
|
2023-12-19 19:39:54 +01:00
|
|
|
* SPDX-FileCopyrightText: 2017-2024 Espressif Systems (Shanghai) CO LTD
|
2022-02-08 17:39:38 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
2020-04-29 17:24:01 +08:00
|
|
|
|
2023-12-21 20:58:40 +01:00
|
|
|
#pragma once
|
2020-04-29 17:24:01 +08:00
|
|
|
|
|
|
|
#include "esp_hidh.h"
|
|
|
|
#include "freertos/FreeRTOS.h"
|
|
|
|
#include "freertos/semphr.h"
|
|
|
|
#include "sys/queue.h"
|
2021-09-07 17:08:43 +08:00
|
|
|
#include "esp_timer.h"
|
2023-07-31 15:32:07 +05:30
|
|
|
#if CONFIG_BT_NIMBLE_ENABLED
|
|
|
|
#include "nimble/ble.h"
|
|
|
|
#endif
|
2020-04-29 17:24:01 +08:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief HIDH device report data
|
|
|
|
*/
|
|
|
|
typedef struct esp_hidh_dev_report_s {
|
|
|
|
struct esp_hidh_dev_report_s *next;
|
|
|
|
uint8_t map_index; //the index of the report map
|
|
|
|
uint8_t report_id; //the id of the report
|
|
|
|
uint8_t report_type; //input, output or feature
|
|
|
|
uint8_t protocol_mode; //boot or report
|
|
|
|
size_t value_len; //maximum len of value by report map
|
|
|
|
esp_hid_usage_t usage; //generic, keyboard or mouse
|
|
|
|
//BLE properties
|
|
|
|
uint16_t handle; //handle to the value
|
|
|
|
uint16_t ccc_handle; //handle to client config
|
|
|
|
uint8_t permissions; //report permissions
|
|
|
|
} esp_hidh_dev_report_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief HIDH device data
|
|
|
|
*/
|
|
|
|
struct esp_hidh_dev_s {
|
2023-12-21 20:58:40 +01:00
|
|
|
esp_hid_address_t addr;
|
2020-04-29 17:24:01 +08:00
|
|
|
esp_hid_device_config_t config;
|
|
|
|
esp_hid_usage_t usage;
|
2021-09-07 17:08:43 +08:00
|
|
|
esp_hid_transport_t transport; //BT, BLE or USB
|
|
|
|
esp_hid_trans_type_t trans_type; //indicate what transaction is going on, new transaction only be allowed after the previous done
|
2024-03-06 21:26:29 +01:00
|
|
|
esp_timer_handle_t trans_timer; //transaction timer
|
|
|
|
uint8_t report_type; //Get_Report transaction report_type
|
|
|
|
uint8_t report_id; //Get_Report transaction report_id
|
2023-07-31 15:32:07 +05:30
|
|
|
#if CONFIG_BT_NIMBLE_ENABLED
|
|
|
|
uint8_t *protocol_mode; // protocol mode is unique for each hid service instance
|
|
|
|
#else
|
2021-09-07 17:08:43 +08:00
|
|
|
uint8_t protocol_mode; //device protocol mode
|
2023-07-31 15:32:07 +05:30
|
|
|
#endif
|
2021-09-07 17:08:43 +08:00
|
|
|
bool connected; //we have all required data to communicate
|
|
|
|
bool opened; //we opened the device manually, else the device connected to us
|
|
|
|
bool added; //If lower layer has added the device
|
|
|
|
bool is_orig; //If host initiate the connection
|
|
|
|
bool in_use; //If false, it will be deleted from the devices list.
|
|
|
|
int status; //status of the last command
|
2020-04-29 17:24:01 +08:00
|
|
|
|
|
|
|
size_t reports_len;
|
|
|
|
esp_hidh_dev_report_t *reports;
|
|
|
|
|
|
|
|
void *tmp;
|
|
|
|
size_t tmp_len;
|
|
|
|
|
2024-03-06 21:26:29 +01:00
|
|
|
SemaphoreHandle_t semaphore;
|
|
|
|
SemaphoreHandle_t mutex;
|
2020-04-29 17:24:01 +08:00
|
|
|
|
2024-02-27 14:46:55 +01:00
|
|
|
esp_err_t (*close)(esp_hidh_dev_t *dev);
|
|
|
|
esp_err_t (*report_write)(esp_hidh_dev_t *dev, size_t map_index, size_t report_id, int report_type, uint8_t *data, size_t len);
|
|
|
|
esp_err_t (*report_read)(esp_hidh_dev_t *dev, size_t map_index, size_t report_id, int report_type, size_t max_length, uint8_t *value, size_t *value_len);
|
|
|
|
esp_err_t (*set_report)(esp_hidh_dev_t *dev, size_t map_index, size_t report_id, int report_type, uint8_t *data, size_t len);
|
|
|
|
esp_err_t (*get_idle)(esp_hidh_dev_t *dev);
|
|
|
|
esp_err_t (*set_idle)(esp_hidh_dev_t *dev, uint8_t idle_time);
|
|
|
|
esp_err_t (*get_protocol)(esp_hidh_dev_t *dev);
|
|
|
|
esp_err_t (*set_protocol)(esp_hidh_dev_t *dev, uint8_t protocol_mode);
|
|
|
|
void (*dump)(esp_hidh_dev_t *dev, FILE *fp);
|
2020-04-29 17:24:01 +08:00
|
|
|
|
|
|
|
union {
|
|
|
|
#if CONFIG_BT_HID_HOST_ENABLED
|
|
|
|
struct {
|
2021-09-07 17:08:43 +08:00
|
|
|
uint8_t handle;
|
2020-04-29 17:24:01 +08:00
|
|
|
} bt;
|
|
|
|
#endif /* CONFIG_BT_HID_HOST_ENABLED */
|
|
|
|
#if CONFIG_GATTC_ENABLE
|
|
|
|
struct {
|
|
|
|
esp_ble_addr_type_t address_type;
|
|
|
|
int conn_id;
|
|
|
|
uint16_t appearance;
|
|
|
|
uint16_t battery_handle;
|
|
|
|
uint16_t battery_ccc_handle;
|
|
|
|
} ble;
|
|
|
|
#endif /* CONFIG_GATTC_ENABLE */
|
2023-07-31 15:32:07 +05:30
|
|
|
#if CONFIG_BT_NIMBLE_ENABLED
|
|
|
|
struct {
|
|
|
|
uint8_t address_type;
|
|
|
|
int conn_id;
|
|
|
|
uint16_t appearance;
|
|
|
|
uint16_t battery_handle;
|
|
|
|
uint16_t battery_ccc_handle;
|
|
|
|
} ble;
|
|
|
|
#endif
|
2020-04-29 17:24:01 +08:00
|
|
|
};
|
|
|
|
TAILQ_ENTRY(esp_hidh_dev_s) devices;
|
|
|
|
};
|
|
|
|
|
2024-03-06 21:26:29 +01:00
|
|
|
// ------------------------------------------------- Transport layer functions --------------------------------------------------
|
2020-04-29 17:24:01 +08:00
|
|
|
|
2024-03-06 21:26:29 +01:00
|
|
|
/**
|
|
|
|
* @brief Get HIDH event loop
|
|
|
|
*
|
|
|
|
* Transport layers will post events into the loop
|
|
|
|
*
|
|
|
|
* @return esp_event_loop_handle_t Handle to HIDH event loop
|
|
|
|
*/
|
|
|
|
esp_event_loop_handle_t esp_hidh_get_event_loop(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Allocate HIDH device
|
|
|
|
*
|
|
|
|
* The resources can be freed by esp_hidh_dev_free_inner()
|
|
|
|
*
|
|
|
|
* @return esp_hidh_dev_t* Pointer to newly allocated HIDH device
|
|
|
|
*/
|
2020-04-29 17:24:01 +08:00
|
|
|
esp_hidh_dev_t *esp_hidh_dev_malloc(void);
|
|
|
|
|
2024-03-06 21:26:29 +01:00
|
|
|
/**
|
|
|
|
* @brief Free HIDH device
|
|
|
|
*
|
|
|
|
* @param[in] dev Device handle obtained from esp_hidh_dev_malloc()
|
|
|
|
* @return
|
|
|
|
* - ESP_OK: Success
|
|
|
|
* - ESP_FAIL: Parameter is NULL or it is not a valid HIDH device
|
|
|
|
*/
|
|
|
|
esp_err_t esp_hidh_dev_free_inner(esp_hidh_dev_t *dev);
|
|
|
|
|
2020-04-29 17:24:01 +08:00
|
|
|
#if CONFIG_BLUEDROID_ENABLED
|
|
|
|
esp_hidh_dev_t *esp_hidh_dev_get_by_bda(esp_bd_addr_t bda); //BT/BLE
|
2021-09-07 17:08:43 +08:00
|
|
|
esp_hidh_dev_t *esp_hidh_dev_get_by_handle(uint8_t handle); //Classic Bluetooth Only
|
2020-04-29 17:24:01 +08:00
|
|
|
esp_hidh_dev_t *esp_hidh_dev_get_by_conn_id(uint16_t conn_id); //BLE Only
|
|
|
|
#endif /* CONFIG_BLUEDROID_ENABLED */
|
2023-07-31 15:32:07 +05:30
|
|
|
#if CONFIG_BT_NIMBLE_ENABLED
|
|
|
|
esp_hidh_dev_t *esp_hidh_dev_get_by_bda(uint8_t* bda); // BLE Only
|
|
|
|
esp_hidh_dev_t *esp_hidh_dev_get_by_conn_id(uint16_t conn_id); //BLE Only
|
|
|
|
#endif
|
2020-04-29 17:24:01 +08:00
|
|
|
|
2021-09-07 17:08:43 +08:00
|
|
|
esp_hidh_dev_report_t *esp_hidh_dev_get_report_by_id_type_proto(esp_hidh_dev_t *dev, size_t map_index, size_t report_id, int report_type, uint8_t protocol_mode);
|
2020-04-29 17:24:01 +08:00
|
|
|
esp_hidh_dev_report_t *esp_hidh_dev_get_report_by_id_and_type(esp_hidh_dev_t *dev, size_t map_index, size_t report_id, int report_type);
|
2021-09-07 17:08:43 +08:00
|
|
|
esp_hidh_dev_report_t *esp_hidh_dev_get_input_report_by_len_and_proto(esp_hidh_dev_t *dev, size_t len, int protocol_mode);
|
2020-04-29 17:24:01 +08:00
|
|
|
esp_hidh_dev_report_t *esp_hidh_dev_get_input_report_by_id_and_proto(esp_hidh_dev_t *dev, size_t report_id, int protocol_mode);
|
2021-09-07 17:08:43 +08:00
|
|
|
esp_hidh_dev_report_t *esp_hidh_dev_get_input_report_by_proto_and_data(esp_hidh_dev_t *dev, int protocol_mode,
|
|
|
|
size_t len, const uint8_t *data, bool *has_report_id);
|
2020-04-29 17:24:01 +08:00
|
|
|
esp_hidh_dev_report_t *esp_hidh_dev_get_report_by_handle(esp_hidh_dev_t *dev, uint16_t handle); //BLE Only
|
2022-11-03 11:29:09 +08:00
|
|
|
void esp_hidh_preprocess_event_handler(void *event_handler_arg, esp_event_base_t event_base, int32_t event_id,
|
|
|
|
void *event_data);
|
2024-03-06 21:26:29 +01:00
|
|
|
void esp_hidh_postprocess_event_handler(void *event_handler_arg, esp_event_base_t event_base, int32_t event_id,
|
|
|
|
void *event_data);
|
2021-09-07 17:08:43 +08:00
|
|
|
void esp_hidh_dev_lock(esp_hidh_dev_t *dev);
|
|
|
|
void esp_hidh_dev_unlock(esp_hidh_dev_t *dev);
|
|
|
|
void esp_hidh_dev_wait(esp_hidh_dev_t *dev);
|
|
|
|
void esp_hidh_dev_send(esp_hidh_dev_t *dev);
|
2020-04-29 17:24:01 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|