blob: 63a5a2586707df6e846008aade8679d2010a1282 [file] [log] [blame]
Ping Cheng3bea7332006-07-13 18:01:36 -07001/*
Dmitry Torokhov4104d132007-05-07 16:16:29 -04002 * drivers/input/tablet/wacom_wac.h
Ping Cheng3bea7332006-07-13 18:01:36 -07003 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
8 */
9#ifndef WACOM_WAC_H
10#define WACOM_WAC_H
11
Dmitry Torokhov51269fe2010-03-19 22:18:15 -070012#include <linux/types.h>
Benjamin Tissoiresd97a5522015-01-05 16:32:12 -050013#include <linux/hid.h>
Dmitry Torokhov51269fe2010-03-19 22:18:15 -070014
Ping Chengee545002009-12-15 00:35:24 -080015/* maximum packet length for USB devices */
Ping Cheng500d4162015-01-27 13:30:03 -080016#define WACOM_PKGLEN_MAX 192
Ping Chengee545002009-12-15 00:35:24 -080017
Ping Cheng57bcfce2013-10-15 23:44:00 -070018#define WACOM_NAME_MAX 64
Aaron Skomra72b236d2015-08-20 16:05:17 -070019#define WACOM_MAX_REMOTES 5
20#define WACOM_STATUS_UNKNOWN 255
Ping Cheng57bcfce2013-10-15 23:44:00 -070021
Ping Chengee545002009-12-15 00:35:24 -080022/* packet length for individual models */
Jason Childse33da8a2010-02-17 22:38:31 -080023#define WACOM_PKGLEN_BBFUN 9
Ping Chengee545002009-12-15 00:35:24 -080024#define WACOM_PKGLEN_TPC1FG 5
Jason Gerecke61616ed2014-05-14 11:42:22 -070025#define WACOM_PKGLEN_TPC1FG_B 10
Jason Childse33da8a2010-02-17 22:38:31 -080026#define WACOM_PKGLEN_TPC2FG 14
Ping Cheng4a880812010-09-05 12:25:40 -070027#define WACOM_PKGLEN_BBTOUCH 20
Chris Bagwell41343612011-10-26 22:32:52 -070028#define WACOM_PKGLEN_BBTOUCH3 64
Chris Bagwell73149ab2011-10-26 22:34:21 -070029#define WACOM_PKGLEN_BBPEN 10
Chris Bagwelld3825d52012-03-25 23:26:11 -070030#define WACOM_PKGLEN_WIRELESS 32
Jason Gerecked51ddb22014-05-14 17:14:29 -070031#define WACOM_PKGLEN_PENABLED 8
Benjamin Tissoires8c97a762015-02-26 11:28:50 -050032#define WACOM_PKGLEN_BPAD_TOUCH 32
33#define WACOM_PKGLEN_BPAD_TOUCH_USB 64
Ping Cheng19635182012-04-29 21:09:18 -070034
35/* wacom data size per MT contact */
36#define WACOM_BYTES_PER_MT_PACKET 11
Jason Gereckeb1e42792012-10-21 00:38:04 -070037#define WACOM_BYTES_PER_24HDT_PACKET 14
Ping Cheng500d4162015-01-27 13:30:03 -080038#define WACOM_BYTES_PER_QHDTHID_PACKET 6
Ping Chengee545002009-12-15 00:35:24 -080039
Ping Chengec67bbe2009-12-15 00:35:24 -080040/* device IDs */
Ping Cheng3bea7332006-07-13 18:01:36 -070041#define STYLUS_DEVICE_ID 0x02
Ping Cheng545f4e92008-11-24 11:44:27 -050042#define TOUCH_DEVICE_ID 0x03
Ping Cheng3bea7332006-07-13 18:01:36 -070043#define CURSOR_DEVICE_ID 0x06
44#define ERASER_DEVICE_ID 0x0A
Ping Cheng80d4e8e2007-02-23 12:22:48 -080045#define PAD_DEVICE_ID 0x0F
Ping Cheng3bea7332006-07-13 18:01:36 -070046
Ping Chengcad74702009-12-15 00:35:25 -080047/* wacom data packet report IDs */
48#define WACOM_REPORT_PENABLED 2
Benjamin Tissoires387142b2014-08-06 13:52:56 -070049#define WACOM_REPORT_PENABLED_BT 3
Jason Gerecke06109992015-11-30 17:13:52 -080050#define WACOM_REPORT_INTUOS_ID1 5
51#define WACOM_REPORT_INTUOS_ID2 6
Ping Chengcad74702009-12-15 00:35:25 -080052#define WACOM_REPORT_INTUOSPAD 12
Jason Gereckef860e582012-04-03 15:48:35 -070053#define WACOM_REPORT_INTUOS5PAD 3
Ping Cheng497ab1f2014-01-20 20:18:04 -080054#define WACOM_REPORT_DTUSPAD 21
Ping Chengcad74702009-12-15 00:35:25 -080055#define WACOM_REPORT_TPC1FG 6
56#define WACOM_REPORT_TPC2FG 13
Ping Cheng19635182012-04-29 21:09:18 -070057#define WACOM_REPORT_TPCMT 13
Jason Gerecked51ddb22014-05-14 17:14:29 -070058#define WACOM_REPORT_TPCMT2 3
Ping Cheng31175a82012-01-31 00:07:33 -080059#define WACOM_REPORT_TPCHID 15
Ping Cheng500d4162015-01-27 13:30:03 -080060#define WACOM_REPORT_CINTIQ 16
61#define WACOM_REPORT_CINTIQPAD 17
Ping Cheng31175a82012-01-31 00:07:33 -080062#define WACOM_REPORT_TPCST 16
Ping Cheng497ab1f2014-01-20 20:18:04 -080063#define WACOM_REPORT_DTUS 17
Ping Chengac173832012-06-12 00:15:06 -070064#define WACOM_REPORT_TPC1FGE 18
Jason Gereckeb1e42792012-10-21 00:38:04 -070065#define WACOM_REPORT_24HDT 1
Ping Chengb5fd2a32013-11-25 18:44:55 -080066#define WACOM_REPORT_WL 128
Ping Cheng961794a2013-12-05 12:54:53 -080067#define WACOM_REPORT_USB 192
Benjamin Tissoires8c97a762015-02-26 11:28:50 -050068#define WACOM_REPORT_BPAD_PEN 3
69#define WACOM_REPORT_BPAD_TOUCH 16
Aaron Skomra72b236d2015-08-20 16:05:17 -070070#define WACOM_REPORT_DEVICE_LIST 16
Ping Chengeda01da2015-09-23 13:51:15 -070071#define WACOM_REPORT_INTUOS_PEN 16
Aaron Skomra72b236d2015-08-20 16:05:17 -070072#define WACOM_REPORT_REMOTE 17
Jason Gerecke0bbfe282016-01-06 13:25:53 -080073#define WACOM_REPORT_INTUOSHT2_ID 8
Ping Chengcad74702009-12-15 00:35:25 -080074
Henrik Rydbergbc73dd32010-09-05 12:26:16 -070075/* device quirks */
Ping Chengf3586d22015-03-20 14:57:00 -070076#define WACOM_QUIRK_BBTOUCH_LOWRES 0x0001
Ping Chengf3586d22015-03-20 14:57:00 -070077#define WACOM_QUIRK_BATTERY 0x0008
Henrik Rydbergbc73dd32010-09-05 12:26:16 -070078
Jason Gereckeaa86b182015-06-15 18:01:42 -070079/* device types */
80#define WACOM_DEVICETYPE_NONE 0x0000
81#define WACOM_DEVICETYPE_PEN 0x0001
82#define WACOM_DEVICETYPE_TOUCH 0x0002
Jason Gerecke862cf552015-06-15 18:01:43 -070083#define WACOM_DEVICETYPE_PAD 0x0004
Jason Gereckeccad85c2015-08-03 10:17:04 -070084#define WACOM_DEVICETYPE_WL_MONITOR 0x0008
Jason Gereckee5bc8eb2016-08-08 12:06:29 -070085#define WACOM_DEVICETYPE_DIRECT 0x0010
Jason Gereckeaa86b182015-06-15 18:01:42 -070086
Jason Gerecke8de82282016-10-19 18:03:37 -070087#define WACOM_HID_UP_WACOMDIGITIZER 0xff0d0000
Jason Gereckec9c09582016-10-19 18:03:43 -070088#define WACOM_HID_SP_DIGITIZER 0x000d0000
89#define WACOM_HID_SP_DIGITIZERINFO 0x00100000
Jason Gerecke8de82282016-10-19 18:03:37 -070090#define WACOM_HID_WD_DIGITIZER (WACOM_HID_UP_WACOMDIGITIZER | 0x01)
Jason Gereckeb5c921e2016-10-19 18:03:44 -070091#define WACOM_HID_WD_DISTANCE (WACOM_HID_UP_WACOMDIGITIZER | 0x0132)
Jason Gereckec9c09582016-10-19 18:03:43 -070092#define WACOM_HID_WD_DATAMODE (WACOM_HID_UP_WACOMDIGITIZER | 0x1002)
Jason Gerecke8de82282016-10-19 18:03:37 -070093#define WACOM_HID_UP_G9 0xff090000
94#define WACOM_HID_G9_PEN (WACOM_HID_UP_G9 | 0x02)
95#define WACOM_HID_G9_TOUCHSCREEN (WACOM_HID_UP_G9 | 0x11)
96#define WACOM_HID_UP_G11 0xff110000
97#define WACOM_HID_G11_PEN (WACOM_HID_UP_G11 | 0x02)
98#define WACOM_HID_G11_TOUCHSCREEN (WACOM_HID_UP_G11 | 0x11)
Jason Gerecke042628a2015-04-30 17:51:54 -070099
Benjamin Tissoiresd97a5522015-01-05 16:32:12 -0500100#define WACOM_PEN_FIELD(f) (((f)->logical == HID_DG_STYLUS) || \
101 ((f)->physical == HID_DG_STYLUS) || \
Benjamin Tissoires61e9e7e2015-01-05 16:32:13 -0500102 ((f)->physical == HID_DG_PEN) || \
Jason Gerecke042628a2015-04-30 17:51:54 -0700103 ((f)->application == HID_DG_PEN) || \
104 ((f)->application == HID_DG_DIGITIZER) || \
Jason Gerecke1b18b752016-10-19 18:03:38 -0700105 ((f)->application == WACOM_HID_WD_DIGITIZER) || \
106 ((f)->application == WACOM_HID_G9_PEN) || \
107 ((f)->application == WACOM_HID_G11_PEN))
Benjamin Tissoiresd97a5522015-01-05 16:32:12 -0500108#define WACOM_FINGER_FIELD(f) (((f)->logical == HID_DG_FINGER) || \
109 ((f)->physical == HID_DG_FINGER) || \
Jason Gerecke1b18b752016-10-19 18:03:38 -0700110 ((f)->application == HID_DG_TOUCHSCREEN) || \
111 ((f)->application == WACOM_HID_G9_TOUCHSCREEN) || \
112 ((f)->application == WACOM_HID_G11_TOUCHSCREEN))
Benjamin Tissoiresd97a5522015-01-05 16:32:12 -0500113
Ping Cheng3bea7332006-07-13 18:01:36 -0700114enum {
115 PENPARTNER = 0,
116 GRAPHIRE,
Benjamin Tissoires387142b2014-08-06 13:52:56 -0700117 GRAPHIRE_BT,
Ping Cheng3bea7332006-07-13 18:01:36 -0700118 WACOM_G4,
119 PTU,
120 PL,
Ping Chengc8f2edc2010-06-28 01:10:51 -0700121 DTU,
Ping Cheng497ab1f2014-01-20 20:18:04 -0800122 DTUS,
Ping Chengfff00bf2014-12-04 18:23:04 -0800123 DTUSX,
Ping Cheng3bea7332006-07-13 18:01:36 -0700124 INTUOS,
Ping Cheng8d32e3a2006-09-26 13:34:47 -0700125 INTUOS3S,
Ping Cheng3bea7332006-07-13 18:01:36 -0700126 INTUOS3,
127 INTUOS3L,
Ping Cheng6f660f12009-05-08 18:30:33 -0700128 INTUOS4S,
129 INTUOS4,
Benjamin Tissoires81af7e62014-08-06 13:55:56 -0700130 INTUOS4WL,
Ping Cheng6f660f12009-05-08 18:30:33 -0700131 INTUOS4L,
Jason Gerecke9fee6192012-04-03 15:47:22 -0700132 INTUOS5S,
133 INTUOS5,
134 INTUOS5L,
Ping Cheng9a35c412013-09-20 09:51:56 -0700135 INTUOSPS,
136 INTUOSPM,
137 INTUOSPL,
Ping Cheng3a4b4aa2010-06-03 22:10:21 -0700138 WACOM_21UX2,
Ping Chengd838c642012-07-24 23:54:11 -0700139 WACOM_22HD,
Ping Chenga112e9f2013-02-13 20:20:01 -0800140 DTK,
Ping Chengd838c642012-07-24 23:54:11 -0700141 WACOM_24HD,
Ping Cheng500d4162015-01-27 13:30:03 -0800142 WACOM_27QHD,
Jason Gerecke36d3c512013-09-20 09:47:35 -0700143 CINTIQ_HYBRID,
Jason Gereckef7acb552015-10-13 10:03:49 -0700144 CINTIQ_COMPANION_2,
Ping Cheng3bea7332006-07-13 18:01:36 -0700145 CINTIQ,
Ping Cheng0e1763f2008-03-13 16:46:46 -0400146 WACOM_BEE,
Ping Cheng56218562013-05-05 19:56:18 -0700147 WACOM_13HD,
Ping Cheng7ecfbfd2007-06-14 23:32:48 -0400148 WACOM_MO,
Ping Cheng3b164a02015-09-23 09:59:10 -0700149 BAMBOO_PEN,
150 INTUOSHT,
Ping Chengeda01da2015-09-23 13:51:15 -0700151 INTUOSHT2,
Ping Cheng3b164a02015-09-23 09:59:10 -0700152 BAMBOO_TOUCH,
Ping Chengea2e6022012-06-12 00:14:12 -0700153 BAMBOO_PT,
Jason Gereckeb1e42792012-10-21 00:38:04 -0700154 WACOM_24HDT,
Ping Cheng500d4162015-01-27 13:30:03 -0800155 WACOM_27QHDT,
Benjamin Tissoires8c97a762015-02-26 11:28:50 -0500156 BAMBOO_PAD,
Ping Cheng7adb91b2015-10-26 14:29:12 -0700157 WIRELESS,
Aaron Skomra72b236d2015-08-20 16:05:17 -0700158 REMOTE,
Ping Chengea2e6022012-06-12 00:14:12 -0700159 TABLETPC, /* add new TPC below */
Ping Chengac173832012-06-12 00:15:06 -0700160 TABLETPCE,
Ping Chengec67bbe2009-12-15 00:35:24 -0800161 TABLETPC2FG,
Ping Cheng19635182012-04-29 21:09:18 -0700162 MTSCREEN,
Ping Cheng6afdc282012-11-03 12:16:15 -0700163 MTTPC,
Jason Gerecked51ddb22014-05-14 17:14:29 -0700164 MTTPC_B,
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400165 HID_GENERIC,
Ping Cheng3bea7332006-07-13 18:01:36 -0700166 MAX_TYPE
167};
168
169struct wacom_features {
Jason Childse33da8a2010-02-17 22:38:31 -0800170 const char *name;
Ping Cheng3bea7332006-07-13 18:01:36 -0700171 int x_max;
172 int y_max;
173 int pressure_max;
174 int distance_max;
175 int type;
Ping Chenge35fb8c2011-03-26 21:16:05 -0700176 int x_resolution;
177 int y_resolution;
Aaron Skomra70ee06c2015-08-20 16:05:16 -0700178 int numbered_buttons;
Ping Chengac414da2014-05-29 00:08:41 -0700179 int x_min;
180 int y_min;
Ping Chengec67bbe2009-12-15 00:35:24 -0800181 int device_type;
182 int x_phy;
183 int y_phy;
Benjamin Tissoiresc669fb22014-07-24 13:02:14 -0700184 unsigned unit;
185 int unitExpo;
Henrik Rydbergfed87e62010-09-05 12:25:11 -0700186 int x_fuzz;
187 int y_fuzz;
188 int pressure_fuzz;
189 int distance_fuzz;
Jason Gereckebef7e202016-04-22 14:30:53 -0700190 int tilt_fuzz;
Henrik Rydbergbc73dd32010-09-05 12:26:16 -0700191 unsigned quirks;
Ping Chengf393ee22012-04-29 21:09:17 -0700192 unsigned touch_max;
Jason Gereckeaea2bf62012-10-21 00:38:03 -0700193 int oVid;
194 int oPid;
Benjamin Tissoires80befa92014-07-24 13:05:19 -0700195 int pktlen;
Benjamin Tissoires29b47392014-07-24 12:52:23 -0700196 bool check_for_hid_type;
197 int hid_type;
Ping Cheng3bea7332006-07-13 18:01:36 -0700198};
199
Ping Cheng4492eff2010-03-19 22:18:15 -0700200struct wacom_shared {
201 bool stylus_in_proximity;
Ping Chenga43c7c52011-03-12 20:34:42 -0800202 bool touch_down;
Ping Cheng961794a2013-12-05 12:54:53 -0800203 /* for wireless device to access USB interfaces */
204 unsigned touch_max;
205 int type;
206 struct input_dev *touch_input;
Benjamin Tissoiresa97ac102015-02-25 11:43:39 -0500207 struct hid_device *pen;
208 struct hid_device *touch;
Ping Cheng4492eff2010-03-19 22:18:15 -0700209};
210
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400211struct hid_data {
Benjamin Tissoires5ae6e892014-09-23 12:08:09 -0400212 __s16 inputmode; /* InputMode HID feature, -1 if non-existent */
213 __s16 inputmode_index; /* InputMode HID feature index in the report */
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400214 bool inrange_state;
215 bool invert_state;
216 bool tipswitch;
Benjamin Tissoires5ae6e892014-09-23 12:08:09 -0400217 int x;
218 int y;
219 int pressure;
220 int width;
221 int height;
222 int id;
Jason Gerecke499522c2015-10-07 16:54:21 -0700223 int cc_report;
Jason Gerecke1b5d514a2015-07-21 11:07:24 -0700224 int cc_index;
225 int cc_value_index;
Jason Gerecke003f50a2016-07-21 09:10:46 -0700226 int last_slot_field;
Jason Gerecke1b5d514a2015-07-21 11:07:24 -0700227 int num_expected;
228 int num_received;
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400229};
230
Benjamin Tissoirese6f28132016-07-13 18:06:01 +0200231struct wacom_remote_data {
232 struct {
233 u32 serial;
234 bool connected;
235 } remote[WACOM_MAX_REMOTES];
236};
237
Ping Cheng3bea7332006-07-13 18:01:36 -0700238struct wacom_wac {
Benjamin Tissoires99569532016-07-13 18:06:17 +0200239 char name[WACOM_NAME_MAX];
Jason Gerecke2a6cdbd2015-06-15 18:01:45 -0700240 char pen_name[WACOM_NAME_MAX];
241 char touch_name[WACOM_NAME_MAX];
Benjamin Tissoiresd2d13f12014-07-24 12:48:28 -0700242 char pad_name[WACOM_NAME_MAX];
Benjamin Tissoires29b47392014-07-24 12:52:23 -0700243 unsigned char data[WACOM_PKGLEN_MAX];
Ping Cheng4fc19382011-03-12 20:33:33 -0800244 int tool[2];
245 int id[2];
Benjamin Tissoires83e6b402016-07-13 18:06:02 +0200246 __u32 serial[2];
Ping Chengb3bd7ef2015-01-09 11:05:13 -0800247 bool reporting_data;
Jason Childse33da8a2010-02-17 22:38:31 -0800248 struct wacom_features features;
Ping Cheng4492eff2010-03-19 22:18:15 -0700249 struct wacom_shared *shared;
Jason Gerecke2a6cdbd2015-06-15 18:01:45 -0700250 struct input_dev *pen_input;
251 struct input_dev *touch_input;
Benjamin Tissoiresd2d13f12014-07-24 12:48:28 -0700252 struct input_dev *pad_input;
Chris Bagwell16bf2882012-03-25 23:26:20 -0700253 int pid;
Ping Cheng19635182012-04-29 21:09:18 -0700254 int num_contacts_left;
Benjamin Tissoiresf81a1292014-08-06 13:48:01 -0700255 u8 bt_features;
256 u8 bt_high_speed;
Jason Gerecke326ea2a2016-04-04 11:26:52 -0700257 int mode_report;
258 int mode_value;
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400259 struct hid_data hid_data;
Ping Cheng3bea7332006-07-13 18:01:36 -0700260};
261
262#endif