nsc_gpio.c 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. /* linux/drivers/char/nsc_gpio.c
  2. National Semiconductor common GPIO device-file/VFS methods.
  3. Allows a user space process to control the GPIO pins.
  4. Copyright (c) 2001,2002 Christer Weinigel <wingel@nano-system.com>
  5. Copyright (c) 2005 Jim Cromie <jim.cromie@gmail.com>
  6. */
  7. #include <linux/config.h>
  8. #include <linux/fs.h>
  9. #include <linux/module.h>
  10. #include <linux/errno.h>
  11. #include <linux/kernel.h>
  12. #include <linux/init.h>
  13. #include <linux/nsc_gpio.h>
  14. #include <linux/platform_device.h>
  15. #include <asm/uaccess.h>
  16. #include <asm/io.h>
  17. #define NAME "nsc_gpio"
  18. void nsc_gpio_dump(struct nsc_gpio_ops *amp, unsigned index)
  19. {
  20. /* retrieve current config w/o changing it */
  21. u32 config = amp->gpio_config(index, ~0, 0);
  22. /* user requested via 'v' command, so its INFO */
  23. dev_info(amp->dev, "io%02u: 0x%04x %s %s %s %s %s %s %s\tio:%d/%d\n",
  24. index, config,
  25. (config & 1) ? "OE" : "TS", /* output-enabled/tristate */
  26. (config & 2) ? "PP" : "OD", /* push pull / open drain */
  27. (config & 4) ? "PUE" : "PUD", /* pull up enabled/disabled */
  28. (config & 8) ? "LOCKED" : "", /* locked / unlocked */
  29. (config & 16) ? "LEVEL" : "EDGE",/* level/edge input */
  30. (config & 32) ? "HI" : "LO", /* trigger on rise/fall edge */
  31. (config & 64) ? "DEBOUNCE" : "", /* debounce */
  32. amp->gpio_get(index), amp->gpio_current(index));
  33. }
  34. ssize_t nsc_gpio_write(struct file *file, const char __user *data,
  35. size_t len, loff_t *ppos)
  36. {
  37. unsigned m = iminor(file->f_dentry->d_inode);
  38. struct nsc_gpio_ops *amp = file->private_data;
  39. struct device *dev = amp->dev;
  40. size_t i;
  41. int err = 0;
  42. for (i = 0; i < len; ++i) {
  43. char c;
  44. if (get_user(c, data + i))
  45. return -EFAULT;
  46. switch (c) {
  47. case '0':
  48. amp->gpio_set(m, 0);
  49. break;
  50. case '1':
  51. amp->gpio_set(m, 1);
  52. break;
  53. case 'O':
  54. dev_dbg(dev, "GPIO%d output enabled\n", m);
  55. amp->gpio_config(m, ~1, 1);
  56. break;
  57. case 'o':
  58. dev_dbg(dev, "GPIO%d output disabled\n", m);
  59. amp->gpio_config(m, ~1, 0);
  60. break;
  61. case 'T':
  62. dev_dbg(dev, "GPIO%d output is push pull\n",
  63. m);
  64. amp->gpio_config(m, ~2, 2);
  65. break;
  66. case 't':
  67. dev_dbg(dev, "GPIO%d output is open drain\n",
  68. m);
  69. amp->gpio_config(m, ~2, 0);
  70. break;
  71. case 'P':
  72. dev_dbg(dev, "GPIO%d pull up enabled\n", m);
  73. amp->gpio_config(m, ~4, 4);
  74. break;
  75. case 'p':
  76. dev_dbg(dev, "GPIO%d pull up disabled\n", m);
  77. amp->gpio_config(m, ~4, 0);
  78. break;
  79. case 'v':
  80. /* View Current pin settings */
  81. amp->gpio_dump(amp, m);
  82. break;
  83. case '\n':
  84. /* end of settings string, do nothing */
  85. break;
  86. default:
  87. dev_err(dev, "io%2d bad setting: chr<0x%2x>\n",
  88. m, (int)c);
  89. err++;
  90. }
  91. }
  92. if (err)
  93. return -EINVAL; /* full string handled, report error */
  94. return len;
  95. }
  96. ssize_t nsc_gpio_read(struct file *file, char __user * buf,
  97. size_t len, loff_t * ppos)
  98. {
  99. unsigned m = iminor(file->f_dentry->d_inode);
  100. int value;
  101. struct nsc_gpio_ops *amp = file->private_data;
  102. value = amp->gpio_get(m);
  103. if (put_user(value ? '1' : '0', buf))
  104. return -EFAULT;
  105. return 1;
  106. }
  107. /* common file-ops routines for both scx200_gpio and pc87360_gpio */
  108. EXPORT_SYMBOL(nsc_gpio_write);
  109. EXPORT_SYMBOL(nsc_gpio_read);
  110. EXPORT_SYMBOL(nsc_gpio_dump);
  111. static int __init nsc_gpio_init(void)
  112. {
  113. printk(KERN_DEBUG NAME " initializing\n");
  114. return 0;
  115. }
  116. static void __exit nsc_gpio_cleanup(void)
  117. {
  118. printk(KERN_DEBUG NAME " cleanup\n");
  119. }
  120. module_init(nsc_gpio_init);
  121. module_exit(nsc_gpio_cleanup);
  122. MODULE_AUTHOR("Jim Cromie <jim.cromie@gmail.com>");
  123. MODULE_DESCRIPTION("NatSemi GPIO Common Methods");
  124. MODULE_LICENSE("GPL");