blob: 466b62cc16dc19e8f29618ed258ea5404a790150 [file] [log] [blame]
Thomas Gleixner2874c5f2019-05-27 08:55:01 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Ping Cheng3bea7332006-07-13 18:01:36 -07002/*
Dmitry Torokhov4104d132007-05-07 16:16:29 -04003 * drivers/input/tablet/wacom_wac.h
Ping Cheng3bea7332006-07-13 18:01:36 -07004 */
5#ifndef WACOM_WAC_H
6#define WACOM_WAC_H
7
Dmitry Torokhov51269fe2010-03-19 22:18:15 -07008#include <linux/types.h>
Benjamin Tissoiresd97a5522015-01-05 16:32:12 -05009#include <linux/hid.h>
Jason Gerecke83417202017-11-10 11:50:01 -080010#include <linux/kfifo.h>
Dmitry Torokhov51269fe2010-03-19 22:18:15 -070011
Jason Gerecke4922cd22017-01-25 12:08:37 -080012/* maximum packet length for USB/BT devices */
13#define WACOM_PKGLEN_MAX 361
Ping Chengee545002009-12-15 00:35:24 -080014
Ping Cheng57bcfce2013-10-15 23:44:00 -070015#define WACOM_NAME_MAX 64
Aaron Skomra72b236d2015-08-20 16:05:17 -070016#define WACOM_MAX_REMOTES 5
17#define WACOM_STATUS_UNKNOWN 255
Ping Cheng57bcfce2013-10-15 23:44:00 -070018
Ping Chengee545002009-12-15 00:35:24 -080019/* packet length for individual models */
Jason Childse33da8a2010-02-17 22:38:31 -080020#define WACOM_PKGLEN_BBFUN 9
Ping Chengee545002009-12-15 00:35:24 -080021#define WACOM_PKGLEN_TPC1FG 5
Jason Gerecke61616ed2014-05-14 11:42:22 -070022#define WACOM_PKGLEN_TPC1FG_B 10
Jason Childse33da8a2010-02-17 22:38:31 -080023#define WACOM_PKGLEN_TPC2FG 14
Ping Cheng4a880812010-09-05 12:25:40 -070024#define WACOM_PKGLEN_BBTOUCH 20
Chris Bagwell41343612011-10-26 22:32:52 -070025#define WACOM_PKGLEN_BBTOUCH3 64
Chris Bagwell73149ab2011-10-26 22:34:21 -070026#define WACOM_PKGLEN_BBPEN 10
Chris Bagwelld3825d52012-03-25 23:26:11 -070027#define WACOM_PKGLEN_WIRELESS 32
Jason Gerecked51ddb22014-05-14 17:14:29 -070028#define WACOM_PKGLEN_PENABLED 8
Benjamin Tissoires8c97a762015-02-26 11:28:50 -050029#define WACOM_PKGLEN_BPAD_TOUCH 32
30#define WACOM_PKGLEN_BPAD_TOUCH_USB 64
Ping Cheng19635182012-04-29 21:09:18 -070031
32/* wacom data size per MT contact */
33#define WACOM_BYTES_PER_MT_PACKET 11
Jason Gereckeb1e42792012-10-21 00:38:04 -070034#define WACOM_BYTES_PER_24HDT_PACKET 14
Ping Cheng500d4162015-01-27 13:30:03 -080035#define WACOM_BYTES_PER_QHDTHID_PACKET 6
Ping Chengee545002009-12-15 00:35:24 -080036
Ping Chengec67bbe2009-12-15 00:35:24 -080037/* device IDs */
Ping Cheng3bea7332006-07-13 18:01:36 -070038#define STYLUS_DEVICE_ID 0x02
Ping Cheng545f4e92008-11-24 11:44:27 -050039#define TOUCH_DEVICE_ID 0x03
Ping Cheng3bea7332006-07-13 18:01:36 -070040#define CURSOR_DEVICE_ID 0x06
41#define ERASER_DEVICE_ID 0x0A
Ping Cheng80d4e8e2007-02-23 12:22:48 -080042#define PAD_DEVICE_ID 0x0F
Ping Cheng3bea7332006-07-13 18:01:36 -070043
Ping Chengcad74702009-12-15 00:35:25 -080044/* wacom data packet report IDs */
45#define WACOM_REPORT_PENABLED 2
Benjamin Tissoires387142b2014-08-06 13:52:56 -070046#define WACOM_REPORT_PENABLED_BT 3
Jason Gerecke06109992015-11-30 17:13:52 -080047#define WACOM_REPORT_INTUOS_ID1 5
48#define WACOM_REPORT_INTUOS_ID2 6
Ping Chengcad74702009-12-15 00:35:25 -080049#define WACOM_REPORT_INTUOSPAD 12
Jason Gereckef860e582012-04-03 15:48:35 -070050#define WACOM_REPORT_INTUOS5PAD 3
Ping Cheng497ab1f2014-01-20 20:18:04 -080051#define WACOM_REPORT_DTUSPAD 21
Ping Chengcad74702009-12-15 00:35:25 -080052#define WACOM_REPORT_TPC1FG 6
53#define WACOM_REPORT_TPC2FG 13
Ping Cheng19635182012-04-29 21:09:18 -070054#define WACOM_REPORT_TPCMT 13
Jason Gerecked51ddb22014-05-14 17:14:29 -070055#define WACOM_REPORT_TPCMT2 3
Ping Cheng31175a82012-01-31 00:07:33 -080056#define WACOM_REPORT_TPCHID 15
Ping Cheng500d4162015-01-27 13:30:03 -080057#define WACOM_REPORT_CINTIQ 16
58#define WACOM_REPORT_CINTIQPAD 17
Ping Cheng31175a82012-01-31 00:07:33 -080059#define WACOM_REPORT_TPCST 16
Ping Cheng497ab1f2014-01-20 20:18:04 -080060#define WACOM_REPORT_DTUS 17
Ping Chengac173832012-06-12 00:15:06 -070061#define WACOM_REPORT_TPC1FGE 18
Jason Gereckeb1e42792012-10-21 00:38:04 -070062#define WACOM_REPORT_24HDT 1
Ping Chengb5fd2a32013-11-25 18:44:55 -080063#define WACOM_REPORT_WL 128
Ping Cheng961794a2013-12-05 12:54:53 -080064#define WACOM_REPORT_USB 192
Benjamin Tissoires8c97a762015-02-26 11:28:50 -050065#define WACOM_REPORT_BPAD_PEN 3
66#define WACOM_REPORT_BPAD_TOUCH 16
Aaron Skomra72b236d2015-08-20 16:05:17 -070067#define WACOM_REPORT_DEVICE_LIST 16
Ping Chengeda01da2015-09-23 13:51:15 -070068#define WACOM_REPORT_INTUOS_PEN 16
Aaron Skomra72b236d2015-08-20 16:05:17 -070069#define WACOM_REPORT_REMOTE 17
Jason Gerecke0bbfe282016-01-06 13:25:53 -080070#define WACOM_REPORT_INTUOSHT2_ID 8
Ping Chengcad74702009-12-15 00:35:25 -080071
Jason Gerecke5ba13c62017-01-25 12:08:36 -080072/* wacom command report ids */
73#define WAC_CMD_WL_LED_CONTROL 0x03
74#define WAC_CMD_LED_CONTROL 0x20
75#define WAC_CMD_ICON_START 0x21
76#define WAC_CMD_ICON_XFER 0x23
77#define WAC_CMD_ICON_BT_XFER 0x26
78#define WAC_CMD_DELETE_PAIRING 0x20
Aaron Armstrong Skomra10c55ca2017-01-25 12:08:42 -080079#define WAC_CMD_LED_CONTROL_GENERIC 0x32
Jason Gerecke5ba13c62017-01-25 12:08:36 -080080#define WAC_CMD_UNPAIR_ALL 0xFF
Jason Gerecke4922cd22017-01-25 12:08:37 -080081#define WAC_CMD_WL_INTUOSP2 0x82
Jason Gerecke5ba13c62017-01-25 12:08:36 -080082
Henrik Rydbergbc73dd32010-09-05 12:26:16 -070083/* device quirks */
Ping Chengf3586d22015-03-20 14:57:00 -070084#define WACOM_QUIRK_BBTOUCH_LOWRES 0x0001
Jason Gerecke61ce3462016-10-19 18:03:46 -070085#define WACOM_QUIRK_SENSE 0x0002
Jason Gerecke99aceda2017-11-10 11:50:00 -080086#define WACOM_QUIRK_AESPEN 0x0004
Ping Chengf3586d22015-03-20 14:57:00 -070087#define WACOM_QUIRK_BATTERY 0x0008
Jason Gerecke83417202017-11-10 11:50:01 -080088#define WACOM_QUIRK_TOOLSERIAL 0x0010
Henrik Rydbergbc73dd32010-09-05 12:26:16 -070089
Jason Gereckeaa86b182015-06-15 18:01:42 -070090/* device types */
91#define WACOM_DEVICETYPE_NONE 0x0000
92#define WACOM_DEVICETYPE_PEN 0x0001
93#define WACOM_DEVICETYPE_TOUCH 0x0002
Jason Gerecke862cf552015-06-15 18:01:43 -070094#define WACOM_DEVICETYPE_PAD 0x0004
Jason Gereckeccad85c2015-08-03 10:17:04 -070095#define WACOM_DEVICETYPE_WL_MONITOR 0x0008
Jason Gereckee5bc8eb2016-08-08 12:06:29 -070096#define WACOM_DEVICETYPE_DIRECT 0x0010
Jason Gereckeaa86b182015-06-15 18:01:42 -070097
Jason Gerecke16e45982017-04-28 09:25:33 -070098#define WACOM_POWER_SUPPLY_STATUS_AUTO -1
99
Jason Gerecke8de82282016-10-19 18:03:37 -0700100#define WACOM_HID_UP_WACOMDIGITIZER 0xff0d0000
Jason Gerecke5922e612016-10-19 18:03:51 -0700101#define WACOM_HID_SP_PAD 0x00040000
102#define WACOM_HID_SP_BUTTON 0x00090000
Jason Gereckec9c09582016-10-19 18:03:43 -0700103#define WACOM_HID_SP_DIGITIZER 0x000d0000
104#define WACOM_HID_SP_DIGITIZERINFO 0x00100000
Jason Gerecke8de82282016-10-19 18:03:37 -0700105#define WACOM_HID_WD_DIGITIZER (WACOM_HID_UP_WACOMDIGITIZER | 0x01)
Aaron Armstrong Skomraac2423c2017-01-25 12:08:40 -0800106#define WACOM_HID_WD_PEN (WACOM_HID_UP_WACOMDIGITIZER | 0x02)
Jason Gerecke61ce3462016-10-19 18:03:46 -0700107#define WACOM_HID_WD_SENSE (WACOM_HID_UP_WACOMDIGITIZER | 0x36)
Jason Gerecke5922e612016-10-19 18:03:51 -0700108#define WACOM_HID_WD_DIGITIZERFNKEYS (WACOM_HID_UP_WACOMDIGITIZER | 0x39)
Jason Gerecke99aceda2017-11-10 11:50:00 -0800109#define WACOM_HID_WD_SERIALNUMBER (WACOM_HID_UP_WACOMDIGITIZER | 0x5b)
Jason Gereckef85c9dc2016-10-19 18:03:48 -0700110#define WACOM_HID_WD_SERIALHI (WACOM_HID_UP_WACOMDIGITIZER | 0x5c)
111#define WACOM_HID_WD_TOOLTYPE (WACOM_HID_UP_WACOMDIGITIZER | 0x77)
Jason Gereckeb5c921e2016-10-19 18:03:44 -0700112#define WACOM_HID_WD_DISTANCE (WACOM_HID_UP_WACOMDIGITIZER | 0x0132)
Jason Gereckebf78adc2016-10-19 18:03:53 -0700113#define WACOM_HID_WD_TOUCHSTRIP (WACOM_HID_UP_WACOMDIGITIZER | 0x0136)
114#define WACOM_HID_WD_TOUCHSTRIP2 (WACOM_HID_UP_WACOMDIGITIZER | 0x0137)
Jason Gerecke5922e612016-10-19 18:03:51 -0700115#define WACOM_HID_WD_TOUCHRING (WACOM_HID_UP_WACOMDIGITIZER | 0x0138)
116#define WACOM_HID_WD_TOUCHRINGSTATUS (WACOM_HID_UP_WACOMDIGITIZER | 0x0139)
Aaron Armstrong Skomrab1f466a2018-03-06 10:48:35 -0800117#define WACOM_HID_WD_REPORT_VALID (WACOM_HID_UP_WACOMDIGITIZER | 0x01d0)
Jason Gerecke5922e612016-10-19 18:03:51 -0700118#define WACOM_HID_WD_ACCELEROMETER_X (WACOM_HID_UP_WACOMDIGITIZER | 0x0401)
119#define WACOM_HID_WD_ACCELEROMETER_Y (WACOM_HID_UP_WACOMDIGITIZER | 0x0402)
120#define WACOM_HID_WD_ACCELEROMETER_Z (WACOM_HID_UP_WACOMDIGITIZER | 0x0403)
Jason Gerecke93aab7f2016-10-19 18:03:52 -0700121#define WACOM_HID_WD_BATTERY_CHARGING (WACOM_HID_UP_WACOMDIGITIZER | 0x0404)
Aaron Armstrong Skomrad2ec58a2017-01-25 12:08:41 -0800122#define WACOM_HID_WD_TOUCHONOFF (WACOM_HID_UP_WACOMDIGITIZER | 0x0454)
Jason Gerecke93aab7f2016-10-19 18:03:52 -0700123#define WACOM_HID_WD_BATTERY_LEVEL (WACOM_HID_UP_WACOMDIGITIZER | 0x043b)
Jason Gerecke5922e612016-10-19 18:03:51 -0700124#define WACOM_HID_WD_EXPRESSKEY00 (WACOM_HID_UP_WACOMDIGITIZER | 0x0910)
Jason Gerecke424d8232021-06-23 09:58:09 -0700125#define WACOM_HID_WD_EXPRESSKEYCAP00 (WACOM_HID_UP_WACOMDIGITIZER | 0x0940)
Benjamin Tissoires4082da82017-02-14 21:27:18 -0800126#define WACOM_HID_WD_MODE_CHANGE (WACOM_HID_UP_WACOMDIGITIZER | 0x0980)
Ping Chengd793ff82017-02-14 21:27:45 -0800127#define WACOM_HID_WD_MUTE_DEVICE (WACOM_HID_UP_WACOMDIGITIZER | 0x0981)
Ping Cheng4eb220c2017-02-14 21:26:21 -0800128#define WACOM_HID_WD_CONTROLPANEL (WACOM_HID_UP_WACOMDIGITIZER | 0x0982)
129#define WACOM_HID_WD_ONSCREEN_KEYBOARD (WACOM_HID_UP_WACOMDIGITIZER | 0x0983)
130#define WACOM_HID_WD_BUTTONCONFIG (WACOM_HID_UP_WACOMDIGITIZER | 0x0986)
Jason Gerecke5922e612016-10-19 18:03:51 -0700131#define WACOM_HID_WD_BUTTONHOME (WACOM_HID_UP_WACOMDIGITIZER | 0x0990)
132#define WACOM_HID_WD_BUTTONUP (WACOM_HID_UP_WACOMDIGITIZER | 0x0991)
133#define WACOM_HID_WD_BUTTONDOWN (WACOM_HID_UP_WACOMDIGITIZER | 0x0992)
134#define WACOM_HID_WD_BUTTONLEFT (WACOM_HID_UP_WACOMDIGITIZER | 0x0993)
135#define WACOM_HID_WD_BUTTONRIGHT (WACOM_HID_UP_WACOMDIGITIZER | 0x0994)
Jason Gereckebf78adc2016-10-19 18:03:53 -0700136#define WACOM_HID_WD_BUTTONCENTER (WACOM_HID_UP_WACOMDIGITIZER | 0x0995)
Jason Gerecke929d6d52016-10-19 18:03:45 -0700137#define WACOM_HID_WD_FINGERWHEEL (WACOM_HID_UP_WACOMDIGITIZER | 0x0d03)
Jason Gerecke345857b2016-10-19 18:03:50 -0700138#define WACOM_HID_WD_OFFSETLEFT (WACOM_HID_UP_WACOMDIGITIZER | 0x0d30)
139#define WACOM_HID_WD_OFFSETTOP (WACOM_HID_UP_WACOMDIGITIZER | 0x0d31)
140#define WACOM_HID_WD_OFFSETRIGHT (WACOM_HID_UP_WACOMDIGITIZER | 0x0d32)
141#define WACOM_HID_WD_OFFSETBOTTOM (WACOM_HID_UP_WACOMDIGITIZER | 0x0d33)
Jason Gereckec9c09582016-10-19 18:03:43 -0700142#define WACOM_HID_WD_DATAMODE (WACOM_HID_UP_WACOMDIGITIZER | 0x1002)
Jason Gerecke5922e612016-10-19 18:03:51 -0700143#define WACOM_HID_WD_DIGITIZERINFO (WACOM_HID_UP_WACOMDIGITIZER | 0x1013)
Aaron Armstrong Skomrad8e98062019-05-10 15:31:16 -0700144#define WACOM_HID_WD_TOUCH_RING_SETTING (WACOM_HID_UP_WACOMDIGITIZER | 0x1032)
Jason Gerecke8de82282016-10-19 18:03:37 -0700145#define WACOM_HID_UP_G9 0xff090000
146#define WACOM_HID_G9_PEN (WACOM_HID_UP_G9 | 0x02)
147#define WACOM_HID_G9_TOUCHSCREEN (WACOM_HID_UP_G9 | 0x11)
148#define WACOM_HID_UP_G11 0xff110000
149#define WACOM_HID_G11_PEN (WACOM_HID_UP_G11 | 0x02)
150#define WACOM_HID_G11_TOUCHSCREEN (WACOM_HID_UP_G11 | 0x11)
Aaron Armstrong Skomraac2423c2017-01-25 12:08:40 -0800151#define WACOM_HID_UP_WACOMTOUCH 0xff000000
152#define WACOM_HID_WT_TOUCHSCREEN (WACOM_HID_UP_WACOMTOUCH | 0x04)
153#define WACOM_HID_WT_TOUCHPAD (WACOM_HID_UP_WACOMTOUCH | 0x05)
154#define WACOM_HID_WT_CONTACTMAX (WACOM_HID_UP_WACOMTOUCH | 0x55)
Jason Gerecke99aceda2017-11-10 11:50:00 -0800155#define WACOM_HID_WT_SERIALNUMBER (WACOM_HID_UP_WACOMTOUCH | 0x5b)
Aaron Armstrong Skomraac2423c2017-01-25 12:08:40 -0800156#define WACOM_HID_WT_X (WACOM_HID_UP_WACOMTOUCH | 0x130)
157#define WACOM_HID_WT_Y (WACOM_HID_UP_WACOMTOUCH | 0x131)
Aaron Armstrong Skomraf4e11d52019-06-12 14:19:30 -0700158#define WACOM_HID_WT_REPORT_VALID (WACOM_HID_UP_WACOMTOUCH | 0x1d0)
Jason Gerecke042628a2015-04-30 17:51:54 -0700159
Jason Gerecke5ac3d4a2017-04-28 09:25:34 -0700160#define WACOM_BATTERY_USAGE(f) (((f)->hid == HID_DG_BATTERYSTRENGTH) || \
161 ((f)->hid == WACOM_HID_WD_BATTERY_CHARGING) || \
162 ((f)->hid == WACOM_HID_WD_BATTERY_LEVEL))
163
Jason Gerecke5922e612016-10-19 18:03:51 -0700164#define WACOM_PAD_FIELD(f) (((f)->physical == HID_DG_TABLETFUNCTIONKEY) || \
165 ((f)->physical == WACOM_HID_WD_DIGITIZERFNKEYS) || \
166 ((f)->physical == WACOM_HID_WD_DIGITIZERINFO))
167
Benjamin Tissoiresd97a5522015-01-05 16:32:12 -0500168#define WACOM_PEN_FIELD(f) (((f)->logical == HID_DG_STYLUS) || \
169 ((f)->physical == HID_DG_STYLUS) || \
Benjamin Tissoires61e9e7e2015-01-05 16:32:13 -0500170 ((f)->physical == HID_DG_PEN) || \
Jason Gerecke042628a2015-04-30 17:51:54 -0700171 ((f)->application == HID_DG_PEN) || \
172 ((f)->application == HID_DG_DIGITIZER) || \
Jason Gerecke885e89f2017-10-18 08:27:13 -0700173 ((f)->application == WACOM_HID_WD_PEN) || \
Jason Gerecke1b18b752016-10-19 18:03:38 -0700174 ((f)->application == WACOM_HID_WD_DIGITIZER) || \
175 ((f)->application == WACOM_HID_G9_PEN) || \
176 ((f)->application == WACOM_HID_G11_PEN))
Benjamin Tissoiresd97a5522015-01-05 16:32:12 -0500177#define WACOM_FINGER_FIELD(f) (((f)->logical == HID_DG_FINGER) || \
178 ((f)->physical == HID_DG_FINGER) || \
Jason Gerecke1b18b752016-10-19 18:03:38 -0700179 ((f)->application == HID_DG_TOUCHSCREEN) || \
180 ((f)->application == WACOM_HID_G9_TOUCHSCREEN) || \
Aaron Armstrong Skomraac2423c2017-01-25 12:08:40 -0800181 ((f)->application == WACOM_HID_G11_TOUCHSCREEN) || \
182 ((f)->application == WACOM_HID_WT_TOUCHPAD) || \
183 ((f)->application == HID_DG_TOUCHPAD))
184
185#define WACOM_DIRECT_DEVICE(f) (((f)->application == HID_DG_TOUCHSCREEN) || \
186 ((f)->application == WACOM_HID_WT_TOUCHSCREEN) || \
187 ((f)->application == HID_DG_PEN) || \
188 ((f)->application == WACOM_HID_WD_PEN))
Benjamin Tissoiresd97a5522015-01-05 16:32:12 -0500189
Ping Cheng3bea7332006-07-13 18:01:36 -0700190enum {
191 PENPARTNER = 0,
192 GRAPHIRE,
Benjamin Tissoires387142b2014-08-06 13:52:56 -0700193 GRAPHIRE_BT,
Ping Cheng3bea7332006-07-13 18:01:36 -0700194 WACOM_G4,
195 PTU,
196 PL,
Ping Chengc8f2edc2010-06-28 01:10:51 -0700197 DTU,
Ping Cheng497ab1f2014-01-20 20:18:04 -0800198 DTUS,
Ping Chengfff00bf2014-12-04 18:23:04 -0800199 DTUSX,
Ping Cheng3bea7332006-07-13 18:01:36 -0700200 INTUOS,
Ping Cheng8d32e3a2006-09-26 13:34:47 -0700201 INTUOS3S,
Ping Cheng3bea7332006-07-13 18:01:36 -0700202 INTUOS3,
203 INTUOS3L,
Ping Cheng6f660f12009-05-08 18:30:33 -0700204 INTUOS4S,
205 INTUOS4,
Benjamin Tissoires81af7e62014-08-06 13:55:56 -0700206 INTUOS4WL,
Ping Cheng6f660f12009-05-08 18:30:33 -0700207 INTUOS4L,
Jason Gerecke9fee6192012-04-03 15:47:22 -0700208 INTUOS5S,
209 INTUOS5,
210 INTUOS5L,
Ping Cheng9a35c412013-09-20 09:51:56 -0700211 INTUOSPS,
212 INTUOSPM,
213 INTUOSPL,
Jason Gerecke4922cd22017-01-25 12:08:37 -0800214 INTUOSP2_BT,
Aaron Armstrong Skomra912c6aa2019-06-12 14:19:28 -0700215 INTUOSP2S_BT,
Aaron Armstrong Skomra87046b62018-03-06 10:48:33 -0800216 INTUOSHT3_BT,
Ping Cheng3a4b4aa2010-06-03 22:10:21 -0700217 WACOM_21UX2,
Ping Chengd838c642012-07-24 23:54:11 -0700218 WACOM_22HD,
Ping Chenga112e9f2013-02-13 20:20:01 -0800219 DTK,
Ping Chengd838c642012-07-24 23:54:11 -0700220 WACOM_24HD,
Ping Cheng500d4162015-01-27 13:30:03 -0800221 WACOM_27QHD,
Jason Gerecke36d3c512013-09-20 09:47:35 -0700222 CINTIQ_HYBRID,
Jason Gereckef7acb552015-10-13 10:03:49 -0700223 CINTIQ_COMPANION_2,
Ping Cheng3bea7332006-07-13 18:01:36 -0700224 CINTIQ,
Ping Cheng0e1763f2008-03-13 16:46:46 -0400225 WACOM_BEE,
Ping Cheng56218562013-05-05 19:56:18 -0700226 WACOM_13HD,
Ping Cheng7ecfbfd2007-06-14 23:32:48 -0400227 WACOM_MO,
Ping Cheng3b164a02015-09-23 09:59:10 -0700228 BAMBOO_PEN,
229 INTUOSHT,
Ping Chengeda01da2015-09-23 13:51:15 -0700230 INTUOSHT2,
Ping Cheng3b164a02015-09-23 09:59:10 -0700231 BAMBOO_TOUCH,
Ping Chengea2e6022012-06-12 00:14:12 -0700232 BAMBOO_PT,
Jason Gereckeb1e42792012-10-21 00:38:04 -0700233 WACOM_24HDT,
Ping Cheng500d4162015-01-27 13:30:03 -0800234 WACOM_27QHDT,
Benjamin Tissoires8c97a762015-02-26 11:28:50 -0500235 BAMBOO_PAD,
Ping Cheng7adb91b2015-10-26 14:29:12 -0700236 WIRELESS,
Aaron Skomra72b236d2015-08-20 16:05:17 -0700237 REMOTE,
Ping Chengea2e6022012-06-12 00:14:12 -0700238 TABLETPC, /* add new TPC below */
Ping Chengac173832012-06-12 00:15:06 -0700239 TABLETPCE,
Ping Chengec67bbe2009-12-15 00:35:24 -0800240 TABLETPC2FG,
Ping Cheng19635182012-04-29 21:09:18 -0700241 MTSCREEN,
Ping Cheng6afdc282012-11-03 12:16:15 -0700242 MTTPC,
Jason Gerecked51ddb22014-05-14 17:14:29 -0700243 MTTPC_B,
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400244 HID_GENERIC,
Ping Cheng3bea7332006-07-13 18:01:36 -0700245 MAX_TYPE
246};
247
248struct wacom_features {
Jason Childse33da8a2010-02-17 22:38:31 -0800249 const char *name;
Ping Cheng3bea7332006-07-13 18:01:36 -0700250 int x_max;
251 int y_max;
252 int pressure_max;
253 int distance_max;
254 int type;
Ping Chenge35fb8c2011-03-26 21:16:05 -0700255 int x_resolution;
256 int y_resolution;
Aaron Skomra70ee06c2015-08-20 16:05:16 -0700257 int numbered_buttons;
Jason Gereckee779ef22016-10-19 18:03:49 -0700258 int offset_left;
259 int offset_right;
260 int offset_top;
261 int offset_bottom;
Ping Chengec67bbe2009-12-15 00:35:24 -0800262 int device_type;
263 int x_phy;
264 int y_phy;
Benjamin Tissoiresc669fb22014-07-24 13:02:14 -0700265 unsigned unit;
266 int unitExpo;
Henrik Rydbergfed87e62010-09-05 12:25:11 -0700267 int x_fuzz;
268 int y_fuzz;
269 int pressure_fuzz;
270 int distance_fuzz;
Jason Gereckebef7e202016-04-22 14:30:53 -0700271 int tilt_fuzz;
Henrik Rydbergbc73dd32010-09-05 12:26:16 -0700272 unsigned quirks;
Ping Chengf393ee22012-04-29 21:09:17 -0700273 unsigned touch_max;
Jason Gereckeaea2bf62012-10-21 00:38:03 -0700274 int oVid;
275 int oPid;
Benjamin Tissoires80befa92014-07-24 13:05:19 -0700276 int pktlen;
Benjamin Tissoires29b47392014-07-24 12:52:23 -0700277 bool check_for_hid_type;
278 int hid_type;
Ping Cheng3bea7332006-07-13 18:01:36 -0700279};
280
Ping Cheng4492eff2010-03-19 22:18:15 -0700281struct wacom_shared {
282 bool stylus_in_proximity;
Ping Chenga43c7c52011-03-12 20:34:42 -0800283 bool touch_down;
Ping Cheng961794a2013-12-05 12:54:53 -0800284 /* for wireless device to access USB interfaces */
285 unsigned touch_max;
286 int type;
287 struct input_dev *touch_input;
Benjamin Tissoiresa97ac102015-02-25 11:43:39 -0500288 struct hid_device *pen;
289 struct hid_device *touch;
Aaron Armstrong Skomrad2ec58a2017-01-25 12:08:41 -0800290 bool has_mute_touch_switch;
Ping Chengd793ff82017-02-14 21:27:45 -0800291 bool is_touch_on;
Ping Cheng4492eff2010-03-19 22:18:15 -0700292};
293
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400294struct hid_data {
Benjamin Tissoires5ae6e892014-09-23 12:08:09 -0400295 __s16 inputmode; /* InputMode HID feature, -1 if non-existent */
296 __s16 inputmode_index; /* InputMode HID feature index in the report */
Jason Gerecke61ce3462016-10-19 18:03:46 -0700297 bool sense_state;
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400298 bool inrange_state;
299 bool invert_state;
300 bool tipswitch;
Jason Gerecke9e429d52017-11-07 08:25:17 -0800301 bool barrelswitch;
302 bool barrelswitch2;
Ping Cheng46fc4662021-04-05 20:46:34 -0700303 bool serialhi;
Jason Gerecke7fb04132021-11-08 16:31:01 -0800304 bool confidence;
Benjamin Tissoires5ae6e892014-09-23 12:08:09 -0400305 int x;
306 int y;
307 int pressure;
308 int width;
309 int height;
310 int id;
Jason Gerecke499522c2015-10-07 16:54:21 -0700311 int cc_report;
Jason Gerecke1b5d514a2015-07-21 11:07:24 -0700312 int cc_index;
313 int cc_value_index;
Jason Gerecke003f50a2016-07-21 09:10:46 -0700314 int last_slot_field;
Jason Gerecke1b5d514a2015-07-21 11:07:24 -0700315 int num_expected;
316 int num_received;
Jason Gerecke16e45982017-04-28 09:25:33 -0700317 int bat_status;
Jason Gerecke93aab7f2016-10-19 18:03:52 -0700318 int battery_capacity;
319 int bat_charging;
320 int bat_connected;
321 int ps_connected;
Ping Chenged1fa732017-04-04 12:31:07 -0700322 bool pad_input_event_flag;
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400323};
324
Benjamin Tissoirese6f28132016-07-13 18:06:01 +0200325struct wacom_remote_data {
326 struct {
327 u32 serial;
328 bool connected;
329 } remote[WACOM_MAX_REMOTES];
330};
331
Ping Cheng3bea7332006-07-13 18:01:36 -0700332struct wacom_wac {
Benjamin Tissoires99569532016-07-13 18:06:17 +0200333 char name[WACOM_NAME_MAX];
Jason Gerecke2a6cdbd2015-06-15 18:01:45 -0700334 char pen_name[WACOM_NAME_MAX];
335 char touch_name[WACOM_NAME_MAX];
Benjamin Tissoiresd2d13f12014-07-24 12:48:28 -0700336 char pad_name[WACOM_NAME_MAX];
Benjamin Tissoires29b47392014-07-24 12:52:23 -0700337 unsigned char data[WACOM_PKGLEN_MAX];
Ping Cheng4fc19382011-03-12 20:33:33 -0800338 int tool[2];
339 int id[2];
Jason Gereckef85c9dc2016-10-19 18:03:48 -0700340 __u64 serial[2];
Jason Gerecke5bed0122021-07-19 13:55:30 -0700341 bool probe_complete;
Ping Chengb3bd7ef2015-01-09 11:05:13 -0800342 bool reporting_data;
Jason Childse33da8a2010-02-17 22:38:31 -0800343 struct wacom_features features;
Ping Cheng4492eff2010-03-19 22:18:15 -0700344 struct wacom_shared *shared;
Jason Gerecke2a6cdbd2015-06-15 18:01:45 -0700345 struct input_dev *pen_input;
346 struct input_dev *touch_input;
Benjamin Tissoiresd2d13f12014-07-24 12:48:28 -0700347 struct input_dev *pad_input;
Jason Gerecke179e8e42021-01-21 10:46:49 -0800348 struct kfifo_rec_ptr_2 *pen_fifo;
Chris Bagwell16bf2882012-03-25 23:26:20 -0700349 int pid;
Ping Cheng19635182012-04-29 21:09:18 -0700350 int num_contacts_left;
Benjamin Tissoiresf81a1292014-08-06 13:48:01 -0700351 u8 bt_features;
352 u8 bt_high_speed;
Jason Gerecke326ea2a2016-04-04 11:26:52 -0700353 int mode_report;
354 int mode_value;
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400355 struct hid_data hid_data;
Aaron Armstrong Skomrad2ec58a2017-01-25 12:08:41 -0800356 bool has_mute_touch_switch;
Ping Chengdc9dc862021-07-19 13:55:29 -0700357 bool is_soft_touch_switch;
Benjamin Tissoires4082da82017-02-14 21:27:18 -0800358 bool has_mode_change;
359 bool is_direct_mode;
Aaron Armstrong Skomrab1f466a2018-03-06 10:48:35 -0800360 bool is_invalid_bt_frame;
Ping Cheng3bea7332006-07-13 18:01:36 -0700361};
362
363#endif