arc_ps2.c 6.2 KB

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