hi6210-i2s.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  1. /*
  2. * linux/sound/soc/hisilicon/hi6210-i2s.h
  3. *
  4. * Copyright (C) 2015 Linaro, Ltd
  5. * Author: Andy Green <andy.green@linaro.org>
  6. *
  7. * This program is free software: you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License as published by
  9. * the Free Software Foundation, version 2 of the License.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. *
  19. * Note at least on 6220, S2 == BT, S1 == Digital FM Radio IF
  20. */
  21. #ifndef _HI6210_I2S_H
  22. #define _HI6210_I2S_H
  23. #define HII2S_SW_RST_N 0
  24. #define HII2S_SW_RST_N__STEREO_UPLINK_WORDLEN_SHIFT 28
  25. #define HII2S_SW_RST_N__STEREO_UPLINK_WORDLEN_MASK 3
  26. #define HII2S_SW_RST_N__THIRDMD_UPLINK_WORDLEN_SHIFT 26
  27. #define HII2S_SW_RST_N__THIRDMD_UPLINK_WORDLEN_MASK 3
  28. #define HII2S_SW_RST_N__VOICE_UPLINK_WORDLEN_SHIFT 24
  29. #define HII2S_SW_RST_N__VOICE_UPLINK_WORDLEN_MASK 3
  30. #define HII2S_SW_RST_N__ST_DL_WORDLEN_SHIFT 20
  31. #define HII2S_SW_RST_N__ST_DL_WORDLEN_MASK 3
  32. #define HII2S_SW_RST_N__THIRDMD_DLINK_WORDLEN_SHIFT 18
  33. #define HII2S_SW_RST_N__THIRDMD_DLINK_WORDLEN_MASK 3
  34. #define HII2S_SW_RST_N__VOICE_DLINK_WORDLEN_SHIFT 16
  35. #define HII2S_SW_RST_N__VOICE_DLINK_WORDLEN_MASK 3
  36. #define HII2S_SW_RST_N__SW_RST_N BIT(0)
  37. enum hi6210_bits {
  38. HII2S_BITS_16,
  39. HII2S_BITS_18,
  40. HII2S_BITS_20,
  41. HII2S_BITS_24,
  42. };
  43. #define HII2S_IF_CLK_EN_CFG 4
  44. #define HII2S_IF_CLK_EN_CFG__THIRDMD_UPLINK_EN BIT(25)
  45. #define HII2S_IF_CLK_EN_CFG__THIRDMD_DLINK_EN BIT(24)
  46. #define HII2S_IF_CLK_EN_CFG__S3_IF_CLK_EN BIT(20)
  47. #define HII2S_IF_CLK_EN_CFG__S2_IF_CLK_EN BIT(16)
  48. #define HII2S_IF_CLK_EN_CFG__S2_OL_MIXER_EN BIT(15)
  49. #define HII2S_IF_CLK_EN_CFG__S2_OL_SRC_EN BIT(14)
  50. #define HII2S_IF_CLK_EN_CFG__S2_IR_PGA_EN BIT(13)
  51. #define HII2S_IF_CLK_EN_CFG__S2_IL_PGA_EN BIT(12)
  52. #define HII2S_IF_CLK_EN_CFG__S1_IR_PGA_EN BIT(10)
  53. #define HII2S_IF_CLK_EN_CFG__S1_IL_PGA_EN BIT(9)
  54. #define HII2S_IF_CLK_EN_CFG__S1_IF_CLK_EN BIT(8)
  55. #define HII2S_IF_CLK_EN_CFG__VOICE_DLINK_SRC_EN BIT(7)
  56. #define HII2S_IF_CLK_EN_CFG__VOICE_DLINK_EN BIT(6)
  57. #define HII2S_IF_CLK_EN_CFG__ST_DL_R_EN BIT(5)
  58. #define HII2S_IF_CLK_EN_CFG__ST_DL_L_EN BIT(4)
  59. #define HII2S_IF_CLK_EN_CFG__VOICE_UPLINK_R_EN BIT(3)
  60. #define HII2S_IF_CLK_EN_CFG__VOICE_UPLINK_L_EN BIT(2)
  61. #define HII2S_IF_CLK_EN_CFG__STEREO_UPLINK_R_EN BIT(1)
  62. #define HII2S_IF_CLK_EN_CFG__STEREO_UPLINK_L_EN BIT(0)
  63. #define HII2S_DIG_FILTER_CLK_EN_CFG 8
  64. #define HII2S_DIG_FILTER_CLK_EN_CFG__DACR_SDM_EN BIT(30)
  65. #define HII2S_DIG_FILTER_CLK_EN_CFG__DACR_HBF2I_EN BIT(28)
  66. #define HII2S_DIG_FILTER_CLK_EN_CFG__DACR_MIXER_EN BIT(25)
  67. #define HII2S_DIG_FILTER_CLK_EN_CFG__DACR_AGC_EN BIT(24)
  68. #define HII2S_DIG_FILTER_CLK_EN_CFG__DACL_SDM_EN BIT(22)
  69. #define HII2S_DIG_FILTER_CLK_EN_CFG__DACL_HBF2I_EN BIT(20)
  70. #define HII2S_DIG_FILTER_CLK_EN_CFG__DACL_MIXER_EN BIT(17)
  71. #define HII2S_DIG_FILTER_CLK_EN_CFG__DACL_AGC_EN BIT(16)
  72. #define HII2S_FS_CFG 0xc
  73. #define HII2S_FS_CFG__FS_S2_SHIFT 28
  74. #define HII2S_FS_CFG__FS_S2_MASK 7
  75. #define HII2S_FS_CFG__FS_S1_SHIFT 24
  76. #define HII2S_FS_CFG__FS_S1_MASK 7
  77. #define HII2S_FS_CFG__FS_ADCLR_SHIFT 20
  78. #define HII2S_FS_CFG__FS_ADCLR_MASK 7
  79. #define HII2S_FS_CFG__FS_DACLR_SHIFT 16
  80. #define HII2S_FS_CFG__FS_DACLR_MASK 7
  81. #define HII2S_FS_CFG__FS_ST_DL_R_SHIFT 8
  82. #define HII2S_FS_CFG__FS_ST_DL_R_MASK 7
  83. #define HII2S_FS_CFG__FS_ST_DL_L_SHIFT 4
  84. #define HII2S_FS_CFG__FS_ST_DL_L_MASK 7
  85. #define HII2S_FS_CFG__FS_VOICE_DLINK_SHIFT 0
  86. #define HII2S_FS_CFG__FS_VOICE_DLINK_MASK 7
  87. enum hi6210_i2s_rates {
  88. HII2S_FS_RATE_8KHZ = 0,
  89. HII2S_FS_RATE_16KHZ = 1,
  90. HII2S_FS_RATE_32KHZ = 2,
  91. HII2S_FS_RATE_48KHZ = 4,
  92. HII2S_FS_RATE_96KHZ = 5,
  93. HII2S_FS_RATE_192KHZ = 6,
  94. };
  95. #define HII2S_I2S_CFG 0x10
  96. #define HII2S_I2S_CFG__S2_IF_TX_EN BIT(31)
  97. #define HII2S_I2S_CFG__S2_IF_RX_EN BIT(30)
  98. #define HII2S_I2S_CFG__S2_FRAME_MODE BIT(29)
  99. #define HII2S_I2S_CFG__S2_MST_SLV BIT(28)
  100. #define HII2S_I2S_CFG__S2_LRCK_MODE BIT(27)
  101. #define HII2S_I2S_CFG__S2_CHNNL_MODE BIT(26)
  102. #define HII2S_I2S_CFG__S2_CODEC_IO_WORDLENGTH_SHIFT 24
  103. #define HII2S_I2S_CFG__S2_CODEC_IO_WORDLENGTH_MASK 3
  104. #define HII2S_I2S_CFG__S2_DIRECT_LOOP_SHIFT 22
  105. #define HII2S_I2S_CFG__S2_DIRECT_LOOP_MASK 3
  106. #define HII2S_I2S_CFG__S2_TX_CLK_SEL BIT(21)
  107. #define HII2S_I2S_CFG__S2_RX_CLK_SEL BIT(20)
  108. #define HII2S_I2S_CFG__S2_CODEC_DATA_FORMAT BIT(19)
  109. #define HII2S_I2S_CFG__S2_FUNC_MODE_SHIFT 16
  110. #define HII2S_I2S_CFG__S2_FUNC_MODE_MASK 7
  111. #define HII2S_I2S_CFG__S1_IF_TX_EN BIT(15)
  112. #define HII2S_I2S_CFG__S1_IF_RX_EN BIT(14)
  113. #define HII2S_I2S_CFG__S1_FRAME_MODE BIT(13)
  114. #define HII2S_I2S_CFG__S1_MST_SLV BIT(12)
  115. #define HII2S_I2S_CFG__S1_LRCK_MODE BIT(11)
  116. #define HII2S_I2S_CFG__S1_CHNNL_MODE BIT(10)
  117. #define HII2S_I2S_CFG__S1_CODEC_IO_WORDLENGTH_SHIFT 8
  118. #define HII2S_I2S_CFG__S1_CODEC_IO_WORDLENGTH_MASK 3
  119. #define HII2S_I2S_CFG__S1_DIRECT_LOOP_SHIFT 6
  120. #define HII2S_I2S_CFG__S1_DIRECT_LOOP_MASK 3
  121. #define HII2S_I2S_CFG__S1_TX_CLK_SEL BIT(5)
  122. #define HII2S_I2S_CFG__S1_RX_CLK_SEL BIT(4)
  123. #define HII2S_I2S_CFG__S1_CODEC_DATA_FORMAT BIT(3)
  124. #define HII2S_I2S_CFG__S1_FUNC_MODE_SHIFT 0
  125. #define HII2S_I2S_CFG__S1_FUNC_MODE_MASK 7
  126. enum hi6210_i2s_formats {
  127. HII2S_FORMAT_I2S,
  128. HII2S_FORMAT_PCM_STD,
  129. HII2S_FORMAT_PCM_USER,
  130. HII2S_FORMAT_LEFT_JUST,
  131. HII2S_FORMAT_RIGHT_JUST,
  132. };
  133. #define HII2S_DIG_FILTER_MODULE_CFG 0x14
  134. #define HII2S_DIG_FILTER_MODULE_CFG__DACR_MIXER_GAIN_SHIFT 28
  135. #define HII2S_DIG_FILTER_MODULE_CFG__DACR_MIXER_GAIN_MASK 3
  136. #define HII2S_DIG_FILTER_MODULE_CFG__DACR_MIXER_IN4_MUTE BIT(27)
  137. #define HII2S_DIG_FILTER_MODULE_CFG__DACR_MIXER_IN3_MUTE BIT(26)
  138. #define HII2S_DIG_FILTER_MODULE_CFG__DACR_MIXER_IN2_MUTE BIT(25)
  139. #define HII2S_DIG_FILTER_MODULE_CFG__DACR_MIXER_IN1_MUTE BIT(24)
  140. #define HII2S_DIG_FILTER_MODULE_CFG__DACL_MIXER_GAIN_SHIFT 20
  141. #define HII2S_DIG_FILTER_MODULE_CFG__DACL_MIXER_GAIN_MASK 3
  142. #define HII2S_DIG_FILTER_MODULE_CFG__DACL_MIXER_IN4_MUTE BIT(19)
  143. #define HII2S_DIG_FILTER_MODULE_CFG__DACL_MIXER_IN3_MUTE BIT(18)
  144. #define HII2S_DIG_FILTER_MODULE_CFG__DACL_MIXER_IN2_MUTE BIT(17)
  145. #define HII2S_DIG_FILTER_MODULE_CFG__DACL_MIXER_IN1_MUTE BIT(16)
  146. #define HII2S_DIG_FILTER_MODULE_CFG__SW_DACR_SDM_DITHER BIT(9)
  147. #define HII2S_DIG_FILTER_MODULE_CFG__SW_DACL_SDM_DITHER BIT(8)
  148. #define HII2S_DIG_FILTER_MODULE_CFG__LM_CODEC_DAC2ADC_SHIFT 4
  149. #define HII2S_DIG_FILTER_MODULE_CFG__LM_CODEC_DAC2ADC_MASK 7
  150. #define HII2S_DIG_FILTER_MODULE_CFG__RM_CODEC_DAC2ADC_SHIFT 0
  151. #define HII2S_DIG_FILTER_MODULE_CFG__RM_CODEC_DAC2ADC_MASK 7
  152. enum hi6210_gains {
  153. HII2S_GAIN_100PC,
  154. HII2S_GAIN_50PC,
  155. HII2S_GAIN_25PC,
  156. };
  157. #define HII2S_MUX_TOP_MODULE_CFG 0x18
  158. #define HII2S_MUX_TOP_MODULE_CFG__VOICE_DLINK_MIXER_GAIN_SHIFT 14
  159. #define HII2S_MUX_TOP_MODULE_CFG__VOICE_DLINK_MIXER_GAIN_MASK 3
  160. #define HII2S_MUX_TOP_MODULE_CFG__VOICE_DLINK_MIXER_IN2_MUTE BIT(13)
  161. #define HII2S_MUX_TOP_MODULE_CFG__VOICE_DLINK_MIXER_IN1_MUTE BIT(12)
  162. #define HII2S_MUX_TOP_MODULE_CFG__S2_OL_MIXER_GAIN_SHIFT 10
  163. #define HII2S_MUX_TOP_MODULE_CFG__S2_OL_MIXER_GAIN_MASK 3
  164. #define HII2S_MUX_TOP_MODULE_CFG__S2_OL_MIXER_IN2_MUTE BIT(9)
  165. #define HII2S_MUX_TOP_MODULE_CFG__S2_OL_MIXER_IN1_MUTE BIT(8)
  166. #define HII2S_MUX_TOP_MODULE_CFG__S2_OL_SRC_RDY BIT(6)
  167. #define HII2S_MUX_TOP_MODULE_CFG__S2_OL_SRC_MODE_SHIFT 4
  168. #define HII2S_MUX_TOP_MODULE_CFG__S2_OL_SRC_MODE_MASK 3
  169. #define HII2S_MUX_TOP_MODULE_CFG__VOICE_DLINK_SRC_RDY BIT(3)
  170. #define HII2S_MUX_TOP_MODULE_CFG__VOICE_DLINK_SRC_MODE_SHIFT 0
  171. #define HII2S_MUX_TOP_MODULE_CFG__VOICE_DLINK_SRC_MODE_MASK 7
  172. enum hi6210_s2_src_mode {
  173. HII2S_S2_SRC_MODE_3,
  174. HII2S_S2_SRC_MODE_12,
  175. HII2S_S2_SRC_MODE_6,
  176. HII2S_S2_SRC_MODE_2,
  177. };
  178. enum hi6210_voice_dlink_src_mode {
  179. HII2S_VOICE_DL_SRC_MODE_12 = 1,
  180. HII2S_VOICE_DL_SRC_MODE_6,
  181. HII2S_VOICE_DL_SRC_MODE_2,
  182. HII2S_VOICE_DL_SRC_MODE_3,
  183. };
  184. #define HII2S_ADC_PGA_CFG 0x1c
  185. #define HII2S_S1_INPUT_PGA_CFG 0x20
  186. #define HII2S_S2_INPUT_PGA_CFG 0x24
  187. #define HII2S_ST_DL_PGA_CFG 0x28
  188. #define HII2S_VOICE_SIDETONE_DLINK_PGA_CFG 0x2c
  189. #define HII2S_APB_AFIFO_CFG_1 0x30
  190. #define HII2S_APB_AFIFO_CFG_2 0x34
  191. #define HII2S_ST_DL_FIFO_TH_CFG 0x38
  192. #define HII2S_ST_DL_FIFO_TH_CFG__ST_DL_R_AEMPTY_SHIFT 24
  193. #define HII2S_ST_DL_FIFO_TH_CFG__ST_DL_R_AEMPTY_MASK 0x1f
  194. #define HII2S_ST_DL_FIFO_TH_CFG__ST_DL_R_AFULL_SHIFT 16
  195. #define HII2S_ST_DL_FIFO_TH_CFG__ST_DL_R_AFULL_MASK 0x1f
  196. #define HII2S_ST_DL_FIFO_TH_CFG__ST_DL_L_AEMPTY_SHIFT 8
  197. #define HII2S_ST_DL_FIFO_TH_CFG__ST_DL_L_AEMPTY_MASK 0x1f
  198. #define HII2S_ST_DL_FIFO_TH_CFG__ST_DL_L_AFULL_SHIFT 0
  199. #define HII2S_ST_DL_FIFO_TH_CFG__ST_DL_L_AFULL_MASK 0x1f
  200. #define HII2S_STEREO_UPLINK_FIFO_TH_CFG 0x3c
  201. #define HII2S_VOICE_UPLINK_FIFO_TH_CFG 0x40
  202. #define HII2S_CODEC_IRQ_MASK 0x44
  203. #define HII2S_CODEC_IRQ 0x48
  204. #define HII2S_DACL_AGC_CFG_1 0x4c
  205. #define HII2S_DACL_AGC_CFG_2 0x50
  206. #define HII2S_DACR_AGC_CFG_1 0x54
  207. #define HII2S_DACR_AGC_CFG_2 0x58
  208. #define HII2S_DMIC_SIF_CFG 0x5c
  209. #define HII2S_MISC_CFG 0x60
  210. #define HII2S_MISC_CFG__THIRDMD_DLINK_TEST_SEL BIT(17)
  211. #define HII2S_MISC_CFG__THIRDMD_DLINK_DIN_SEL BIT(16)
  212. #define HII2S_MISC_CFG__S3_DOUT_RIGHT_SEL BIT(14)
  213. #define HII2S_MISC_CFG__S3_DOUT_LEFT_SEL BIT(13)
  214. #define HII2S_MISC_CFG__S3_DIN_TEST_SEL BIT(12)
  215. #define HII2S_MISC_CFG__VOICE_DLINK_SRC_UP_DOUT_VLD_SEL BIT(8)
  216. #define HII2S_MISC_CFG__VOICE_DLINK_TEST_SEL BIT(7)
  217. #define HII2S_MISC_CFG__VOICE_DLINK_DIN_SEL BIT(6)
  218. #define HII2S_MISC_CFG__ST_DL_TEST_SEL BIT(4)
  219. #define HII2S_MISC_CFG__S2_DOUT_RIGHT_SEL BIT(3)
  220. #define HII2S_MISC_CFG__S2_DOUT_TEST_SEL BIT(2)
  221. #define HII2S_MISC_CFG__S1_DOUT_TEST_SEL BIT(1)
  222. #define HII2S_MISC_CFG__S2_DOUT_LEFT_SEL BIT(0)
  223. #define HII2S_S2_SRC_CFG 0x64
  224. #define HII2S_MEM_CFG 0x68
  225. #define HII2S_THIRDMD_PCM_PGA_CFG 0x6c
  226. #define HII2S_THIRD_MODEM_FIFO_TH 0x70
  227. #define HII2S_S3_ANTI_FREQ_JITTER_TX_INC_CNT 0x74
  228. #define HII2S_S3_ANTI_FREQ_JITTER_TX_DEC_CNT 0x78
  229. #define HII2S_S3_ANTI_FREQ_JITTER_RX_INC_CNT 0x7c
  230. #define HII2S_S3_ANTI_FREQ_JITTER_RX_DEC_CNT 0x80
  231. #define HII2S_ANTI_FREQ_JITTER_EN 0x84
  232. #define HII2S_CLK_SEL 0x88
  233. /* 0 = BT owns the i2s */
  234. #define HII2S_CLK_SEL__I2S_BT_FM_SEL BIT(0)
  235. /* 0 = internal source, 1 = ext */
  236. #define HII2S_CLK_SEL__EXT_12_288MHZ_SEL BIT(1)
  237. #define HII2S_THIRDMD_DLINK_CHANNEL 0xe8
  238. #define HII2S_THIRDMD_ULINK_CHANNEL 0xec
  239. #define HII2S_VOICE_DLINK_CHANNEL 0xf0
  240. /* shovel data in here for playback */
  241. #define HII2S_ST_DL_CHANNEL 0xf4
  242. #define HII2S_STEREO_UPLINK_CHANNEL 0xf8
  243. #define HII2S_VOICE_UPLINK_CHANNEL 0xfc
  244. #endif/* _HI6210_I2S_H */