sbi.h 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * Copyright (C) 2015 Regents of the University of California
  4. * Copyright (c) 2020 Western Digital Corporation or its affiliates.
  5. *
  6. * Taken from Linux arch/riscv/include/asm/sbi.h
  7. */
  8. #ifndef _ASM_RISCV_SBI_H
  9. #define _ASM_RISCV_SBI_H
  10. #include <linux/types.h>
  11. enum sbi_ext_id {
  12. SBI_EXT_0_1_SET_TIMER = 0x0,
  13. SBI_EXT_0_1_CONSOLE_PUTCHAR = 0x1,
  14. SBI_EXT_0_1_CONSOLE_GETCHAR = 0x2,
  15. SBI_EXT_0_1_CLEAR_IPI = 0x3,
  16. SBI_EXT_0_1_SEND_IPI = 0x4,
  17. SBI_EXT_0_1_REMOTE_FENCE_I = 0x5,
  18. SBI_EXT_0_1_REMOTE_SFENCE_VMA = 0x6,
  19. SBI_EXT_0_1_REMOTE_SFENCE_VMA_ASID = 0x7,
  20. SBI_EXT_0_1_SHUTDOWN = 0x8,
  21. SBI_EXT_BASE = 0x10,
  22. SBI_EXT_TIME = 0x54494D45,
  23. SBI_EXT_IPI = 0x735049,
  24. SBI_EXT_RFENCE = 0x52464E43,
  25. SBI_EXT_HSM = 0x48534D,
  26. SBI_EXT_SRST = 0x53525354,
  27. SBI_EXT_PMU = 0x504D55,
  28. SBI_EXT_DBCN = 0x4442434E,
  29. SBI_EXT_SUSP = 0x53555350,
  30. SBI_EXT_CPPC = 0x43505043,
  31. SBI_EXT_NACL = 0x4E41434C,
  32. SBI_EXT_STA = 0x535441,
  33. };
  34. enum sbi_ext_base_fid {
  35. SBI_EXT_BASE_GET_SPEC_VERSION = 0,
  36. SBI_EXT_BASE_GET_IMP_ID,
  37. SBI_EXT_BASE_GET_IMP_VERSION,
  38. SBI_EXT_BASE_PROBE_EXT,
  39. SBI_EXT_BASE_GET_MVENDORID,
  40. SBI_EXT_BASE_GET_MARCHID,
  41. SBI_EXT_BASE_GET_MIMPID,
  42. };
  43. enum sbi_ext_time_fid {
  44. SBI_EXT_TIME_SET_TIMER = 0,
  45. };
  46. enum sbi_ext_ipi_fid {
  47. SBI_EXT_IPI_SEND_IPI = 0,
  48. };
  49. enum sbi_ext_rfence_fid {
  50. SBI_EXT_RFENCE_REMOTE_FENCE_I = 0,
  51. SBI_EXT_RFENCE_REMOTE_SFENCE_VMA,
  52. SBI_EXT_RFENCE_REMOTE_SFENCE_VMA_ASID,
  53. SBI_EXT_RFENCE_REMOTE_HFENCE_GVMA_VMID,
  54. SBI_EXT_RFENCE_REMOTE_HFENCE_GVMA,
  55. SBI_EXT_RFENCE_REMOTE_HFENCE_VVMA_ASID,
  56. SBI_EXT_RFENCE_REMOTE_HFENCE_VVMA,
  57. };
  58. enum sbi_ext_hsm_fid {
  59. SBI_EXT_HSM_HART_START = 0,
  60. SBI_EXT_HSM_HART_STOP,
  61. SBI_EXT_HSM_HART_STATUS,
  62. SBI_EXT_HSM_HART_SUSPEND,
  63. };
  64. enum sbi_hsm_hart_status {
  65. SBI_HSM_HART_STATUS_STARTED = 0,
  66. SBI_HSM_HART_STATUS_STOPPED,
  67. SBI_HSM_HART_STATUS_START_PENDING,
  68. SBI_HSM_HART_STATUS_STOP_PENDING,
  69. SBI_HSM_HART_STATUS_SUSPEND_PENDING,
  70. SBI_HSM_HART_STATUS_RESUME_PENDING,
  71. };
  72. enum sbi_ext_srst_fid {
  73. SBI_EXT_SRST_RESET = 0,
  74. };
  75. enum sbi_srst_reset_type {
  76. SBI_SRST_RESET_TYPE_SHUTDOWN = 0,
  77. SBI_SRST_RESET_TYPE_COLD_REBOOT,
  78. SBI_SRST_RESET_TYPE_WARM_REBOOT,
  79. };
  80. enum sbi_srst_reset_reason {
  81. SBI_SRST_RESET_REASON_NONE = 0,
  82. SBI_SRST_RESET_REASON_SYS_FAILURE,
  83. };
  84. enum sbi_ext_dbcn_fid {
  85. SBI_EXT_DBCN_CONSOLE_WRITE = 0,
  86. SBI_EXT_DBCN_CONSOLE_READ,
  87. SBI_EXT_DBCN_CONSOLE_WRITE_BYTE,
  88. };
  89. #ifdef CONFIG_SBI_V01
  90. #define SBI_EXT_SET_TIMER SBI_EXT_0_1_SET_TIMER
  91. #define SBI_FID_SET_TIMER 0
  92. #define SBI_EXT_SEND_IPI SBI_EXT_0_1_SEND_IPI
  93. #define SBI_FID_SEND_IPI 0
  94. #define SBI_EXT_REMOTE_FENCE_I SBI_EXT_0_1_REMOTE_FENCE_I
  95. #define SBI_FID_REMOTE_FENCE_I 0
  96. #define SBI_EXT_REMOTE_SFENCE_VMA SBI_EXT_0_1_REMOTE_SFENCE_VMA
  97. #define SBI_FID_REMOTE_SFENCE_VMA 0
  98. #define SBI_EXT_REMOTE_SFENCE_VMA_ASID SBI_EXT_0_1_REMOTE_SFENCE_VMA_ASID
  99. #define SBI_FID_REMOTE_SFENCE_VMA_ASID 0
  100. #else
  101. #define SBI_EXT_SET_TIMER SBI_EXT_TIME
  102. #define SBI_FID_SET_TIMER SBI_EXT_TIME_SET_TIMER
  103. #define SBI_EXT_SEND_IPI SBI_EXT_IPI
  104. #define SBI_FID_SEND_IPI SBI_EXT_IPI_SEND_IPI
  105. #define SBI_EXT_REMOTE_FENCE_I SBI_EXT_RFENCE
  106. #define SBI_FID_REMOTE_FENCE_I SBI_EXT_RFENCE_REMOTE_FENCE_I
  107. #define SBI_EXT_REMOTE_SFENCE_VMA SBI_EXT_RFENCE
  108. #define SBI_FID_REMOTE_SFENCE_VMA SBI_EXT_RFENCE_REMOTE_SFENCE_VMA
  109. #define SBI_EXT_REMOTE_SFENCE_VMA_ASID SBI_EXT_RFENCE
  110. #define SBI_FID_REMOTE_SFENCE_VMA_ASID SBI_EXT_RFENCE_REMOTE_SFENCE_VMA_ASID
  111. #endif
  112. #define SBI_SPEC_VERSION_MAJOR_SHIFT 24
  113. #define SBI_SPEC_VERSION_MAJOR_MASK 0x7f
  114. #define SBI_SPEC_VERSION_MINOR_MASK 0xffffff
  115. /* SBI return error codes */
  116. #define SBI_SUCCESS 0
  117. #define SBI_ERR_FAILURE -1
  118. #define SBI_ERR_NOT_SUPPORTED -2
  119. #define SBI_ERR_INVALID_PARAM -3
  120. #define SBI_ERR_DENIED -4
  121. #define SBI_ERR_INVALID_ADDRESS -5
  122. struct sbiret {
  123. long error;
  124. long value;
  125. };
  126. struct sbiret sbi_ecall(int ext, int fid, unsigned long arg0,
  127. unsigned long arg1, unsigned long arg2,
  128. unsigned long arg3, unsigned long arg4,
  129. unsigned long arg5);
  130. #ifdef CONFIG_SBI_V01
  131. void sbi_console_putchar(int ch);
  132. int sbi_console_getchar(void);
  133. void sbi_clear_ipi(void);
  134. void sbi_shutdown(void);
  135. void sbi_send_ipi(const unsigned long *hart_mask);
  136. void sbi_remote_fence_i(const unsigned long *hart_mask);
  137. void sbi_remote_sfence_vma(const unsigned long *hart_mask,
  138. unsigned long start,
  139. unsigned long size);
  140. void sbi_remote_sfence_vma_asid(const unsigned long *hart_mask,
  141. unsigned long start,
  142. unsigned long size,
  143. unsigned long asid);
  144. #endif
  145. void sbi_set_timer(uint64_t stime_value);
  146. long sbi_get_spec_version(void);
  147. int sbi_get_impl_id(void);
  148. int sbi_get_impl_version(long *version);
  149. int sbi_probe_extension(int ext);
  150. int sbi_get_mvendorid(long *mvendorid);
  151. int sbi_get_marchid(long *marchid);
  152. int sbi_get_mimpid(long *mimpid);
  153. void sbi_srst_reset(unsigned long type, unsigned long reason);
  154. int sbi_dbcn_write_byte(unsigned char ch);
  155. #endif