maplemouse.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. /*
  2. * SEGA Dreamcast mouse driver
  3. * Based on drivers/usb/usbmouse.c
  4. *
  5. * Copyright Yaegashi Takeshi, 2001
  6. * Adrian McMenamin, 2008
  7. */
  8. #include <linux/kernel.h>
  9. #include <linux/slab.h>
  10. #include <linux/input.h>
  11. #include <linux/module.h>
  12. #include <linux/init.h>
  13. #include <linux/timer.h>
  14. #include <linux/maple.h>
  15. MODULE_AUTHOR("Adrian McMenamin <adrian@mcmen.demon.co.uk>");
  16. MODULE_DESCRIPTION("SEGA Dreamcast mouse driver");
  17. MODULE_LICENSE("GPL");
  18. struct dc_mouse {
  19. struct input_dev *dev;
  20. struct maple_device *mdev;
  21. };
  22. static void dc_mouse_callback(struct mapleq *mq)
  23. {
  24. int buttons, relx, rely, relz;
  25. struct maple_device *mapledev = mq->dev;
  26. struct dc_mouse *mse = maple_get_drvdata(mapledev);
  27. struct input_dev *dev = mse->dev;
  28. unsigned char *res = mq->recvbuf;
  29. buttons = ~res[8];
  30. relx = *(unsigned short *)(res + 12) - 512;
  31. rely = *(unsigned short *)(res + 14) - 512;
  32. relz = *(unsigned short *)(res + 16) - 512;
  33. input_report_key(dev, BTN_LEFT, buttons & 4);
  34. input_report_key(dev, BTN_MIDDLE, buttons & 9);
  35. input_report_key(dev, BTN_RIGHT, buttons & 2);
  36. input_report_rel(dev, REL_X, relx);
  37. input_report_rel(dev, REL_Y, rely);
  38. input_report_rel(dev, REL_WHEEL, relz);
  39. input_sync(dev);
  40. }
  41. static int dc_mouse_open(struct input_dev *dev)
  42. {
  43. struct dc_mouse *mse = dev->dev.platform_data;
  44. maple_getcond_callback(mse->mdev, dc_mouse_callback, HZ/50,
  45. MAPLE_FUNC_MOUSE);
  46. return 0;
  47. }
  48. static void dc_mouse_close(struct input_dev *dev)
  49. {
  50. struct dc_mouse *mse = dev->dev.platform_data;
  51. maple_getcond_callback(mse->mdev, dc_mouse_callback, 0,
  52. MAPLE_FUNC_MOUSE);
  53. }
  54. static int __devinit probe_maple_mouse(struct device *dev)
  55. {
  56. struct maple_device *mdev = to_maple_dev(dev);
  57. struct maple_driver *mdrv = to_maple_driver(dev->driver);
  58. struct input_dev *input_dev;
  59. struct dc_mouse *mse;
  60. int error;
  61. mse = kzalloc(sizeof(struct dc_mouse), GFP_KERNEL);
  62. input_dev = input_allocate_device();
  63. if (!mse || !input_dev) {
  64. error = -ENOMEM;
  65. goto fail;
  66. }
  67. mse->dev = input_dev;
  68. mse->mdev = mdev;
  69. input_set_drvdata(input_dev, mse);
  70. input_dev->evbit[0] = BIT_MASK(EV_KEY) | BIT_MASK(EV_REL);
  71. input_dev->keybit[BIT_WORD(BTN_MOUSE)] = BIT_MASK(BTN_LEFT) |
  72. BIT_MASK(BTN_RIGHT) | BIT_MASK(BTN_MIDDLE);
  73. input_dev->relbit[0] = BIT_MASK(REL_X) | BIT_MASK(REL_Y) |
  74. BIT_MASK(REL_WHEEL);
  75. input_dev->name = mdev->product_name;
  76. input_dev->id.bustype = BUS_HOST;
  77. input_dev->open = dc_mouse_open;
  78. input_dev->close = dc_mouse_close;
  79. mdev->driver = mdrv;
  80. maple_set_drvdata(mdev, mse);
  81. error = input_register_device(input_dev);
  82. if (error)
  83. goto fail;
  84. return 0;
  85. fail:
  86. input_free_device(input_dev);
  87. maple_set_drvdata(mdev, NULL);
  88. kfree(mse);
  89. mdev->driver = NULL;
  90. return error;
  91. }
  92. static int __devexit remove_maple_mouse(struct device *dev)
  93. {
  94. struct maple_device *mdev = to_maple_dev(dev);
  95. struct dc_mouse *mse = maple_get_drvdata(mdev);
  96. mdev->callback = NULL;
  97. input_unregister_device(mse->dev);
  98. maple_set_drvdata(mdev, NULL);
  99. kfree(mse);
  100. return 0;
  101. }
  102. static struct maple_driver dc_mouse_driver = {
  103. .function = MAPLE_FUNC_MOUSE,
  104. .drv = {
  105. .name = "Dreamcast_mouse",
  106. .probe = probe_maple_mouse,
  107. .remove = __devexit_p(remove_maple_mouse),
  108. },
  109. };
  110. static int __init dc_mouse_init(void)
  111. {
  112. return maple_driver_register(&dc_mouse_driver);
  113. }
  114. static void __exit dc_mouse_exit(void)
  115. {
  116. maple_driver_unregister(&dc_mouse_driver);
  117. }
  118. module_init(dc_mouse_init);
  119. module_exit(dc_mouse_exit);