hanwang.c 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. * USB Hanwang tablet support
  4. *
  5. * Copyright (c) 2010 Xing Wei <[email protected]>
  6. */
  7. #include <linux/types.h>
  8. #include <linux/kernel.h>
  9. #include <linux/slab.h>
  10. #include <linux/module.h>
  11. #include <linux/usb/input.h>
  12. MODULE_AUTHOR("Xing Wei <[email protected]>");
  13. MODULE_DESCRIPTION("USB Hanwang tablet driver");
  14. MODULE_LICENSE("GPL");
  15. #define USB_VENDOR_ID_HANWANG 0x0b57
  16. #define HANWANG_TABLET_INT_CLASS 0x0003
  17. #define HANWANG_TABLET_INT_SUB_CLASS 0x0001
  18. #define HANWANG_TABLET_INT_PROTOCOL 0x0002
  19. #define ART_MASTER_PKGLEN_MAX 10
  20. /* device IDs */
  21. #define STYLUS_DEVICE_ID 0x02
  22. #define TOUCH_DEVICE_ID 0x03
  23. #define CURSOR_DEVICE_ID 0x06
  24. #define ERASER_DEVICE_ID 0x0A
  25. #define PAD_DEVICE_ID 0x0F
  26. /* match vendor and interface info */
  27. #define HANWANG_TABLET_DEVICE(vend, cl, sc, pr) \
  28. .match_flags = USB_DEVICE_ID_MATCH_VENDOR \
  29. | USB_DEVICE_ID_MATCH_INT_INFO, \
  30. .idVendor = (vend), \
  31. .bInterfaceClass = (cl), \
  32. .bInterfaceSubClass = (sc), \
  33. .bInterfaceProtocol = (pr)
  34. enum hanwang_tablet_type {
  35. HANWANG_ART_MASTER_III,
  36. HANWANG_ART_MASTER_HD,
  37. HANWANG_ART_MASTER_II,
  38. };
  39. struct hanwang {
  40. unsigned char *data;
  41. dma_addr_t data_dma;
  42. struct input_dev *dev;
  43. struct usb_device *usbdev;
  44. struct urb *irq;
  45. const struct hanwang_features *features;
  46. unsigned int current_tool;
  47. unsigned int current_id;
  48. char name[64];
  49. char phys[32];
  50. };
  51. struct hanwang_features {
  52. unsigned short pid;
  53. char *name;
  54. enum hanwang_tablet_type type;
  55. int pkg_len;
  56. int max_x;
  57. int max_y;
  58. int max_tilt_x;
  59. int max_tilt_y;
  60. int max_pressure;
  61. };
  62. static const struct hanwang_features features_array[] = {
  63. { 0x8528, "Hanwang Art Master III 0906", HANWANG_ART_MASTER_III,
  64. ART_MASTER_PKGLEN_MAX, 0x5757, 0x3692, 0x3f, 0x7f, 2048 },
  65. { 0x8529, "Hanwang Art Master III 0604", HANWANG_ART_MASTER_III,
  66. ART_MASTER_PKGLEN_MAX, 0x3d84, 0x2672, 0x3f, 0x7f, 2048 },
  67. { 0x852a, "Hanwang Art Master III 1308", HANWANG_ART_MASTER_III,
  68. ART_MASTER_PKGLEN_MAX, 0x7f00, 0x4f60, 0x3f, 0x7f, 2048 },
  69. { 0x8401, "Hanwang Art Master HD 5012", HANWANG_ART_MASTER_HD,
  70. ART_MASTER_PKGLEN_MAX, 0x678e, 0x4150, 0x3f, 0x7f, 1024 },
  71. { 0x8503, "Hanwang Art Master II", HANWANG_ART_MASTER_II,
  72. ART_MASTER_PKGLEN_MAX, 0x27de, 0x1cfe, 0x3f, 0x7f, 1024 },
  73. };
  74. static const int hw_eventtypes[] = {
  75. EV_KEY, EV_ABS, EV_MSC,
  76. };
  77. static const int hw_absevents[] = {
  78. ABS_X, ABS_Y, ABS_TILT_X, ABS_TILT_Y, ABS_WHEEL,
  79. ABS_RX, ABS_RY, ABS_PRESSURE, ABS_MISC,
  80. };
  81. static const int hw_btnevents[] = {
  82. BTN_STYLUS, BTN_STYLUS2, BTN_TOOL_PEN, BTN_TOOL_RUBBER,
  83. BTN_TOOL_MOUSE, BTN_TOOL_FINGER,
  84. BTN_0, BTN_1, BTN_2, BTN_3, BTN_4, BTN_5, BTN_6, BTN_7, BTN_8,
  85. };
  86. static const int hw_mscevents[] = {
  87. MSC_SERIAL,
  88. };
  89. static void hanwang_parse_packet(struct hanwang *hanwang)
  90. {
  91. unsigned char *data = hanwang->data;
  92. struct input_dev *input_dev = hanwang->dev;
  93. struct usb_device *dev = hanwang->usbdev;
  94. enum hanwang_tablet_type type = hanwang->features->type;
  95. int i;
  96. u16 p;
  97. if (type == HANWANG_ART_MASTER_II) {
  98. hanwang->current_tool = BTN_TOOL_PEN;
  99. hanwang->current_id = STYLUS_DEVICE_ID;
  100. }
  101. switch (data[0]) {
  102. case 0x02: /* data packet */
  103. switch (data[1]) {
  104. case 0x80: /* tool prox out */
  105. if (type != HANWANG_ART_MASTER_II) {
  106. hanwang->current_id = 0;
  107. input_report_key(input_dev,
  108. hanwang->current_tool, 0);
  109. }
  110. break;
  111. case 0x00: /* artmaster ii pen leave */
  112. if (type == HANWANG_ART_MASTER_II) {
  113. hanwang->current_id = 0;
  114. input_report_key(input_dev,
  115. hanwang->current_tool, 0);
  116. }
  117. break;
  118. case 0xc2: /* first time tool prox in */
  119. switch (data[3] & 0xf0) {
  120. case 0x20: /* art_master III */
  121. case 0x30: /* art_master_HD */
  122. hanwang->current_id = STYLUS_DEVICE_ID;
  123. hanwang->current_tool = BTN_TOOL_PEN;
  124. input_report_key(input_dev, BTN_TOOL_PEN, 1);
  125. break;
  126. case 0xa0: /* art_master III */
  127. case 0xb0: /* art_master_HD */
  128. hanwang->current_id = ERASER_DEVICE_ID;
  129. hanwang->current_tool = BTN_TOOL_RUBBER;
  130. input_report_key(input_dev, BTN_TOOL_RUBBER, 1);
  131. break;
  132. default:
  133. hanwang->current_id = 0;
  134. dev_dbg(&dev->dev,
  135. "unknown tablet tool %02x\n", data[0]);
  136. break;
  137. }
  138. break;
  139. default: /* tool data packet */
  140. switch (type) {
  141. case HANWANG_ART_MASTER_III:
  142. p = (data[6] << 3) |
  143. ((data[7] & 0xc0) >> 5) |
  144. (data[1] & 0x01);
  145. break;
  146. case HANWANG_ART_MASTER_HD:
  147. case HANWANG_ART_MASTER_II:
  148. p = (data[7] >> 6) | (data[6] << 2);
  149. break;
  150. default:
  151. p = 0;
  152. break;
  153. }
  154. input_report_abs(input_dev, ABS_X,
  155. be16_to_cpup((__be16 *)&data[2]));
  156. input_report_abs(input_dev, ABS_Y,
  157. be16_to_cpup((__be16 *)&data[4]));
  158. input_report_abs(input_dev, ABS_PRESSURE, p);
  159. input_report_abs(input_dev, ABS_TILT_X, data[7] & 0x3f);
  160. input_report_abs(input_dev, ABS_TILT_Y, data[8] & 0x7f);
  161. input_report_key(input_dev, BTN_STYLUS, data[1] & 0x02);
  162. if (type != HANWANG_ART_MASTER_II)
  163. input_report_key(input_dev, BTN_STYLUS2,
  164. data[1] & 0x04);
  165. else
  166. input_report_key(input_dev, BTN_TOOL_PEN, 1);
  167. break;
  168. }
  169. input_report_abs(input_dev, ABS_MISC, hanwang->current_id);
  170. input_event(input_dev, EV_MSC, MSC_SERIAL,
  171. hanwang->features->pid);
  172. break;
  173. case 0x0c:
  174. /* roll wheel */
  175. hanwang->current_id = PAD_DEVICE_ID;
  176. switch (type) {
  177. case HANWANG_ART_MASTER_III:
  178. input_report_key(input_dev, BTN_TOOL_FINGER,
  179. data[1] || data[2] || data[3]);
  180. input_report_abs(input_dev, ABS_WHEEL, data[1]);
  181. input_report_key(input_dev, BTN_0, data[2]);
  182. for (i = 0; i < 8; i++)
  183. input_report_key(input_dev,
  184. BTN_1 + i, data[3] & (1 << i));
  185. break;
  186. case HANWANG_ART_MASTER_HD:
  187. input_report_key(input_dev, BTN_TOOL_FINGER, data[1] ||
  188. data[2] || data[3] || data[4] ||
  189. data[5] || data[6]);
  190. input_report_abs(input_dev, ABS_RX,
  191. ((data[1] & 0x1f) << 8) | data[2]);
  192. input_report_abs(input_dev, ABS_RY,
  193. ((data[3] & 0x1f) << 8) | data[4]);
  194. input_report_key(input_dev, BTN_0, data[5] & 0x01);
  195. for (i = 0; i < 4; i++) {
  196. input_report_key(input_dev,
  197. BTN_1 + i, data[5] & (1 << i));
  198. input_report_key(input_dev,
  199. BTN_5 + i, data[6] & (1 << i));
  200. }
  201. break;
  202. case HANWANG_ART_MASTER_II:
  203. dev_dbg(&dev->dev, "error packet %02x\n", data[0]);
  204. return;
  205. }
  206. input_report_abs(input_dev, ABS_MISC, hanwang->current_id);
  207. input_event(input_dev, EV_MSC, MSC_SERIAL, 0xffffffff);
  208. break;
  209. default:
  210. dev_dbg(&dev->dev, "error packet %02x\n", data[0]);
  211. break;
  212. }
  213. input_sync(input_dev);
  214. }
  215. static void hanwang_irq(struct urb *urb)
  216. {
  217. struct hanwang *hanwang = urb->context;
  218. struct usb_device *dev = hanwang->usbdev;
  219. int retval;
  220. switch (urb->status) {
  221. case 0:
  222. /* success */;
  223. hanwang_parse_packet(hanwang);
  224. break;
  225. case -ECONNRESET:
  226. case -ENOENT:
  227. case -ESHUTDOWN:
  228. /* this urb is terminated, clean up */
  229. dev_err(&dev->dev, "%s - urb shutting down with status: %d",
  230. __func__, urb->status);
  231. return;
  232. default:
  233. dev_err(&dev->dev, "%s - nonzero urb status received: %d",
  234. __func__, urb->status);
  235. break;
  236. }
  237. retval = usb_submit_urb(urb, GFP_ATOMIC);
  238. if (retval)
  239. dev_err(&dev->dev, "%s - usb_submit_urb failed with result %d",
  240. __func__, retval);
  241. }
  242. static int hanwang_open(struct input_dev *dev)
  243. {
  244. struct hanwang *hanwang = input_get_drvdata(dev);
  245. hanwang->irq->dev = hanwang->usbdev;
  246. if (usb_submit_urb(hanwang->irq, GFP_KERNEL))
  247. return -EIO;
  248. return 0;
  249. }
  250. static void hanwang_close(struct input_dev *dev)
  251. {
  252. struct hanwang *hanwang = input_get_drvdata(dev);
  253. usb_kill_urb(hanwang->irq);
  254. }
  255. static bool get_features(struct usb_device *dev, struct hanwang *hanwang)
  256. {
  257. int i;
  258. for (i = 0; i < ARRAY_SIZE(features_array); i++) {
  259. if (le16_to_cpu(dev->descriptor.idProduct) ==
  260. features_array[i].pid) {
  261. hanwang->features = &features_array[i];
  262. return true;
  263. }
  264. }
  265. return false;
  266. }
  267. static int hanwang_probe(struct usb_interface *intf, const struct usb_device_id *id)
  268. {
  269. struct usb_device *dev = interface_to_usbdev(intf);
  270. struct usb_endpoint_descriptor *endpoint;
  271. struct hanwang *hanwang;
  272. struct input_dev *input_dev;
  273. int error;
  274. int i;
  275. if (intf->cur_altsetting->desc.bNumEndpoints < 1)
  276. return -ENODEV;
  277. hanwang = kzalloc(sizeof(struct hanwang), GFP_KERNEL);
  278. input_dev = input_allocate_device();
  279. if (!hanwang || !input_dev) {
  280. error = -ENOMEM;
  281. goto fail1;
  282. }
  283. if (!get_features(dev, hanwang)) {
  284. error = -ENXIO;
  285. goto fail1;
  286. }
  287. hanwang->data = usb_alloc_coherent(dev, hanwang->features->pkg_len,
  288. GFP_KERNEL, &hanwang->data_dma);
  289. if (!hanwang->data) {
  290. error = -ENOMEM;
  291. goto fail1;
  292. }
  293. hanwang->irq = usb_alloc_urb(0, GFP_KERNEL);
  294. if (!hanwang->irq) {
  295. error = -ENOMEM;
  296. goto fail2;
  297. }
  298. hanwang->usbdev = dev;
  299. hanwang->dev = input_dev;
  300. usb_make_path(dev, hanwang->phys, sizeof(hanwang->phys));
  301. strlcat(hanwang->phys, "/input0", sizeof(hanwang->phys));
  302. strscpy(hanwang->name, hanwang->features->name, sizeof(hanwang->name));
  303. input_dev->name = hanwang->name;
  304. input_dev->phys = hanwang->phys;
  305. usb_to_input_id(dev, &input_dev->id);
  306. input_dev->dev.parent = &intf->dev;
  307. input_set_drvdata(input_dev, hanwang);
  308. input_dev->open = hanwang_open;
  309. input_dev->close = hanwang_close;
  310. for (i = 0; i < ARRAY_SIZE(hw_eventtypes); ++i)
  311. __set_bit(hw_eventtypes[i], input_dev->evbit);
  312. for (i = 0; i < ARRAY_SIZE(hw_absevents); ++i)
  313. __set_bit(hw_absevents[i], input_dev->absbit);
  314. for (i = 0; i < ARRAY_SIZE(hw_btnevents); ++i)
  315. __set_bit(hw_btnevents[i], input_dev->keybit);
  316. for (i = 0; i < ARRAY_SIZE(hw_mscevents); ++i)
  317. __set_bit(hw_mscevents[i], input_dev->mscbit);
  318. input_set_abs_params(input_dev, ABS_X,
  319. 0, hanwang->features->max_x, 4, 0);
  320. input_set_abs_params(input_dev, ABS_Y,
  321. 0, hanwang->features->max_y, 4, 0);
  322. input_set_abs_params(input_dev, ABS_TILT_X,
  323. 0, hanwang->features->max_tilt_x, 0, 0);
  324. input_set_abs_params(input_dev, ABS_TILT_Y,
  325. 0, hanwang->features->max_tilt_y, 0, 0);
  326. input_set_abs_params(input_dev, ABS_PRESSURE,
  327. 0, hanwang->features->max_pressure, 0, 0);
  328. endpoint = &intf->cur_altsetting->endpoint[0].desc;
  329. usb_fill_int_urb(hanwang->irq, dev,
  330. usb_rcvintpipe(dev, endpoint->bEndpointAddress),
  331. hanwang->data, hanwang->features->pkg_len,
  332. hanwang_irq, hanwang, endpoint->bInterval);
  333. hanwang->irq->transfer_dma = hanwang->data_dma;
  334. hanwang->irq->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
  335. error = input_register_device(hanwang->dev);
  336. if (error)
  337. goto fail3;
  338. usb_set_intfdata(intf, hanwang);
  339. return 0;
  340. fail3: usb_free_urb(hanwang->irq);
  341. fail2: usb_free_coherent(dev, hanwang->features->pkg_len,
  342. hanwang->data, hanwang->data_dma);
  343. fail1: input_free_device(input_dev);
  344. kfree(hanwang);
  345. return error;
  346. }
  347. static void hanwang_disconnect(struct usb_interface *intf)
  348. {
  349. struct hanwang *hanwang = usb_get_intfdata(intf);
  350. input_unregister_device(hanwang->dev);
  351. usb_free_urb(hanwang->irq);
  352. usb_free_coherent(interface_to_usbdev(intf),
  353. hanwang->features->pkg_len, hanwang->data,
  354. hanwang->data_dma);
  355. kfree(hanwang);
  356. usb_set_intfdata(intf, NULL);
  357. }
  358. static const struct usb_device_id hanwang_ids[] = {
  359. { HANWANG_TABLET_DEVICE(USB_VENDOR_ID_HANWANG, HANWANG_TABLET_INT_CLASS,
  360. HANWANG_TABLET_INT_SUB_CLASS, HANWANG_TABLET_INT_PROTOCOL) },
  361. {}
  362. };
  363. MODULE_DEVICE_TABLE(usb, hanwang_ids);
  364. static struct usb_driver hanwang_driver = {
  365. .name = "hanwang",
  366. .probe = hanwang_probe,
  367. .disconnect = hanwang_disconnect,
  368. .id_table = hanwang_ids,
  369. };
  370. module_usb_driver(hanwang_driver);