123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290 |
- /* SPDX-License-Identifier: GPL-2.0-only */
- /*
- * Copyright (c) 2011-2014, The Linux Foundation. All rights reserved.
- */
- #ifndef __USF_H__
- #define __USF_H__
- #include <linux/types.h>
- #include <linux/ioctl.h>
- #define USF_IOCTL_MAGIC 'U'
- #define US_SET_TX_INFO _IOW(USF_IOCTL_MAGIC, 0, \
- struct us_tx_info_type)
- #define US_START_TX _IO(USF_IOCTL_MAGIC, 1)
- #define US_GET_TX_UPDATE _IOWR(USF_IOCTL_MAGIC, 2, \
- struct us_tx_update_info_type)
- #define US_SET_RX_INFO _IOW(USF_IOCTL_MAGIC, 3, \
- struct us_rx_info_type)
- #define US_SET_RX_UPDATE _IOWR(USF_IOCTL_MAGIC, 4, \
- struct us_rx_update_info_type)
- #define US_START_RX _IO(USF_IOCTL_MAGIC, 5)
- #define US_STOP_TX _IO(USF_IOCTL_MAGIC, 6)
- #define US_STOP_RX _IO(USF_IOCTL_MAGIC, 7)
- #define US_SET_DETECTION _IOWR(USF_IOCTL_MAGIC, 8, \
- struct us_detect_info_type)
- #define US_GET_VERSION _IOWR(USF_IOCTL_MAGIC, 9, \
- struct us_version_info_type)
- #define US_SET_TX_STREAM_PARAM _IOW(USF_IOCTL_MAGIC, 10, \
- struct us_stream_param_type)
- #define US_GET_TX_STREAM_PARAM _IOWR(USF_IOCTL_MAGIC, 11, \
- struct us_stream_param_type)
- #define US_SET_RX_STREAM_PARAM _IOW(USF_IOCTL_MAGIC, 12, \
- struct us_stream_param_type)
- #define US_GET_RX_STREAM_PARAM _IOWR(USF_IOCTL_MAGIC, 13, \
- struct us_stream_param_type)
- /* Special timeout values */
- #define USF_NO_WAIT_TIMEOUT 0x00000000
- /* Infinitive */
- #define USF_INFINITIVE_TIMEOUT 0xffffffff
- /* Default value, used by the driver */
- #define USF_DEFAULT_TIMEOUT 0xfffffffe
- /* US detection place (HW|FW) */
- enum us_detect_place_enum {
- /* US is detected in HW */
- US_DETECT_HW,
- /* US is detected in FW */
- US_DETECT_FW
- };
- /* US detection mode */
- enum us_detect_mode_enum {
- /* US detection is disabled */
- US_DETECT_DISABLED_MODE,
- /* US detection is enabled in continue mode */
- US_DETECT_CONTINUE_MODE,
- /* US detection is enabled in one shot mode */
- US_DETECT_SHOT_MODE
- };
- /* Encoder (TX), decoder (RX) supported US data formats */
- #define USF_POINT_EPOS_FORMAT 0
- #define USF_RAW_FORMAT 1
- /* Indexes of event types, produced by the calculators */
- #define USF_TSC_EVENT_IND 0
- #define USF_TSC_PTR_EVENT_IND 1
- #define USF_MOUSE_EVENT_IND 2
- #define USF_KEYBOARD_EVENT_IND 3
- #define USF_TSC_EXT_EVENT_IND 4
- #define USF_MAX_EVENT_IND 5
- /* Types of events, produced by the calculators */
- #define USF_NO_EVENT 0
- #define USF_TSC_EVENT (1 << USF_TSC_EVENT_IND)
- #define USF_TSC_PTR_EVENT (1 << USF_TSC_PTR_EVENT_IND)
- #define USF_MOUSE_EVENT (1 << USF_MOUSE_EVENT_IND)
- #define USF_KEYBOARD_EVENT (1 << USF_KEYBOARD_EVENT_IND)
- #define USF_TSC_EXT_EVENT (1 << USF_TSC_EXT_EVENT_IND)
- #define USF_ALL_EVENTS (USF_TSC_EVENT |\
- USF_TSC_PTR_EVENT |\
- USF_MOUSE_EVENT |\
- USF_KEYBOARD_EVENT |\
- USF_TSC_EXT_EVENT)
- /* min, max array dimension */
- #define MIN_MAX_DIM 2
- /* coordinates (x,y,z) array dimension */
- #define COORDINATES_DIM 3
- /* tilts (x,y) array dimension */
- #define TILTS_DIM 2
- /* Max size of the client name */
- #define USF_MAX_CLIENT_NAME_SIZE 20
- /* Max number of the ports (mics/speakers) */
- #define USF_MAX_PORT_NUM 8
- /* Info structure common for TX and RX */
- struct us_xx_info_type {
- /* Input: general info */
- /* Name of the client - event calculator */
- const char __user *client_name;
- /* Selected device identification, accepted in the kernel's CAD */
- uint32_t dev_id;
- /* 0 - point_epos type; (e.g. 1 - gr_mmrd) */
- uint32_t stream_format;
- /* Required sample rate in Hz */
- uint32_t sample_rate;
- /* Size of a buffer (bytes) for US data transfer between the module and USF */
- uint32_t buf_size;
- /* Number of the buffers for the US data transfer */
- uint16_t buf_num;
- /* Number of the microphones (TX) or speakers(RX) */
- uint16_t port_cnt;
- /* Microphones(TX) or speakers(RX) indexes in their enumeration */
- uint8_t port_id[USF_MAX_PORT_NUM];
- /* Bits per sample 16 or 32 */
- uint16_t bits_per_sample;
- /* Input: Transparent info for encoder in the LPASS */
- /* Parameters data size in bytes */
- uint16_t params_data_size;
- /* Pointer to the parameters */
- uint8_t __user *params_data;
- /* Max size of buffer for get and set parameter */
- uint32_t max_get_set_param_buf_size;
- };
- struct us_input_info_type {
- /* Touch screen dimensions: min & max;for input module */
- int tsc_x_dim[MIN_MAX_DIM];
- int tsc_y_dim[MIN_MAX_DIM];
- int tsc_z_dim[MIN_MAX_DIM];
- /* Touch screen tilt dimensions: min & max;for input module */
- int tsc_x_tilt[MIN_MAX_DIM];
- int tsc_y_tilt[MIN_MAX_DIM];
- /* Touch screen pressure limits: min & max; for input module */
- int tsc_pressure[MIN_MAX_DIM];
- /* The requested buttons bitmap */
- uint16_t req_buttons_bitmap;
- /* Bitmap of types of events (USF_X_EVENT), produced by calculator */
- uint16_t event_types;
- /* Bitmap of types of events from devs, conflicting with USF */
- uint16_t conflicting_event_types;
- };
- struct us_tx_info_type {
- /* Common info */
- struct us_xx_info_type us_xx_info;
- /* Info specific for TX*/
- struct us_input_info_type input_info;
- };
- struct us_rx_info_type {
- /* Common info */
- struct us_xx_info_type us_xx_info;
- /* Info specific for RX*/
- };
- struct point_event_type {
- /* Pen coordinates (x, y, z) in units, defined by <coordinates_type> */
- int coordinates[COORDINATES_DIM];
- /* {x;y} in transparent units */
- int inclinations[TILTS_DIM];
- /* [0-1023] (10bits); 0 - pen up */
- uint32_t pressure;
- /* Bitmap for button state. 1 - down, 0 - up */
- uint16_t buttons_state_bitmap;
- };
- /* Mouse buttons, supported by USF */
- #define USF_BUTTON_LEFT_MASK 1
- #define USF_BUTTON_MIDDLE_MASK 2
- #define USF_BUTTON_RIGHT_MASK 4
- struct mouse_event_type {
- /* The mouse relative movement (dX, dY, dZ) */
- int rels[COORDINATES_DIM];
- /* Bitmap of mouse buttons states: 1 - down, 0 - up; */
- uint16_t buttons_states;
- };
- struct key_event_type {
- /* Calculated MS key- see input.h. */
- uint32_t key;
- /* Keyboard's key state: 1 - down, 0 - up; */
- uint8_t key_state;
- };
- struct usf_event_type {
- /* Event sequence number */
- uint32_t seq_num;
- /* Event generation system time */
- uint32_t timestamp;
- /* Destination input event type index (e.g. touch screen, mouse, key) */
- uint16_t event_type_ind;
- union {
- struct point_event_type point_event;
- struct mouse_event_type mouse_event;
- struct key_event_type key_event;
- } event_data;
- };
- struct us_tx_update_info_type {
- /* Input general: */
- /* Number of calculated events */
- uint16_t event_counter;
- /* Calculated events or NULL */
- struct usf_event_type __user *event;
- /* Pointer (read index) to the end of available region */
- /* in the shared US data memory */
- uint32_t free_region;
- /* Time (sec) to wait for data or special values: */
- /* USF_NO_WAIT_TIMEOUT, USF_INFINITIVE_TIMEOUT, USF_DEFAULT_TIMEOUT */
- uint32_t timeout;
- /* Events (from conflicting devs) to be disabled/enabled */
- uint16_t event_filters;
- /* Input transparent data: */
- /* Parameters size */
- uint16_t params_data_size;
- /* Pointer to the parameters */
- uint8_t __user *params_data;
- /* Output parameters: */
- /* Pointer (write index) to the end of ready US data region */
- /* in the shared memory */
- uint32_t ready_region;
- };
- struct us_rx_update_info_type {
- /* Input general: */
- /* Pointer (write index) to the end of ready US data region */
- /* in the shared memory */
- uint32_t ready_region;
- /* Input transparent data: */
- /* Parameters size */
- uint16_t params_data_size;
- /* pPointer to the parameters */
- uint8_t __user *params_data;
- /* Output parameters: */
- /* Pointer (read index) to the end of available region */
- /* in the shared US data memory */
- uint32_t free_region;
- };
- struct us_detect_info_type {
- /* US detection place (HW|FW) */
- /* NA in the Active and OFF states */
- enum us_detect_place_enum us_detector;
- /* US detection mode */
- enum us_detect_mode_enum us_detect_mode;
- /* US data dropped during this time (msec) */
- uint32_t skip_time;
- /* Transparent data size */
- uint16_t params_data_size;
- /* Pointer to the transparent data */
- uint8_t __user *params_data;
- /* Time (sec) to wait for US presence event */
- uint32_t detect_timeout;
- /* Out parameter: US presence */
- bool is_us;
- };
- struct us_version_info_type {
- /* Size of memory for the version string */
- uint16_t buf_size;
- /* Pointer to the memory for the version string */
- char __user *pbuf;
- };
- struct us_stream_param_type {
- /* Id of module */
- uint32_t module_id;
- /* Id of parameter */
- uint32_t param_id;
- /* Size of memory of the parameter buffer */
- uint32_t buf_size;
- /* Pointer to the memory of the parameter buffer */
- uint8_t __user *pbuf;
- };
- #endif /* __USF_H__ */
|