riscv_io.h 3.4 KB

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