146 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			146 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
| /*
 | |
|  * Copyright (c) 2006-2023, RT-Thread Development Team
 | |
|  *
 | |
|  * SPDX-License-Identifier: Apache-2.0
 | |
|  *
 | |
|  * Change Logs:
 | |
|  * Date           Author       Notes
 | |
|  * 2021-11-11     GuEe-GUI     the first version
 | |
|  */
 | |
| 
 | |
| #ifndef __VIRTIO_INPUT_H__
 | |
| #define __VIRTIO_INPUT_H__
 | |
| 
 | |
| #include <rtdef.h>
 | |
| 
 | |
| #include <virtio.h>
 | |
| #include <virtio_input_event_codes.h>
 | |
| 
 | |
| #define VIRTIO_INPUT_QUEUE_EVENT        0
 | |
| #define VIRTIO_INPUT_QUEUE_STATUS       1
 | |
| #define VIRTIO_INPUT_EVENT_QUEUE_SIZE   64
 | |
| #define VIRTIO_INPUT_STATUS_QUEUE_SIZE  8
 | |
| #define VIRTIO_INPUT_QUEUE_MAX_SIZE     (VIRTIO_INPUT_EVENT_QUEUE_SIZE > VIRTIO_INPUT_STATUS_QUEUE_SIZE ? \
 | |
|         VIRTIO_INPUT_EVENT_QUEUE_SIZE : VIRTIO_INPUT_STATUS_QUEUE_SIZE)
 | |
| 
 | |
| #define VIRTIO_INPUT_ABS_AXIS_X         0
 | |
| #define VIRTIO_INPUT_ABS_AXIS_Y         1
 | |
| 
 | |
| enum virtio_input_type
 | |
| {
 | |
|     VIRTIO_INPUT_TYPE_KEYBOARD,
 | |
|     VIRTIO_INPUT_TYPE_MOUSE,
 | |
|     VIRTIO_INPUT_TYPE_TABLET,
 | |
| 
 | |
|     VIRTIO_INPUT_TYPE_SIZE,
 | |
| };
 | |
| 
 | |
| enum virtio_input_config_select
 | |
| {
 | |
|     VIRTIO_INPUT_CFG_UNSET      = 0x00,
 | |
|     VIRTIO_INPUT_CFG_ID_NAME    = 0x01,
 | |
|     VIRTIO_INPUT_CFG_ID_SERIAL  = 0x02,
 | |
|     VIRTIO_INPUT_CFG_ID_DEVIDS  = 0x03,
 | |
|     VIRTIO_INPUT_CFG_PROP_BITS  = 0x10,
 | |
|     VIRTIO_INPUT_CFG_EV_BITS    = 0x11,
 | |
|     VIRTIO_INPUT_CFG_ABS_INFO   = 0x12,
 | |
| };
 | |
| 
 | |
| struct virtio_input_absinfo
 | |
| {
 | |
|     rt_uint32_t min;    /* Minimum value for the axis */
 | |
|     rt_uint32_t max;    /* Maximum value for the axis */
 | |
|     rt_uint32_t fuzz;   /* Fuzz value that is used to filter noise from the event stream */
 | |
|     rt_uint32_t flat;   /* Within this value will be discarded by joydev interface and reported as 0 instead */
 | |
|     rt_uint32_t res;    /* Resolution for the values reported for the axis */
 | |
| };
 | |
| 
 | |
| struct virtio_input_devids
 | |
| {
 | |
|     rt_uint16_t bustype;
 | |
|     rt_uint16_t vendor;
 | |
|     rt_uint16_t product;
 | |
|     rt_uint16_t version;
 | |
| };
 | |
| 
 | |
| struct virtio_input_config
 | |
| {
 | |
|     rt_uint8_t select;
 | |
|     rt_uint8_t subsel;
 | |
|     rt_uint8_t size;
 | |
|     rt_uint8_t reserved[5];
 | |
| 
 | |
|     union
 | |
|     {
 | |
|         char string[128];
 | |
|         rt_uint8_t bitmap[128];
 | |
|         struct virtio_input_absinfo abs;
 | |
|         struct virtio_input_devids ids;
 | |
|     };
 | |
| } __attribute__((packed));
 | |
