2006-07-13 18:01:36 -07:00
/*
2007-05-07 16:16:29 -04:00
* drivers / input / tablet / wacom_wac . h
2006-07-13 18:01:36 -07:00
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 2 of the License , or
* ( at your option ) any later version .
*/
# ifndef WACOM_WAC_H
# define WACOM_WAC_H
2010-03-19 22:18:15 -07:00
# include <linux/types.h>
2015-01-05 16:32:12 -05:00
# include <linux/hid.h>
2010-03-19 22:18:15 -07:00
2009-12-15 00:35:24 -08:00
/* maximum packet length for USB devices */
2015-01-27 13:30:03 -08:00
# define WACOM_PKGLEN_MAX 192
2009-12-15 00:35:24 -08:00
2013-10-15 23:44:00 -07:00
# define WACOM_NAME_MAX 64
2009-12-15 00:35:24 -08:00
/* packet length for individual models */
# define WACOM_PKGLEN_PENPRTN 7
# define WACOM_PKGLEN_GRAPHIRE 8
2010-02-17 22:38:31 -08:00
# define WACOM_PKGLEN_BBFUN 9
# define WACOM_PKGLEN_INTUOS 10
2009-12-15 00:35:24 -08:00
# define WACOM_PKGLEN_TPC1FG 5
2014-05-14 11:42:22 -07:00
# define WACOM_PKGLEN_TPC1FG_B 10
2010-02-17 22:38:31 -08:00
# define WACOM_PKGLEN_TPC2FG 14
2010-09-05 12:25:40 -07:00
# define WACOM_PKGLEN_BBTOUCH 20
2011-10-26 22:32:52 -07:00
# define WACOM_PKGLEN_BBTOUCH3 64
2011-10-26 22:34:21 -07:00
# define WACOM_PKGLEN_BBPEN 10
2012-03-25 23:26:11 -07:00
# define WACOM_PKGLEN_WIRELESS 32
2012-04-29 21:09:18 -07:00
# define WACOM_PKGLEN_MTOUCH 62
2012-11-03 12:16:15 -07:00
# define WACOM_PKGLEN_MTTPC 40
2014-01-20 20:18:04 -08:00
# define WACOM_PKGLEN_DTUS 68
2014-05-14 17:14:29 -07:00
# define WACOM_PKGLEN_PENABLED 8
2015-02-26 11:28:50 -05:00
# define WACOM_PKGLEN_BPAD_TOUCH 32
# define WACOM_PKGLEN_BPAD_TOUCH_USB 64
2012-04-29 21:09:18 -07:00
/* wacom data size per MT contact */
# define WACOM_BYTES_PER_MT_PACKET 11
2012-10-21 00:38:04 -07:00
# define WACOM_BYTES_PER_24HDT_PACKET 14
2015-01-27 13:30:03 -08:00
# define WACOM_BYTES_PER_QHDTHID_PACKET 6
2009-12-15 00:35:24 -08:00
2009-12-15 00:35:24 -08:00
/* device IDs */
2006-07-13 18:01:36 -07:00
# define STYLUS_DEVICE_ID 0x02
2008-11-24 11:44:27 -05:00
# define TOUCH_DEVICE_ID 0x03
2006-07-13 18:01:36 -07:00
# define CURSOR_DEVICE_ID 0x06
# define ERASER_DEVICE_ID 0x0A
2007-02-23 12:22:48 -08:00
# define PAD_DEVICE_ID 0x0F
2006-07-13 18:01:36 -07:00
2009-12-15 00:35:25 -08:00
/* wacom data packet report IDs */
# define WACOM_REPORT_PENABLED 2
2014-08-06 13:52:56 -07:00
# define WACOM_REPORT_PENABLED_BT 3
2009-12-15 00:35:25 -08:00
# define WACOM_REPORT_INTUOSREAD 5
# define WACOM_REPORT_INTUOSWRITE 6
# define WACOM_REPORT_INTUOSPAD 12
2012-04-03 15:48:35 -07:00
# define WACOM_REPORT_INTUOS5PAD 3
2014-01-20 20:18:04 -08:00
# define WACOM_REPORT_DTUSPAD 21
2009-12-15 00:35:25 -08:00
# define WACOM_REPORT_TPC1FG 6
# define WACOM_REPORT_TPC2FG 13
2012-04-29 21:09:18 -07:00
# define WACOM_REPORT_TPCMT 13
2014-05-14 17:14:29 -07:00
# define WACOM_REPORT_TPCMT2 3
2012-01-31 00:07:33 -08:00
# define WACOM_REPORT_TPCHID 15
2015-01-27 13:30:03 -08:00
# define WACOM_REPORT_CINTIQ 16
# define WACOM_REPORT_CINTIQPAD 17
2012-01-31 00:07:33 -08:00
# define WACOM_REPORT_TPCST 16
2014-01-20 20:18:04 -08:00
# define WACOM_REPORT_DTUS 17
2012-06-12 00:15:06 -07:00
# define WACOM_REPORT_TPC1FGE 18
2012-10-21 00:38:04 -07:00
# define WACOM_REPORT_24HDT 1
2013-11-25 18:44:55 -08:00
# define WACOM_REPORT_WL 128
2013-12-05 12:54:53 -08:00
# define WACOM_REPORT_USB 192
2015-02-26 11:28:50 -05:00
# define WACOM_REPORT_BPAD_PEN 3
# define WACOM_REPORT_BPAD_TOUCH 16
2015-03-06 11:47:38 -08:00
# define WACOM_PKGLEN_STATUS 10
2009-12-15 00:35:25 -08:00
2010-09-05 12:26:16 -07:00
/* device quirks */
# define WACOM_QUIRK_MULTI_INPUT 0x0001
2010-09-05 12:57:13 -07:00
# define WACOM_QUIRK_BBTOUCH_LOWRES 0x0002
2012-03-25 23:26:11 -07:00
# define WACOM_QUIRK_NO_INPUT 0x0004
# define WACOM_QUIRK_MONITOR 0x0008
2014-07-25 17:29:48 -07:00
# define WACOM_QUIRK_BATTERY 0x0010
2010-09-05 12:26:16 -07:00
2015-01-05 16:32:12 -05:00
# define WACOM_PEN_FIELD(f) (((f)->logical == HID_DG_STYLUS) || \
( ( f ) - > physical = = HID_DG_STYLUS ) | | \
2015-01-05 16:32:13 -05:00
( ( f ) - > physical = = HID_DG_PEN ) | | \
2015-01-05 16:32:12 -05:00
( ( f ) - > application = = HID_DG_PEN ) )
# define WACOM_FINGER_FIELD(f) (((f)->logical == HID_DG_FINGER) || \
( ( f ) - > physical = = HID_DG_FINGER ) | | \
( ( f ) - > application = = HID_DG_TOUCHSCREEN ) )
2006-07-13 18:01:36 -07:00
enum {
PENPARTNER = 0 ,
GRAPHIRE ,
2014-08-06 13:52:56 -07:00
GRAPHIRE_BT ,
2006-07-13 18:01:36 -07:00
WACOM_G4 ,
PTU ,
PL ,
2010-06-28 01:10:51 -07:00
DTU ,
2014-01-20 20:18:04 -08:00
DTUS ,
2014-12-04 18:23:04 -08:00
DTUSX ,
2006-07-13 18:01:36 -07:00
INTUOS ,
2006-09-26 13:34:47 -07:00
INTUOS3S ,
2006-07-13 18:01:36 -07:00
INTUOS3 ,
INTUOS3L ,
2009-05-08 18:30:33 -07:00
INTUOS4S ,
INTUOS4 ,
2014-08-06 13:55:56 -07:00
INTUOS4WL ,
2009-05-08 18:30:33 -07:00
INTUOS4L ,
2012-04-03 15:47:22 -07:00
INTUOS5S ,
INTUOS5 ,
INTUOS5L ,
2013-09-20 09:51:56 -07:00
INTUOSPS ,
INTUOSPM ,
INTUOSPL ,
2013-11-25 18:44:55 -08:00
INTUOSHT ,
2010-06-03 22:10:21 -07:00
WACOM_21UX2 ,
2012-07-24 23:54:11 -07:00
WACOM_22HD ,
2013-02-13 20:20:01 -08:00
DTK ,
2012-07-24 23:54:11 -07:00
WACOM_24HD ,
2015-01-27 13:30:03 -08:00
WACOM_27QHD ,
2013-09-20 09:47:35 -07:00
CINTIQ_HYBRID ,
2006-07-13 18:01:36 -07:00
CINTIQ ,
2008-03-13 16:46:46 -04:00
WACOM_BEE ,
2013-05-05 19:56:18 -07:00
WACOM_13HD ,
2007-06-14 23:32:48 -04:00
WACOM_MO ,
2012-06-12 00:14:12 -07:00
WIRELESS ,
BAMBOO_PT ,
2012-10-21 00:38:04 -07:00
WACOM_24HDT ,
2015-01-27 13:30:03 -08:00
WACOM_27QHDT ,
2015-02-26 11:28:50 -05:00
BAMBOO_PAD ,
2012-06-12 00:14:12 -07:00
TABLETPC , /* add new TPC below */
2012-06-12 00:15:06 -07:00
TABLETPCE ,
2009-12-15 00:35:24 -08:00
TABLETPC2FG ,
2012-04-29 21:09:18 -07:00
MTSCREEN ,
2012-11-03 12:16:15 -07:00
MTTPC ,
2014-05-14 17:14:29 -07:00
MTTPC_B ,
2014-09-23 12:08:08 -04:00
HID_GENERIC ,
2006-07-13 18:01:36 -07:00
MAX_TYPE
} ;
struct wacom_features {
2010-02-17 22:38:31 -08:00
const char * name ;
2006-07-13 18:01:36 -07:00
int x_max ;
int y_max ;
int pressure_max ;
int distance_max ;
int type ;
2011-03-26 21:16:05 -07:00
int x_resolution ;
int y_resolution ;
2014-05-29 00:08:41 -07:00
int x_min ;
int y_min ;
2009-12-15 00:35:24 -08:00
int device_type ;
int x_phy ;
int y_phy ;
2014-07-24 13:02:14 -07:00
unsigned unit ;
int unitExpo ;
2010-09-05 12:25:11 -07:00
int x_fuzz ;
int y_fuzz ;
int pressure_fuzz ;
int distance_fuzz ;
2010-09-05 12:26:16 -07:00
unsigned quirks ;
2012-04-29 21:09:17 -07:00
unsigned touch_max ;
2012-10-21 00:38:03 -07:00
int oVid ;
int oPid ;
2014-07-24 13:05:19 -07:00
int pktlen ;
2014-07-24 12:52:23 -07:00
bool check_for_hid_type ;
int hid_type ;
2014-12-10 16:26:04 -08:00
int last_slot_field ;
2006-07-13 18:01:36 -07:00
} ;
2010-03-19 22:18:15 -07:00
struct wacom_shared {
bool stylus_in_proximity ;
2011-03-12 20:34:42 -08:00
bool touch_down ;
2013-12-05 12:54:53 -08:00
/* for wireless device to access USB interfaces */
unsigned touch_max ;
int type ;
struct input_dev * touch_input ;
2015-02-25 11:43:39 -05:00
struct hid_device * pen ;
struct hid_device * touch ;
2010-03-19 22:18:15 -07:00
} ;
2014-09-23 12:08:08 -04:00
struct hid_data {
2014-09-23 12:08:09 -04:00
__s16 inputmode ; /* InputMode HID feature, -1 if non-existent */
__s16 inputmode_index ; /* InputMode HID feature index in the report */
2014-09-23 12:08:08 -04:00
bool inrange_state ;
bool invert_state ;
bool tipswitch ;
2014-09-23 12:08:09 -04:00
int x ;
int y ;
int pressure ;
int width ;
int height ;
int id ;
2014-09-23 12:08:08 -04:00
} ;
2006-07-13 18:01:36 -07:00
struct wacom_wac {
2013-10-15 23:44:00 -07:00
char name [ WACOM_NAME_MAX ] ;
Input: wacom - create a separate input device for pads
Currently, the pad events are sent through the stylus input device
for the Intuos/Cintiqs, and through the touch input device for the
Bamboos.
To differentiate the buttons pressed on the pad from the ones pressed
on the stylus, the Intuos/Cintiq uses MISC_SERIAL and ABS_MISC. This
lead to a multiplexing of the events into one device, which are then
splitted out in xf86-input-wacom. Bamboos are not using MISC events
because the pad is attached to the touch interface, and only BTN_TOUCH
is used for the finger (and DOUBLE_TAP, etc...). However, the user space
driver still splits out the pad from the touch interface in the same
way it does for the pro line devices.
The other problem we can see with this fact is that some of the Intuos
and Cintiq have a wheel, and the effective range of the reported values
is [0..71]. Unfortunately, the airbrush stylus also sends wheel events
(there is a small wheel on it), but in the range [0..1023]. From the user
space point of view it is kind of difficult to understand that because
the wheel on the pad are quite common, while the airbrush tool is not.
A solution to fix all of these problems is to split out the pad device
from the stylus/touch. This decision makes more sense because the pad is
not linked to the absolute position of the finger or pen, and usually, the
events from the pad are filtered out by the compositor, which then convert
them into actions or keyboard shortcuts.
For backward compatibility with current xf86-input-wacom, the pad devices
still present the ABS_X, ABS_Y and ABS_MISC events, but they can be
completely ignored in the new implementation.
Signed-off-by: Benjamin Tissoires <benjamin.tissoires@redhat.com>
Reviewed-by: Ping Cheng <pingc@wacom.com>
Reviewed-by: Jason Gerecke <killertofu@gmail.com>
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
2014-07-24 12:48:28 -07:00
char pad_name [ WACOM_NAME_MAX ] ;
2014-07-25 17:31:51 -07:00
char bat_name [ WACOM_NAME_MAX ] ;
2014-07-25 17:32:41 -07:00
char ac_name [ WACOM_NAME_MAX ] ;
2014-07-24 12:52:23 -07:00
unsigned char data [ WACOM_PKGLEN_MAX ] ;
2011-03-12 20:33:33 -08:00
int tool [ 2 ] ;
int id [ 2 ] ;
2010-02-20 00:53:49 -08:00
__u32 serial [ 2 ] ;
2015-01-09 11:05:13 -08:00
bool reporting_data ;
2010-02-17 22:38:31 -08:00
struct wacom_features features ;
2010-03-19 22:18:15 -07:00
struct wacom_shared * shared ;
2010-03-19 22:18:15 -07:00
struct input_dev * input ;
Input: wacom - create a separate input device for pads
Currently, the pad events are sent through the stylus input device
for the Intuos/Cintiqs, and through the touch input device for the
Bamboos.
To differentiate the buttons pressed on the pad from the ones pressed
on the stylus, the Intuos/Cintiq uses MISC_SERIAL and ABS_MISC. This
lead to a multiplexing of the events into one device, which are then
splitted out in xf86-input-wacom. Bamboos are not using MISC events
because the pad is attached to the touch interface, and only BTN_TOUCH
is used for the finger (and DOUBLE_TAP, etc...). However, the user space
driver still splits out the pad from the touch interface in the same
way it does for the pro line devices.
The other problem we can see with this fact is that some of the Intuos
and Cintiq have a wheel, and the effective range of the reported values
is [0..71]. Unfortunately, the airbrush stylus also sends wheel events
(there is a small wheel on it), but in the range [0..1023]. From the user
space point of view it is kind of difficult to understand that because
the wheel on the pad are quite common, while the airbrush tool is not.
A solution to fix all of these problems is to split out the pad device
from the stylus/touch. This decision makes more sense because the pad is
not linked to the absolute position of the finger or pen, and usually, the
events from the pad are filtered out by the compositor, which then convert
them into actions or keyboard shortcuts.
For backward compatibility with current xf86-input-wacom, the pad devices
still present the ABS_X, ABS_Y and ABS_MISC events, but they can be
completely ignored in the new implementation.
Signed-off-by: Benjamin Tissoires <benjamin.tissoires@redhat.com>
Reviewed-by: Ping Cheng <pingc@wacom.com>
Reviewed-by: Jason Gerecke <killertofu@gmail.com>
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
2014-07-24 12:48:28 -07:00
struct input_dev * pad_input ;
2014-09-23 12:08:06 -04:00
bool input_registered ;
2014-11-20 16:31:12 -08:00
bool pad_registered ;
2012-03-25 23:26:20 -07:00
int pid ;
2012-03-25 23:26:30 -07:00
int battery_capacity ;
2012-04-29 21:09:18 -07:00
int num_contacts_left ;
2014-07-25 17:29:48 -07:00
int bat_charging ;
int ps_connected ;
2014-08-06 13:48:01 -07:00
u8 bt_features ;
u8 bt_high_speed ;
2014-09-23 12:08:08 -04:00
struct hid_data hid_data ;
2006-07-13 18:01:36 -07:00
} ;
# endif