#ifndef _SYS_USB_USBWCM_H
#define _SYS_USB_USBWCM_H
#ifdef __cplusplus
extern "C" {
#endif
#include <sys/ioccom.h>
#if defined(_LP64)
#include <sys/types32.h>
#else
#include <sys/types.h>
#endif
#include <sys/time.h>
#define EVTIOCGVERSION _IOR('E', 0x1, int)
#define EVTIOCGDEVID _IOR('E', 0x2, struct event_dev_id)
#define EVTIOCGBM(i, s) _IORN('E', 0x20 + (i), (s))
#define EVTIOCGABS(i) _IOR('E', 0x40 + (i), struct event_abs_axis)
#define EVTIOC ('E' << 8)
struct event_dev_id {
uint16_t bus;
#define ID_BUS_USB 3
uint16_t vendor;
uint16_t product;
uint16_t version;
};
struct event_abs_axis {
int32_t value;
int32_t min;
int32_t max;
int32_t fuzz;
int32_t flat;
};
struct event_input {
#if defined(_LP64)
struct timeval32 time;
#else
struct timeval time;
#endif
uint16_t type;
uint16_t code;
int32_t value;
};
#define EVT_SYN 0x0000
#define EVT_BTN 0x0001
#define EVT_REL 0x0002
#define EVT_ABS 0x0003
#define EVT_MSC 0x0004
#define EVT_USED 0x0005
#define EVT_MAX 0x001f
#define SYN_REPORT 0x0000
#define BTN_MISC_0 0x0100
#define BTN_MISC_1 0x0101
#define BTN_MISC_2 0x0102
#define BTN_MISC_3 0x0103
#define BTN_MISC_4 0x0104
#define BTN_MISC_5 0x0105
#define BTN_MISC_6 0x0106
#define BTN_MISC_7 0x0107
#define BTN_MISC_8 0x0108
#define BTN_LEFT 0x0110
#define BTN_RIGHT 0x0111
#define BTN_MIDDLE 0x0112
#define BTN_SIDE 0x0113
#define BTN_EXTRA 0x0114
#define BTN_TOOL_PEN 0x0140
#define BTN_TOOL_ERASER 0x0141
#define BTN_TOOL_PAD 0x0145
#define BTN_TOOL_MOUSE 0x0146
#define BTN_TIP 0x014a
#define BTN_STYLUS_1 0x014b
#define BTN_STYLUS_2 0x014c
#define BTN_USED 0x014d
#define BTN_MISC_UND 0x01ff
#define BTN_MAX 0x01ff
#define REL_WHEEL 0x0008
#define REL_MAX 0x000f
#define ABS_X 0x0000
#define ABS_Y 0x0001
#define ABS_Z 0x0002
#define ABS_RX 0x0003
#define ABS_RY 0x0004
#define ABS_RZ 0x0005
#define ABS_WHEEL 0x0008
#define ABS_PRESSURE 0x0018
#define ABS_DISTANCE 0x0019
#define ABS_TILT_X 0x001a
#define ABS_TILT_Y 0x001b
#define ABS_MISC 0x0028
#define ABS_USED 0x0029
#define ABS_MAX 0x003f
#define MSC_SERIAL 0x0000
#define MSC_MAX 0x0007
#ifdef _KERNEL
#define USB_VENDOR_WACOM 0x056a
#define USB_PRODUCT_WACOM_GRAPHIRE 0x0010
#define USB_PRODUCT_WACOM_GRAPHIRE2_4X5 0x0011
#define USB_PRODUCT_WACOM_GRAPHIRE2_5X7 0x0012
#define USB_PRODUCT_WACOM_GRAPHIRE3_4X5 0x0013
#define USB_PRODUCT_WACOM_GRAPHIRE3_6X8 0x0014
#define USB_PRODUCT_WACOM_GRAPHIRE4_4X5 0x0015
#define USB_PRODUCT_WACOM_GRAPHIRE4_6X8 0x0016
#define USB_PRODUCT_WACOM_BAMBOO_FUN_4X5 0x0017
#define USB_PRODUCT_WACOM_BAMBOO_FUN_6X8 0x0018
#define USB_PRODUCT_WACOM_BAMBOO_ONE_6X8 0x0019
#define USB_PRODUCT_WACOM_CINTIQ_21UX 0x003f
#define USB_PRODUCT_WACOM_VOLITO 0x0060
#define USB_PRODUCT_WACOM_PENSTATION2 0x0061
#define USB_PRODUCT_WACOM_VOLITO2_4X5 0x0062
#define USB_PRODUCT_WACOM_VOLITO2_2X3 0x0063
#define USB_PRODUCT_WACOM_PENPARTNER2 0x0064
#define USB_PRODUCT_WACOM_BAMBOO 0x0065
#define USB_PRODUCT_WACOM_BAMBOO_ONE_4X5 0x0069
#define USB_PRODUCT_WACOM_INTUOS3_4X5 0x00b0
#define USB_PRODUCT_WACOM_INTUOS3_6X8 0x00b1
#define USB_PRODUCT_WACOM_INTUOS3_9X12 0x00b2
#define USB_PRODUCT_WACOM_INTUOS3_12X12 0x00b3
#define USB_PRODUCT_WACOM_INTUOS3_12X19 0x00b4
#define USB_PRODUCT_WACOM_INTUOS3_6X11 0x00b5
#define USB_PRODUCT_WACOM_INTUOS3_4X6 0x00b7
#define USB_PRODUCT_WACOM_INTUOS4_4X6 0x00b8
#define USB_PRODUCT_WACOM_INTUOS4_6X9 0x00b9
#define USB_PRODUCT_WACOM_INTUOS4_8X13 0x00ba
#define USB_PRODUCT_WACOM_INTUOS4_12X19 0x00bb
#define TOOL_ID_PEN 0x0002
#define TOOL_ID_MOUSE 0x0006
#define TOOL_ID_ERASER 0x000a
#define TOOL_ID_PAD 0x000f
#define SERIAL_PAD_INTUOS 0xffffffff
#define SERIAL_PAD_GRAPHIRE4 0x000000f0
#define EUWACOMGETVERSION 0x01
#define EUWACOMGETID 0x02
#define EUWACOMGETBM 0x20
#define EUWACOMGETABS 0x40
struct uwacom_protocol_type {
int packet_size;
int distance_max;
};
enum uwacom_protocol {
GRAPHIRE = 0,
GRAPHIRE4,
MYOFFICE,
INTUOS3S,
INTUOS3L,
INTUOS4S,
INTUOS4L,
CINTIQ
};
struct uwacom_id {
uint16_t vid;
uint16_t pid;
};
struct uwacom_type {
struct uwacom_id devno;
enum uwacom_protocol protocol;
int x_max;
int y_max;
int pressure_max;
};
static const struct uwacom_protocol_type uwacom_protocols[] = {
{ 8, 63},
{ 8, 63},
{ 9, 63},
{10, 63},
{10, 63},
{10, 63},
{10, 63},
{10, 63}
};
struct uwacom_softc {
const struct uwacom_type *sc_type;
struct event_dev_id sc_id;
unsigned long *sc_bm[EVT_USED];
int *sc_btn;
struct event_abs_axis *sc_abs;
int sc_tool[2];
int sc_tool_id[2];
unsigned int sc_serial[2];
int sc_sync;
};
typedef struct usbwcm_state {
queue_t *usbwcm_rq;
queue_t *usbwcm_wq;
int32_t usbwcm_flags;
#define USBWCM_OPEN 0x00000001
#define USBWCM_QWAIT 0x00000002
struct uwacom_softc usbwcm_softc;
hid_vid_pid_t usbwcm_devid;
mblk_t *usbwcm_mioctl;
bufcall_id_t usbwcm_bufcall;
} usbwcm_state_t;
#define abs(x) ((x) < 0 ? -(x) : (x))
typedef struct usbwcm_copyin_s {
caddr_t addr;
int state;
#define USBWCM_GETSTRUCT 1
#define USBWCM_GETRESULT 2
} usbwcm_copyin_t;
static const struct uwacom_type uwacom_devs[] = {
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_GRAPHIRE},
GRAPHIRE, 10206, 7422, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_GRAPHIRE2_4X5},
GRAPHIRE, 10206, 7422, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_GRAPHIRE2_5X7},
GRAPHIRE, 13918, 10206, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_GRAPHIRE3_4X5},
GRAPHIRE, 10208, 7424, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_GRAPHIRE3_6X8},
GRAPHIRE, 16704, 12064, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_GRAPHIRE4_4X5},
GRAPHIRE4, 10208, 7424, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_GRAPHIRE4_6X8},
GRAPHIRE4, 16704, 12064, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_BAMBOO_FUN_4X5},
MYOFFICE, 14760, 9225, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_BAMBOO_FUN_6X8},
MYOFFICE, 21648, 13530, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_BAMBOO_ONE_6X8},
GRAPHIRE, 16704, 12064, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_CINTIQ_21UX},
CINTIQ, 87200, 65600, 1023
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_VOLITO},
GRAPHIRE, 5104, 3712, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_PENSTATION2},
GRAPHIRE, 3250, 2320, 255
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_VOLITO2_4X5},
GRAPHIRE, 5104, 3712, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_VOLITO2_2X3},
GRAPHIRE, 3248, 2320, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_PENPARTNER2},
GRAPHIRE, 3250, 2320, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_BAMBOO},
MYOFFICE, 14760, 9225, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_BAMBOO_ONE_4X5},
GRAPHIRE, 5104, 3712, 511
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_INTUOS3_4X5},
INTUOS3S, 25400, 20320, 1023
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_INTUOS3_6X8},
INTUOS3L, 40640, 30480, 1023
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_INTUOS3_9X12},
INTUOS3L, 60960, 45720, 1023
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_INTUOS3_12X12},
INTUOS3L, 60960, 60960, 1023
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_INTUOS3_12X19},
INTUOS3L, 97536, 60960, 1023
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_INTUOS3_6X11},
INTUOS3L, 54204, 31750, 1023
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_INTUOS3_4X6},
INTUOS3S, 31496, 19685, 1023
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_INTUOS4_4X6},
INTUOS4S, 31496, 19685, 2047
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_INTUOS4_6X9},
INTUOS4L, 44704, 27940, 2047
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_INTUOS4_8X13},
INTUOS4L, 65024, 40640, 2047
},
{
{USB_VENDOR_WACOM, USB_PRODUCT_WACOM_INTUOS4_12X19},
INTUOS4L, 97536, 60960, 2047
},
{{0, 0}, 0, 0, 0, 0}
};
#define PACKET_BIT(b, s) ((packet[b] >> (s)) & 1)
#define PACKET_BITS(b, s, n) \
((((s) + (n) > 32 ? ((packet[(b) - 4]) << (32 - (s))) : 0) | \
((s) + (n) > 24 ? ((packet[(b) - 3]) << (24 - (s))) : 0) | \
((s) + (n) > 16 ? ((packet[(b) - 2]) << (16 - (s))) : 0) | \
((s) + (n) > 8 ? ((packet[(b) - 1]) << (8 - (s))) : 0) | \
((packet[(b)]) >> (s))) & \
((n) == 32 ? 0xffffffff : (1 << (n)) - 1))
#define BM_SIZE(x) \
(((x) / (sizeof (long) * 8) + 1) * sizeof (long))
#define BM_SET_BIT(x, y) \
((x)[(y) / (sizeof (long) * 8)] |= (1ul << ((y) % (sizeof (long) * 8))))
static const size_t bm_size[EVT_USED] = {
BM_SIZE(EVT_MAX),
BM_SIZE(BTN_MAX),
BM_SIZE(REL_MAX),
BM_SIZE(ABS_MAX),
BM_SIZE(MSC_MAX),
};
#define PRINT_MASK_ALL 0xFFFFFFFF
#endif
#ifdef __cplusplus
}
#endif
#endif