| 
 | |
| struct virtio_input_event
 | |
| {
 | |
|     rt_uint16_t type;
 | |
|     rt_uint16_t code;
 | |
|     rt_uint32_t value;
 | |
| };
 | |
| 
 | |
| #ifdef ARCH_CPU_64BIT
 | |
| #define BITS_PER_LONG 64
 | |
| #else
 | |
| #define BITS_PER_LONG 32
 | |
| #endif
 | |
| #define BIT_MASK(nr)        (1UL << ((nr) % BITS_PER_LONG))
 | |
| #define BIT_WORD(nr)        ((nr) / BITS_PER_LONG)
 | |
| #define DIV_ROUND_UP(n, d)  (((n) + (d) - 1) / (d))
 | |
| 
 | |
| #define BITS_PER_BYTE       8
 | |
| #define BITS_PER_TYPE(type) (sizeof(type) * BITS_PER_BYTE)
 | |
| #define BITS_TO_BYTES(nr)   DIV_ROUND_UP(nr, BITS_PER_TYPE(char))
 | |
| #define BITS_TO_LONGS(nr)   DIV_ROUND_UP(nr, BITS_PER_TYPE(long))
 | |
| 
 | |
| struct virtio_input_device
 | |
| {
 | |
|     struct rt_device parent;
 | |
| 
 | |
|     struct virtio_device virtio_dev;
 | |
| 
 | |
|     rt_ubase_t ev_bit[BITS_TO_LONGS(EV_CNT)];
 | |
|     rt_ubase_t key_bit[BITS_TO_LONGS(KEY_CNT)];
 | |
|     rt_ubase_t rel_bit[BITS_TO_LONGS(REL_CNT)];
 | |
|     rt_ubase_t abs_bit[BITS_TO_LONGS(ABS_CNT)];
 | |
| 
 | |
|     enum virtio_input_type type;
 | |
|     struct virtio_input_config *config;
 | |
| 
 | |
|     /* Broadcast events */
 | |
|     struct rt_mutex rw_mutex;
 | |
|     void (*bsct_handler)(struct virtio_input_event event);
 | |
|     struct virtio_input_event bcst_events[VIRTIO_INPUT_EVENT_QUEUE_SIZE];
 | |
| 
 | |
|     /* Receive events */
 | |
|     struct virtio_input_event recv_events[VIRTIO_INPUT_EVENT_QUEUE_SIZE];
 | |
| 
 | |
|     /* Transmit status */
 | |
|     struct virtio_input_event xmit_events[VIRTIO_INPUT_STATUS_QUEUE_SIZE];
 | |
| };
 | |
| 
 | |
| enum
 | |
| {
 | |
|     VIRTIO_DEVICE_CTRL_INPUT_GET_TYPE           = 0x20,
 | |
|     VIRTIO_DEVICE_CTRL_INPUT_BIND_BSCT_HANDLER,
 | |
|     VIRTIO_DEVICE_CTRL_INPUT_GET_ABS_X_INFO,
 | |
|     VIRTIO_DEVICE_CTRL_INPUT_GET_ABS_Y_INFO,
 | |
|     VIRTIO_DEVICE_CTRL_INPUT_SET_STATUS,
 | |
| 
 | |
|     VIRTIO_DEVICE_CTRL_INPUT_GET_EV_BIT,
 | |
|     VIRTIO_DEVICE_CTRL_INPUT_GET_KEY_BIT,
 | |
|     VIRTIO_DEVICE_CTRL_INPUT_GET_REL_BIT,
 | |
|     VIRTIO_DEVICE_CTRL_INPUT_GET_ABS_BIT,
 | |
| };
 | |
| 
 | |
| rt_err_t rt_virtio_input_init(rt_ubase_t *mmio_base, rt_uint32_t irq);
 | |
| 
 | |
| #endif /* __VIRTIO_INPUT_H__ */
 |