1 /* SPDX-License-Identifier: GPL-2.0-or-later */
6 #include <linux/types.h>
8 #include <linux/kfifo.h>
10 /* maximum packet length for USB/BT devices */
11 #define WACOM_PKGLEN_MAX 361
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
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
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
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
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
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
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
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
98 #define WACOM_POWER_SUPPLY_STATUS_AUTO -1
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)
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))
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))
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))
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))
240 TABLETPC, /* add new TPC below */
251 struct wacom_features {
260 int numbered_buttons;
280 bool check_for_hid_type;
284 struct wacom_shared {
285 bool stylus_in_proximity;
287 /* for wireless device to access USB interfaces */
290 struct input_dev *touch_input;
291 struct hid_device *pen;
292 struct hid_device *touch;
293 bool has_mute_touch_switch;
298 __s16 inputmode; /* InputMode HID feature, -1 if non-existent */
299 __s16 inputmode_index; /* InputMode HID feature index in the report */
322 int battery_capacity;
326 bool pad_input_event_flag;
327 unsigned short sequence_number;
328 ktime_t time_delayed;
331 struct wacom_remote_work_data {
334 } remote[WACOM_MAX_REMOTES];
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];
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;
355 int num_contacts_left;
360 struct hid_data hid_data;
361 bool has_mute_touch_switch;
362 bool is_soft_touch_switch;
363 bool has_mode_change;
365 bool is_invalid_bt_frame;