xref: /linux/drivers/input/rmi4/rmi_driver.h (revision 5fcb6013dd2e2c9b4db3c5a512639371cc04d04e)
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3  * Copyright (c) 2011-2016 Synaptics Incorporated
4  * Copyright (c) 2011 Unixphere
5  */
6 
7 #ifndef _RMI_DRIVER_H
8 #define _RMI_DRIVER_H
9 
10 #include <linux/ctype.h>
11 #include <linux/hrtimer.h>
12 #include <linux/ktime.h>
13 #include <linux/input.h>
14 #include "rmi_bus.h"
15 
16 #define SYNAPTICS_INPUT_DEVICE_NAME "Synaptics RMI4 Touch Sensor"
17 #define SYNAPTICS_VENDOR_ID 0x06cb
18 
19 #define GROUP(_attrs) { \
20 	.attrs = _attrs,  \
21 }
22 
23 #define PDT_PROPERTIES_LOCATION 0x00EF
24 #define BSR_LOCATION 0x00FE
25 
26 #define RMI_PDT_PROPS_HAS_BSR 0x02
27 
28 #define NAME_BUFFER_SIZE 256
29 
30 #define RMI_PDT_ENTRY_SIZE 6
31 #define RMI_PDT_FUNCTION_VERSION_MASK   0x60
32 #define RMI_PDT_INT_SOURCE_COUNT_MASK   0x07
33 
34 #define PDT_START_SCAN_LOCATION 0x00e9
35 #define PDT_END_SCAN_LOCATION	0x0005
36 #define RMI4_END_OF_PDT(id) ((id) == 0x00 || (id) == 0xff)
37 
38 struct pdt_entry {
39 	u16 page_start;
40 	u8 query_base_addr;
41 	u8 command_base_addr;
42 	u8 control_base_addr;
43 	u8 data_base_addr;
44 	u8 interrupt_source_count;
45 	u8 function_version;
46 	u8 function_number;
47 };
48 
49 #define RMI_REG_DESC_PRESENCE_BITS	(32 * BITS_PER_BYTE)
50 #define RMI_REG_DESC_PRESENCE_REGS_MAX	(3 + RMI_REG_DESC_PRESENCE_BITS / 8)
51 #define RMI_REG_DESC_SUBPACKET_BITS	(37 * BITS_PER_BYTE)
52 
53 /* describes a single packet register */
54 struct rmi_register_desc_item {
55 	u32 reg_size;
56 	u16 reg;
57 	u16 num_subpackets;
58 	DECLARE_BITMAP(subpacket_map, RMI_REG_DESC_SUBPACKET_BITS);
59 };
60 
61 /*
62  * describes the packet registers for a particular type
63  * (ie query, control, data)
64  */
65 struct rmi_register_descriptor {
66 	unsigned long struct_size;
67 	u16 num_registers;
68 	struct rmi_register_desc_item *registers;
69 };
70 
71 int rmi_read_register_desc(struct rmi_device *d, u16 addr,
72 				struct rmi_register_descriptor *rdesc);
73 const struct rmi_register_desc_item *rmi_get_register_desc_item(
74 				struct rmi_register_descriptor *rdesc, u16 reg);
75 
76 /*
77  * Calculate the total size of all of the registers described in the
78  * descriptor.
79  */
80 size_t rmi_register_desc_calc_size(struct rmi_register_descriptor *rdesc);
81 int rmi_register_desc_calc_reg_offset(
82 			struct rmi_register_descriptor *rdesc, u16 reg);
83 bool rmi_register_desc_has_subpacket(const struct rmi_register_desc_item *item,
84 			u8 subpacket);
85 
86 bool rmi_is_physical_driver(const struct device_driver *);
87 int rmi_register_physical_driver(void);
88 void rmi_unregister_physical_driver(void);
89 void rmi_free_function_list(struct rmi_device *rmi_dev);
90 struct rmi_function *rmi_find_function(struct rmi_device *rmi_dev, u8 number);
91 int rmi_enable_sensor(struct rmi_device *rmi_dev);
92 int rmi_scan_pdt(struct rmi_device *rmi_dev, void *ctx,
93 		 int (*callback)(struct rmi_device *rmi_dev, void *ctx,
94 		 const struct pdt_entry *entry));
95 int rmi_probe_interrupts(struct rmi_driver_data *data);
96 void rmi_enable_irq(struct rmi_device *rmi_dev, bool clear_wake);
97 void rmi_disable_irq(struct rmi_device *rmi_dev, bool enable_wake);
98 int rmi_init_functions(struct rmi_driver_data *data);
99 int rmi_initial_reset(struct rmi_device *rmi_dev, void *ctx,
100 		      const struct pdt_entry *pdt);
101 
102 const char *rmi_f01_get_product_ID(struct rmi_function *fn);
103 
104 #ifdef CONFIG_RMI4_F03
105 int rmi_f03_overwrite_button(struct rmi_function *fn, unsigned int button,
106 			     int value);
107 void rmi_f03_commit_buttons(struct rmi_function *fn);
108 #else
109 static inline int rmi_f03_overwrite_button(struct rmi_function *fn,
110 					   unsigned int button, int value)
111 {
112 	return 0;
113 }
114 static inline void rmi_f03_commit_buttons(struct rmi_function *fn) {}
115 #endif
116 
117 #ifdef CONFIG_RMI4_F34
118 int rmi_f34_create_sysfs(struct rmi_device *rmi_dev);
119 void rmi_f34_remove_sysfs(struct rmi_device *rmi_dev);
120 #else
121 static inline int rmi_f34_create_sysfs(struct rmi_device *rmi_dev)
122 {
123 	return 0;
124 }
125 
126 static inline void rmi_f34_remove_sysfs(struct rmi_device *rmi_dev)
127 {
128 }
129 #endif /* CONFIG_RMI_F34 */
130 
131 extern struct rmi_function_handler rmi_f01_handler;
132 extern struct rmi_function_handler rmi_f03_handler;
133 extern struct rmi_function_handler rmi_f11_handler;
134 extern struct rmi_function_handler rmi_f12_handler;
135 extern struct rmi_function_handler rmi_f1a_handler;
136 extern struct rmi_function_handler rmi_f21_handler;
137 extern struct rmi_function_handler rmi_f30_handler;
138 extern struct rmi_function_handler rmi_f34_handler;
139 extern struct rmi_function_handler rmi_f3a_handler;
140 extern struct rmi_function_handler rmi_f54_handler;
141 extern struct rmi_function_handler rmi_f55_handler;
142 #endif
143