io_trivial.h 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /* Trivial implementations of basic i/o routines. Assumes that all
  3. of the hard work has been done by ioremap and ioportmap, and that
  4. access to i/o space is linear. */
  5. /* This file may be included multiple times. */
  6. #if IO_CONCAT(__IO_PREFIX,trivial_io_bw)
  7. __EXTERN_INLINE unsigned int
  8. IO_CONCAT(__IO_PREFIX,ioread8)(void __iomem *a)
  9. {
  10. return __kernel_ldbu(*(volatile u8 __force *)a);
  11. }
  12. __EXTERN_INLINE unsigned int
  13. IO_CONCAT(__IO_PREFIX,ioread16)(void __iomem *a)
  14. {
  15. return __kernel_ldwu(*(volatile u16 __force *)a);
  16. }
  17. __EXTERN_INLINE void
  18. IO_CONCAT(__IO_PREFIX,iowrite8)(u8 b, void __iomem *a)
  19. {
  20. __kernel_stb(b, *(volatile u8 __force *)a);
  21. }
  22. __EXTERN_INLINE void
  23. IO_CONCAT(__IO_PREFIX,iowrite16)(u16 b, void __iomem *a)
  24. {
  25. __kernel_stw(b, *(volatile u16 __force *)a);
  26. }
  27. #endif
  28. #if IO_CONCAT(__IO_PREFIX,trivial_io_lq)
  29. __EXTERN_INLINE unsigned int
  30. IO_CONCAT(__IO_PREFIX,ioread32)(void __iomem *a)
  31. {
  32. return *(volatile u32 __force *)a;
  33. }
  34. __EXTERN_INLINE void
  35. IO_CONCAT(__IO_PREFIX,iowrite32)(u32 b, void __iomem *a)
  36. {
  37. *(volatile u32 __force *)a = b;
  38. }
  39. #endif
  40. #if IO_CONCAT(__IO_PREFIX,trivial_rw_bw) == 1
  41. __EXTERN_INLINE u8
  42. IO_CONCAT(__IO_PREFIX,readb)(const volatile void __iomem *a)
  43. {
  44. return __kernel_ldbu(*(const volatile u8 __force *)a);
  45. }
  46. __EXTERN_INLINE u16
  47. IO_CONCAT(__IO_PREFIX,readw)(const volatile void __iomem *a)
  48. {
  49. return __kernel_ldwu(*(const volatile u16 __force *)a);
  50. }
  51. __EXTERN_INLINE void
  52. IO_CONCAT(__IO_PREFIX,writeb)(u8 b, volatile void __iomem *a)
  53. {
  54. __kernel_stb(b, *(volatile u8 __force *)a);
  55. }
  56. __EXTERN_INLINE void
  57. IO_CONCAT(__IO_PREFIX,writew)(u16 b, volatile void __iomem *a)
  58. {
  59. __kernel_stw(b, *(volatile u16 __force *)a);
  60. }
  61. #elif IO_CONCAT(__IO_PREFIX,trivial_rw_bw) == 2
  62. __EXTERN_INLINE u8
  63. IO_CONCAT(__IO_PREFIX,readb)(const volatile void __iomem *a)
  64. {
  65. void __iomem *addr = (void __iomem *)a;
  66. return IO_CONCAT(__IO_PREFIX,ioread8)(addr);
  67. }
  68. __EXTERN_INLINE u16
  69. IO_CONCAT(__IO_PREFIX,readw)(const volatile void __iomem *a)
  70. {
  71. void __iomem *addr = (void __iomem *)a;
  72. return IO_CONCAT(__IO_PREFIX,ioread16)(addr);
  73. }
  74. __EXTERN_INLINE void
  75. IO_CONCAT(__IO_PREFIX,writeb)(u8 b, volatile void __iomem *a)
  76. {
  77. void __iomem *addr = (void __iomem *)a;
  78. IO_CONCAT(__IO_PREFIX,iowrite8)(b, addr);
  79. }
  80. __EXTERN_INLINE void
  81. IO_CONCAT(__IO_PREFIX,writew)(u16 b, volatile void __iomem *a)
  82. {
  83. void __iomem *addr = (void __iomem *)a;
  84. IO_CONCAT(__IO_PREFIX,iowrite16)(b, addr);
  85. }
  86. #endif
  87. #if IO_CONCAT(__IO_PREFIX,trivial_rw_lq) == 1
  88. __EXTERN_INLINE u32
  89. IO_CONCAT(__IO_PREFIX,readl)(const volatile void __iomem *a)
  90. {
  91. return *(const volatile u32 __force *)a;
  92. }
  93. __EXTERN_INLINE u64
  94. IO_CONCAT(__IO_PREFIX,readq)(const volatile void __iomem *a)
  95. {
  96. return *(const volatile u64 __force *)a;
  97. }
  98. __EXTERN_INLINE void
  99. IO_CONCAT(__IO_PREFIX,writel)(u32 b, volatile void __iomem *a)
  100. {
  101. *(volatile u32 __force *)a = b;
  102. }
  103. __EXTERN_INLINE void
  104. IO_CONCAT(__IO_PREFIX,writeq)(u64 b, volatile void __iomem *a)
  105. {
  106. *(volatile u64 __force *)a = b;
  107. }
  108. #endif
  109. #if IO_CONCAT(__IO_PREFIX,trivial_iounmap)
  110. __EXTERN_INLINE void IO_CONCAT(__IO_PREFIX,iounmap)(volatile void __iomem *a)
  111. {
  112. }
  113. #endif