iopin_85xx.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. /*
  2. * MPC85xx I/O port pin manipulation functions
  3. */
  4. #ifndef _ASM_IOPIN_85xx_H_
  5. #define _ASM_IOPIN_85xx_H_
  6. #include <linux/types.h>
  7. #include <asm/immap_85xx.h>
  8. #ifdef __KERNEL__
  9. typedef struct {
  10. u_char port:2; /* port number (A=0, B=1, C=2, D=3) */
  11. u_char pin:5; /* port pin (0-31) */
  12. u_char flag:1; /* for whatever */
  13. } iopin_t;
  14. #define IOPIN_PORTA 0
  15. #define IOPIN_PORTB 1
  16. #define IOPIN_PORTC 2
  17. #define IOPIN_PORTD 3
  18. extern __inline__ void iopin_set_high (iopin_t * iopin)
  19. {
  20. volatile uint *datp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.pdata;
  21. datp[iopin->port * 8] |= (1 << (31 - iopin->pin));
  22. }
  23. extern __inline__ void iopin_set_low (iopin_t * iopin)
  24. {
  25. volatile uint *datp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.pdata;
  26. datp[iopin->port * 8] &= ~(1 << (31 - iopin->pin));
  27. }
  28. extern __inline__ uint iopin_is_high (iopin_t * iopin)
  29. {
  30. volatile uint *datp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.pdata;
  31. return (datp[iopin->port * 8] >> (31 - iopin->pin)) & 1;
  32. }
  33. extern __inline__ uint iopin_is_low (iopin_t * iopin)
  34. {
  35. volatile uint *datp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.pdata;
  36. return ((datp[iopin->port * 8] >> (31 - iopin->pin)) & 1) ^ 1;
  37. }
  38. extern __inline__ void iopin_set_out (iopin_t * iopin)
  39. {
  40. volatile uint *dirp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.pdira;
  41. dirp[iopin->port * 8] |= (1 << (31 - iopin->pin));
  42. }
  43. extern __inline__ void iopin_set_in (iopin_t * iopin)
  44. {
  45. volatile uint *dirp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.pdira;
  46. dirp[iopin->port * 8] &= ~(1 << (31 - iopin->pin));
  47. }
  48. extern __inline__ uint iopin_is_out (iopin_t * iopin)
  49. {
  50. volatile uint *dirp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.pdira;
  51. return (dirp[iopin->port * 8] >> (31 - iopin->pin)) & 1;
  52. }
  53. extern __inline__ uint iopin_is_in (iopin_t * iopin)
  54. {
  55. volatile uint *dirp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.pdira;
  56. return ((dirp[iopin->port * 8] >> (31 - iopin->pin)) & 1) ^ 1;
  57. }
  58. extern __inline__ void iopin_set_odr (iopin_t * iopin)
  59. {
  60. volatile uint *odrp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.podra;
  61. odrp[iopin->port * 8] |= (1 << (31 - iopin->pin));
  62. }
  63. extern __inline__ void iopin_set_act (iopin_t * iopin)
  64. {
  65. volatile uint *odrp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.podra;
  66. odrp[iopin->port * 8] &= ~(1 << (31 - iopin->pin));
  67. }
  68. extern __inline__ uint iopin_is_odr (iopin_t * iopin)
  69. {
  70. volatile uint *odrp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.podra;
  71. return (odrp[iopin->port * 8] >> (31 - iopin->pin)) & 1;
  72. }
  73. extern __inline__ uint iopin_is_act (iopin_t * iopin)
  74. {
  75. volatile uint *odrp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.podra;
  76. return ((odrp[iopin->port * 8] >> (31 - iopin->pin)) & 1) ^ 1;
  77. }
  78. extern __inline__ void iopin_set_ded (iopin_t * iopin)
  79. {
  80. volatile uint *parp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.ppara;
  81. parp[iopin->port * 8] |= (1 << (31 - iopin->pin));
  82. }
  83. extern __inline__ void iopin_set_gen (iopin_t * iopin)
  84. {
  85. volatile uint *parp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.ppara;
  86. parp[iopin->port * 8] &= ~(1 << (31 - iopin->pin));
  87. }
  88. extern __inline__ uint iopin_is_ded (iopin_t * iopin)
  89. {
  90. volatile uint *parp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.ppara;
  91. return (parp[iopin->port * 8] >> (31 - iopin->pin)) & 1;
  92. }
  93. extern __inline__ uint iopin_is_gen (iopin_t * iopin)
  94. {
  95. volatile uint *parp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.ppara;
  96. return ((parp[iopin->port * 8] >> (31 - iopin->pin)) & 1) ^ 1;
  97. }
  98. extern __inline__ void iopin_set_opt2 (iopin_t * iopin)
  99. {
  100. volatile uint *sorp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.psora;
  101. sorp[iopin->port * 8] |= (1 << (31 - iopin->pin));
  102. }
  103. extern __inline__ void iopin_set_opt1 (iopin_t * iopin)
  104. {
  105. volatile uint *sorp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.psora;
  106. sorp[iopin->port * 8] &= ~(1 << (31 - iopin->pin));
  107. }
  108. extern __inline__ uint iopin_is_opt2 (iopin_t * iopin)
  109. {
  110. volatile uint *sorp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.psora;
  111. return (sorp[iopin->port * 8] >> (31 - iopin->pin)) & 1;
  112. }
  113. extern __inline__ uint iopin_is_opt1 (iopin_t * iopin)
  114. {
  115. volatile uint *sorp = &((ccsr_cpm_t *) CFG_MPC85xx_CPM_ADDR)->im_cpm_iop.psora;
  116. return ((sorp[iopin->port * 8] >> (31 - iopin->pin)) & 1) ^ 1;
  117. }
  118. #endif /* __KERNEL__ */
  119. #endif /* _ASM_IOPIN_85xx_H_ */