2019-05-27 09:55:01 +03:00
/* SPDX-License-Identifier: GPL-2.0-or-later */
2022-08-02 22:35:57 +03:00
2006-07-14 05:01:36 +04:00
# ifndef WACOM_WAC_H
# define WACOM_WAC_H
2010-03-20 08:18:15 +03:00
# include <linux/types.h>
2015-01-06 00:32:12 +03:00
# include <linux/hid.h>
2017-11-10 22:50:01 +03:00
# include <linux/kfifo.h>
2010-03-20 08:18:15 +03:00
2017-01-25 23:08:37 +03:00
/* maximum packet length for USB/BT devices */
# define WACOM_PKGLEN_MAX 361
2009-12-15 11:35:24 +03:00
2013-10-16 10:44:00 +04:00
# define WACOM_NAME_MAX 64
2015-08-21 02:05:17 +03:00
# define WACOM_MAX_REMOTES 5
# define WACOM_STATUS_UNKNOWN 255
2023-07-26 01:20:25 +03:00
# define WACOM_REMOTE_BATTERY_TIMEOUT 21000000000ll
2013-10-16 10:44:00 +04:00
2009-12-15 11:35:24 +03:00
/* packet length for individual models */
2010-02-18 09:38:31 +03:00
# define WACOM_PKGLEN_BBFUN 9
2009-12-15 11:35:24 +03:00
# define WACOM_PKGLEN_TPC1FG 5
2014-05-14 22:42:22 +04:00
# define WACOM_PKGLEN_TPC1FG_B 10
2010-02-18 09:38:31 +03:00
# define WACOM_PKGLEN_TPC2FG 14
2010-09-05 23:25:40 +04:00
# define WACOM_PKGLEN_BBTOUCH 20
2011-10-27 09:32:52 +04:00
# define WACOM_PKGLEN_BBTOUCH3 64
2011-10-27 09:34:21 +04:00
# define WACOM_PKGLEN_BBPEN 10
2012-03-26 10:26:11 +04:00
# define WACOM_PKGLEN_WIRELESS 32
2014-05-15 04:14:29 +04:00
# define WACOM_PKGLEN_PENABLED 8
2015-02-26 19:28:50 +03:00
# define WACOM_PKGLEN_BPAD_TOUCH 32
# define WACOM_PKGLEN_BPAD_TOUCH_USB 64
2012-04-30 08:09:18 +04:00
/* wacom data size per MT contact */
# define WACOM_BYTES_PER_MT_PACKET 11
2012-10-21 11:38:04 +04:00
# define WACOM_BYTES_PER_24HDT_PACKET 14
2015-01-28 00:30:03 +03:00
# define WACOM_BYTES_PER_QHDTHID_PACKET 6
2009-12-15 11:35:24 +03:00
2009-12-15 11:35:24 +03:00
/* device IDs */
2006-07-14 05:01:36 +04:00
# define STYLUS_DEVICE_ID 0x02
2008-11-24 19:44:27 +03:00
# define TOUCH_DEVICE_ID 0x03
2006-07-14 05:01:36 +04:00
# define CURSOR_DEVICE_ID 0x06
# define ERASER_DEVICE_ID 0x0A
2007-02-23 23:22:48 +03:00
# define PAD_DEVICE_ID 0x0F
2006-07-14 05:01:36 +04:00
2009-12-15 11:35:25 +03:00
/* wacom data packet report IDs */
# define WACOM_REPORT_PENABLED 2
2014-08-07 00:52:56 +04:00
# define WACOM_REPORT_PENABLED_BT 3
2015-12-01 04:13:52 +03:00
# define WACOM_REPORT_INTUOS_ID1 5
# define WACOM_REPORT_INTUOS_ID2 6
2009-12-15 11:35:25 +03:00
# define WACOM_REPORT_INTUOSPAD 12
2012-04-04 02:48:35 +04:00
# define WACOM_REPORT_INTUOS5PAD 3
2014-01-21 08:18:04 +04:00
# define WACOM_REPORT_DTUSPAD 21
2009-12-15 11:35:25 +03:00
# define WACOM_REPORT_TPC1FG 6
# define WACOM_REPORT_TPC2FG 13
2012-04-30 08:09:18 +04:00
# define WACOM_REPORT_TPCMT 13
2014-05-15 04:14:29 +04:00
# define WACOM_REPORT_TPCMT2 3
2012-01-31 12:07:33 +04:00
# define WACOM_REPORT_TPCHID 15
2015-01-28 00:30:03 +03:00
# define WACOM_REPORT_CINTIQ 16
# define WACOM_REPORT_CINTIQPAD 17
2012-01-31 12:07:33 +04:00
# define WACOM_REPORT_TPCST 16
2014-01-21 08:18:04 +04:00
# define WACOM_REPORT_DTUS 17
2012-06-12 11:15:06 +04:00
# define WACOM_REPORT_TPC1FGE 18
2012-10-21 11:38:04 +04:00
# define WACOM_REPORT_24HDT 1
2013-11-26 06:44:55 +04:00
# define WACOM_REPORT_WL 128
2013-12-06 00:54:53 +04:00
# define WACOM_REPORT_USB 192
2015-02-26 19:28:50 +03:00
# define WACOM_REPORT_BPAD_PEN 3
# define WACOM_REPORT_BPAD_TOUCH 16
2015-08-21 02:05:17 +03:00
# define WACOM_REPORT_DEVICE_LIST 16
2015-09-23 23:51:15 +03:00
# define WACOM_REPORT_INTUOS_PEN 16
2015-08-21 02:05:17 +03:00
# define WACOM_REPORT_REMOTE 17
2016-01-07 00:25:53 +03:00
# define WACOM_REPORT_INTUOSHT2_ID 8
2009-12-15 11:35:25 +03:00
2017-01-25 23:08:36 +03:00
/* wacom command report ids */
# define WAC_CMD_WL_LED_CONTROL 0x03
# define WAC_CMD_LED_CONTROL 0x20
# define WAC_CMD_ICON_START 0x21
# define WAC_CMD_ICON_XFER 0x23
# define WAC_CMD_ICON_BT_XFER 0x26
# define WAC_CMD_DELETE_PAIRING 0x20
2017-01-25 23:08:42 +03:00
# define WAC_CMD_LED_CONTROL_GENERIC 0x32
2017-01-25 23:08:36 +03:00
# define WAC_CMD_UNPAIR_ALL 0xFF
2017-01-25 23:08:37 +03:00
# define WAC_CMD_WL_INTUOSP2 0x82
2017-01-25 23:08:36 +03:00
2010-09-05 23:26:16 +04:00
/* device quirks */
2015-03-21 00:57:00 +03:00
# define WACOM_QUIRK_BBTOUCH_LOWRES 0x0001
2016-10-20 04:03:46 +03:00
# define WACOM_QUIRK_SENSE 0x0002
2017-11-10 22:50:00 +03:00
# define WACOM_QUIRK_AESPEN 0x0004
2015-03-21 00:57:00 +03:00
# define WACOM_QUIRK_BATTERY 0x0008
2017-11-10 22:50:01 +03:00
# define WACOM_QUIRK_TOOLSERIAL 0x0010
2022-03-23 00:33:16 +03:00
# define WACOM_QUIRK_PEN_BUTTON3 0x0020
2010-09-05 23:26:16 +04:00
2015-06-16 04:01:42 +03:00
/* device types */
# define WACOM_DEVICETYPE_NONE 0x0000
# define WACOM_DEVICETYPE_PEN 0x0001
# define WACOM_DEVICETYPE_TOUCH 0x0002
2015-06-16 04:01:43 +03:00
# define WACOM_DEVICETYPE_PAD 0x0004
2015-08-03 20:17:04 +03:00
# define WACOM_DEVICETYPE_WL_MONITOR 0x0008
2016-08-08 22:06:29 +03:00
# define WACOM_DEVICETYPE_DIRECT 0x0010
2015-06-16 04:01:42 +03:00
2017-04-28 19:25:33 +03:00
# define WACOM_POWER_SUPPLY_STATUS_AUTO -1
2016-10-20 04:03:37 +03:00
# define WACOM_HID_UP_WACOMDIGITIZER 0xff0d0000
2016-10-20 04:03:51 +03:00
# define WACOM_HID_SP_PAD 0x00040000
# define WACOM_HID_SP_BUTTON 0x00090000
2016-10-20 04:03:43 +03:00
# define WACOM_HID_SP_DIGITIZER 0x000d0000
# define WACOM_HID_SP_DIGITIZERINFO 0x00100000
2016-10-20 04:03:37 +03:00
# define WACOM_HID_WD_DIGITIZER (WACOM_HID_UP_WACOMDIGITIZER | 0x01)
2017-01-25 23:08:40 +03:00
# define WACOM_HID_WD_PEN (WACOM_HID_UP_WACOMDIGITIZER | 0x02)
2016-10-20 04:03:46 +03:00
# define WACOM_HID_WD_SENSE (WACOM_HID_UP_WACOMDIGITIZER | 0x36)
2016-10-20 04:03:51 +03:00
# define WACOM_HID_WD_DIGITIZERFNKEYS (WACOM_HID_UP_WACOMDIGITIZER | 0x39)
2017-11-10 22:50:00 +03:00
# define WACOM_HID_WD_SERIALNUMBER (WACOM_HID_UP_WACOMDIGITIZER | 0x5b)
2016-10-20 04:03:48 +03:00
# define WACOM_HID_WD_SERIALHI (WACOM_HID_UP_WACOMDIGITIZER | 0x5c)
2022-03-23 00:33:16 +03:00
# define WACOM_HID_WD_BARRELSWITCH3 (WACOM_HID_UP_WACOMDIGITIZER | 0x5d)
2016-10-20 04:03:48 +03:00
# define WACOM_HID_WD_TOOLTYPE (WACOM_HID_UP_WACOMDIGITIZER | 0x77)
2016-10-20 04:03:44 +03:00
# define WACOM_HID_WD_DISTANCE (WACOM_HID_UP_WACOMDIGITIZER | 0x0132)
2016-10-20 04:03:53 +03:00
# define WACOM_HID_WD_TOUCHSTRIP (WACOM_HID_UP_WACOMDIGITIZER | 0x0136)
# define WACOM_HID_WD_TOUCHSTRIP2 (WACOM_HID_UP_WACOMDIGITIZER | 0x0137)
2016-10-20 04:03:51 +03:00
# define WACOM_HID_WD_TOUCHRING (WACOM_HID_UP_WACOMDIGITIZER | 0x0138)
# define WACOM_HID_WD_TOUCHRINGSTATUS (WACOM_HID_UP_WACOMDIGITIZER | 0x0139)
2018-03-06 21:48:35 +03:00
# define WACOM_HID_WD_REPORT_VALID (WACOM_HID_UP_WACOMDIGITIZER | 0x01d0)
2022-03-23 00:33:16 +03:00
# define WACOM_HID_WD_SEQUENCENUMBER (WACOM_HID_UP_WACOMDIGITIZER | 0x0220)
2016-10-20 04:03:51 +03:00
# define WACOM_HID_WD_ACCELEROMETER_X (WACOM_HID_UP_WACOMDIGITIZER | 0x0401)
# define WACOM_HID_WD_ACCELEROMETER_Y (WACOM_HID_UP_WACOMDIGITIZER | 0x0402)
# define WACOM_HID_WD_ACCELEROMETER_Z (WACOM_HID_UP_WACOMDIGITIZER | 0x0403)
2016-10-20 04:03:52 +03:00
# define WACOM_HID_WD_BATTERY_CHARGING (WACOM_HID_UP_WACOMDIGITIZER | 0x0404)
2017-01-25 23:08:41 +03:00
# define WACOM_HID_WD_TOUCHONOFF (WACOM_HID_UP_WACOMDIGITIZER | 0x0454)
2016-10-20 04:03:52 +03:00
# define WACOM_HID_WD_BATTERY_LEVEL (WACOM_HID_UP_WACOMDIGITIZER | 0x043b)
2016-10-20 04:03:51 +03:00
# define WACOM_HID_WD_EXPRESSKEY00 (WACOM_HID_UP_WACOMDIGITIZER | 0x0910)
2021-06-23 19:58:09 +03:00
# define WACOM_HID_WD_EXPRESSKEYCAP00 (WACOM_HID_UP_WACOMDIGITIZER | 0x0940)
2017-02-15 08:27:18 +03:00
# define WACOM_HID_WD_MODE_CHANGE (WACOM_HID_UP_WACOMDIGITIZER | 0x0980)
2017-02-15 08:27:45 +03:00
# define WACOM_HID_WD_MUTE_DEVICE (WACOM_HID_UP_WACOMDIGITIZER | 0x0981)
2017-02-15 08:26:21 +03:00
# define WACOM_HID_WD_CONTROLPANEL (WACOM_HID_UP_WACOMDIGITIZER | 0x0982)
# define WACOM_HID_WD_ONSCREEN_KEYBOARD (WACOM_HID_UP_WACOMDIGITIZER | 0x0983)
# define WACOM_HID_WD_BUTTONCONFIG (WACOM_HID_UP_WACOMDIGITIZER | 0x0986)
2016-10-20 04:03:51 +03:00
# define WACOM_HID_WD_BUTTONHOME (WACOM_HID_UP_WACOMDIGITIZER | 0x0990)
# define WACOM_HID_WD_BUTTONUP (WACOM_HID_UP_WACOMDIGITIZER | 0x0991)
# define WACOM_HID_WD_BUTTONDOWN (WACOM_HID_UP_WACOMDIGITIZER | 0x0992)
# define WACOM_HID_WD_BUTTONLEFT (WACOM_HID_UP_WACOMDIGITIZER | 0x0993)
# define WACOM_HID_WD_BUTTONRIGHT (WACOM_HID_UP_WACOMDIGITIZER | 0x0994)
2016-10-20 04:03:53 +03:00
# define WACOM_HID_WD_BUTTONCENTER (WACOM_HID_UP_WACOMDIGITIZER | 0x0995)
2016-10-20 04:03:45 +03:00
# define WACOM_HID_WD_FINGERWHEEL (WACOM_HID_UP_WACOMDIGITIZER | 0x0d03)
2016-10-20 04:03:50 +03:00
# define WACOM_HID_WD_OFFSETLEFT (WACOM_HID_UP_WACOMDIGITIZER | 0x0d30)
# define WACOM_HID_WD_OFFSETTOP (WACOM_HID_UP_WACOMDIGITIZER | 0x0d31)
# define WACOM_HID_WD_OFFSETRIGHT (WACOM_HID_UP_WACOMDIGITIZER | 0x0d32)
# define WACOM_HID_WD_OFFSETBOTTOM (WACOM_HID_UP_WACOMDIGITIZER | 0x0d33)
2016-10-20 04:03:43 +03:00
# define WACOM_HID_WD_DATAMODE (WACOM_HID_UP_WACOMDIGITIZER | 0x1002)
2016-10-20 04:03:51 +03:00
# define WACOM_HID_WD_DIGITIZERINFO (WACOM_HID_UP_WACOMDIGITIZER | 0x1013)
2019-05-11 01:31:16 +03:00
# define WACOM_HID_WD_TOUCH_RING_SETTING (WACOM_HID_UP_WACOMDIGITIZER | 0x1032)
2016-10-20 04:03:37 +03:00
# define WACOM_HID_UP_G9 0xff090000
# define WACOM_HID_G9_PEN (WACOM_HID_UP_G9 | 0x02)
# define WACOM_HID_G9_TOUCHSCREEN (WACOM_HID_UP_G9 | 0x11)
# define WACOM_HID_UP_G11 0xff110000
# define WACOM_HID_G11_PEN (WACOM_HID_UP_G11 | 0x02)
# define WACOM_HID_G11_TOUCHSCREEN (WACOM_HID_UP_G11 | 0x11)
2017-01-25 23:08:40 +03:00
# define WACOM_HID_UP_WACOMTOUCH 0xff000000
# define WACOM_HID_WT_TOUCHSCREEN (WACOM_HID_UP_WACOMTOUCH | 0x04)
# define WACOM_HID_WT_TOUCHPAD (WACOM_HID_UP_WACOMTOUCH | 0x05)
# define WACOM_HID_WT_CONTACTMAX (WACOM_HID_UP_WACOMTOUCH | 0x55)
2017-11-10 22:50:00 +03:00
# define WACOM_HID_WT_SERIALNUMBER (WACOM_HID_UP_WACOMTOUCH | 0x5b)
2017-01-25 23:08:40 +03:00
# define WACOM_HID_WT_X (WACOM_HID_UP_WACOMTOUCH | 0x130)
# define WACOM_HID_WT_Y (WACOM_HID_UP_WACOMTOUCH | 0x131)
2019-06-13 00:19:30 +03:00
# define WACOM_HID_WT_REPORT_VALID (WACOM_HID_UP_WACOMTOUCH | 0x1d0)
2015-05-01 03:51:54 +03:00
2017-04-28 19:25:34 +03:00
# define WACOM_BATTERY_USAGE(f) (((f)->hid == HID_DG_BATTERYSTRENGTH) || \
( ( f ) - > hid = = WACOM_HID_WD_BATTERY_CHARGING ) | | \
( ( f ) - > hid = = WACOM_HID_WD_BATTERY_LEVEL ) )
2016-10-20 04:03:51 +03:00
# define WACOM_PAD_FIELD(f) (((f)->physical == HID_DG_TABLETFUNCTIONKEY) || \
( ( f ) - > physical = = WACOM_HID_WD_DIGITIZERFNKEYS ) | | \
( ( f ) - > physical = = WACOM_HID_WD_DIGITIZERINFO ) )
2015-01-06 00:32:12 +03:00
# define WACOM_PEN_FIELD(f) (((f)->logical == HID_DG_STYLUS) || \
( ( f ) - > physical = = HID_DG_STYLUS ) | | \
2015-01-06 00:32:13 +03:00
( ( f ) - > physical = = HID_DG_PEN ) | | \
2015-05-01 03:51:54 +03:00
( ( f ) - > application = = HID_DG_PEN ) | | \
( ( f ) - > application = = HID_DG_DIGITIZER ) | | \
2017-10-18 18:27:13 +03:00
( ( f ) - > application = = WACOM_HID_WD_PEN ) | | \
2016-10-20 04:03:38 +03:00
( ( f ) - > application = = WACOM_HID_WD_DIGITIZER ) | | \
( ( f ) - > application = = WACOM_HID_G9_PEN ) | | \
( ( f ) - > application = = WACOM_HID_G11_PEN ) )
2015-01-06 00:32:12 +03:00
# define WACOM_FINGER_FIELD(f) (((f)->logical == HID_DG_FINGER) || \
( ( f ) - > physical = = HID_DG_FINGER ) | | \
2016-10-20 04:03:38 +03:00
( ( f ) - > application = = HID_DG_TOUCHSCREEN ) | | \
( ( f ) - > application = = WACOM_HID_G9_TOUCHSCREEN ) | | \
2017-01-25 23:08:40 +03:00
( ( f ) - > application = = WACOM_HID_G11_TOUCHSCREEN ) | | \
( ( f ) - > application = = WACOM_HID_WT_TOUCHPAD ) | | \
( ( f ) - > application = = HID_DG_TOUCHPAD ) )
# define WACOM_DIRECT_DEVICE(f) (((f)->application == HID_DG_TOUCHSCREEN) || \
( ( f ) - > application = = WACOM_HID_WT_TOUCHSCREEN ) | | \
( ( f ) - > application = = HID_DG_PEN ) | | \
( ( f ) - > application = = WACOM_HID_WD_PEN ) )
2015-01-06 00:32:12 +03:00
2006-07-14 05:01:36 +04:00
enum {
PENPARTNER = 0 ,
GRAPHIRE ,
2014-08-07 00:52:56 +04:00
GRAPHIRE_BT ,
2006-07-14 05:01:36 +04:00
WACOM_G4 ,
PTU ,
PL ,
2010-06-28 12:10:51 +04:00
DTU ,
2014-01-21 08:18:04 +04:00
DTUS ,
2014-12-05 05:23:04 +03:00
DTUSX ,
2006-07-14 05:01:36 +04:00
INTUOS ,
2006-09-27 00:34:47 +04:00
INTUOS3S ,
2006-07-14 05:01:36 +04:00
INTUOS3 ,
INTUOS3L ,
2009-05-09 05:30:33 +04:00
INTUOS4S ,
INTUOS4 ,
2014-08-07 00:55:56 +04:00
INTUOS4WL ,
2009-05-09 05:30:33 +04:00
INTUOS4L ,
2012-04-04 02:47:22 +04:00
INTUOS5S ,
INTUOS5 ,
INTUOS5L ,
2013-09-20 20:51:56 +04:00
INTUOSPS ,
INTUOSPM ,
INTUOSPL ,
2017-01-25 23:08:37 +03:00
INTUOSP2_BT ,
2019-06-13 00:19:28 +03:00
INTUOSP2S_BT ,
2018-03-06 21:48:33 +03:00
INTUOSHT3_BT ,
2010-06-04 09:10:21 +04:00
WACOM_21UX2 ,
2012-07-25 10:54:11 +04:00
WACOM_22HD ,
2013-02-14 08:20:01 +04:00
DTK ,
2012-07-25 10:54:11 +04:00
WACOM_24HD ,
2015-01-28 00:30:03 +03:00
WACOM_27QHD ,
2013-09-20 20:47:35 +04:00
CINTIQ_HYBRID ,
2015-10-13 20:03:49 +03:00
CINTIQ_COMPANION_2 ,
2006-07-14 05:01:36 +04:00
CINTIQ ,
2008-03-13 23:46:46 +03:00
WACOM_BEE ,
2013-05-06 06:56:18 +04:00
WACOM_13HD ,
2007-06-15 07:32:48 +04:00
WACOM_MO ,
2015-09-23 19:59:10 +03:00
BAMBOO_PEN ,
INTUOSHT ,
2015-09-23 23:51:15 +03:00
INTUOSHT2 ,
2015-09-23 19:59:10 +03:00
BAMBOO_TOUCH ,
2012-06-12 11:14:12 +04:00
BAMBOO_PT ,
2012-10-21 11:38:04 +04:00
WACOM_24HDT ,
2015-01-28 00:30:03 +03:00
WACOM_27QHDT ,
2015-02-26 19:28:50 +03:00
BAMBOO_PAD ,
2015-10-27 00:29:12 +03:00
WIRELESS ,
2015-08-21 02:05:17 +03:00
REMOTE ,
2012-06-12 11:14:12 +04:00
TABLETPC , /* add new TPC below */
2012-06-12 11:15:06 +04:00
TABLETPCE ,
2009-12-15 11:35:24 +03:00
TABLETPC2FG ,
2012-04-30 08:09:18 +04:00
MTSCREEN ,
2012-11-03 23:16:15 +04:00
MTTPC ,
2014-05-15 04:14:29 +04:00
MTTPC_B ,
2014-09-23 20:08:08 +04:00
HID_GENERIC ,
2022-12-02 02:11:41 +03:00
BOOTLOADER ,
2006-07-14 05:01:36 +04:00
MAX_TYPE
} ;
struct wacom_features {
2010-02-18 09:38:31 +03:00
const char * name ;
2006-07-14 05:01:36 +04:00
int x_max ;
int y_max ;
int pressure_max ;
int distance_max ;
int type ;
2011-03-27 08:16:05 +04:00
int x_resolution ;
int y_resolution ;
2015-08-21 02:05:16 +03:00
int numbered_buttons ;
HID: wacom: Fix sensor outbounds and redefine as offsets from each edge
Many of Wacom's display tablets include an "outbound" area where pen
digitizing is possible but outside of the display area. To ensure that
pen coordinates are mapped to the correct on-screen location, the driver
sets the minimum and maximum axis values of X and Y to those coordinates
which coincide with the screen edge. These values are simply the
hardware minimum/maximum plus/minus the outbound size for a particular
edge.
When outbound support was added/updated in ac414da, fa77034, and
ecd618d, we decided to have the wacom_features structs store the desired
minimum and maximum values directly. In hindsight, this was perhaps not
the best choice since it has allowed minor errors to crop up unnoticed.
Some tablets have had their coordinates over-corrected (e.g. most of the
devices "fixed" in ecd618d were already adjusted in ac414da), while
others never had a correction applied (e.g. the ISDv5 325, whose
declared maximum the hardware maximum instead of the outbound maximum).
A less error-prone method of handling the outbound is to let the driver
calculate the correct minimum/maximum values by providing it with both
the actual hardware maximums and the size of the outbound on each edge.
These values are more easy to verify as correct since the values can be
trivially compared against specifications.
This patch reverts the declared maximum values to the actual hardware
maximums, e.g. as declared prior to ac414da (values for these and other
display tablets that were subsuquently introduced have been verified
against specs). Per-edge outbound sizes are stored in the wacom_features
struct as offset_{left,right,top,bottom} and used in combination with
the hardware ranges to calculate effective axis ranges for ABS_X and
ABS_Y.
Signed-off-by: Jason Gerecke <jason.gerecke@wacom.com>
Reviewed-by: Benjamin Tissoires <benjamin.tissoires@redhat.com>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
2016-10-20 04:03:49 +03:00
int offset_left ;
int offset_right ;
int offset_top ;
int offset_bottom ;
2009-12-15 11:35:24 +03:00
int device_type ;
int x_phy ;
int y_phy ;
2014-07-25 00:02:14 +04:00
unsigned unit ;
int unitExpo ;
2010-09-05 23:25:11 +04:00
int x_fuzz ;
int y_fuzz ;
int pressure_fuzz ;
int distance_fuzz ;
2016-04-23 00:30:53 +03:00
int tilt_fuzz ;
2010-09-05 23:26:16 +04:00
unsigned quirks ;
2012-04-30 08:09:17 +04:00
unsigned touch_max ;
2012-10-21 11:38:03 +04:00
int oVid ;
int oPid ;
2014-07-25 00:05:19 +04:00
int pktlen ;
2014-07-24 23:52:23 +04:00
bool check_for_hid_type ;
int hid_type ;
2006-07-14 05:01:36 +04:00
} ;
2010-03-20 08:18:15 +03:00
struct wacom_shared {
bool stylus_in_proximity ;
2011-03-13 07:34:42 +03:00
bool touch_down ;
2013-12-06 00:54:53 +04:00
/* for wireless device to access USB interfaces */
unsigned touch_max ;
int type ;
struct input_dev * touch_input ;
2015-02-25 19:43:39 +03:00
struct hid_device * pen ;
struct hid_device * touch ;
2017-01-25 23:08:41 +03:00
bool has_mute_touch_switch ;
2017-02-15 08:27:45 +03:00
bool is_touch_on ;
2010-03-20 08:18:15 +03:00
} ;
2014-09-23 20:08:08 +04:00
struct hid_data {
2014-09-23 20:08:09 +04:00
__s16 inputmode ; /* InputMode HID feature, -1 if non-existent */
__s16 inputmode_index ; /* InputMode HID feature index in the report */
2016-10-20 04:03:46 +03:00
bool sense_state ;
2014-09-23 20:08:08 +04:00
bool inrange_state ;
bool invert_state ;
bool tipswitch ;
2017-11-07 19:25:17 +03:00
bool barrelswitch ;
bool barrelswitch2 ;
2022-03-23 00:33:16 +03:00
bool barrelswitch3 ;
2021-04-06 06:46:34 +03:00
bool serialhi ;
2021-11-09 03:31:01 +03:00
bool confidence ;
2014-09-23 20:08:09 +04:00
int x ;
int y ;
int pressure ;
int width ;
int height ;
int id ;
2015-10-08 02:54:21 +03:00
int cc_report ;
2015-07-21 21:07:24 +03:00
int cc_index ;
int cc_value_index ;
2016-07-21 19:10:46 +03:00
int last_slot_field ;
2015-07-21 21:07:24 +03:00
int num_expected ;
int num_received ;
2017-04-28 19:25:33 +03:00
int bat_status ;
2016-10-20 04:03:52 +03:00
int battery_capacity ;
int bat_charging ;
int bat_connected ;
int ps_connected ;
2017-04-04 22:31:07 +03:00
bool pad_input_event_flag ;
2022-03-23 00:33:16 +03:00
unsigned short sequence_number ;
2023-06-09 00:38:28 +03:00
ktime_t time_delayed ;
2014-09-23 20:08:08 +04:00
} ;
2023-07-26 01:21:25 +03:00
struct wacom_remote_work_data {
2016-07-13 19:06:01 +03:00
struct {
u32 serial ;
} remote [ WACOM_MAX_REMOTES ] ;
} ;
2006-07-14 05:01:36 +04:00
struct wacom_wac {
2016-07-13 19:06:17 +03:00
char name [ WACOM_NAME_MAX ] ;
2015-06-16 04:01:45 +03:00
char pen_name [ WACOM_NAME_MAX ] ;
char touch_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 23:48:28 +04:00
char pad_name [ WACOM_NAME_MAX ] ;
2014-07-24 23:52:23 +04:00
unsigned char data [ WACOM_PKGLEN_MAX ] ;
2011-03-13 07:33:33 +03:00
int tool [ 2 ] ;
int id [ 2 ] ;
2016-10-20 04:03:48 +03:00
__u64 serial [ 2 ] ;
2021-07-19 23:55:30 +03:00
bool probe_complete ;
2015-01-09 22:05:13 +03:00
bool reporting_data ;
2010-02-18 09:38:31 +03:00
struct wacom_features features ;
2010-03-20 08:18:15 +03:00
struct wacom_shared * shared ;
2015-06-16 04:01:45 +03:00
struct input_dev * pen_input ;
struct input_dev * touch_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 23:48:28 +04:00
struct input_dev * pad_input ;
2021-01-21 21:46:49 +03:00
struct kfifo_rec_ptr_2 * pen_fifo ;
2012-03-26 10:26:20 +04:00
int pid ;
2012-04-30 08:09:18 +04:00
int num_contacts_left ;
2014-08-07 00:48:01 +04:00
u8 bt_features ;
u8 bt_high_speed ;
2016-04-04 21:26:52 +03:00
int mode_report ;
int mode_value ;
2014-09-23 20:08:08 +04:00
struct hid_data hid_data ;
2017-01-25 23:08:41 +03:00
bool has_mute_touch_switch ;
2021-07-19 23:55:29 +03:00
bool is_soft_touch_switch ;
2017-02-15 08:27:18 +03:00
bool has_mode_change ;
bool is_direct_mode ;
2018-03-06 21:48:35 +03:00
bool is_invalid_bt_frame ;
2006-07-14 05:01:36 +04:00
} ;
# endif