arc_ps2.c 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275
  1. /*
  2. * Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License version 2 as
  6. * published by the Free Software Foundation.
  7. *
  8. * Driver is originally developed by Pavel Sokolov <psokolov@synopsys.com>
  9. */
  10. #include <linux/err.h>
  11. #include <linux/module.h>
  12. #include <linux/interrupt.h>
  13. #include <linux/input.h>
  14. #include <linux/serio.h>
  15. #include <linux/platform_device.h>
  16. #include <linux/io.h>
  17. #include <linux/kernel.h>
  18. #include <linux/slab.h>
  19. #define ARC_PS2_PORTS 2
  20. #define ARC_ARC_PS2_ID 0x0001f609
  21. #define STAT_TIMEOUT 128
  22. #define PS2_STAT_RX_FRM_ERR (1)
  23. #define PS2_STAT_RX_BUF_OVER (1 << 1)
  24. #define PS2_STAT_RX_INT_EN (1 << 2)
  25. #define PS2_STAT_RX_VAL (1 << 3)
  26. #define PS2_STAT_TX_ISNOT_FUL (1 << 4)
  27. #define PS2_STAT_TX_INT_EN (1 << 5)
  28. struct arc_ps2_port {
  29. void __iomem *data_addr;
  30. void __iomem *status_addr;
  31. struct serio *io;
  32. };
  33. struct arc_ps2_data {
  34. struct arc_ps2_port port[ARC_PS2_PORTS];
  35. void __iomem *addr;
  36. unsigned int frame_error;
  37. unsigned int buf_overflow;
  38. unsigned int total_int;
  39. };
  40. static void arc_ps2_check_rx(struct arc_ps2_data *arc_ps2,
  41. struct arc_ps2_port *port)
  42. {
  43. unsigned int timeout = 1000;
  44. unsigned int flag, status;
  45. unsigned char data;
  46. do {
  47. status = ioread32(port->status_addr);
  48. if (!(status & PS2_STAT_RX_VAL))
  49. return;
  50. data = ioread32(port->data_addr) & 0xff;
  51. flag = 0;
  52. arc_ps2->total_int++;
  53. if (status & PS2_STAT_RX_FRM_ERR) {
  54. arc_ps2->frame_error++;
  55. flag |= SERIO_PARITY;
  56. } else if (status & PS2_STAT_RX_BUF_OVER) {
  57. arc_ps2->buf_overflow++;
  58. flag |= SERIO_FRAME;
  59. }
  60. serio_interrupt(port->io, data, flag);
  61. } while (--timeout);
  62. dev_err(&port->io->dev, "PS/2 hardware stuck\n");
  63. }
  64. static irqreturn_t arc_ps2_interrupt(int irq, void *dev)
  65. {
  66. struct arc_ps2_data *arc_ps2 = dev;
  67. int i;
  68. for (i = 0; i < ARC_PS2_PORTS; i++)
  69. arc_ps2_check_rx(arc_ps2, &arc_ps2->port[i]);
  70. return IRQ_HANDLED;
  71. }
  72. static int arc_ps2_write(struct serio *io, unsigned char val)
  73. {
  74. unsigned status;
  75. struct arc_ps2_port *port = io->port_data;
  76. int timeout = STAT_TIMEOUT;
  77. do {
  78. status = ioread32(port->status_addr);
  79. cpu_relax();
  80. if (status & PS2_STAT_TX_ISNOT_FUL) {
  81. iowrite32(val & 0xff, port->data_addr);
  82. return 0;
  83. }
  84. } while (--timeout);
  85. dev_err(&io->dev, "write timeout\n");
  86. return -ETIMEDOUT;
  87. }
  88. static int arc_ps2_open(struct serio *io)
  89. {
  90. struct arc_ps2_port *port = io->port_data;
  91. iowrite32(PS2_STAT_RX_INT_EN, port->status_addr);
  92. return 0;
  93. }
  94. static void arc_ps2_close(struct serio *io)
  95. {
  96. struct arc_ps2_port *port = io->port_data;
  97. iowrite32(ioread32(port->status_addr) & ~PS2_STAT_RX_INT_EN,
  98. port->status_addr);
  99. }
  100. static void __iomem *arc_ps2_calc_addr(struct arc_ps2_data *arc_ps2,
  101. int index, bool status)
  102. {
  103. void __iomem *addr;
  104. addr = arc_ps2->addr + 4 + 4 * index;
  105. if (status)
  106. addr += ARC_PS2_PORTS * 4;
  107. return addr;
  108. }
  109. static void arc_ps2_inhibit_ports(struct arc_ps2_data *arc_ps2)
  110. {
  111. void __iomem *addr;
  112. u32 val;
  113. int i;
  114. for (i = 0; i < ARC_PS2_PORTS; i++) {
  115. addr = arc_ps2_calc_addr(arc_ps2, i, true);
  116. val = ioread32(addr);
  117. val &= ~(PS2_STAT_RX_INT_EN | PS2_STAT_TX_INT_EN);
  118. iowrite32(val, addr);
  119. }
  120. }
  121. static int arc_ps2_create_port(struct platform_device *pdev,
  122. struct arc_ps2_data *arc_ps2,
  123. int index)
  124. {
  125. struct arc_ps2_port *port = &arc_ps2->port[index];
  126. struct serio *io;
  127. io = kzalloc(sizeof(struct serio), GFP_KERNEL);
  128. if (!io)
  129. return -ENOMEM;
  130. io->id.type = SERIO_8042;
  131. io->write = arc_ps2_write;
  132. io->open = arc_ps2_open;
  133. io->close = arc_ps2_close;
  134. snprintf(io->name, sizeof(io->name), "ARC PS/2 port%d", index);
  135. snprintf(io->phys, sizeof(io->phys), "arc/serio%d", index);
  136. io->port_data = port;
  137. port->io = io;
  138. port->data_addr = arc_ps2_calc_addr(arc_ps2, index, false);
  139. port->status_addr = arc_ps2_calc_addr(arc_ps2, index, true);
  140. dev_dbg(&pdev->dev, "port%d is allocated (data = 0x%p, status = 0x%p)\n",
  141. index, port->data_addr, port->status_addr);
  142. serio_register_port(port->io);
  143. return 0;
  144. }
  145. static int arc_ps2_probe(struct platform_device *pdev)
  146. {
  147. struct arc_ps2_data *arc_ps2;
  148. struct resource *res;
  149. int irq;
  150. int error, id, i;
  151. res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  152. if (!res) {
  153. dev_err(&pdev->dev, "no IO memory defined\n");
  154. return -EINVAL;
  155. }
  156. irq = platform_get_irq_byname(pdev, "arc_ps2_irq");
  157. if (irq < 0) {
  158. dev_err(&pdev->dev, "no IRQ defined\n");
  159. return -EINVAL;
  160. }
  161. arc_ps2 = devm_kzalloc(&pdev->dev, sizeof(struct arc_ps2_data),
  162. GFP_KERNEL);
  163. if (!arc_ps2) {
  164. dev_err(&pdev->dev, "out of memory\n");
  165. return -ENOMEM;
  166. }
  167. arc_ps2->addr = devm_ioremap_resource(&pdev->dev, res);
  168. if (IS_ERR(arc_ps2->addr))
  169. return PTR_ERR(arc_ps2->addr);
  170. dev_info(&pdev->dev, "irq = %d, address = 0x%p, ports = %i\n",
  171. irq, arc_ps2->addr, ARC_PS2_PORTS);
  172. id = ioread32(arc_ps2->addr);
  173. if (id != ARC_ARC_PS2_ID) {
  174. dev_err(&pdev->dev, "device id does not match\n");
  175. return -ENXIO;
  176. }
  177. arc_ps2_inhibit_ports(arc_ps2);
  178. error = devm_request_irq(&pdev->dev, irq, arc_ps2_interrupt,
  179. 0, "arc_ps2", arc_ps2);
  180. if (error) {
  181. dev_err(&pdev->dev, "Could not allocate IRQ\n");
  182. return error;
  183. }
  184. for (i = 0; i < ARC_PS2_PORTS; i++) {
  185. error = arc_ps2_create_port(pdev, arc_ps2, i);
  186. if (error) {
  187. while (--i >= 0)
  188. serio_unregister_port(arc_ps2->port[i].io);
  189. return error;
  190. }
  191. }
  192. platform_set_drvdata(pdev, arc_ps2);
  193. return 0;
  194. }
  195. static int arc_ps2_remove(struct platform_device *pdev)
  196. {
  197. struct arc_ps2_data *arc_ps2 = platform_get_drvdata(pdev);
  198. int i;
  199. for (i = 0; i < ARC_PS2_PORTS; i++)
  200. serio_unregister_port(arc_ps2->port[i].io);
  201. dev_dbg(&pdev->dev, "interrupt count = %i\n", arc_ps2->total_int);
  202. dev_dbg(&pdev->dev, "frame error count = %i\n", arc_ps2->frame_error);
  203. dev_dbg(&pdev->dev, "buffer overflow count = %i\n",
  204. arc_ps2->buf_overflow);
  205. return 0;
  206. }
  207. static struct platform_driver arc_ps2_driver = {
  208. .driver = {
  209. .name = "arc_ps2",
  210. .owner = THIS_MODULE,
  211. },
  212. .probe = arc_ps2_probe,
  213. .remove = arc_ps2_remove,
  214. };
  215. module_platform_driver(arc_ps2_driver);
  216. MODULE_LICENSE("GPL");
  217. MODULE_AUTHOR("Pavel Sokolov <psokolov@synopsys.com>");
  218. MODULE_DESCRIPTION("ARC PS/2 Driver");