swr-mstr-registers.h 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (c) 2015, 2018-2021 The Linux Foundation. All rights reserved.
  4. * Copyright (c) 2022 Qualcomm Innovation Center, Inc. All rights reserved.
  5. */
  6. #ifndef _SWRM_REGISTERS_H
  7. #define _SWRM_REGISTERS_H
  8. #define SWRM_BASE 0x00
  9. #define SWRM_COMP_HW_VERSION (SWRM_BASE+0x0000)
  10. #define SWRM_COMP_CFG (SWRM_BASE+0x0004)
  11. #define SWRM_COMP_SW_RESET (SWRM_BASE+0x0008)
  12. #define SWRM_COMP_POWER_CFG (SWRM_BASE+0x000C)
  13. #define SWRM_COMP_FEATURE_CFG (SWRM_BASE+0x0010)
  14. #define SWRM_COMP_STATUS (SWRM_BASE+0x0014)
  15. #define SWRM_LINK_MANAGER_EE (SWRM_BASE+0x0018)
  16. #define SWRM_COMP_PARAMS (SWRM_BASE+0x0100)
  17. #define SWRM_COMP_MASTER_ID (SWRM_BASE+0x0104)
  18. #define MM_SYNC_CONFIG (SWRM_BASE+0x0108)
  19. #define SWRM_COMP_NPL_PARAMS (SWRM_BASE+0x0120)
  20. #ifdef CONFIG_SWRM_VER_2P0
  21. #define SWRM_INTERRUPT_STATUS(n) (SWRM_BASE+0x4000+0x1000*n)
  22. #define SWRM_INTERRUPT_EN(n) (SWRM_BASE+0x4004+0x1000*n)
  23. #define SWRM_INTERRUPT_CLEAR(n) (SWRM_BASE+0x4008+0x1000*n)
  24. #define SWRM_CMD_FIFO_WR_CMD(n) (SWRM_BASE+0x4020+0x1000*n)
  25. #define SWRM_CMD_FIFO_RD_CMD(n) (SWRM_BASE+0x4024+0x1000*n)
  26. #define SWRM_NUM_ENTRIES_CMD_FIFO(n) (SWRM_BASE+0x4028+0x1000*n)
  27. #define SWRM_CMD_FIFO_RD_FIFO(n) (SWRM_BASE+0x4040+0x1000*n)
  28. #define SWRM_NUM_ENTRIES_RD_FIFO(n) (SWRM_BASE+0x4044+0x1000*n)
  29. #define SWRM_CMD_FIFO_STATUS(n) (SWRM_BASE+0x4050+0x1000*n)
  30. #define SWRM_CMD_RESPONSE(n) (SWRM_BASE+0x4054+0x1000*n)
  31. #define SWRM_CLK_CTRL(n) (SWRM_BASE+0x4060+0x1000*n)
  32. #define SWRM_LINK_STATUS(n) (SWRM_BASE+0x4064+0x1000*n)
  33. #define SWRM_TO_CPU_SW_MESSAGE(n, m) (SWRM_BASE+0x4090+0x1000*n+0x4*m)
  34. #define SWRM_TO_CPU_SW_MESSAGE_READ(n, m) (SWRM_BASE+0x40A0+0x1000*n+0x4*m)
  35. #define SWRM_DOUT_DP_FIFO_WATERMARK_CTRL(n) (SWRM_BASE+0x1060+0x100*n)
  36. #define SWRM_INTERRUPT_STATUS_RD_FIFO_OVERFLOW 0x10
  37. #define SWRM_INTERRUPT_STATUS_RD_FIFO_UNDERFLOW 0x20
  38. #define SWRM_INTERRUPT_STATUS_SPECIAL_CMD_ID_FINISHED 0x400
  39. #define SWRM_INTERRUPT_STATUS_MASK 0x1DFDFD
  40. #define SWRM_INTERRUPT_MAX 0x17
  41. #else
  42. #define SWRM_INTERRUPT_STATUS(n) (SWRM_BASE+0x0200*n)
  43. #define SWRM_INTERRUPT_CLEAR(n) (SWRM_BASE+0x0208*n)
  44. #define SWRM_INTERRUPT_STATUS_1(n) (SWRM_BASE+0x0220*n)
  45. #define SWRM_INTERRUPT_CLEAR_1(n) (SWRM_BASE+0x0228*n)
  46. #define SWRM_CPU1_INTERRUPT_EN(n) (SWRM_BASE+0x0210*n)
  47. #define SWRM_CPU1_INTERRUPT_EN_1(n) (SWRM_BASE+0x0230*n)
  48. #define SWRM_CPU0_CMD_RESPONSE(n) (SWRM_BASE+0x0250*n)
  49. #define SWRM_CPU1_CMD_FIFO_WR_CMD(n) (SWRM_BASE+0x031C*n)
  50. #define SWRM_CPU1_CMD_FIFO_RD_CMD(n) (SWRM_BASE+0x0320*n)
  51. #define SWRM_CPU1_CMD_FIFO_STATUS(n) (SWRM_BASE+0x0328*n)
  52. #define SWRM_CPU1_CMD_FIFO_RD_FIFO(n) (SWRM_BASE+0x0334*n)
  53. #ifdef CONFIG_SWRM_VER_1P7
  54. #define SWRM_INTERRUPT_EN SWRM_CPU1_INTERRUPT_EN
  55. #define SWRM_INTERRUPT_EN_1 SWRM_CPU1_INTERRUPT_EN_1
  56. #define SWRM_CMD_FIFO_WR_CMD SWRM_CPU1_CMD_FIFO_WR_CMD
  57. #define SWRM_CMD_FIFO_RD_CMD SWRM_CPU1_CMD_FIFO_RD_CMD
  58. #define SWRM_CMD_FIFO_STATUS SWRM_CPU1_CMD_FIFO_STATUS
  59. #define SWRM_CMD_FIFO_RD_FIFO SWRM_CPU1_CMD_FIFO_RD_FIFO
  60. #define SWRM_INTERRUPT_STATUS_MASK 0x1DFDFD
  61. #define SWRM_INTERRUPT_STATUS_RD_FIFO_OVERFLOW 0x40000
  62. #define SWRM_INTERRUPT_STATUS_RD_FIFO_UNDERFLOW 0x80000
  63. #define SWRM_INTERRUPT_STATUS_SPECIAL_CMD_ID_FINISHED 0x100000
  64. #define SWRM_INTERRUPT_MAX 0x20
  65. #else
  66. #define SWRM_INTERRUPT_EN(n) SWRM_CPU1_INTERRUPT_EN(n)
  67. #define SWRM_INTERRUPT_EN_1(n) (SWRM_BASE+0x0224*n)
  68. #define SWRM_CMD_FIFO_WR_CMD(n) (SWRM_BASE+0x0300*n)
  69. #define SWRM_CMD_FIFO_RD_CMD(n) (SWRM_BASE+0x0304*n)
  70. #define SWRM_CMD_FIFO_STATUS(n) (SWRM_BASE+0x030C*n)
  71. #define SWRM_CMD_FIFO_RD_FIFO(n) (SWRM_BASE+0x0318*n)
  72. #define SWRM_INTERRUPT_STATUS_MASK 0x1FDFD
  73. #define SWRM_INTERRUPT_STATUS_RD_FIFO_OVERFLOW 0x10
  74. #define SWRM_INTERRUPT_STATUS_RD_FIFO_UNDERFLOW 0x20
  75. #define SWRM_INTERRUPT_STATUS_SPECIAL_CMD_ID_FINISHED 0x400
  76. #define SWRM_INTERRUPT_MAX 0x11
  77. #endif /* CONFIG_SWRM_VER_1P7 */
  78. #endif /* CONFIG_SWRM_VER_2P0 */
  79. #define SWRM_CMD_FIFO_CMD (SWRM_BASE+0x0308)
  80. #define SWRM_CMD_FIFO_CFG (SWRM_BASE+0x0314)
  81. #define SWRM_CPU_NUM_ENTRIES_WR_CMD_FIFO (SWRM_BASE+0x0370)
  82. #define SWRM_CPU0_SW_INTERRUPT_SET (SWRM_BASE+0x0374)
  83. #define SWRM_CPU0_SW_MESSAGE0 (SWRM_BASE+0x0384)
  84. #define SWRM_CPU0_SW_MESSAGE1 (SWRM_BASE+0x0394)
  85. #define SWRM_ENUMERATOR_CFG (SWRM_BASE+0x0500)
  86. #define SWRM_ENUMERATOR_STATUS (SWRM_BASE+0x0504)
  87. #define SWRM_ENUMERATOR_PRE_ENUM_CFG (SWRM_BASE+0x0530)
  88. #define SWRM_ENUMERATOR_SLAVE_DEV_ID_1(m) (SWRM_BASE+0x0530+0x8*m)
  89. #define SWRM_ENUMERATOR_SLAVE_DEV_ID_2(m) (SWRM_BASE+0x0534+0x8*m)
  90. #define SWRM_CTRL_W_GEN_STATUS (SWRM_BASE+0x0600)
  91. #define SWRM_SW_RESET_STATUS (SWRM_BASE+0x0700)
  92. #define SWRM_FORCE_BANK_SWITCH_SUCCESS (SWRM_BASE+0x0704)
  93. #define SWRM_SILENCE_TONE_REPEAT_VALUE_THRESHOLD (SWRM_BASE+0x0710)
  94. #define SWRM_SELF_GENERATE_FRAME_SYNC (SWRM_BASE+0x0714)
  95. #define SWRM_MCP_FRAME_CTRL_BANK(m) (SWRM_BASE+0x101C+0x40*m)
  96. #define SWRM_MCP_BUS_CTRL (SWRM_BASE+0x1044)
  97. #define SWRM_MCP_CFG (SWRM_BASE+0x1048)
  98. #define SWRM_MCP_STATUS (SWRM_BASE+0x104C)
  99. #define SWRM_MCP_SLV_STATUS (SWRM_BASE+0x1090)
  100. #define SWRM_DP_PORT_CONTROL(n) (SWRM_BASE+0x1020+0x100*n)
  101. #define SWRM_DP_PORT_CTRL_BANK(n, m) (SWRM_BASE+0x1024+0x100*n+0x40*m)
  102. #define SWRM_DP_PORT_CTRL_2_BANK(n, m) (SWRM_BASE+0x1028+0x100*n+0x40*m)
  103. #define SWRM_DP_BLOCK_CTRL_1(n) (SWRM_BASE+0x102C+0x100*n)
  104. #define SWRM_DP_BLOCK_CTRL2_BANK(n, m) (SWRM_BASE+0x1030+0x100*n+0x40*m)
  105. #define SWRM_DP_PORT_HCTRL_BANK(n, m) (SWRM_BASE+0x1034+0x100*n+0x40*m)
  106. #define SWRM_DP_BLOCK_CTRL3_BANK(n, m) (SWRM_BASE+0x1038+0x100*n+0x40*m)
  107. #define SWRM_DP_SAMPLECTRL2_BANK(n, m) (SWRM_BASE+0x103C+0x100*n+0x40*m)
  108. #define SWRM_DOUT_DP_INT_STATUS(n) (SWRM_BASE+0x1000+0x100*n)
  109. #define SWRM_DOUT_DP_INT_CLEAR(n) (SWRM_BASE+0x1008+0x100*n)
  110. #define SWRM_DOUT_DP_FEATURES_EN(n) (SWRM_BASE+0x104C+0x100*n)
  111. #define SWRM_DOUT_DP_SILENCE_TONE_CFG(n) (SWRM_BASE+0x1050+0x100*n)
  112. #define SWRM_DOUT_DP_PCM_PORT_CTRL(n) (SWRM_BASE+0x1054+0x100*n)
  113. #define SWRM_DIN_DP_INT_STATUS(n) (SWRM_BASE+0x1000+0x100*n)
  114. #define SWRM_DIN_DP_INT_CLEAR(n) (SWRM_BASE+0x1008+0x100*n)
  115. #define SWRM_DIN_DP_FEATURES_EN(n) (SWRM_BASE+0x104C+0x100*n)
  116. #define SWRM_DIN_DP_PCM_PORT_CTRL(n) (SWRM_BASE+0x1054+0x100*n)
  117. #ifdef CONFIG_SWRM_VER_2P0
  118. #define SWRM_MAX_REGISTER SWRM_TO_CPU_SW_MESSAGE_READ(2, 2)
  119. #else
  120. #define SWRM_MAX_REGISTER SWRM_DIN_DP_PCM_PORT_CTRL(9)
  121. #endif /* CONFIG_SWRM_VER_2P0 */
  122. #define SWRM_INTERRUPT_STATUS_SLAVE_PEND_IRQ 0x1
  123. #define SWRM_INTERRUPT_STATUS_NEW_SLAVE_ATTACHED 0x2
  124. #define SWRM_INTERRUPT_STATUS_CHANGE_ENUM_SLAVE_STATUS 0x4
  125. #define SWRM_INTERRUPT_STATUS_MASTER_CLASH_DET 0x8
  126. #define SWRM_INTERRUPT_STATUS_WR_CMD_FIFO_OVERFLOW 0x40
  127. #define SWRM_INTERRUPT_STATUS_CMD_ERROR 0x80
  128. #define SWRM_INTERRUPT_STATUS_DOUT_PORT_COLLISION 0x100
  129. #define SWRM_INTERRUPT_STATUS_READ_EN_RD_VALID_MISMATCH 0x200
  130. #ifdef CONFIG_SWRM_VER_1P1
  131. #define SWRM_INTERRUPT_STATUS_NEW_SLAVE_AUTO_ENUM_FINISHED 0x800
  132. #define SWRM_INTERRUPT_STATUS_AUTO_ENUM_FAILED 0x1000
  133. #define SWRM_INTERRUPT_STATUS_AUTO_ENUM_TABLE_IS_FULL 0x2000
  134. #define SWRM_INTERRUPT_STATUS_BUS_RESET_FINISHED 0x4000
  135. #define SWRM_INTERRUPT_STATUS_CLK_STOP_FINISHED 0x8000
  136. #define SWRM_INTERRUPT_STATUS_ERROR_PORT_TEST 0x10000
  137. #else
  138. #define SWRM_INTERRUPT_STATUS_AUTO_ENUM_FAILED 0x800
  139. #define SWRM_INTERRUPT_STATUS_AUTO_ENUM_TABLE_IS_FULL 0x1000
  140. #define SWRM_INTERRUPT_STATUS_BUS_RESET_FINISHED 0x2000
  141. #define SWRM_INTERRUPT_STATUS_CLK_STOP_FINISHED 0x4000
  142. #define SWRM_INTERRUPT_STATUS_ERROR_PORT_TEST 0x8000
  143. #endif /* CONFIG_SWRM_VER_1P1 */
  144. #define SWRM_INTERRUPT_STATUS_EXT_CLK_STOP_WAKEUP 0x10000
  145. #define SWRM_INTERRUPT_STATUS_DOUT_RATE_MISMATCH 0x20000
  146. #define SWRM_INTERRUPT_STATUS_BUS_REL_REQUEST_NON_MONITOR_MODE 0x40000
  147. #define SWRM_INTERRUPT_STATUS_CMD_IGNORED_AND_EXEC_CONTINUED 0x80000
  148. #define SWRM_INTERRUPT_STATUS_SW_INTERRUPT_FROM_CPU0 0x100000
  149. #define SWRM_INTERRUPT_STATUS_SW_INTERRUPT_FROM_CPU1 0x200000
  150. #define SWRM_INTERRUPT_STATUS_SW_INTERRUPT_FROM_CPU2 0x400000
  151. #define SWRM_INTERRUPT_STATUS_SW_INTERRUPT_FROM_CPU3 0x800000
  152. #define SWRM_COMP_PARAMS_WR_FIFO_DEPTH 0x00007C00
  153. #define SWRM_COMP_PARAMS_RD_FIFO_DEPTH 0x000F8000
  154. #define SWRM_COMP_FEATURE_CFG_DEFAULT_VAL 0x06
  155. #define SWRM_COMP_FEATURE_CFG_DEFAULT_VAL_V1P7 0x406
  156. #define SWRM_COMP_FEATURE_CFG_DEFAULT_VAL_V2P0 0x40E
  157. #define SWRM_COMP_FEATURE_CFG_PCM_EN_MASK 0x18
  158. #define SWRM_COMP_PARAMS_AUTO_ENUM_SLAVES 0x00F00000
  159. #endif /* _SWRM_REGISTERS_H */