nsc_gpio.c 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  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\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. }
  33. ssize_t nsc_gpio_write(struct file *file, const char __user *data,
  34. size_t len, loff_t *ppos)
  35. {
  36. unsigned m = iminor(file->f_dentry->d_inode);
  37. struct nsc_gpio_ops *amp = file->private_data;
  38. struct device *dev = amp->dev;
  39. size_t i;
  40. int err = 0;
  41. for (i = 0; i < len; ++i) {
  42. char c;
  43. if (get_user(c, data + i))
  44. return -EFAULT;
  45. switch (c) {
  46. case '0':
  47. amp->gpio_set(m, 0);
  48. break;
  49. case '1':
  50. amp->gpio_set(m, 1);
  51. break;
  52. case 'O':
  53. dev_dbg(dev, "GPIO%d output enabled\n", m);
  54. amp->gpio_config(m, ~1, 1);
  55. break;
  56. case 'o':
  57. dev_dbg(dev, "GPIO%d output disabled\n", m);
  58. amp->gpio_config(m, ~1, 0);
  59. break;
  60. case 'T':
  61. dev_dbg(dev, "GPIO%d output is push pull\n",
  62. m);
  63. amp->gpio_config(m, ~2, 2);
  64. break;
  65. case 't':
  66. dev_dbg(dev, "GPIO%d output is open drain\n",
  67. m);
  68. amp->gpio_config(m, ~2, 0);
  69. break;
  70. case 'P':
  71. dev_dbg(dev, "GPIO%d pull up enabled\n", m);
  72. amp->gpio_config(m, ~4, 4);
  73. break;
  74. case 'p':
  75. dev_dbg(dev, "GPIO%d pull up disabled\n", m);
  76. amp->gpio_config(m, ~4, 0);
  77. break;
  78. case 'v':
  79. /* View Current pin settings */
  80. amp->gpio_dump(amp, m);
  81. break;
  82. case '\n':
  83. /* end of settings string, do nothing */
  84. break;
  85. default:
  86. dev_err(dev, "io%2d bad setting: chr<0x%2x>\n",
  87. m, (int)c);
  88. err++;
  89. }
  90. }
  91. if (err)
  92. return -EINVAL; /* full string handled, report error */
  93. return len;
  94. }
  95. ssize_t nsc_gpio_read(struct file *file, char __user * buf,
  96. size_t len, loff_t * ppos)
  97. {
  98. unsigned m = iminor(file->f_dentry->d_inode);
  99. int value;
  100. struct nsc_gpio_ops *amp = file->private_data;
  101. value = amp->gpio_get(m);
  102. if (put_user(value ? '1' : '0', buf))
  103. return -EFAULT;
  104. return 1;
  105. }
  106. /* common file-ops routines for both scx200_gpio and pc87360_gpio */
  107. EXPORT_SYMBOL(nsc_gpio_write);
  108. EXPORT_SYMBOL(nsc_gpio_read);
  109. EXPORT_SYMBOL(nsc_gpio_dump);
  110. static int __init nsc_gpio_init(void)
  111. {
  112. printk(KERN_DEBUG NAME " initializing\n");
  113. return 0;
  114. }
  115. static void __exit nsc_gpio_cleanup(void)
  116. {
  117. printk(KERN_DEBUG NAME " cleanup\n");
  118. }
  119. module_init(nsc_gpio_init);
  120. module_exit(nsc_gpio_cleanup);
  121. MODULE_AUTHOR("Jim Cromie <jim.cromie@gmail.com>");
  122. MODULE_DESCRIPTION("NatSemi GPIO Common Methods");
  123. MODULE_LICENSE("GPL");