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