gpio.h 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. #ifndef _IMX_GPIO_H
  2. #include <mach/imx-regs.h>
  3. #define IMX_GPIO_ALLOC_MODE_NORMAL 0
  4. #define IMX_GPIO_ALLOC_MODE_NO_ALLOC 1
  5. #define IMX_GPIO_ALLOC_MODE_TRY_ALLOC 2
  6. #define IMX_GPIO_ALLOC_MODE_ALLOC_ONLY 4
  7. #define IMX_GPIO_ALLOC_MODE_RELEASE 8
  8. extern int imx_gpio_request(unsigned gpio, const char *label);
  9. extern void imx_gpio_free(unsigned gpio);
  10. extern int imx_gpio_setup_multiple_pins(const int *pin_list, unsigned count,
  11. int alloc_mode, const char *label);
  12. extern int imx_gpio_direction_input(unsigned gpio);
  13. extern int imx_gpio_direction_output(unsigned gpio, int value);
  14. extern void __imx_gpio_set_value(unsigned gpio, int value);
  15. static inline int imx_gpio_get_value(unsigned gpio)
  16. {
  17. return SSR(gpio >> GPIO_PORT_SHIFT) & (1 << (gpio & GPIO_PIN_MASK));
  18. }
  19. static inline void imx_gpio_set_value_inline(unsigned gpio, int value)
  20. {
  21. unsigned long flags;
  22. raw_local_irq_save(flags);
  23. if(value)
  24. DR(gpio >> GPIO_PORT_SHIFT) |= (1 << (gpio & GPIO_PIN_MASK));
  25. else
  26. DR(gpio >> GPIO_PORT_SHIFT) &= ~(1 << (gpio & GPIO_PIN_MASK));
  27. raw_local_irq_restore(flags);
  28. }
  29. static inline void imx_gpio_set_value(unsigned gpio, int value)
  30. {
  31. if(__builtin_constant_p(gpio))
  32. imx_gpio_set_value_inline(gpio, value);
  33. else
  34. __imx_gpio_set_value(gpio, value);
  35. }
  36. extern int imx_gpio_to_irq(unsigned gpio);
  37. extern int imx_irq_to_gpio(unsigned irq);
  38. /*-------------------------------------------------------------------------*/
  39. /* Wrappers for "new style" GPIO calls. These calls i.MX specific versions
  40. * to allow future extension of GPIO logic.
  41. */
  42. static inline int gpio_request(unsigned gpio, const char *label)
  43. {
  44. return imx_gpio_request(gpio, label);
  45. }
  46. static inline void gpio_free(unsigned gpio)
  47. {
  48. imx_gpio_free(gpio);
  49. }
  50. static inline int gpio_direction_input(unsigned gpio)
  51. {
  52. return imx_gpio_direction_input(gpio);
  53. }
  54. static inline int gpio_direction_output(unsigned gpio, int value)
  55. {
  56. return imx_gpio_direction_output(gpio, value);
  57. }
  58. static inline int gpio_get_value(unsigned gpio)
  59. {
  60. return imx_gpio_get_value(gpio);
  61. }
  62. static inline void gpio_set_value(unsigned gpio, int value)
  63. {
  64. imx_gpio_set_value(gpio, value);
  65. }
  66. #include <asm-generic/gpio.h> /* cansleep wrappers */
  67. static inline int gpio_to_irq(unsigned gpio)
  68. {
  69. return imx_gpio_to_irq(gpio);
  70. }
  71. static inline int irq_to_gpio(unsigned irq)
  72. {
  73. return imx_irq_to_gpio(irq);
  74. }
  75. #endif