1 /* SPDX-License-Identifier: Apache-2.0 */ 2 /* 3 * Copyright (c) 2023 Intel Corporation 4 * 5 * Author: Adrian Warecki <adrian.warecki@intel.com> 6 */ 7 8 #ifndef __INTEL_DAI_DRIVER_DMIC_REGS_H__ 9 #define __INTEL_DAI_DRIVER_DMIC_REGS_H__ 10 11 /* DMIC timestamping registers */ 12 #define TS_DMIC_LOCAL_TSCTRL_OFFSET 0x000 13 #define TS_DMIC_LOCAL_OFFS_OFFSET 0x004 14 #define TS_DMIC_LOCAL_SAMPLE_OFFSET 0x008 15 #define TS_DMIC_LOCAL_WALCLK_OFFSET 0x010 16 #define TS_DMIC_TSCC_OFFSET 0x018 17 18 /* Timestamping */ 19 #define TIMESTAMP_BASE 0x00071800 20 21 /* Time Stamp Control Register */ 22 #define TS_DMIC_LOCAL_TSCTRL (TIMESTAMP_BASE + TS_DMIC_LOCAL_TSCTRL_OFFSET) 23 24 /* Intersample offset Register */ 25 #define TS_DMIC_LOCAL_OFFS (TIMESTAMP_BASE + TS_DMIC_LOCAL_OFFS_OFFSET) 26 27 #define TS_DMIC_LOCAL_SAMPLE (TIMESTAMP_BASE + TS_DMIC_LOCAL_SAMPLE_OFFSET) 28 #define TS_DMIC_LOCAL_WALCLK (TIMESTAMP_BASE + TS_DMIC_LOCAL_WALCLK_OFFSET) 29 30 /* Time Stamp Counter Captured 64 bits */ 31 #define TS_DMIC_TSCC (TIMESTAMP_BASE + TS_DMIC_TSCC_OFFSET) 32 33 /* New Timestamp Taken */ 34 #define TS_LOCAL_TSCTRL_NTK BIT(31) 35 36 /* Interrupt on New Timestamp Enable */ 37 #define TS_LOCAL_TSCTRL_IONTE BIT(30) 38 39 /* DMA Type Select */ 40 #define TS_LOCAL_TSCTRL_DMATS GENMASK(13, 12) 41 42 /* Capture Link Select - select which link wall clock to time stamp. */ 43 #define TS_LOCAL_TSCTRL_CLNKS GENMASK(11, 10) 44 45 /* Hammock Harbor Time Stamp Enable */ 46 #define TS_LOCAL_TSCTRL_HHTSE BIT(7) 47 48 /* Link Wall Clock Select */ 49 #define TS_LOCAL_TSCTRL_LWCS BIT(6) 50 51 /* On Demand Time Stamp */ 52 #define TS_LOCAL_TSCTRL_ODTS BIT(5) 53 54 /* Capture DMA Select */ 55 #define TS_LOCAL_TSCTRL_CDMAS GENMASK(4, 0) 56 57 /* Snapshot of Audio Wall Clock Offset counter (frame offset). */ 58 #define TS_LOCAL_OFFS_FRM GENMASK(15, 12) 59 60 /* Snapshot of Audio Wall Clock Offset counter (clock offset). */ 61 #define TS_LOCAL_OFFS_CLK GENMASK(11, 0) 62 63 64 /* DMIC register offsets */ 65 66 /* Global registers */ 67 68 /* Common FIFO channels register (primary & secondary) (0000 - 0FFF) 69 * PDM Primary Channel 70 */ 71 72 /* Control registers for packers */ 73 #define OUTCONTROL 0x0000 74 75 /* Status Register for FIFO interface */ 76 #define OUTSTAT 0x0004 77 78 /* Data read/Write port for FIFO */ 79 #define OUTDATA 0x0008 80 81 /* (crossed out) 000Ch LOCAL_OFFS Offset Counter 82 * (crossed out) 0010h LOCAL_TSC0 64-bit Wall Clock timestamp 83 * (crossed out) 0018h LOCAL_SAMPLE0 64-bit Sample Count 84 * 001Ch - 00FFh Reserved space for extensions 85 */ 86 87 /* Offset to PDM Secondary Channel */ 88 #define PDM_CHANNEL_REGS_SIZE 0x100 89 90 91 #define GLOBAL_CAPABILITIES 0x200 92 93 #define PDM_COEFFICIENT_A 0x400 94 #define PDM_COEF_RAM_A_LENGTH 0x400 95 96 #define PDM_COEFFICIENT_B 0x800 97 #define PDM_COEF_RAM_B_LENGTH 0x400 98 99 #define PDM0 0x1000 100 #define PDM1 0x2000 101 #define PDM2 0x3000 102 #define PDM3 0x4000 103 104 105 /* Local registers in each PDMx */ 106 107 /* Control register for CIC configuration and decimator setting */ 108 #define CIC_CONTROL 0x000 109 110 /* Control of the CIC filter plus voice channel (B) FIR decimation factor */ 111 #define CIC_CONFIG 0x004 112 113 /* Microphone interface control register */ 114 #define MIC_CONTROL 0x00c 115 116 /* FIR config */ 117 118 /* Control for the FIR decimator */ 119 #define FIR_CONTROL 0x020 120 121 /* Configuration of FIR decimator parameters */ 122 #define FIR_CONFIG 0x024 123 124 /* DC offset for left channel */ 125 #define DC_OFFSET_LEFT 0x028 126 127 /* DC offset for right channel */ 128 #define DC_OFFSET_RIGHT 0x02c 129 130 /* Gain for left channel */ 131 #define OUT_GAIN_LEFT 0x030 132 133 /* Gain for right channel */ 134 #define OUT_GAIN_RIGHT 0x034 135 136 /* Offset to secondary FIR */ 137 #define FIR_CHANNEL_REGS_SIZE 0x20 138 139 140 /* Digital Mic Shim Registers */ 141 142 /* Digital Microphone Link Control */ 143 #define DMICLCTL 0x04 144 145 /* Digital Microphone IP Pointer */ 146 #define DMICIPPTR 0x08 147 148 149 /* OUTCONTROL0 and OUTCONTROL1 */ 150 151 /* OUTCONTROLx IPM bit fields style */ 152 #define OUTCONTROL_BFTH_MAX 4 /* Max depth 16 */ 153 154 /* Threshold Interrupt Enable */ 155 #define OUTCONTROL_TIE BIT(27) 156 157 /* Start Input Packer */ 158 #define OUTCONTROL_SIP BIT(26) 159 160 /* FIFO Initialize (FINIT): The software will set this bit to immediately clear FIFO pointers. */ 161 #define OUTCONTROL_FINIT BIT(25) 162 163 /* Input Format Change Indicator */ 164 #define OUTCONTROL_FCI BIT(24) 165 166 /* Burst FIFO Threshold */ 167 #define OUTCONTROL_BFTH GENMASK(23, 20) 168 169 /* Output Format */ 170 #define OUTCONTROL_OF GENMASK(19, 18) 171 172 173 /* This field decides the packer mode */ 174 #define OUTCONTROL_IPM GENMASK(17, 15) 175 176 /* Source decimator for 1st stereo/mono data placeholder. */ 177 #define OUTCONTROL_IPM_SOURCE_1 GENMASK(14, 13) 178 179 /* Source decimator for 2nd stereo/mono data placeholder. */ 180 #define OUTCONTROL_IPM_SOURCE_2 GENMASK(12, 11) 181 182 /* Source decimator for 3rd stereo/mono data placeholder. */ 183 #define OUTCONTROL_IPM_SOURCE_3 GENMASK(10, 9) 184 185 /* Source decimator for 4th stereo/mono data placeholder. */ 186 #define OUTCONTROL_IPM_SOURCE_4 GENMASK(8, 7) 187 188 /* Defines the mode of operation for all source decimator. */ 189 #define OUTCONTROL_IPM_SOURCE_MODE BIT(6) 190 191 /* FIFO Trigger Threshold */ 192 #define OUTCONTROL_TH GENMASK(5, 0) 193 194 195 /* OUTSTAT0 and OUTSTAT1 bits */ 196 197 /* Asynchronous FIFO is empty */ 198 #define OUTSTAT_AFE BIT(31) 199 200 /* Asynchronous FIFO Not Empty */ 201 #define OUTSTAT_ASNE BIT(29) 202 203 /* FIFO Service Request */ 204 #define OUTSTAT_RFS BIT(28) 205 206 /* Overrun */ 207 #define OUTSTAT_ROR BIT(27) 208 209 /* FIFO Level (FL): Current FIFO Level in the Asynchronous FIFO. */ 210 #define OUTSTAT_FL_MASK GENMASK(8, 0) 211 212 /* CIC_CONTROL bits */ 213 214 /* Microphone interface reset. */ 215 #define CIC_CONTROL_SOFT_RESET BIT(16) 216 217 /* When set to 1, the CIC channel B (right) is started, otherwise it is muted and idle. */ 218 #define CIC_CONTROL_CIC_START_B BIT(15) 219 220 /* When set to 1, the CIC channel A (left) is started, otherwise it is muted and idle. */ 221 #define CIC_CONTROL_CIC_START_A BIT(14) 222 223 /* Polarity of the microphone output. */ 224 #define CIC_CONTROL_MIC_B_POLARITY BIT(3) 225 226 /* Polarity of the microphone output. */ 227 #define CIC_CONTROL_MIC_A_POLARITY BIT(2) 228 229 /* Mute currently active microphones */ 230 #define CIC_CONTROL_MIC_MUTE BIT(1) 231 232 233 /* CIC_CONFIG masks */ 234 235 /* Number of bits for shift right in the output stage of the CIC filter to compensate the gain 236 * accumulated due to decimation. 237 */ 238 #define CIC_CONFIG_CIC_SHIFT GENMASK(27, 24) 239 240 /* Period of activation of comb section in the microphone clocks minus 1 */ 241 #define CIC_CONFIG_COMB_COUNT GENMASK(15, 8) 242 243 244 /* MIC_CONTROL */ 245 246 /* Clock divider used for producing the microphone clock from audio IO clock with approximately 50% 247 * duty cycle. 248 */ 249 #define MIC_CONTROL_PDM_CLKDIV GENMASK(15, 8) 250 251 /* Inverts the clock edge that will be used to sample microphone data stream. */ 252 #define MIC_CONTROL_CLK_EDGE BIT(3) 253 254 /* Indicates the PDM DMIC clock for the decimator will be sourced from external component instead 255 * of using the PDM DMIC clock generator output 256 */ 257 #define MIC_CONTROL_SLAVE_MODE BIT(2) 258 259 /* Enable clock on microphone B (Right) */ 260 #define MIC_CONTROL_PDM_EN_B BIT(1) 261 262 /* Enable clock on microphone A (left) */ 263 #define MIC_CONTROL_PDM_EN_A BIT(0) 264 265 266 /* FIR_CONTROL_A bits */ 267 268 /* Enable the power gating capability of the coefficient. */ 269 #define FIR_CONTROL_CRFPGE BIT(28) 270 271 /* Power gating capability of the left channel */ 272 #define FIR_CONTROL_LDRFPGE BIT(29) 273 274 /* Enable the power gating capability of the right channel */ 275 #define FIR_CONTROL_RDRFPGE BIT(30) 276 277 /* FIR decimation filter is started. */ 278 #define FIR_CONTROL_START BIT(7) 279 280 /* Array microphone control bit for synchronous start of multiple interfaces. */ 281 #define FIR_CONTROL_ARRAY_START_EN BIT(6) 282 283 /* Periodic synchronous start control of multiple PDM */ 284 #define FIR_CONTROL_PERIODIC_START_EN BIT(5) 285 286 /* Automatic DC compensation enable */ 287 #define FIR_CONTROL_DCCOMP BIT(4) 288 289 /* Write in the coefficient memory will mute the output for the N audio clocks */ 290 #define FIR_CONTROL_AUTO_MUTE BIT(2) 291 292 /* Mute outputs of this filter and set it to zero. */ 293 #define FIR_CONTROL_MUTE BIT(1) 294 295 /* Filter operates in stereo mode */ 296 #define FIR_CONTROL_STEREO BIT(0) 297 298 299 /* FIR_CONFIG bits */ 300 301 /* Decimation factor of the FIR filter minus 1. */ 302 #define FIR_CONFIG_FIR_DECIMATION GENMASK(20, 16) 303 304 /* Number of bits for shift right in the output stage of the CIC filter to compensate the gain 305 * accumulated due to decimation. 306 */ 307 #define FIR_CONFIG_FIR_SHIFT GENMASK(11, 8) 308 309 /* The number of active taps of the FIR filter minus 1. */ 310 #define FIR_CONFIG_FIR_LENGTH GENMASK(7, 0) 311 312 313 /* DC_OFFSET_LEFT and DC_OFFSET_RIGHT */ 314 315 /* Value added to the output of the FIR filter. */ 316 #define DC_OFFSET_DC_OFFS GENMASK(21, 0) 317 318 319 /* OUT_GAIN_LEFT and OUT_GAIN_RIGHT */ 320 321 /* Value added to the output of the FIR filter. */ 322 #define OUT_GAIN GENMASK(19, 0) 323 324 /* FIR coefficients */ 325 #define FIR_COEF GENMASK(19, 0) 326 327 328 /* GLOBAL_CAPABILITIES */ 329 330 /* Nnumber of data entries supported in the PCM XCLK FIFO per FIR output. */ 331 #define GLOBAL_CAP_PCM_XCLK_FIFO_DEPTH GENMASK(5, 0) 332 333 /* Port Count */ 334 #define GLOBAL_CAP_PORT_COUNT GENMASK(7, 6) 335 336 /* FIR Count */ 337 #define GLOBAL_CAP_FIR_COUNT BIT(8) 338 339 /* FIR max gain configuration. */ 340 #define GLOBAL_CAP_FIR_MAX_GAIN BIT(9) 341 342 /* FIR A RF Depth */ 343 #define GLOBAL_CAP_FIR_A_RF_DEPTH GENMASK(23, 16) 344 345 /* FIR B RF Depth */ 346 #define GLOBAL_CAP_FIR_B_RF_DEPTH GENMASK(31, 24) 347 348 349 /* Digital Mic Shim Registers */ 350 #ifdef CONFIG_SOC_INTEL_ACE20_LNL 351 #include <ace20_lnl/dmic_regs_ace2x.h> 352 #elif CONFIG_SOC_INTEL_ACE15_MTPM 353 #include <ace15_mtpm/dmic_regs_ace1x.h> 354 #elif CONFIG_SOC_INTEL_ACE30 355 #include <ace30/dmic_regs_ace3x.h> 356 #else 357 #error "Unknown SoC" 358 #endif 359 360 #endif /* !__INTEL_DAI_DRIVER_DMIC_REGS_H__ */ 361