/* SPDX-License-Identifier: GPL-2.0 */ /* Copyright 2024 Intel Corporation */ #ifndef _HID_OVER_SPI_H_ #define _HID_OVER_SPI_H_ #include #include /* Input report type definition in HIDSPI protocol */ enum input_report_type { INVALID_INPUT_REPORT_TYPE_0 = 0, DATA = 1, INVALID_TYPE_2 = 2, RESET_RESPONSE = 3, COMMAND_RESPONSE = 4, GET_FEATURE_RESPONSE = 5, INVALID_TYPE_6 = 6, DEVICE_DESCRIPTOR_RESPONSE = 7, REPORT_DESCRIPTOR_RESPONSE = 8, SET_FEATURE_RESPONSE = 9, OUTPUT_REPORT_RESPONSE = 10, GET_INPUT_REPORT_RESPONSE = 11, INVALID_INPUT_REPORT_TYPE = 0xF, }; /* Output report type definition in HIDSPI protocol */ enum output_report_type { INVALID_OUTPUT_REPORT_TYPE_0 = 0, DEVICE_DESCRIPTOR = 1, REPORT_DESCRIPTOR = 2, SET_FEATURE = 3, GET_FEATURE = 4, OUTPUT_REPORT = 5, GET_INPUT_REPORT = 6, COMMAND_CONTENT = 7, }; /* Set power command ID for output report */ #define HIDSPI_SET_POWER_CMD_ID 1 /* Power state definition in HIDSPI protocol */ enum hidspi_power_state { HIDSPI_ON = 1, HIDSPI_SLEEP = 2, HIDSPI_OFF = 3, }; /** * Input report header definition in HIDSPI protocol * Report header size is 32bits, it includes: * protocol_ver: [0:3] Current supported HIDSPI protocol version, must be 0x3 * reserved0: [4:7] Reserved bits * input_report_len: [8:21] Input report length in number bytes divided by 4 * last_frag_flag: [22]Indicate if this packet is last fragment. * 1 - indicates last fragment * 0 - indicates additional fragments * reserved1: [23] Reserved bits * @sync_const: [24:31] Used to validate input report header, must be 0x5A */ #define HIDSPI_INPUT_HEADER_SIZE sizeof(u32) #define HIDSPI_INPUT_HEADER_VER GENMASK(3, 0) #define HIDSPI_INPUT_HEADER_REPORT_LEN GENMASK(21, 8) #define HIDSPI_INPUT_HEADER_LAST_FLAG BIT(22) #define HIDSPI_INPUT_HEADER_SYNC GENMASK(31, 24) /** * struct input_report_body_header - Input report body header definition in HIDSPI protocol * @input_report_type: indicate input report type, reference to enum input_report_type * @content_len: this input report body packet length * @content_id: indicate this input report's report id */ struct input_report_body_header { u8 input_report_type; __le16 content_len; u8 content_id; } __packed; #define HIDSPI_INPUT_BODY_HEADER_SIZE sizeof(struct input_report_body_header) /** * struct input_report_body - Input report body definition in HIDSPI protocol * @body_hdr: input report body header * @content: input report body content */ struct input_report_body { struct input_report_body_header body_hdr; u8 content[]; } __packed; #define HIDSPI_INPUT_BODY_SIZE(content_len) ((content_len) + HIDSPI_INPUT_BODY_HEADER_SIZE) /** * struct output_report_header - Output report header definition in HIDSPI protocol * @report_type: output report type, reference to enum output_report_type * @content_len: length of content * @content_id: 0x00 - descriptors * report id - Set/Feature feature or Input/Output Reports * command opcode - for commands */ struct output_report_header { u8 report_type; __le16 content_len; u8 content_id; } __packed; #define HIDSPI_OUTPUT_REPORT_HEADER_SIZE sizeof(struct output_report_header) /** * struct output_report - Output report definition in HIDSPI protocol * @output_hdr: output report header * @content: output report content */ struct output_report { struct output_report_header output_hdr; u8 content[]; } __packed; #define HIDSPI_OUTPUT_REPORT_SIZE(content_len) ((content_len) + HIDSPI_OUTPUT_REPORT_HEADER_SIZE) /** * struct hidspi_dev_descriptor - HIDSPI device descriptor definition * @dev_desc_len: The length of the complete device descriptor, fixed to 0x18 (24). * @bcd_ver: The version number of the HIDSPI protocol supported. * In binary coded decimal (BCD) format. Must be fixed to 0x0300. * @rep_desc_len: The length of the report descriptor * @max_input_len: The length of the largest possible HID input (or feature) report * @max_output_len: The length of the largest output (or feature) report * @max_frag_len: The length of the largest fragment, where a fragment represents * the body of an input report. * @vendor_id: Device manufacturers vendor ID * @product_id: Device unique model/product ID * @version_id: Device’s unique version * @flags: Specify flags for the device’s operation * @reserved: Reserved and should be 0 */ struct hidspi_dev_descriptor { __le16 dev_desc_len; __le16 bcd_ver; __le16 rep_desc_len; __le16 max_input_len; __le16 max_output_len; __le16 max_frag_len; __le16 vendor_id; __le16 product_id; __le16 version_id; __le16 flags; __le32 reserved; }; #define HIDSPI_DEVICE_DESCRIPTOR_SIZE sizeof(struct hidspi_dev_descriptor) #define HIDSPI_INPUT_DEVICE_DESCRIPTOR_SIZE \ (HIDSPI_INPUT_BODY_HEADER_SIZE + HIDSPI_DEVICE_DESCRIPTOR_SIZE) #endif /* _HID_OVER_SPI_H_ */