riscv_io.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  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 void __raw_writeb(rt_uint8_t val, volatile void *addr)
  12. {
  13. asm volatile("sb %0, 0(%1)" : : "r"(val), "r"(addr));
  14. }
  15. static inline void __raw_writew(rt_uint16_t val, volatile void *addr)
  16. {
  17. asm volatile("sh %0, 0(%1)" : : "r"(val), "r"(addr));
  18. }
  19. static inline void __raw_writel(rt_uint32_t val, volatile void *addr)
  20. {
  21. asm volatile("sw %0, 0(%1)" : : "r"(val), "r"(addr));
  22. }
  23. #if __riscv_xlen != 32
  24. static inline void __raw_writeq(rt_uint64_t val, volatile void *addr)
  25. {
  26. asm volatile("sd %0, 0(%1)" : : "r"(val), "r"(addr));
  27. }
  28. #endif
  29. static inline rt_uint8_t __raw_readb(const volatile void *addr)
  30. {
  31. rt_uint8_t val;
  32. asm volatile("lb %0, 0(%1)" : "=r"(val) : "r"(addr));
  33. return val;
  34. }
  35. static inline rt_uint16_t __raw_readw(const volatile void *addr)
  36. {
  37. rt_uint16_t val;
  38. asm volatile("lh %0, 0(%1)" : "=r"(val) : "r"(addr));
  39. return val;
  40. }
  41. static inline rt_uint32_t __raw_readl(const volatile void *addr)
  42. {
  43. rt_uint32_t val;
  44. asm volatile("lw %0, 0(%1)" : "=r"(val) : "r"(addr));
  45. return val;
  46. }
  47. #if __riscv_xlen != 32
  48. static inline rt_uint64_t __raw_readq(const volatile void *addr)
  49. {
  50. rt_uint64_t val;
  51. asm volatile("ld %0, 0(%1)" : "=r"(val) : "r"(addr));
  52. return val;
  53. }
  54. #endif
  55. /* FIXME: These are now the same as asm-generic */
  56. /* clang-format off */
  57. #define __io_rbr() do {} while (0)
  58. #define __io_rar() do {} while (0)
  59. #define __io_rbw() do {} while (0)
  60. #define __io_raw() do {} while (0)
  61. #define readb_relaxed(c) ({ rt_uint8_t __v; __io_rbr(); __v = __raw_readb(c); __io_rar(); __v; })
  62. #define readw_relaxed(c) ({ rt_uint16_t __v; __io_rbr(); __v = __raw_readw(c); __io_rar(); __v; })
  63. #define readl_relaxed(c) ({ rt_uint32_t __v; __io_rbr(); __v = __raw_readl(c); __io_rar(); __v; })
  64. #define writeb_relaxed(v,c) ({ __io_rbw(); __raw_writeb((v),(c)); __io_raw(); })
  65. #define writew_relaxed(v,c) ({ __io_rbw(); __raw_writew((v),(c)); __io_raw(); })
  66. #define writel_relaxed(v,c) ({ __io_rbw(); __raw_writel((v),(c)); __io_raw(); })
  67. #if __riscv_xlen != 32
  68. #define readq_relaxed(c) ({ rt_uint64_t __v; __io_rbr(); __v = __raw_readq(c); __io_rar(); __v; })
  69. #define writeq_relaxed(v,c) ({ __io_rbw(); __raw_writeq((v),(c)); __io_raw(); })
  70. #endif
  71. #define __io_br() do {} while (0)
  72. #define __io_ar() __asm__ __volatile__ ("fence i,r" : : : "memory");
  73. #define __io_bw() __asm__ __volatile__ ("fence w,o" : : : "memory");
  74. #define __io_aw() do {} while (0)
  75. #define readb(c) ({ rt_uint8_t __v; __io_br(); __v = __raw_readb(c); __io_ar(); __v; })
  76. #define readw(c) ({ rt_uint16_t __v; __io_br(); __v = __raw_readw(c); __io_ar(); __v; })
  77. #define readl(c) ({ rt_uint32_t __v; __io_br(); __v = __raw_readl(c); __io_ar(); __v; })
  78. #define writeb(v,c) ({ __io_bw(); __raw_writeb((v),(c)); __io_aw(); })
  79. #define writew(v,c) ({ __io_bw(); __raw_writew((v),(c)); __io_aw(); })
  80. #define writel(v,c) ({ __io_bw(); __raw_writel((v),(c)); __io_aw(); })
  81. #if __riscv_xlen != 32
  82. #define readq(c) ({ rt_uint64_t __v; __io_br(); __v = __raw_readq(c); __io_ar(); __v; })
  83. #define writeq(v,c) ({ __io_bw(); __raw_writeq((v),(c)); __io_aw(); })
  84. #endif
  85. #endif