riscv_io.h 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. /*
  2. * SPDX-License-Identifier: BSD-2-Clause
  3. *
  4. * Copyright (c) 2019 Western Digital Corporation or its affiliates.
  5. *
  6. * Authors:
  7. * Anup Patel <anup.patel@wdc.com>
  8. */
  9. #ifndef __RISCV_IO_H__
  10. #define __RISCV_IO_H__
  11. static inline uint32_t __raw_hartid(void)
  12. {
  13. extern int boot_hartid;
  14. return boot_hartid;
  15. }
  16. static inline void __raw_writeb(rt_uint8_t val, volatile void *addr)
  17. {
  18. asm volatile("sb %0, 0(%1)"
  19. :
  20. : "r"(val), "r"(addr));
  21. }
  22. static inline void __raw_writew(rt_uint16_t val, volatile void *addr)
  23. {
  24. asm volatile("sh %0, 0(%1)"
  25. :
  26. : "r"(val), "r"(addr));
  27. }
  28. static inline void __raw_writel(rt_uint32_t val, volatile void *addr)
  29. {
  30. asm volatile("sw %0, 0(%1)"
  31. :
  32. : "r"(val), "r"(addr));
  33. }
  34. #if __riscv_xlen != 32
  35. static inline void __raw_writeq(rt_uint64_t val, volatile void *addr)
  36. {
  37. asm volatile("sd %0, 0(%1)"
  38. :
  39. : "r"(val), "r"(addr));
  40. }
  41. #endif
  42. static inline rt_uint8_t __raw_readb(const volatile void *addr)
  43. {
  44. rt_uint8_t val;
  45. asm volatile("lb %0, 0(%1)"
  46. : "=r"(val)
  47. : "r"(addr));
  48. return val;
  49. }
  50. static inline rt_uint16_t __raw_readw(const volatile void *addr)
  51. {
  52. rt_uint16_t val;
  53. asm volatile("lh %0, 0(%1)"
  54. : "=r"(val)
  55. : "r"(addr));
  56. return val;
  57. }
  58. static inline rt_uint32_t __raw_readl(const volatile void *addr)
  59. {
  60. rt_uint32_t val;
  61. asm volatile("lw %0, 0(%1)"
  62. : "=r"(val)
  63. : "r"(addr));
  64. return val;
  65. }
  66. #if __riscv_xlen != 32
  67. static inline rt_uint64_t __raw_readq(const volatile void *addr)
  68. {
  69. rt_uint64_t val;
  70. asm volatile("ld %0, 0(%1)"
  71. : "=r"(val)
  72. : "r"(addr));
  73. return val;
  74. }
  75. #endif
  76. /* FIXME: These are now the same as asm-generic */
  77. /* clang-format off */
  78. #define __io_rbr() do {} while (0)
  79. #define __io_rar() do {} while (0)
  80. #define __io_rbw() do {} while (0)
  81. #define __io_raw() do {} while (0)
  82. #define readb_relaxed(c) ({ rt_uint8_t __v; __io_rbr(); __v = __raw_readb(c); __io_rar(); __v; })
  83. #define readw_relaxed(c) ({ rt_uint16_t __v; __io_rbr(); __v = __raw_readw(c); __io_rar(); __v; })
  84. #define readl_relaxed(c) ({ rt_uint32_t __v; __io_rbr(); __v = __raw_readl(c); __io_rar(); __v; })
  85. #define writeb_relaxed(v,c) ({ __io_rbw(); __raw_writeb((v),(c)); __io_raw(); })
  86. #define writew_relaxed(v,c) ({ __io_rbw(); __raw_writew((v),(c)); __io_raw(); })
  87. #define writel_relaxed(v,c) ({ __io_rbw(); __raw_writel((v),(c)); __io_raw(); })
  88. #if __riscv_xlen != 32
  89. #define readq_relaxed(c) ({ rt_uint64_t __v; __io_rbr(); __v = __raw_readq(c); __io_rar(); __v; })
  90. #define writeq_relaxed(v,c) ({ __io_rbw(); __raw_writeq((v),(c)); __io_raw(); })
  91. #endif
  92. #define __io_br() do {} while (0)
  93. #define __io_ar() __asm__ __volatile__ ("fence i,r" : : : "memory");
  94. #define __io_bw() __asm__ __volatile__ ("fence w,o" : : : "memory");
  95. #define __io_aw() do {} while (0)
  96. #define readb(c) ({ rt_uint8_t __v; __io_br(); __v = __raw_readb(c); __io_ar(); __v; })
  97. #define readw(c) ({ rt_uint16_t __v; __io_br(); __v = __raw_readw(c); __io_ar(); __v; })
  98. #define readl(c) ({ rt_uint32_t __v; __io_br(); __v = __raw_readl(c); __io_ar(); __v; })
  99. #define writeb(v,c) ({ __io_bw(); __raw_writeb((v),(c)); __io_aw(); })
  100. #define writew(v,c) ({ __io_bw(); __raw_writew((v),(c)); __io_aw(); })
  101. #define writel(v,c) ({ __io_bw(); __raw_writel((v),(c)); __io_aw(); })
  102. #if __riscv_xlen != 32
  103. #define readq(c) ({ rt_uint64_t __v; __io_br(); __v = __raw_readq(c); __io_ar(); __v; })
  104. #define writeq(v,c) ({ __io_bw(); __raw_writeq((v),(c)); __io_aw(); })
  105. #endif
  106. #endif