blob: e2084d914c14aa3902b42e2cb852517c31327256 [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 Gereckeaa86b182015-06-15 18:01:42 -070085
Jason Gerecke042628a2015-04-30 17:51:54 -070086#define WACOM_VENDORDEFINED_PEN 0xff0d0001
Jason Gerecke326ea2a2016-04-04 11:26:52 -070087#define WACOM_G9_PAGE 0xff090000
88#define WACOM_G9_DIGITIZER (WACOM_G9_PAGE | 0x02)
89#define WACOM_G9_TOUCHSCREEN (WACOM_G9_PAGE | 0x11)
90#define WACOM_G11_PAGE 0xff110000
91#define WACOM_G11_DIGITIZER (WACOM_G11_PAGE | 0x02)
92#define WACOM_G11_TOUCHSCREEN (WACOM_G11_PAGE | 0x11)
Jason Gerecke042628a2015-04-30 17:51:54 -070093
Benjamin Tissoiresd97a5522015-01-05 16:32:12 -050094#define WACOM_PEN_FIELD(f) (((f)->logical == HID_DG_STYLUS) || \
95 ((f)->physical == HID_DG_STYLUS) || \
Benjamin Tissoires61e9e7e2015-01-05 16:32:13 -050096 ((f)->physical == HID_DG_PEN) || \
Jason Gerecke042628a2015-04-30 17:51:54 -070097 ((f)->application == HID_DG_PEN) || \
98 ((f)->application == HID_DG_DIGITIZER) || \
99 ((f)->application == WACOM_VENDORDEFINED_PEN))
Benjamin Tissoiresd97a5522015-01-05 16:32:12 -0500100#define WACOM_FINGER_FIELD(f) (((f)->logical == HID_DG_FINGER) || \
101 ((f)->physical == HID_DG_FINGER) || \
102 ((f)->application == HID_DG_TOUCHSCREEN))
103
Ping Cheng3bea7332006-07-13 18:01:36 -0700104enum {
105 PENPARTNER = 0,
106 GRAPHIRE,
Benjamin Tissoires387142b2014-08-06 13:52:56 -0700107 GRAPHIRE_BT,
Ping Cheng3bea7332006-07-13 18:01:36 -0700108 WACOM_G4,
109 PTU,
110 PL,
Ping Chengc8f2edc2010-06-28 01:10:51 -0700111 DTU,
Ping Cheng497ab1f2014-01-20 20:18:04 -0800112 DTUS,
Ping Chengfff00bf2014-12-04 18:23:04 -0800113 DTUSX,
Ping Cheng3bea7332006-07-13 18:01:36 -0700114 INTUOS,
Ping Cheng8d32e3a2006-09-26 13:34:47 -0700115 INTUOS3S,
Ping Cheng3bea7332006-07-13 18:01:36 -0700116 INTUOS3,
117 INTUOS3L,
Ping Cheng6f660f12009-05-08 18:30:33 -0700118 INTUOS4S,
119 INTUOS4,
Benjamin Tissoires81af7e62014-08-06 13:55:56 -0700120 INTUOS4WL,
Ping Cheng6f660f12009-05-08 18:30:33 -0700121 INTUOS4L,
Jason Gerecke9fee6192012-04-03 15:47:22 -0700122 INTUOS5S,
123 INTUOS5,
124 INTUOS5L,
Ping Cheng9a35c412013-09-20 09:51:56 -0700125 INTUOSPS,
126 INTUOSPM,
127 INTUOSPL,
Ping Cheng3a4b4aa2010-06-03 22:10:21 -0700128 WACOM_21UX2,
Ping Chengd838c642012-07-24 23:54:11 -0700129 WACOM_22HD,
Ping Chenga112e9f2013-02-13 20:20:01 -0800130 DTK,
Ping Chengd838c642012-07-24 23:54:11 -0700131 WACOM_24HD,
Ping Cheng500d4162015-01-27 13:30:03 -0800132 WACOM_27QHD,
Jason Gerecke36d3c512013-09-20 09:47:35 -0700133 CINTIQ_HYBRID,
Jason Gereckef7acb552015-10-13 10:03:49 -0700134 CINTIQ_COMPANION_2,
Ping Cheng3bea7332006-07-13 18:01:36 -0700135 CINTIQ,
Ping Cheng0e1763f2008-03-13 16:46:46 -0400136 WACOM_BEE,
Ping Cheng56218562013-05-05 19:56:18 -0700137 WACOM_13HD,
Ping Cheng7ecfbfd2007-06-14 23:32:48 -0400138 WACOM_MO,
Ping Cheng3b164a02015-09-23 09:59:10 -0700139 BAMBOO_PEN,
140 INTUOSHT,
Ping Chengeda01da2015-09-23 13:51:15 -0700141 INTUOSHT2,
Ping Cheng3b164a02015-09-23 09:59:10 -0700142 BAMBOO_TOUCH,
Ping Chengea2e6022012-06-12 00:14:12 -0700143 BAMBOO_PT,
Jason Gereckeb1e42792012-10-21 00:38:04 -0700144 WACOM_24HDT,
Ping Cheng500d4162015-01-27 13:30:03 -0800145 WACOM_27QHDT,
Benjamin Tissoires8c97a762015-02-26 11:28:50 -0500146 BAMBOO_PAD,
Ping Cheng7adb91b2015-10-26 14:29:12 -0700147 WIRELESS,
Aaron Skomra72b236d2015-08-20 16:05:17 -0700148 REMOTE,
Ping Chengea2e6022012-06-12 00:14:12 -0700149 TABLETPC, /* add new TPC below */
Ping Chengac173832012-06-12 00:15:06 -0700150 TABLETPCE,
Ping Chengec67bbe2009-12-15 00:35:24 -0800151 TABLETPC2FG,
Ping Cheng19635182012-04-29 21:09:18 -0700152 MTSCREEN,
Ping Cheng6afdc282012-11-03 12:16:15 -0700153 MTTPC,
Jason Gerecked51ddb22014-05-14 17:14:29 -0700154 MTTPC_B,
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400155 HID_GENERIC,
Ping Cheng3bea7332006-07-13 18:01:36 -0700156 MAX_TYPE
157};
158
159struct wacom_features {
Jason Childse33da8a2010-02-17 22:38:31 -0800160 const char *name;
Ping Cheng3bea7332006-07-13 18:01:36 -0700161 int x_max;
162 int y_max;
163 int pressure_max;
164 int distance_max;
165 int type;
Ping Chenge35fb8c2011-03-26 21:16:05 -0700166 int x_resolution;
167 int y_resolution;
Aaron Skomra70ee06c2015-08-20 16:05:16 -0700168 int numbered_buttons;
Ping Chengac414da2014-05-29 00:08:41 -0700169 int x_min;
170 int y_min;
Ping Chengec67bbe2009-12-15 00:35:24 -0800171 int device_type;
172 int x_phy;
173 int y_phy;
Benjamin Tissoiresc669fb22014-07-24 13:02:14 -0700174 unsigned unit;
175 int unitExpo;
Henrik Rydbergfed87e62010-09-05 12:25:11 -0700176 int x_fuzz;
177 int y_fuzz;
178 int pressure_fuzz;
179 int distance_fuzz;
Henrik Rydbergbc73dd32010-09-05 12:26:16 -0700180 unsigned quirks;
Ping Chengf393ee22012-04-29 21:09:17 -0700181 unsigned touch_max;
Jason Gereckeaea2bf62012-10-21 00:38:03 -0700182 int oVid;
183 int oPid;
Benjamin Tissoires80befa92014-07-24 13:05:19 -0700184 int pktlen;
Benjamin Tissoires29b47392014-07-24 12:52:23 -0700185 bool check_for_hid_type;
186 int hid_type;
Jason Gerecke601a22f2014-12-10 16:26:04 -0800187 int last_slot_field;
Ping Cheng3bea7332006-07-13 18:01:36 -0700188};
189
Ping Cheng4492eff2010-03-19 22:18:15 -0700190struct wacom_shared {
191 bool stylus_in_proximity;
Ping Chenga43c7c52011-03-12 20:34:42 -0800192 bool touch_down;
Ping Cheng961794a2013-12-05 12:54:53 -0800193 /* for wireless device to access USB interfaces */
194 unsigned touch_max;
195 int type;
196 struct input_dev *touch_input;
Benjamin Tissoiresa97ac102015-02-25 11:43:39 -0500197 struct hid_device *pen;
198 struct hid_device *touch;
Ping Cheng4492eff2010-03-19 22:18:15 -0700199};
200
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400201struct hid_data {
Benjamin Tissoires5ae6e892014-09-23 12:08:09 -0400202 __s16 inputmode; /* InputMode HID feature, -1 if non-existent */
203 __s16 inputmode_index; /* InputMode HID feature index in the report */
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400204 bool inrange_state;
205 bool invert_state;
206 bool tipswitch;
Benjamin Tissoires5ae6e892014-09-23 12:08:09 -0400207 int x;
208 int y;
209 int pressure;
210 int width;
211 int height;
212 int id;
Jason Gerecke499522c2015-10-07 16:54:21 -0700213 int cc_report;
Jason Gerecke1b5d514a2015-07-21 11:07:24 -0700214 int cc_index;
215 int cc_value_index;
216 int num_expected;
217 int num_received;
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400218};
219
Ping Cheng3bea7332006-07-13 18:01:36 -0700220struct wacom_wac {
Jason Gerecke2a6cdbd2015-06-15 18:01:45 -0700221 char pen_name[WACOM_NAME_MAX];
222 char touch_name[WACOM_NAME_MAX];
Benjamin Tissoiresd2d13f12014-07-24 12:48:28 -0700223 char pad_name[WACOM_NAME_MAX];
Benjamin Tissoiresd70420b2014-07-25 17:31:51 -0700224 char bat_name[WACOM_NAME_MAX];
Benjamin Tissoires7dbd2292014-07-25 17:32:41 -0700225 char ac_name[WACOM_NAME_MAX];
Benjamin Tissoires29b47392014-07-24 12:52:23 -0700226 unsigned char data[WACOM_PKGLEN_MAX];
Ping Cheng4fc19382011-03-12 20:33:33 -0800227 int tool[2];
228 int id[2];
Aaron Skomra72b236d2015-08-20 16:05:17 -0700229 __u32 serial[5];
Ping Chengb3bd7ef2015-01-09 11:05:13 -0800230 bool reporting_data;
Jason Childse33da8a2010-02-17 22:38:31 -0800231 struct wacom_features features;
Ping Cheng4492eff2010-03-19 22:18:15 -0700232 struct wacom_shared *shared;
Jason Gerecke2a6cdbd2015-06-15 18:01:45 -0700233 struct input_dev *pen_input;
234 struct input_dev *touch_input;
Benjamin Tissoiresd2d13f12014-07-24 12:48:28 -0700235 struct input_dev *pad_input;
Jason Gerecke2a6cdbd2015-06-15 18:01:45 -0700236 bool pen_registered;
237 bool touch_registered;
Ping Cheng954df6a2014-11-20 16:31:12 -0800238 bool pad_registered;
Chris Bagwell16bf2882012-03-25 23:26:20 -0700239 int pid;
Chris Bagwella1d552c2012-03-25 23:26:30 -0700240 int battery_capacity;
Ping Cheng19635182012-04-29 21:09:18 -0700241 int num_contacts_left;
Benjamin Tissoiresac8d1012014-07-25 17:29:48 -0700242 int bat_charging;
Jason Gerecke71fa6412015-03-11 10:25:41 -0700243 int bat_connected;
Benjamin Tissoiresac8d1012014-07-25 17:29:48 -0700244 int ps_connected;
Benjamin Tissoiresf81a1292014-08-06 13:48:01 -0700245 u8 bt_features;
246 u8 bt_high_speed;
Jason Gerecke326ea2a2016-04-04 11:26:52 -0700247 int mode_report;
248 int mode_value;
Benjamin Tissoires7704ac92014-09-23 12:08:08 -0400249 struct hid_data hid_data;
Ping Cheng3bea7332006-07-13 18:01:36 -0700250};
251
252#endif