xref: /kernel/linux/linux-6.6/drivers/hid/wacom_wac.h (revision 62306a36)
1/* SPDX-License-Identifier: GPL-2.0-or-later */
2
3#ifndef WACOM_WAC_H
4#define WACOM_WAC_H
5
6#include <linux/types.h>
7#include <linux/hid.h>
8#include <linux/kfifo.h>
9
10/* maximum packet length for USB/BT devices */
11#define WACOM_PKGLEN_MAX	361
12
13#define WACOM_NAME_MAX		64
14#define WACOM_MAX_REMOTES	5
15#define WACOM_STATUS_UNKNOWN	255
16#define WACOM_REMOTE_BATTERY_TIMEOUT	21000000000ll
17
18/* packet length for individual models */
19#define WACOM_PKGLEN_BBFUN	 9
20#define WACOM_PKGLEN_TPC1FG	 5
21#define WACOM_PKGLEN_TPC1FG_B	10
22#define WACOM_PKGLEN_TPC2FG	14
23#define WACOM_PKGLEN_BBTOUCH	20
24#define WACOM_PKGLEN_BBTOUCH3	64
25#define WACOM_PKGLEN_BBPEN	10
26#define WACOM_PKGLEN_WIRELESS	32
27#define WACOM_PKGLEN_PENABLED	 8
28#define WACOM_PKGLEN_BPAD_TOUCH	32
29#define WACOM_PKGLEN_BPAD_TOUCH_USB	64
30
31/* wacom data size per MT contact */
32#define WACOM_BYTES_PER_MT_PACKET	11
33#define WACOM_BYTES_PER_24HDT_PACKET	14
34#define WACOM_BYTES_PER_QHDTHID_PACKET	 6
35
36/* device IDs */
37#define STYLUS_DEVICE_ID	0x02
38#define TOUCH_DEVICE_ID		0x03
39#define CURSOR_DEVICE_ID	0x06
40#define ERASER_DEVICE_ID	0x0A
41#define PAD_DEVICE_ID		0x0F
42
43/* wacom data packet report IDs */
44#define WACOM_REPORT_PENABLED		2
45#define WACOM_REPORT_PENABLED_BT	3
46#define WACOM_REPORT_INTUOS_ID1		5
47#define WACOM_REPORT_INTUOS_ID2		6
48#define WACOM_REPORT_INTUOSPAD		12
49#define WACOM_REPORT_INTUOS5PAD		3
50#define WACOM_REPORT_DTUSPAD		21
51#define WACOM_REPORT_TPC1FG		6
52#define WACOM_REPORT_TPC2FG		13
53#define WACOM_REPORT_TPCMT		13
54#define WACOM_REPORT_TPCMT2		3
55#define WACOM_REPORT_TPCHID		15
56#define WACOM_REPORT_CINTIQ		16
57#define WACOM_REPORT_CINTIQPAD		17
58#define WACOM_REPORT_TPCST		16
59#define WACOM_REPORT_DTUS		17
60#define WACOM_REPORT_TPC1FGE		18
61#define WACOM_REPORT_24HDT		1
62#define WACOM_REPORT_WL			128
63#define WACOM_REPORT_USB		192
64#define WACOM_REPORT_BPAD_PEN		3
65#define WACOM_REPORT_BPAD_TOUCH		16
66#define WACOM_REPORT_DEVICE_LIST	16
67#define WACOM_REPORT_INTUOS_PEN		16
68#define WACOM_REPORT_REMOTE		17
69#define WACOM_REPORT_INTUOSHT2_ID	8
70
71/* wacom command report ids */
72#define WAC_CMD_WL_LED_CONTROL          0x03
73#define WAC_CMD_LED_CONTROL             0x20
74#define WAC_CMD_ICON_START              0x21
75#define WAC_CMD_ICON_XFER               0x23
76#define WAC_CMD_ICON_BT_XFER            0x26
77#define WAC_CMD_DELETE_PAIRING          0x20
78#define WAC_CMD_LED_CONTROL_GENERIC     0x32
79#define WAC_CMD_UNPAIR_ALL              0xFF
80#define WAC_CMD_WL_INTUOSP2             0x82
81
82/* device quirks */
83#define WACOM_QUIRK_BBTOUCH_LOWRES	0x0001
84#define WACOM_QUIRK_SENSE		0x0002
85#define WACOM_QUIRK_AESPEN		0x0004
86#define WACOM_QUIRK_BATTERY		0x0008
87#define WACOM_QUIRK_TOOLSERIAL		0x0010
88#define WACOM_QUIRK_PEN_BUTTON3	0x0020
89
90/* device types */
91#define WACOM_DEVICETYPE_NONE           0x0000
92#define WACOM_DEVICETYPE_PEN            0x0001
93#define WACOM_DEVICETYPE_TOUCH          0x0002
94#define WACOM_DEVICETYPE_PAD            0x0004
95#define WACOM_DEVICETYPE_WL_MONITOR     0x0008
96#define WACOM_DEVICETYPE_DIRECT         0x0010
97
98#define WACOM_POWER_SUPPLY_STATUS_AUTO  -1
99
100#define WACOM_HID_UP_WACOMDIGITIZER     0xff0d0000
101#define WACOM_HID_SP_PAD                0x00040000
102#define WACOM_HID_SP_BUTTON             0x00090000
103#define WACOM_HID_SP_DIGITIZER          0x000d0000
104#define WACOM_HID_SP_DIGITIZERINFO      0x00100000
105#define WACOM_HID_WD_DIGITIZER          (WACOM_HID_UP_WACOMDIGITIZER | 0x01)
106#define WACOM_HID_WD_PEN                (WACOM_HID_UP_WACOMDIGITIZER | 0x02)
107#define WACOM_HID_WD_SENSE              (WACOM_HID_UP_WACOMDIGITIZER | 0x36)
108#define WACOM_HID_WD_DIGITIZERFNKEYS    (WACOM_HID_UP_WACOMDIGITIZER | 0x39)
109#define WACOM_HID_WD_SERIALNUMBER       (WACOM_HID_UP_WACOMDIGITIZER | 0x5b)
110#define WACOM_HID_WD_SERIALHI           (WACOM_HID_UP_WACOMDIGITIZER | 0x5c)
111#define WACOM_HID_WD_BARRELSWITCH3      (WACOM_HID_UP_WACOMDIGITIZER | 0x5d)
112#define WACOM_HID_WD_TOOLTYPE           (WACOM_HID_UP_WACOMDIGITIZER | 0x77)
113#define WACOM_HID_WD_DISTANCE           (WACOM_HID_UP_WACOMDIGITIZER | 0x0132)
114#define WACOM_HID_WD_TOUCHSTRIP         (WACOM_HID_UP_WACOMDIGITIZER | 0x0136)
115#define WACOM_HID_WD_TOUCHSTRIP2        (WACOM_HID_UP_WACOMDIGITIZER | 0x0137)
116#define WACOM_HID_WD_TOUCHRING          (WACOM_HID_UP_WACOMDIGITIZER | 0x0138)
117#define WACOM_HID_WD_TOUCHRINGSTATUS    (WACOM_HID_UP_WACOMDIGITIZER | 0x0139)
118#define WACOM_HID_WD_REPORT_VALID       (WACOM_HID_UP_WACOMDIGITIZER | 0x01d0)
119#define WACOM_HID_WD_SEQUENCENUMBER     (WACOM_HID_UP_WACOMDIGITIZER | 0x0220)
120#define WACOM_HID_WD_ACCELEROMETER_X    (WACOM_HID_UP_WACOMDIGITIZER | 0x0401)
121#define WACOM_HID_WD_ACCELEROMETER_Y    (WACOM_HID_UP_WACOMDIGITIZER | 0x0402)
122#define WACOM_HID_WD_ACCELEROMETER_Z    (WACOM_HID_UP_WACOMDIGITIZER | 0x0403)
123#define WACOM_HID_WD_BATTERY_CHARGING   (WACOM_HID_UP_WACOMDIGITIZER | 0x0404)
124#define WACOM_HID_WD_TOUCHONOFF         (WACOM_HID_UP_WACOMDIGITIZER | 0x0454)
125#define WACOM_HID_WD_BATTERY_LEVEL      (WACOM_HID_UP_WACOMDIGITIZER | 0x043b)
126#define WACOM_HID_WD_EXPRESSKEY00       (WACOM_HID_UP_WACOMDIGITIZER | 0x0910)
127#define WACOM_HID_WD_EXPRESSKEYCAP00    (WACOM_HID_UP_WACOMDIGITIZER | 0x0940)
128#define WACOM_HID_WD_MODE_CHANGE        (WACOM_HID_UP_WACOMDIGITIZER | 0x0980)
129#define WACOM_HID_WD_MUTE_DEVICE        (WACOM_HID_UP_WACOMDIGITIZER | 0x0981)
130#define WACOM_HID_WD_CONTROLPANEL       (WACOM_HID_UP_WACOMDIGITIZER | 0x0982)
131#define WACOM_HID_WD_ONSCREEN_KEYBOARD  (WACOM_HID_UP_WACOMDIGITIZER | 0x0983)
132#define WACOM_HID_WD_BUTTONCONFIG       (WACOM_HID_UP_WACOMDIGITIZER | 0x0986)
133#define WACOM_HID_WD_BUTTONHOME         (WACOM_HID_UP_WACOMDIGITIZER | 0x0990)
134#define WACOM_HID_WD_BUTTONUP           (WACOM_HID_UP_WACOMDIGITIZER | 0x0991)
135#define WACOM_HID_WD_BUTTONDOWN         (WACOM_HID_UP_WACOMDIGITIZER | 0x0992)
136#define WACOM_HID_WD_BUTTONLEFT         (WACOM_HID_UP_WACOMDIGITIZER | 0x0993)
137#define WACOM_HID_WD_BUTTONRIGHT        (WACOM_HID_UP_WACOMDIGITIZER | 0x0994)
138#define WACOM_HID_WD_BUTTONCENTER       (WACOM_HID_UP_WACOMDIGITIZER | 0x0995)
139#define WACOM_HID_WD_FINGERWHEEL        (WACOM_HID_UP_WACOMDIGITIZER | 0x0d03)
140#define WACOM_HID_WD_OFFSETLEFT         (WACOM_HID_UP_WACOMDIGITIZER | 0x0d30)
141#define WACOM_HID_WD_OFFSETTOP          (WACOM_HID_UP_WACOMDIGITIZER | 0x0d31)
142#define WACOM_HID_WD_OFFSETRIGHT        (WACOM_HID_UP_WACOMDIGITIZER | 0x0d32)
143#define WACOM_HID_WD_OFFSETBOTTOM       (WACOM_HID_UP_WACOMDIGITIZER | 0x0d33)
144#define WACOM_HID_WD_DATAMODE           (WACOM_HID_UP_WACOMDIGITIZER | 0x1002)
145#define WACOM_HID_WD_DIGITIZERINFO      (WACOM_HID_UP_WACOMDIGITIZER | 0x1013)
146#define WACOM_HID_WD_TOUCH_RING_SETTING (WACOM_HID_UP_WACOMDIGITIZER | 0x1032)
147#define WACOM_HID_UP_G9                 0xff090000
148#define WACOM_HID_G9_PEN                (WACOM_HID_UP_G9 | 0x02)
149#define WACOM_HID_G9_TOUCHSCREEN        (WACOM_HID_UP_G9 | 0x11)
150#define WACOM_HID_UP_G11                0xff110000
151#define WACOM_HID_G11_PEN               (WACOM_HID_UP_G11 | 0x02)
152#define WACOM_HID_G11_TOUCHSCREEN       (WACOM_HID_UP_G11 | 0x11)
153#define WACOM_HID_UP_WACOMTOUCH         0xff000000
154#define WACOM_HID_WT_TOUCHSCREEN        (WACOM_HID_UP_WACOMTOUCH | 0x04)
155#define WACOM_HID_WT_TOUCHPAD           (WACOM_HID_UP_WACOMTOUCH | 0x05)
156#define WACOM_HID_WT_CONTACTMAX         (WACOM_HID_UP_WACOMTOUCH | 0x55)
157#define WACOM_HID_WT_SERIALNUMBER       (WACOM_HID_UP_WACOMTOUCH | 0x5b)
158#define WACOM_HID_WT_X                  (WACOM_HID_UP_WACOMTOUCH | 0x130)
159#define WACOM_HID_WT_Y                  (WACOM_HID_UP_WACOMTOUCH | 0x131)
160#define WACOM_HID_WT_REPORT_VALID       (WACOM_HID_UP_WACOMTOUCH | 0x1d0)
161
162#define WACOM_BATTERY_USAGE(f)	(((f)->hid == HID_DG_BATTERYSTRENGTH) || \
163				 ((f)->hid == WACOM_HID_WD_BATTERY_CHARGING) || \
164				 ((f)->hid == WACOM_HID_WD_BATTERY_LEVEL))
165
166#define WACOM_PAD_FIELD(f)	(((f)->physical == HID_DG_TABLETFUNCTIONKEY) || \
167				 ((f)->physical == WACOM_HID_WD_DIGITIZERFNKEYS) || \
168				 ((f)->physical == WACOM_HID_WD_DIGITIZERINFO))
169
170#define WACOM_PEN_FIELD(f)	(((f)->logical == HID_DG_STYLUS) || \
171				 ((f)->physical == HID_DG_STYLUS) || \
172				 ((f)->physical == HID_DG_PEN) || \
173				 ((f)->application == HID_DG_PEN) || \
174				 ((f)->application == HID_DG_DIGITIZER) || \
175				 ((f)->application == WACOM_HID_WD_PEN) || \
176				 ((f)->application == WACOM_HID_WD_DIGITIZER) || \
177				 ((f)->application == WACOM_HID_G9_PEN) || \
178				 ((f)->application == WACOM_HID_G11_PEN))
179#define WACOM_FINGER_FIELD(f)	(((f)->logical == HID_DG_FINGER) || \
180				 ((f)->physical == HID_DG_FINGER) || \
181				 ((f)->application == HID_DG_TOUCHSCREEN) || \
182				 ((f)->application == WACOM_HID_G9_TOUCHSCREEN) || \
183				 ((f)->application == WACOM_HID_G11_TOUCHSCREEN) || \
184				 ((f)->application == WACOM_HID_WT_TOUCHPAD) || \
185				 ((f)->application == HID_DG_TOUCHPAD))
186
187#define WACOM_DIRECT_DEVICE(f)	(((f)->application == HID_DG_TOUCHSCREEN) || \
188				 ((f)->application == WACOM_HID_WT_TOUCHSCREEN) || \
189				 ((f)->application == HID_DG_PEN) || \
190				 ((f)->application == WACOM_HID_WD_PEN))
191
192enum {
193	PENPARTNER = 0,
194	GRAPHIRE,
195	GRAPHIRE_BT,
196	WACOM_G4,
197	PTU,
198	PL,
199	DTU,
200	DTUS,
201	DTUSX,
202	INTUOS,
203	INTUOS3S,
204	INTUOS3,
205	INTUOS3L,
206	INTUOS4S,
207	INTUOS4,
208	INTUOS4WL,
209	INTUOS4L,
210	INTUOS5S,
211	INTUOS5,
212	INTUOS5L,
213	INTUOSPS,
214	INTUOSPM,
215	INTUOSPL,
216	INTUOSP2_BT,
217	INTUOSP2S_BT,
218	INTUOSHT3_BT,
219	WACOM_21UX2,
220	WACOM_22HD,
221	DTK,
222	WACOM_24HD,
223	WACOM_27QHD,
224	CINTIQ_HYBRID,
225	CINTIQ_COMPANION_2,
226	CINTIQ,
227	WACOM_BEE,
228	WACOM_13HD,
229	WACOM_MO,
230	BAMBOO_PEN,
231	INTUOSHT,
232	INTUOSHT2,
233	BAMBOO_TOUCH,
234	BAMBOO_PT,
235	WACOM_24HDT,
236	WACOM_27QHDT,
237	BAMBOO_PAD,
238	WIRELESS,
239	REMOTE,
240	TABLETPC,   /* add new TPC below */
241	TABLETPCE,
242	TABLETPC2FG,
243	MTSCREEN,
244	MTTPC,
245	MTTPC_B,
246	HID_GENERIC,
247	BOOTLOADER,
248	MAX_TYPE
249};
250
251struct wacom_features {
252	const char *name;
253	int x_max;
254	int y_max;
255	int pressure_max;
256	int distance_max;
257	int type;
258	int x_resolution;
259	int y_resolution;
260	int numbered_buttons;
261	int offset_left;
262	int offset_right;
263	int offset_top;
264	int offset_bottom;
265	int device_type;
266	int x_phy;
267	int y_phy;
268	unsigned unit;
269	int unitExpo;
270	int x_fuzz;
271	int y_fuzz;
272	int pressure_fuzz;
273	int distance_fuzz;
274	int tilt_fuzz;
275	unsigned quirks;
276	unsigned touch_max;
277	int oVid;
278	int oPid;
279	int pktlen;
280	bool check_for_hid_type;
281	int hid_type;
282};
283
284struct wacom_shared {
285	bool stylus_in_proximity;
286	bool touch_down;
287	/* for wireless device to access USB interfaces */
288	unsigned touch_max;
289	int type;
290	struct input_dev *touch_input;
291	struct hid_device *pen;
292	struct hid_device *touch;
293	bool has_mute_touch_switch;
294	bool is_touch_on;
295};
296
297struct hid_data {
298	__s16 inputmode;	/* InputMode HID feature, -1 if non-existent */
299	__s16 inputmode_index;	/* InputMode HID feature index in the report */
300	bool sense_state;
301	bool inrange_state;
302	bool invert_state;
303	bool tipswitch;
304	bool barrelswitch;
305	bool barrelswitch2;
306	bool barrelswitch3;
307	bool serialhi;
308	bool confidence;
309	int x;
310	int y;
311	int pressure;
312	int width;
313	int height;
314	int id;
315	int cc_report;
316	int cc_index;
317	int cc_value_index;
318	int last_slot_field;
319	int num_expected;
320	int num_received;
321	int bat_status;
322	int battery_capacity;
323	int bat_charging;
324	int bat_connected;
325	int ps_connected;
326	bool pad_input_event_flag;
327	unsigned short sequence_number;
328	ktime_t time_delayed;
329};
330
331struct wacom_remote_work_data {
332	struct {
333		u32 serial;
334	} remote[WACOM_MAX_REMOTES];
335};
336
337struct wacom_wac {
338	char name[WACOM_NAME_MAX];
339	char pen_name[WACOM_NAME_MAX];
340	char touch_name[WACOM_NAME_MAX];
341	char pad_name[WACOM_NAME_MAX];
342	unsigned char data[WACOM_PKGLEN_MAX];
343	int tool[2];
344	int id[2];
345	__u64 serial[2];
346	bool probe_complete;
347	bool reporting_data;
348	struct wacom_features features;
349	struct wacom_shared *shared;
350	struct input_dev *pen_input;
351	struct input_dev *touch_input;
352	struct input_dev *pad_input;
353	struct kfifo_rec_ptr_2 *pen_fifo;
354	int pid;
355	int num_contacts_left;
356	u8 bt_features;
357	u8 bt_high_speed;
358	int mode_report;
359	int mode_value;
360	struct hid_data hid_data;
361	bool has_mute_touch_switch;
362	bool is_soft_touch_switch;
363	bool has_mode_change;
364	bool is_direct_mode;
365	bool is_invalid_bt_frame;
366};
367
368#endif
369