hpm_sdm_regs.h 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753
  1. /*
  2. * Copyright (c) 2021-2023 HPMicro
  3. *
  4. * SPDX-License-Identifier: BSD-3-Clause
  5. *
  6. */
  7. #ifndef HPM_SDM_H
  8. #define HPM_SDM_H
  9. typedef struct {
  10. __RW uint32_t CTRL; /* 0x0: SDM control register */
  11. __RW uint32_t INT_EN; /* 0x4: Interrupt enable register. */
  12. __R uint32_t STATUS; /* 0x8: Status Registers */
  13. __R uint8_t RESERVED0[4]; /* 0xC - 0xF: Reserved */
  14. struct {
  15. __RW uint32_t SDFIFOCTRL; /* 0x10: Data FIFO Path Control Register */
  16. __RW uint32_t SDCTRLP; /* 0x14: Data Path Control Primary Register */
  17. __RW uint32_t SDCTRLE; /* 0x18: Data Path Control Extra Register */
  18. __RW uint32_t SDST; /* 0x1C: Data Path Status */
  19. __R uint32_t SDATA; /* 0x20: Data */
  20. __R uint32_t SDFIFO; /* 0x24: FIFO Data */
  21. __R uint32_t SCAMP; /* 0x28: instant Amplitude Results */
  22. __RW uint32_t SCHTL; /* 0x2C: Amplitude Threshold for High Limit */
  23. __RW uint32_t SCHTLZ; /* 0x30: Amplitude Threshold for zero crossing */
  24. __RW uint32_t SCLLT; /* 0x34: Amplitude Threshold for low limit */
  25. __RW uint32_t SCCTRL; /* 0x38: Amplitude Path Control */
  26. __RW uint32_t SCST; /* 0x3C: Amplitude Path Status */
  27. __R uint8_t RESERVED0[16]; /* 0x40 - 0x4F: Reserved */
  28. } CH[4];
  29. } SDM_Type;
  30. /* Bitfield definition for register: CTRL */
  31. /*
  32. * SFTRST (RW)
  33. *
  34. * software reset the module if asserted to be1’b1.
  35. */
  36. #define SDM_CTRL_SFTRST_MASK (0x80000000UL)
  37. #define SDM_CTRL_SFTRST_SHIFT (31U)
  38. #define SDM_CTRL_SFTRST_SET(x) (((uint32_t)(x) << SDM_CTRL_SFTRST_SHIFT) & SDM_CTRL_SFTRST_MASK)
  39. #define SDM_CTRL_SFTRST_GET(x) (((uint32_t)(x) & SDM_CTRL_SFTRST_MASK) >> SDM_CTRL_SFTRST_SHIFT)
  40. /*
  41. * CHMD (RW)
  42. *
  43. * Channel Rcv mode
  44. * Bits[2:0] for Ch0.
  45. * Bits[5:3] for Ch1
  46. * Bits[8:6] for Ch2
  47. * Bits[11:9] for Ch3
  48. * 3'b000: Capture at posedge of MCLK
  49. * 3'b001: Capture at both posedge and negedge of MCLK
  50. * 3'b010: Manchestor Mode
  51. * 3'b011: Capture at negedge of MCLK
  52. * 3'b100: Capture at every other posedge of MCLK
  53. * 3'b101: Capture at every other negedge of MCLK
  54. * Others: Undefined
  55. */
  56. #define SDM_CTRL_CHMD_MASK (0x3FFC000UL)
  57. #define SDM_CTRL_CHMD_SHIFT (14U)
  58. #define SDM_CTRL_CHMD_SET(x) (((uint32_t)(x) << SDM_CTRL_CHMD_SHIFT) & SDM_CTRL_CHMD_MASK)
  59. #define SDM_CTRL_CHMD_GET(x) (((uint32_t)(x) & SDM_CTRL_CHMD_MASK) >> SDM_CTRL_CHMD_SHIFT)
  60. /*
  61. * SYNC_MCLK (RW)
  62. *
  63. * Asserted to double sync the mclk input pin before its usage inside the module
  64. */
  65. #define SDM_CTRL_SYNC_MCLK_MASK (0x3C00U)
  66. #define SDM_CTRL_SYNC_MCLK_SHIFT (10U)
  67. #define SDM_CTRL_SYNC_MCLK_SET(x) (((uint32_t)(x) << SDM_CTRL_SYNC_MCLK_SHIFT) & SDM_CTRL_SYNC_MCLK_MASK)
  68. #define SDM_CTRL_SYNC_MCLK_GET(x) (((uint32_t)(x) & SDM_CTRL_SYNC_MCLK_MASK) >> SDM_CTRL_SYNC_MCLK_SHIFT)
  69. /*
  70. * SYNC_MDAT (RW)
  71. *
  72. * Asserted to double sync the mdat input pin before its usage inside the module
  73. */
  74. #define SDM_CTRL_SYNC_MDAT_MASK (0x3C0U)
  75. #define SDM_CTRL_SYNC_MDAT_SHIFT (6U)
  76. #define SDM_CTRL_SYNC_MDAT_SET(x) (((uint32_t)(x) << SDM_CTRL_SYNC_MDAT_SHIFT) & SDM_CTRL_SYNC_MDAT_MASK)
  77. #define SDM_CTRL_SYNC_MDAT_GET(x) (((uint32_t)(x) & SDM_CTRL_SYNC_MDAT_MASK) >> SDM_CTRL_SYNC_MDAT_SHIFT)
  78. /*
  79. * CH_EN (RW)
  80. *
  81. * Channel Enable
  82. */
  83. #define SDM_CTRL_CH_EN_MASK (0x3CU)
  84. #define SDM_CTRL_CH_EN_SHIFT (2U)
  85. #define SDM_CTRL_CH_EN_SET(x) (((uint32_t)(x) << SDM_CTRL_CH_EN_SHIFT) & SDM_CTRL_CH_EN_MASK)
  86. #define SDM_CTRL_CH_EN_GET(x) (((uint32_t)(x) & SDM_CTRL_CH_EN_MASK) >> SDM_CTRL_CH_EN_SHIFT)
  87. /*
  88. * IE (RW)
  89. *
  90. * Interrupt Enable
  91. */
  92. #define SDM_CTRL_IE_MASK (0x2U)
  93. #define SDM_CTRL_IE_SHIFT (1U)
  94. #define SDM_CTRL_IE_SET(x) (((uint32_t)(x) << SDM_CTRL_IE_SHIFT) & SDM_CTRL_IE_MASK)
  95. #define SDM_CTRL_IE_GET(x) (((uint32_t)(x) & SDM_CTRL_IE_MASK) >> SDM_CTRL_IE_SHIFT)
  96. /* Bitfield definition for register: INT_EN */
  97. /*
  98. * CH3DRY (RW)
  99. *
  100. * Ch3 Data Ready interrupt enable.
  101. */
  102. #define SDM_INT_EN_CH3DRY_MASK (0x80U)
  103. #define SDM_INT_EN_CH3DRY_SHIFT (7U)
  104. #define SDM_INT_EN_CH3DRY_SET(x) (((uint32_t)(x) << SDM_INT_EN_CH3DRY_SHIFT) & SDM_INT_EN_CH3DRY_MASK)
  105. #define SDM_INT_EN_CH3DRY_GET(x) (((uint32_t)(x) & SDM_INT_EN_CH3DRY_MASK) >> SDM_INT_EN_CH3DRY_SHIFT)
  106. /*
  107. * CH2DRY (RW)
  108. *
  109. * Ch2 Data Ready interrupt enable
  110. */
  111. #define SDM_INT_EN_CH2DRY_MASK (0x40U)
  112. #define SDM_INT_EN_CH2DRY_SHIFT (6U)
  113. #define SDM_INT_EN_CH2DRY_SET(x) (((uint32_t)(x) << SDM_INT_EN_CH2DRY_SHIFT) & SDM_INT_EN_CH2DRY_MASK)
  114. #define SDM_INT_EN_CH2DRY_GET(x) (((uint32_t)(x) & SDM_INT_EN_CH2DRY_MASK) >> SDM_INT_EN_CH2DRY_SHIFT)
  115. /*
  116. * CH1DRY (RW)
  117. *
  118. * Ch1 Data Ready interrupt enable
  119. */
  120. #define SDM_INT_EN_CH1DRY_MASK (0x20U)
  121. #define SDM_INT_EN_CH1DRY_SHIFT (5U)
  122. #define SDM_INT_EN_CH1DRY_SET(x) (((uint32_t)(x) << SDM_INT_EN_CH1DRY_SHIFT) & SDM_INT_EN_CH1DRY_MASK)
  123. #define SDM_INT_EN_CH1DRY_GET(x) (((uint32_t)(x) & SDM_INT_EN_CH1DRY_MASK) >> SDM_INT_EN_CH1DRY_SHIFT)
  124. /*
  125. * CH0DRY (RW)
  126. *
  127. * Ch0 Data Ready interrupt enable
  128. */
  129. #define SDM_INT_EN_CH0DRY_MASK (0x10U)
  130. #define SDM_INT_EN_CH0DRY_SHIFT (4U)
  131. #define SDM_INT_EN_CH0DRY_SET(x) (((uint32_t)(x) << SDM_INT_EN_CH0DRY_SHIFT) & SDM_INT_EN_CH0DRY_MASK)
  132. #define SDM_INT_EN_CH0DRY_GET(x) (((uint32_t)(x) & SDM_INT_EN_CH0DRY_MASK) >> SDM_INT_EN_CH0DRY_SHIFT)
  133. /*
  134. * CH3ERR (RW)
  135. *
  136. * Ch3 Error interrupt enable.
  137. */
  138. #define SDM_INT_EN_CH3ERR_MASK (0x8U)
  139. #define SDM_INT_EN_CH3ERR_SHIFT (3U)
  140. #define SDM_INT_EN_CH3ERR_SET(x) (((uint32_t)(x) << SDM_INT_EN_CH3ERR_SHIFT) & SDM_INT_EN_CH3ERR_MASK)
  141. #define SDM_INT_EN_CH3ERR_GET(x) (((uint32_t)(x) & SDM_INT_EN_CH3ERR_MASK) >> SDM_INT_EN_CH3ERR_SHIFT)
  142. /*
  143. * CH2ERR (RW)
  144. *
  145. * Ch2 Error interrupt enable
  146. */
  147. #define SDM_INT_EN_CH2ERR_MASK (0x4U)
  148. #define SDM_INT_EN_CH2ERR_SHIFT (2U)
  149. #define SDM_INT_EN_CH2ERR_SET(x) (((uint32_t)(x) << SDM_INT_EN_CH2ERR_SHIFT) & SDM_INT_EN_CH2ERR_MASK)
  150. #define SDM_INT_EN_CH2ERR_GET(x) (((uint32_t)(x) & SDM_INT_EN_CH2ERR_MASK) >> SDM_INT_EN_CH2ERR_SHIFT)
  151. /*
  152. * CH1ERR (RW)
  153. *
  154. * Ch1 Error interrupt enable
  155. */
  156. #define SDM_INT_EN_CH1ERR_MASK (0x2U)
  157. #define SDM_INT_EN_CH1ERR_SHIFT (1U)
  158. #define SDM_INT_EN_CH1ERR_SET(x) (((uint32_t)(x) << SDM_INT_EN_CH1ERR_SHIFT) & SDM_INT_EN_CH1ERR_MASK)
  159. #define SDM_INT_EN_CH1ERR_GET(x) (((uint32_t)(x) & SDM_INT_EN_CH1ERR_MASK) >> SDM_INT_EN_CH1ERR_SHIFT)
  160. /*
  161. * CH0ERR (RW)
  162. *
  163. * Ch0 Error interrupt enable
  164. */
  165. #define SDM_INT_EN_CH0ERR_MASK (0x1U)
  166. #define SDM_INT_EN_CH0ERR_SHIFT (0U)
  167. #define SDM_INT_EN_CH0ERR_SET(x) (((uint32_t)(x) << SDM_INT_EN_CH0ERR_SHIFT) & SDM_INT_EN_CH0ERR_MASK)
  168. #define SDM_INT_EN_CH0ERR_GET(x) (((uint32_t)(x) & SDM_INT_EN_CH0ERR_MASK) >> SDM_INT_EN_CH0ERR_SHIFT)
  169. /* Bitfield definition for register: STATUS */
  170. /*
  171. * CH3DRY (RO)
  172. *
  173. * Ch3 Data Ready.
  174. * De-assert this bit by reading the data (or data fifo) registers.
  175. */
  176. #define SDM_STATUS_CH3DRY_MASK (0x80U)
  177. #define SDM_STATUS_CH3DRY_SHIFT (7U)
  178. #define SDM_STATUS_CH3DRY_GET(x) (((uint32_t)(x) & SDM_STATUS_CH3DRY_MASK) >> SDM_STATUS_CH3DRY_SHIFT)
  179. /*
  180. * CH2DRY (RO)
  181. *
  182. * Ch2 Data Ready
  183. */
  184. #define SDM_STATUS_CH2DRY_MASK (0x40U)
  185. #define SDM_STATUS_CH2DRY_SHIFT (6U)
  186. #define SDM_STATUS_CH2DRY_GET(x) (((uint32_t)(x) & SDM_STATUS_CH2DRY_MASK) >> SDM_STATUS_CH2DRY_SHIFT)
  187. /*
  188. * CH1DRY (RO)
  189. *
  190. * Ch1 Data Ready
  191. */
  192. #define SDM_STATUS_CH1DRY_MASK (0x20U)
  193. #define SDM_STATUS_CH1DRY_SHIFT (5U)
  194. #define SDM_STATUS_CH1DRY_GET(x) (((uint32_t)(x) & SDM_STATUS_CH1DRY_MASK) >> SDM_STATUS_CH1DRY_SHIFT)
  195. /*
  196. * CH0DRY (RO)
  197. *
  198. * Ch0 Data Ready
  199. */
  200. #define SDM_STATUS_CH0DRY_MASK (0x10U)
  201. #define SDM_STATUS_CH0DRY_SHIFT (4U)
  202. #define SDM_STATUS_CH0DRY_GET(x) (((uint32_t)(x) & SDM_STATUS_CH0DRY_MASK) >> SDM_STATUS_CH0DRY_SHIFT)
  203. /*
  204. * CH3ERR (RO)
  205. *
  206. * Ch3 Error.
  207. * ORed together by channel related error signals and corresponding error interrupt enable signals.
  208. * De-assert this bit by write-1-clear the corresponding error status bits in the channel status registers.
  209. */
  210. #define SDM_STATUS_CH3ERR_MASK (0x8U)
  211. #define SDM_STATUS_CH3ERR_SHIFT (3U)
  212. #define SDM_STATUS_CH3ERR_GET(x) (((uint32_t)(x) & SDM_STATUS_CH3ERR_MASK) >> SDM_STATUS_CH3ERR_SHIFT)
  213. /*
  214. * CH2ERR (RO)
  215. *
  216. * Ch2 Error
  217. */
  218. #define SDM_STATUS_CH2ERR_MASK (0x4U)
  219. #define SDM_STATUS_CH2ERR_SHIFT (2U)
  220. #define SDM_STATUS_CH2ERR_GET(x) (((uint32_t)(x) & SDM_STATUS_CH2ERR_MASK) >> SDM_STATUS_CH2ERR_SHIFT)
  221. /*
  222. * CH1ERR (RO)
  223. *
  224. * Ch1 Error
  225. */
  226. #define SDM_STATUS_CH1ERR_MASK (0x2U)
  227. #define SDM_STATUS_CH1ERR_SHIFT (1U)
  228. #define SDM_STATUS_CH1ERR_GET(x) (((uint32_t)(x) & SDM_STATUS_CH1ERR_MASK) >> SDM_STATUS_CH1ERR_SHIFT)
  229. /*
  230. * CH0ERR (RO)
  231. *
  232. * Ch0 Error
  233. */
  234. #define SDM_STATUS_CH0ERR_MASK (0x1U)
  235. #define SDM_STATUS_CH0ERR_SHIFT (0U)
  236. #define SDM_STATUS_CH0ERR_GET(x) (((uint32_t)(x) & SDM_STATUS_CH0ERR_MASK) >> SDM_STATUS_CH0ERR_SHIFT)
  237. /* Bitfield definition for register of struct array CH: SDFIFOCTRL */
  238. /*
  239. * THRSH (RW)
  240. *
  241. * FIFO threshold (0,..,16) (fillings > threshold, then gen int)
  242. */
  243. #define SDM_CH_SDFIFOCTRL_THRSH_MASK (0x1F0U)
  244. #define SDM_CH_SDFIFOCTRL_THRSH_SHIFT (4U)
  245. #define SDM_CH_SDFIFOCTRL_THRSH_SET(x) (((uint32_t)(x) << SDM_CH_SDFIFOCTRL_THRSH_SHIFT) & SDM_CH_SDFIFOCTRL_THRSH_MASK)
  246. #define SDM_CH_SDFIFOCTRL_THRSH_GET(x) (((uint32_t)(x) & SDM_CH_SDFIFOCTRL_THRSH_MASK) >> SDM_CH_SDFIFOCTRL_THRSH_SHIFT)
  247. /*
  248. * D_RDY_INT_EN (RW)
  249. *
  250. * FIFO data ready interrupt enable
  251. */
  252. #define SDM_CH_SDFIFOCTRL_D_RDY_INT_EN_MASK (0x4U)
  253. #define SDM_CH_SDFIFOCTRL_D_RDY_INT_EN_SHIFT (2U)
  254. #define SDM_CH_SDFIFOCTRL_D_RDY_INT_EN_SET(x) (((uint32_t)(x) << SDM_CH_SDFIFOCTRL_D_RDY_INT_EN_SHIFT) & SDM_CH_SDFIFOCTRL_D_RDY_INT_EN_MASK)
  255. #define SDM_CH_SDFIFOCTRL_D_RDY_INT_EN_GET(x) (((uint32_t)(x) & SDM_CH_SDFIFOCTRL_D_RDY_INT_EN_MASK) >> SDM_CH_SDFIFOCTRL_D_RDY_INT_EN_SHIFT)
  256. /* Bitfield definition for register of struct array CH: SDCTRLP */
  257. /*
  258. * MANCH_THR (RW)
  259. *
  260. * Manchester Decoding threshold. 3/4 of PERIOD_MCLK[7:0]
  261. */
  262. #define SDM_CH_SDCTRLP_MANCH_THR_MASK (0xFE000000UL)
  263. #define SDM_CH_SDCTRLP_MANCH_THR_SHIFT (25U)
  264. #define SDM_CH_SDCTRLP_MANCH_THR_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLP_MANCH_THR_SHIFT) & SDM_CH_SDCTRLP_MANCH_THR_MASK)
  265. #define SDM_CH_SDCTRLP_MANCH_THR_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLP_MANCH_THR_MASK) >> SDM_CH_SDCTRLP_MANCH_THR_SHIFT)
  266. /*
  267. * WDOG_THR (RW)
  268. *
  269. * Watch dog threshold for channel failure of CLK halting
  270. */
  271. #define SDM_CH_SDCTRLP_WDOG_THR_MASK (0x1FE0000UL)
  272. #define SDM_CH_SDCTRLP_WDOG_THR_SHIFT (17U)
  273. #define SDM_CH_SDCTRLP_WDOG_THR_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLP_WDOG_THR_SHIFT) & SDM_CH_SDCTRLP_WDOG_THR_MASK)
  274. #define SDM_CH_SDCTRLP_WDOG_THR_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLP_WDOG_THR_MASK) >> SDM_CH_SDCTRLP_WDOG_THR_SHIFT)
  275. /*
  276. * AF_IE (RW)
  277. *
  278. * Acknowledge feedback interrupt enable
  279. */
  280. #define SDM_CH_SDCTRLP_AF_IE_MASK (0x10000UL)
  281. #define SDM_CH_SDCTRLP_AF_IE_SHIFT (16U)
  282. #define SDM_CH_SDCTRLP_AF_IE_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLP_AF_IE_SHIFT) & SDM_CH_SDCTRLP_AF_IE_MASK)
  283. #define SDM_CH_SDCTRLP_AF_IE_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLP_AF_IE_MASK) >> SDM_CH_SDCTRLP_AF_IE_SHIFT)
  284. /*
  285. * DFFOVIE (RW)
  286. *
  287. * Ch Data FIFO overflow interrupt enable
  288. */
  289. #define SDM_CH_SDCTRLP_DFFOVIE_MASK (0x8000U)
  290. #define SDM_CH_SDCTRLP_DFFOVIE_SHIFT (15U)
  291. #define SDM_CH_SDCTRLP_DFFOVIE_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLP_DFFOVIE_SHIFT) & SDM_CH_SDCTRLP_DFFOVIE_MASK)
  292. #define SDM_CH_SDCTRLP_DFFOVIE_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLP_DFFOVIE_MASK) >> SDM_CH_SDCTRLP_DFFOVIE_SHIFT)
  293. /*
  294. * DSATIE (RW)
  295. *
  296. * Ch CIC Data Saturation Interrupt Enable
  297. */
  298. #define SDM_CH_SDCTRLP_DSATIE_MASK (0x4000U)
  299. #define SDM_CH_SDCTRLP_DSATIE_SHIFT (14U)
  300. #define SDM_CH_SDCTRLP_DSATIE_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLP_DSATIE_SHIFT) & SDM_CH_SDCTRLP_DSATIE_MASK)
  301. #define SDM_CH_SDCTRLP_DSATIE_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLP_DSATIE_MASK) >> SDM_CH_SDCTRLP_DSATIE_SHIFT)
  302. /*
  303. * DRIE (RW)
  304. *
  305. * Ch Data Ready Interrupt Enable
  306. */
  307. #define SDM_CH_SDCTRLP_DRIE_MASK (0x2000U)
  308. #define SDM_CH_SDCTRLP_DRIE_SHIFT (13U)
  309. #define SDM_CH_SDCTRLP_DRIE_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLP_DRIE_SHIFT) & SDM_CH_SDCTRLP_DRIE_MASK)
  310. #define SDM_CH_SDCTRLP_DRIE_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLP_DRIE_MASK) >> SDM_CH_SDCTRLP_DRIE_SHIFT)
  311. /*
  312. * SYNCSEL (RW)
  313. *
  314. * Select the PWM SYNC Source
  315. */
  316. #define SDM_CH_SDCTRLP_SYNCSEL_MASK (0x1F80U)
  317. #define SDM_CH_SDCTRLP_SYNCSEL_SHIFT (7U)
  318. #define SDM_CH_SDCTRLP_SYNCSEL_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLP_SYNCSEL_SHIFT) & SDM_CH_SDCTRLP_SYNCSEL_MASK)
  319. #define SDM_CH_SDCTRLP_SYNCSEL_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLP_SYNCSEL_MASK) >> SDM_CH_SDCTRLP_SYNCSEL_SHIFT)
  320. /*
  321. * FFSYNCCLREN (RW)
  322. *
  323. * Auto clear FIFO when a new SDSYNC event is found. Only valid when WTSYNCEN=1
  324. */
  325. #define SDM_CH_SDCTRLP_FFSYNCCLREN_MASK (0x40U)
  326. #define SDM_CH_SDCTRLP_FFSYNCCLREN_SHIFT (6U)
  327. #define SDM_CH_SDCTRLP_FFSYNCCLREN_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLP_FFSYNCCLREN_SHIFT) & SDM_CH_SDCTRLP_FFSYNCCLREN_MASK)
  328. #define SDM_CH_SDCTRLP_FFSYNCCLREN_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLP_FFSYNCCLREN_MASK) >> SDM_CH_SDCTRLP_FFSYNCCLREN_SHIFT)
  329. /*
  330. * WTSYNACLR (RW)
  331. *
  332. * 1: Asserted to Auto clear WTSYNFLG when the SDFFINT is gen
  333. * 0: WTSYNFLG should be cleared manually by WTSYNMCLR
  334. */
  335. #define SDM_CH_SDCTRLP_WTSYNACLR_MASK (0x20U)
  336. #define SDM_CH_SDCTRLP_WTSYNACLR_SHIFT (5U)
  337. #define SDM_CH_SDCTRLP_WTSYNACLR_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLP_WTSYNACLR_SHIFT) & SDM_CH_SDCTRLP_WTSYNACLR_MASK)
  338. #define SDM_CH_SDCTRLP_WTSYNACLR_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLP_WTSYNACLR_MASK) >> SDM_CH_SDCTRLP_WTSYNACLR_SHIFT)
  339. /*
  340. * WTSYNMCLR (RW)
  341. *
  342. * 1: Manually clear WTSYNFLG. Auto-clear.
  343. */
  344. #define SDM_CH_SDCTRLP_WTSYNMCLR_MASK (0x10U)
  345. #define SDM_CH_SDCTRLP_WTSYNMCLR_SHIFT (4U)
  346. #define SDM_CH_SDCTRLP_WTSYNMCLR_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLP_WTSYNMCLR_SHIFT) & SDM_CH_SDCTRLP_WTSYNMCLR_MASK)
  347. #define SDM_CH_SDCTRLP_WTSYNMCLR_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLP_WTSYNMCLR_MASK) >> SDM_CH_SDCTRLP_WTSYNMCLR_SHIFT)
  348. /*
  349. * WTSYNCEN (RW)
  350. *
  351. * 1: Start to store data only after PWM SYNC event
  352. * 0: Start to store data whenever enabled
  353. */
  354. #define SDM_CH_SDCTRLP_WTSYNCEN_MASK (0x8U)
  355. #define SDM_CH_SDCTRLP_WTSYNCEN_SHIFT (3U)
  356. #define SDM_CH_SDCTRLP_WTSYNCEN_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLP_WTSYNCEN_SHIFT) & SDM_CH_SDCTRLP_WTSYNCEN_MASK)
  357. #define SDM_CH_SDCTRLP_WTSYNCEN_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLP_WTSYNCEN_MASK) >> SDM_CH_SDCTRLP_WTSYNCEN_SHIFT)
  358. /*
  359. * D32 (RW)
  360. *
  361. * 1:32 bit data
  362. * 0:16 bit data
  363. */
  364. #define SDM_CH_SDCTRLP_D32_MASK (0x4U)
  365. #define SDM_CH_SDCTRLP_D32_SHIFT (2U)
  366. #define SDM_CH_SDCTRLP_D32_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLP_D32_SHIFT) & SDM_CH_SDCTRLP_D32_MASK)
  367. #define SDM_CH_SDCTRLP_D32_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLP_D32_MASK) >> SDM_CH_SDCTRLP_D32_SHIFT)
  368. /*
  369. * DR_OPT (RW)
  370. *
  371. * 1: Use Data FIFO Ready as data ready when fifo fillings are greater than the threshold
  372. * 0: Use Data Reg Ready as data ready
  373. */
  374. #define SDM_CH_SDCTRLP_DR_OPT_MASK (0x2U)
  375. #define SDM_CH_SDCTRLP_DR_OPT_SHIFT (1U)
  376. #define SDM_CH_SDCTRLP_DR_OPT_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLP_DR_OPT_SHIFT) & SDM_CH_SDCTRLP_DR_OPT_MASK)
  377. #define SDM_CH_SDCTRLP_DR_OPT_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLP_DR_OPT_MASK) >> SDM_CH_SDCTRLP_DR_OPT_SHIFT)
  378. /*
  379. * EN (RW)
  380. *
  381. * Data Path Enable
  382. */
  383. #define SDM_CH_SDCTRLP_EN_MASK (0x1U)
  384. #define SDM_CH_SDCTRLP_EN_SHIFT (0U)
  385. #define SDM_CH_SDCTRLP_EN_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLP_EN_SHIFT) & SDM_CH_SDCTRLP_EN_MASK)
  386. #define SDM_CH_SDCTRLP_EN_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLP_EN_MASK) >> SDM_CH_SDCTRLP_EN_SHIFT)
  387. /* Bitfield definition for register of struct array CH: SDCTRLE */
  388. /*
  389. * SGD_ORDR (RW)
  390. *
  391. * CIC order
  392. * 0: SYNC1
  393. * 1: SYNC2
  394. * 2: SYNC3
  395. * 3: FAST_SYNC
  396. */
  397. #define SDM_CH_SDCTRLE_SGD_ORDR_MASK (0x60000UL)
  398. #define SDM_CH_SDCTRLE_SGD_ORDR_SHIFT (17U)
  399. #define SDM_CH_SDCTRLE_SGD_ORDR_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLE_SGD_ORDR_SHIFT) & SDM_CH_SDCTRLE_SGD_ORDR_MASK)
  400. #define SDM_CH_SDCTRLE_SGD_ORDR_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLE_SGD_ORDR_MASK) >> SDM_CH_SDCTRLE_SGD_ORDR_SHIFT)
  401. /*
  402. * PWMSYNC (RW)
  403. *
  404. * Asserted to double sync the PWM trigger signal
  405. */
  406. #define SDM_CH_SDCTRLE_PWMSYNC_MASK (0x10000UL)
  407. #define SDM_CH_SDCTRLE_PWMSYNC_SHIFT (16U)
  408. #define SDM_CH_SDCTRLE_PWMSYNC_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLE_PWMSYNC_SHIFT) & SDM_CH_SDCTRLE_PWMSYNC_MASK)
  409. #define SDM_CH_SDCTRLE_PWMSYNC_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLE_PWMSYNC_MASK) >> SDM_CH_SDCTRLE_PWMSYNC_SHIFT)
  410. /*
  411. * CIC_SCL (RW)
  412. *
  413. * CIC shift control
  414. */
  415. #define SDM_CH_SDCTRLE_CIC_SCL_MASK (0x7800U)
  416. #define SDM_CH_SDCTRLE_CIC_SCL_SHIFT (11U)
  417. #define SDM_CH_SDCTRLE_CIC_SCL_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLE_CIC_SCL_SHIFT) & SDM_CH_SDCTRLE_CIC_SCL_MASK)
  418. #define SDM_CH_SDCTRLE_CIC_SCL_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLE_CIC_SCL_MASK) >> SDM_CH_SDCTRLE_CIC_SCL_SHIFT)
  419. /*
  420. * CIC_DEC_RATIO (RW)
  421. *
  422. * CIC decimation ratio. 0 means div-by-256
  423. */
  424. #define SDM_CH_SDCTRLE_CIC_DEC_RATIO_MASK (0x7F8U)
  425. #define SDM_CH_SDCTRLE_CIC_DEC_RATIO_SHIFT (3U)
  426. #define SDM_CH_SDCTRLE_CIC_DEC_RATIO_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLE_CIC_DEC_RATIO_SHIFT) & SDM_CH_SDCTRLE_CIC_DEC_RATIO_MASK)
  427. #define SDM_CH_SDCTRLE_CIC_DEC_RATIO_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLE_CIC_DEC_RATIO_MASK) >> SDM_CH_SDCTRLE_CIC_DEC_RATIO_SHIFT)
  428. /*
  429. * IGN_INI_SAMPLES (RW)
  430. *
  431. * NotZero: Don't store the first samples that are not accurate
  432. * Zero: Store all samples
  433. */
  434. #define SDM_CH_SDCTRLE_IGN_INI_SAMPLES_MASK (0x7U)
  435. #define SDM_CH_SDCTRLE_IGN_INI_SAMPLES_SHIFT (0U)
  436. #define SDM_CH_SDCTRLE_IGN_INI_SAMPLES_SET(x) (((uint32_t)(x) << SDM_CH_SDCTRLE_IGN_INI_SAMPLES_SHIFT) & SDM_CH_SDCTRLE_IGN_INI_SAMPLES_MASK)
  437. #define SDM_CH_SDCTRLE_IGN_INI_SAMPLES_GET(x) (((uint32_t)(x) & SDM_CH_SDCTRLE_IGN_INI_SAMPLES_MASK) >> SDM_CH_SDCTRLE_IGN_INI_SAMPLES_SHIFT)
  438. /* Bitfield definition for register of struct array CH: SDST */
  439. /*
  440. * PERIOD_MCLK (RO)
  441. *
  442. * maxim of mclk spacing in cycles, using edges of mclk signal. In manchester coding mode, it is just the period of MCLK. In other modes, it is almost the half period.
  443. */
  444. #define SDM_CH_SDST_PERIOD_MCLK_MASK (0x7F800000UL)
  445. #define SDM_CH_SDST_PERIOD_MCLK_SHIFT (23U)
  446. #define SDM_CH_SDST_PERIOD_MCLK_GET(x) (((uint32_t)(x) & SDM_CH_SDST_PERIOD_MCLK_MASK) >> SDM_CH_SDST_PERIOD_MCLK_SHIFT)
  447. /*
  448. * FIFO_DR (W1C)
  449. *
  450. * FIFO data ready
  451. */
  452. #define SDM_CH_SDST_FIFO_DR_MASK (0x200U)
  453. #define SDM_CH_SDST_FIFO_DR_SHIFT (9U)
  454. #define SDM_CH_SDST_FIFO_DR_SET(x) (((uint32_t)(x) << SDM_CH_SDST_FIFO_DR_SHIFT) & SDM_CH_SDST_FIFO_DR_MASK)
  455. #define SDM_CH_SDST_FIFO_DR_GET(x) (((uint32_t)(x) & SDM_CH_SDST_FIFO_DR_MASK) >> SDM_CH_SDST_FIFO_DR_SHIFT)
  456. /*
  457. * AF (W1C)
  458. *
  459. * Achnowledge flag
  460. */
  461. #define SDM_CH_SDST_AF_MASK (0x100U)
  462. #define SDM_CH_SDST_AF_SHIFT (8U)
  463. #define SDM_CH_SDST_AF_SET(x) (((uint32_t)(x) << SDM_CH_SDST_AF_SHIFT) & SDM_CH_SDST_AF_MASK)
  464. #define SDM_CH_SDST_AF_GET(x) (((uint32_t)(x) & SDM_CH_SDST_AF_MASK) >> SDM_CH_SDST_AF_SHIFT)
  465. /*
  466. * DOV_ERR (W1C)
  467. *
  468. * Data FIFO Overflow Error. Error flag.
  469. */
  470. #define SDM_CH_SDST_DOV_ERR_MASK (0x80U)
  471. #define SDM_CH_SDST_DOV_ERR_SHIFT (7U)
  472. #define SDM_CH_SDST_DOV_ERR_SET(x) (((uint32_t)(x) << SDM_CH_SDST_DOV_ERR_SHIFT) & SDM_CH_SDST_DOV_ERR_MASK)
  473. #define SDM_CH_SDST_DOV_ERR_GET(x) (((uint32_t)(x) & SDM_CH_SDST_DOV_ERR_MASK) >> SDM_CH_SDST_DOV_ERR_SHIFT)
  474. /*
  475. * DSAT_ERR (W1C)
  476. *
  477. * CIC out Data saturation err. Error flag.
  478. */
  479. #define SDM_CH_SDST_DSAT_ERR_MASK (0x40U)
  480. #define SDM_CH_SDST_DSAT_ERR_SHIFT (6U)
  481. #define SDM_CH_SDST_DSAT_ERR_SET(x) (((uint32_t)(x) << SDM_CH_SDST_DSAT_ERR_SHIFT) & SDM_CH_SDST_DSAT_ERR_MASK)
  482. #define SDM_CH_SDST_DSAT_ERR_GET(x) (((uint32_t)(x) & SDM_CH_SDST_DSAT_ERR_MASK) >> SDM_CH_SDST_DSAT_ERR_SHIFT)
  483. /*
  484. * WTSYNFLG (RO)
  485. *
  486. * Wait-for-sync event found
  487. */
  488. #define SDM_CH_SDST_WTSYNFLG_MASK (0x20U)
  489. #define SDM_CH_SDST_WTSYNFLG_SHIFT (5U)
  490. #define SDM_CH_SDST_WTSYNFLG_GET(x) (((uint32_t)(x) & SDM_CH_SDST_WTSYNFLG_MASK) >> SDM_CH_SDST_WTSYNFLG_SHIFT)
  491. /*
  492. * FILL (RO)
  493. *
  494. * Data FIFO Fillings
  495. */
  496. #define SDM_CH_SDST_FILL_MASK (0x1FU)
  497. #define SDM_CH_SDST_FILL_SHIFT (0U)
  498. #define SDM_CH_SDST_FILL_GET(x) (((uint32_t)(x) & SDM_CH_SDST_FILL_MASK) >> SDM_CH_SDST_FILL_SHIFT)
  499. /* Bitfield definition for register of struct array CH: SDATA */
  500. /*
  501. * VAL (RO)
  502. *
  503. * Data
  504. */
  505. #define SDM_CH_SDATA_VAL_MASK (0xFFFFFFFFUL)
  506. #define SDM_CH_SDATA_VAL_SHIFT (0U)
  507. #define SDM_CH_SDATA_VAL_GET(x) (((uint32_t)(x) & SDM_CH_SDATA_VAL_MASK) >> SDM_CH_SDATA_VAL_SHIFT)
  508. /* Bitfield definition for register of struct array CH: SDFIFO */
  509. /*
  510. * VAL (RO)
  511. *
  512. * FIFO Data
  513. */
  514. #define SDM_CH_SDFIFO_VAL_MASK (0xFFFFFFFFUL)
  515. #define SDM_CH_SDFIFO_VAL_SHIFT (0U)
  516. #define SDM_CH_SDFIFO_VAL_GET(x) (((uint32_t)(x) & SDM_CH_SDFIFO_VAL_MASK) >> SDM_CH_SDFIFO_VAL_SHIFT)
  517. /* Bitfield definition for register of struct array CH: SCAMP */
  518. /*
  519. * VAL (RO)
  520. *
  521. * instant Amplitude Results
  522. */
  523. #define SDM_CH_SCAMP_VAL_MASK (0xFFFFU)
  524. #define SDM_CH_SCAMP_VAL_SHIFT (0U)
  525. #define SDM_CH_SCAMP_VAL_GET(x) (((uint32_t)(x) & SDM_CH_SCAMP_VAL_MASK) >> SDM_CH_SCAMP_VAL_SHIFT)
  526. /* Bitfield definition for register of struct array CH: SCHTL */
  527. /*
  528. * VAL (RW)
  529. *
  530. * Amplitude Threshold for High Limit
  531. */
  532. #define SDM_CH_SCHTL_VAL_MASK (0xFFFFU)
  533. #define SDM_CH_SCHTL_VAL_SHIFT (0U)
  534. #define SDM_CH_SCHTL_VAL_SET(x) (((uint32_t)(x) << SDM_CH_SCHTL_VAL_SHIFT) & SDM_CH_SCHTL_VAL_MASK)
  535. #define SDM_CH_SCHTL_VAL_GET(x) (((uint32_t)(x) & SDM_CH_SCHTL_VAL_MASK) >> SDM_CH_SCHTL_VAL_SHIFT)
  536. /* Bitfield definition for register of struct array CH: SCHTLZ */
  537. /*
  538. * VAL (RW)
  539. *
  540. * Amplitude Threshold for zero crossing
  541. */
  542. #define SDM_CH_SCHTLZ_VAL_MASK (0xFFFFU)
  543. #define SDM_CH_SCHTLZ_VAL_SHIFT (0U)
  544. #define SDM_CH_SCHTLZ_VAL_SET(x) (((uint32_t)(x) << SDM_CH_SCHTLZ_VAL_SHIFT) & SDM_CH_SCHTLZ_VAL_MASK)
  545. #define SDM_CH_SCHTLZ_VAL_GET(x) (((uint32_t)(x) & SDM_CH_SCHTLZ_VAL_MASK) >> SDM_CH_SCHTLZ_VAL_SHIFT)
  546. /* Bitfield definition for register of struct array CH: SCLLT */
  547. /*
  548. * VAL (RW)
  549. *
  550. * Amplitude Threshold for low limit
  551. */
  552. #define SDM_CH_SCLLT_VAL_MASK (0xFFFFU)
  553. #define SDM_CH_SCLLT_VAL_SHIFT (0U)
  554. #define SDM_CH_SCLLT_VAL_SET(x) (((uint32_t)(x) << SDM_CH_SCLLT_VAL_SHIFT) & SDM_CH_SCLLT_VAL_MASK)
  555. #define SDM_CH_SCLLT_VAL_GET(x) (((uint32_t)(x) & SDM_CH_SCLLT_VAL_MASK) >> SDM_CH_SCLLT_VAL_SHIFT)
  556. /* Bitfield definition for register of struct array CH: SCCTRL */
  557. /*
  558. * HZ_EN (RW)
  559. *
  560. * Zero Crossing Enable
  561. */
  562. #define SDM_CH_SCCTRL_HZ_EN_MASK (0x800000UL)
  563. #define SDM_CH_SCCTRL_HZ_EN_SHIFT (23U)
  564. #define SDM_CH_SCCTRL_HZ_EN_SET(x) (((uint32_t)(x) << SDM_CH_SCCTRL_HZ_EN_SHIFT) & SDM_CH_SCCTRL_HZ_EN_MASK)
  565. #define SDM_CH_SCCTRL_HZ_EN_GET(x) (((uint32_t)(x) & SDM_CH_SCCTRL_HZ_EN_MASK) >> SDM_CH_SCCTRL_HZ_EN_SHIFT)
  566. /*
  567. * MF_IE (RW)
  568. *
  569. * Module failure Interrupt enable
  570. */
  571. #define SDM_CH_SCCTRL_MF_IE_MASK (0x400000UL)
  572. #define SDM_CH_SCCTRL_MF_IE_SHIFT (22U)
  573. #define SDM_CH_SCCTRL_MF_IE_SET(x) (((uint32_t)(x) << SDM_CH_SCCTRL_MF_IE_SHIFT) & SDM_CH_SCCTRL_MF_IE_MASK)
  574. #define SDM_CH_SCCTRL_MF_IE_GET(x) (((uint32_t)(x) & SDM_CH_SCCTRL_MF_IE_MASK) >> SDM_CH_SCCTRL_MF_IE_SHIFT)
  575. /*
  576. * HL_IE (RW)
  577. *
  578. * HLT Interrupt Enable
  579. */
  580. #define SDM_CH_SCCTRL_HL_IE_MASK (0x200000UL)
  581. #define SDM_CH_SCCTRL_HL_IE_SHIFT (21U)
  582. #define SDM_CH_SCCTRL_HL_IE_SET(x) (((uint32_t)(x) << SDM_CH_SCCTRL_HL_IE_SHIFT) & SDM_CH_SCCTRL_HL_IE_MASK)
  583. #define SDM_CH_SCCTRL_HL_IE_GET(x) (((uint32_t)(x) & SDM_CH_SCCTRL_HL_IE_MASK) >> SDM_CH_SCCTRL_HL_IE_SHIFT)
  584. /*
  585. * LL_IE (RW)
  586. *
  587. * LLT interrupt Enable
  588. */
  589. #define SDM_CH_SCCTRL_LL_IE_MASK (0x100000UL)
  590. #define SDM_CH_SCCTRL_LL_IE_SHIFT (20U)
  591. #define SDM_CH_SCCTRL_LL_IE_SET(x) (((uint32_t)(x) << SDM_CH_SCCTRL_LL_IE_SHIFT) & SDM_CH_SCCTRL_LL_IE_MASK)
  592. #define SDM_CH_SCCTRL_LL_IE_GET(x) (((uint32_t)(x) & SDM_CH_SCCTRL_LL_IE_MASK) >> SDM_CH_SCCTRL_LL_IE_SHIFT)
  593. /*
  594. * SGD_ORDR (RW)
  595. *
  596. * CIC order
  597. * 0: SYNC1
  598. * 1: SYNC2
  599. * 2: SYNC3
  600. * 3: FAST_SYNC
  601. */
  602. #define SDM_CH_SCCTRL_SGD_ORDR_MASK (0xC0000UL)
  603. #define SDM_CH_SCCTRL_SGD_ORDR_SHIFT (18U)
  604. #define SDM_CH_SCCTRL_SGD_ORDR_SET(x) (((uint32_t)(x) << SDM_CH_SCCTRL_SGD_ORDR_SHIFT) & SDM_CH_SCCTRL_SGD_ORDR_MASK)
  605. #define SDM_CH_SCCTRL_SGD_ORDR_GET(x) (((uint32_t)(x) & SDM_CH_SCCTRL_SGD_ORDR_MASK) >> SDM_CH_SCCTRL_SGD_ORDR_SHIFT)
  606. /*
  607. * CIC_DEC_RATIO (RW)
  608. *
  609. * CIC decimation ratio. 0 means div-by-32
  610. */
  611. #define SDM_CH_SCCTRL_CIC_DEC_RATIO_MASK (0x1F0U)
  612. #define SDM_CH_SCCTRL_CIC_DEC_RATIO_SHIFT (4U)
  613. #define SDM_CH_SCCTRL_CIC_DEC_RATIO_SET(x) (((uint32_t)(x) << SDM_CH_SCCTRL_CIC_DEC_RATIO_SHIFT) & SDM_CH_SCCTRL_CIC_DEC_RATIO_MASK)
  614. #define SDM_CH_SCCTRL_CIC_DEC_RATIO_GET(x) (((uint32_t)(x) & SDM_CH_SCCTRL_CIC_DEC_RATIO_MASK) >> SDM_CH_SCCTRL_CIC_DEC_RATIO_SHIFT)
  615. /*
  616. * IGN_INI_SAMPLES (RW)
  617. *
  618. * NotZero: Ignore the first samples that are not accurate
  619. * Zero: Use all samples
  620. */
  621. #define SDM_CH_SCCTRL_IGN_INI_SAMPLES_MASK (0xEU)
  622. #define SDM_CH_SCCTRL_IGN_INI_SAMPLES_SHIFT (1U)
  623. #define SDM_CH_SCCTRL_IGN_INI_SAMPLES_SET(x) (((uint32_t)(x) << SDM_CH_SCCTRL_IGN_INI_SAMPLES_SHIFT) & SDM_CH_SCCTRL_IGN_INI_SAMPLES_MASK)
  624. #define SDM_CH_SCCTRL_IGN_INI_SAMPLES_GET(x) (((uint32_t)(x) & SDM_CH_SCCTRL_IGN_INI_SAMPLES_MASK) >> SDM_CH_SCCTRL_IGN_INI_SAMPLES_SHIFT)
  625. /*
  626. * EN (RW)
  627. *
  628. * Amplitude Path Enable
  629. */
  630. #define SDM_CH_SCCTRL_EN_MASK (0x1U)
  631. #define SDM_CH_SCCTRL_EN_SHIFT (0U)
  632. #define SDM_CH_SCCTRL_EN_SET(x) (((uint32_t)(x) << SDM_CH_SCCTRL_EN_SHIFT) & SDM_CH_SCCTRL_EN_MASK)
  633. #define SDM_CH_SCCTRL_EN_GET(x) (((uint32_t)(x) & SDM_CH_SCCTRL_EN_MASK) >> SDM_CH_SCCTRL_EN_SHIFT)
  634. /* Bitfield definition for register of struct array CH: SCST */
  635. /*
  636. * HZ (W1C)
  637. *
  638. * Amplitude rising above HZ event found.
  639. */
  640. #define SDM_CH_SCST_HZ_MASK (0x8U)
  641. #define SDM_CH_SCST_HZ_SHIFT (3U)
  642. #define SDM_CH_SCST_HZ_SET(x) (((uint32_t)(x) << SDM_CH_SCST_HZ_SHIFT) & SDM_CH_SCST_HZ_MASK)
  643. #define SDM_CH_SCST_HZ_GET(x) (((uint32_t)(x) & SDM_CH_SCST_HZ_MASK) >> SDM_CH_SCST_HZ_SHIFT)
  644. /*
  645. * MF (W1C)
  646. *
  647. * power modulator Failure found. MCLK not found. Error flag.
  648. */
  649. #define SDM_CH_SCST_MF_MASK (0x4U)
  650. #define SDM_CH_SCST_MF_SHIFT (2U)
  651. #define SDM_CH_SCST_MF_SET(x) (((uint32_t)(x) << SDM_CH_SCST_MF_SHIFT) & SDM_CH_SCST_MF_MASK)
  652. #define SDM_CH_SCST_MF_GET(x) (((uint32_t)(x) & SDM_CH_SCST_MF_MASK) >> SDM_CH_SCST_MF_SHIFT)
  653. /*
  654. * CMPH (W1C)
  655. *
  656. * HLT out of range. Error flag.
  657. */
  658. #define SDM_CH_SCST_CMPH_MASK (0x2U)
  659. #define SDM_CH_SCST_CMPH_SHIFT (1U)
  660. #define SDM_CH_SCST_CMPH_SET(x) (((uint32_t)(x) << SDM_CH_SCST_CMPH_SHIFT) & SDM_CH_SCST_CMPH_MASK)
  661. #define SDM_CH_SCST_CMPH_GET(x) (((uint32_t)(x) & SDM_CH_SCST_CMPH_MASK) >> SDM_CH_SCST_CMPH_SHIFT)
  662. /*
  663. * CMPL (W1C)
  664. *
  665. * LLT out of range. Error flag.
  666. */
  667. #define SDM_CH_SCST_CMPL_MASK (0x1U)
  668. #define SDM_CH_SCST_CMPL_SHIFT (0U)
  669. #define SDM_CH_SCST_CMPL_SET(x) (((uint32_t)(x) << SDM_CH_SCST_CMPL_SHIFT) & SDM_CH_SCST_CMPL_MASK)
  670. #define SDM_CH_SCST_CMPL_GET(x) (((uint32_t)(x) & SDM_CH_SCST_CMPL_MASK) >> SDM_CH_SCST_CMPL_SHIFT)
  671. /* CH register group index macro definition */
  672. #define SDM_CH_0 (0UL)
  673. #define SDM_CH_1 (1UL)
  674. #define SDM_CH_2 (2UL)
  675. #define SDM_CH_3 (3UL)
  676. #endif /* HPM_SDM_H */