1 /*
2 ** ###################################################################
3 **     Version:             rev. 4.0, 2020-05-18
4 **     Build:               b240521
5 **
6 **     Abstract:
7 **         Chip specific module features.
8 **
9 **     Copyright 2016 Freescale Semiconductor, Inc.
10 **     Copyright 2016-2024 NXP
11 **     SPDX-License-Identifier: BSD-3-Clause
12 **
13 **     http:                 www.nxp.com
14 **     mail:                 support@nxp.com
15 **
16 **     Revisions:
17 **     - rev. 1.0 (2019-04-19)
18 **         Initial version.
19 **     - rev. 2.0 (2019-07-22)
20 **         Base on rev 0.7 RM.
21 **     - rev. 3.0 (2020-03-16)
22 **         Base on Rev.A RM.
23 **     - rev. 4.0 (2020-05-18)
24 **         Base on Rev.B RM.
25 **
26 ** ###################################################################
27 */
28 
29 #ifndef _MIMXRT555S_FEATURES_H_
30 #define _MIMXRT555S_FEATURES_H_
31 
32 /* SOC module features */
33 
34 /* @brief ACMP availability on the SoC. */
35 #define FSL_FEATURE_SOC_ACMP_COUNT (1)
36 /* @brief AIPS availability on the SoC. */
37 #define FSL_FEATURE_SOC_AIPS_COUNT (2)
38 /* @brief CACHE64_CTRL availability on the SoC. */
39 #define FSL_FEATURE_SOC_CACHE64_CTRL_COUNT (2)
40 /* @brief CACHE64_POLSEL availability on the SoC. */
41 #define FSL_FEATURE_SOC_CACHE64_POLSEL_COUNT (2)
42 /* @brief CASPER availability on the SoC. */
43 #define FSL_FEATURE_SOC_CASPER_COUNT (1)
44 /* @brief CLKCTL0 availability on the SoC. */
45 #define FSL_FEATURE_SOC_CLKCTL0_COUNT (1)
46 /* @brief CLKCTL1 availability on the SoC. */
47 #define FSL_FEATURE_SOC_CLKCTL1_COUNT (1)
48 /* @brief CRC availability on the SoC. */
49 #define FSL_FEATURE_SOC_CRC_COUNT (1)
50 /* @brief CTIMER availability on the SoC. */
51 #define FSL_FEATURE_SOC_CTIMER_COUNT (5)
52 /* @brief DMA availability on the SoC. */
53 #define FSL_FEATURE_SOC_DMA_COUNT (2)
54 /* @brief DMIC availability on the SoC. */
55 #define FSL_FEATURE_SOC_DMIC_COUNT (1)
56 /* @brief FLEXCOMM availability on the SoC. */
57 #define FSL_FEATURE_SOC_FLEXCOMM_COUNT (17)
58 /* @brief FLEXIO availability on the SoC. */
59 #define FSL_FEATURE_SOC_FLEXIO_COUNT (1)
60 /* @brief FLEXSPI availability on the SoC. */
61 #define FSL_FEATURE_SOC_FLEXSPI_COUNT (2)
62 /* @brief FREQME availability on the SoC. */
63 #define FSL_FEATURE_SOC_FREQME_COUNT (1)
64 /* @brief GPIO availability on the SoC. */
65 #define FSL_FEATURE_SOC_GPIO_COUNT (1)
66 /* @brief SECGPIO availability on the SoC. */
67 #define FSL_FEATURE_SOC_SECGPIO_COUNT (1)
68 /* @brief HASHCRYPT availability on the SoC. */
69 #define FSL_FEATURE_SOC_HASHCRYPT_COUNT (1)
70 /* @brief I2C availability on the SoC. */
71 #define FSL_FEATURE_SOC_I2C_COUNT (15)
72 /* @brief I3C availability on the SoC. */
73 #define FSL_FEATURE_SOC_I3C_COUNT (2)
74 /* @brief I2S availability on the SoC. */
75 #define FSL_FEATURE_SOC_I2S_COUNT (14)
76 /* @brief INPUTMUX availability on the SoC. */
77 #define FSL_FEATURE_SOC_INPUTMUX_COUNT (1)
78 /* @brief IOPCTL availability on the SoC. */
79 #define FSL_FEATURE_SOC_IOPCTL_COUNT (1)
80 /* @brief LCDIF availability on the SoC. */
81 #define FSL_FEATURE_SOC_LCDIF_COUNT (1)
82 /* @brief LPADC availability on the SoC. */
83 #define FSL_FEATURE_SOC_LPADC_COUNT (1)
84 /* @brief MIPI_DSI_HOST availability on the SoC. */
85 #define FSL_FEATURE_SOC_MIPI_DSI_HOST_COUNT (1)
86 /* @brief MPU availability on the SoC. */
87 #define FSL_FEATURE_SOC_MPU_COUNT (1)
88 /* @brief MRT availability on the SoC. */
89 #define FSL_FEATURE_SOC_MRT_COUNT (1)
90 /* @brief MU availability on the SoC. */
91 #define FSL_FEATURE_SOC_MU_COUNT (1)
92 /* @brief OCOTP availability on the SoC. */
93 #define FSL_FEATURE_SOC_OCOTP_COUNT (1)
94 /* @brief OSTIMER availability on the SoC. */
95 #define FSL_FEATURE_SOC_OSTIMER_COUNT (1)
96 /* @brief OTFAD availability on the SoC. */
97 #define FSL_FEATURE_SOC_OTFAD_COUNT (1)
98 /* @brief PINT availability on the SoC. */
99 #define FSL_FEATURE_SOC_PINT_COUNT (1)
100 /* @brief PMC availability on the SoC. */
101 #define FSL_FEATURE_SOC_PMC_COUNT (1)
102 /* @brief POWERQUAD availability on the SoC. */
103 #define FSL_FEATURE_SOC_POWERQUAD_COUNT (1)
104 /* @brief PUF availability on the SoC. */
105 #define FSL_FEATURE_SOC_PUF_COUNT (1)
106 /* @brief RSTCTL0 availability on the SoC. */
107 #define FSL_FEATURE_SOC_RSTCTL0_COUNT (1)
108 /* @brief RSTCTL1 availability on the SoC. */
109 #define FSL_FEATURE_SOC_RSTCTL1_COUNT (1)
110 /* @brief RTC availability on the SoC. */
111 #define FSL_FEATURE_SOC_RTC_COUNT (1)
112 /* @brief SCT availability on the SoC. */
113 #define FSL_FEATURE_SOC_SCT_COUNT (1)
114 /* @brief SEMA42 availability on the SoC. */
115 #define FSL_FEATURE_SOC_SEMA42_COUNT (1)
116 /* @brief SMARTDMA availability on the SoC. */
117 #define FSL_FEATURE_SOC_SMARTDMA_COUNT (1)
118 /* @brief SPI availability on the SoC. */
119 #define FSL_FEATURE_SOC_SPI_COUNT (16)
120 /* @brief SYSCTL0 availability on the SoC. */
121 #define FSL_FEATURE_SOC_SYSCTL0_COUNT (1)
122 /* @brief SYSCTL1 availability on the SoC. */
123 #define FSL_FEATURE_SOC_SYSCTL1_COUNT (1)
124 /* @brief TRNG availability on the SoC. */
125 #define FSL_FEATURE_SOC_TRNG_COUNT (1)
126 /* @brief USART availability on the SoC. */
127 #define FSL_FEATURE_SOC_USART_COUNT (14)
128 /* @brief USBHSD availability on the SoC. */
129 #define FSL_FEATURE_SOC_USBHSD_COUNT (1)
130 /* @brief USBHSDCD availability on the SoC. */
131 #define FSL_FEATURE_SOC_USBHSDCD_COUNT (1)
132 /* @brief USBHSH availability on the SoC. */
133 #define FSL_FEATURE_SOC_USBHSH_COUNT (1)
134 /* @brief USBPHY availability on the SoC. */
135 #define FSL_FEATURE_SOC_USBPHY_COUNT (1)
136 /* @brief USDHC availability on the SoC. */
137 #define FSL_FEATURE_SOC_USDHC_COUNT (2)
138 /* @brief UTICK availability on the SoC. */
139 #define FSL_FEATURE_SOC_UTICK_COUNT (1)
140 /* @brief WWDT availability on the SoC. */
141 #define FSL_FEATURE_SOC_WWDT_COUNT (2)
142 
143 /* ACMP module features */
144 
145 /* @brief Has CMP_C3. */
146 #define FSL_FEATURE_ACMP_HAS_C3_REG (1)
147 /* @brief Has C0 LINKEN Bit */
148 #define FSL_FEATURE_ACMP_HAS_C0_LINKEN_BIT (1)
149 /* @brief Has C0 OFFSET Bit */
150 #define FSL_FEATURE_ACMP_HAS_C0_OFFSET_BIT (0)
151 /* @brief Has C0 HYSTCTR Bit */
152 #define FSL_FEATURE_ACMP_HAS_C0_HYSTCTR_BIT (1)
153 /* @brief Has C1 INPSEL Bit */
154 #define FSL_FEATURE_ACMP_HAS_C1_INPSEL_BIT (0)
155 /* @brief Has C1 INNSEL Bit */
156 #define FSL_FEATURE_ACMP_HAS_C1_INNSEL_BIT (0)
157 /* @brief Has C1 DACOE Bit */
158 #define FSL_FEATURE_ACMP_HAS_C1_DACOE_BIT (0)
159 /* @brief Has C1 DMODE Bit */
160 #define FSL_FEATURE_ACMP_HAS_C1_DMODE_BIT (1)
161 /* @brief Has C2 RRE Bit */
162 #define FSL_FEATURE_ACMP_HAS_C2_RRE_BIT (0)
163 
164 /* LPADC module features */
165 
166 /* @brief FIFO availability on the SoC. */
167 #define FSL_FEATURE_LPADC_FIFO_COUNT (2)
168 /* @brief Does not support two simultanious single ended conversions (bitfield TCTRL[FIFO_SEL_B]). */
169 #define FSL_FEATURE_LPADC_HAS_NO_TCTRL_FIFO_SEL_B (1)
170 /* @brief Has subsequent trigger priority (bitfield CFG[TPRICTRL]). */
171 #define FSL_FEATURE_LPADC_HAS_CFG_SUBSEQUENT_PRIORITY (1)
172 /* @brief Has differential mode (bitfield CMDLn[DIFF]). */
173 #define FSL_FEATURE_LPADC_HAS_CMDL_DIFF (1)
174 /* @brief Has channel scale (bitfield CMDLn[CSCALE]). */
175 #define FSL_FEATURE_LPADC_HAS_CMDL_CSCALE (1)
176 /* @brief Has conversion type select (bitfield CMDLn[CTYPE]). */
177 #define FSL_FEATURE_LPADC_HAS_CMDL_CTYPE (0)
178 /* @brief Has conversion resolution select  (bitfield CMDLn[MODE]). */
179 #define FSL_FEATURE_LPADC_HAS_CMDL_MODE (0)
180 /* @brief Has compare function enable (bitfield CMDHn[CMPEN]). */
181 #define FSL_FEATURE_LPADC_HAS_CMDH_CMPEN (1)
182 /* @brief Has Wait for trigger assertion before execution (bitfield CMDHn[WAIT_TRIG]). */
183 #define FSL_FEATURE_LPADC_HAS_CMDH_WAIT_TRIG (1)
184 /* @brief Has offset calibration (bitfield CTRL[CALOFS]). */
185 #define FSL_FEATURE_LPADC_HAS_CTRL_CALOFS (0)
186 /* @brief Has gain calibration (bitfield CTRL[CAL_REQ]). */
187 #define FSL_FEATURE_LPADC_HAS_CTRL_CAL_REQ (0)
188 /* @brief Has calibration average (bitfield CTRL[CAL_AVGS]). */
189 #define FSL_FEATURE_LPADC_HAS_CTRL_CAL_AVGS (0)
190 /* @brief Has internal clock (bitfield CFG[ADCKEN]). */
191 #define FSL_FEATURE_LPADC_HAS_CFG_ADCKEN (0)
192 /* @brief Enable support for low voltage reference on option 1 reference (bitfield CFG[VREF1RNG]). */
193 #define FSL_FEATURE_LPADC_HAS_CFG_VREF1RNG (0)
194 /* @brief Has calibration (bitfield CFG[CALOFS]). */
195 #define FSL_FEATURE_LPADC_HAS_CFG_CALOFS (0)
196 /* @brief Has offset trim (register OFSTRIM). */
197 #define FSL_FEATURE_LPADC_HAS_OFSTRIM (0)
198 /* @brief Has Trigger status register. */
199 #define FSL_FEATURE_LPADC_HAS_TSTAT (1)
200 /* @brief Has power select (bitfield CFG[PWRSEL]). */
201 #define FSL_FEATURE_LPADC_HAS_CFG_PWRSEL (1)
202 /* @brief Has alternate channel B scale (bitfield CMDLn[ALTB_CSCALE]). */
203 #define FSL_FEATURE_LPADC_HAS_CMDL_ALTB_CSCALE (0)
204 /* @brief Has alternate channel B select enable (bitfield CMDLn[ALTBEN]). */
205 #define FSL_FEATURE_LPADC_HAS_CMDL_ALTBEN (0)
206 /* @brief Has alternate channel input (bitfield CMDLn[ALTB_ADCH]). */
207 #define FSL_FEATURE_LPADC_HAS_CMDL_ALTB_ADCH (0)
208 /* @brief Has offset calibration mode (bitfield CTRL[CALOFSMODE]). */
209 #define FSL_FEATURE_LPADC_HAS_CTRL_CALOFSMODE (0)
210 /* @brief Conversion averaged bitfiled width. */
211 #define FSL_FEATURE_LPADC_CONVERSIONS_AVERAGED_BITFIELD_WIDTH (3)
212 /* @brief Has B side channels. */
213 #define FSL_FEATURE_LPADC_HAS_B_SIDE_CHANNELS (1)
214 /* @brief Indicate whether the LPADC STAT register has trigger exception interrupt function (bitfield STAT[TEXC_INT]). */
215 #define FSL_FEATURE_LPADC_HAS_STAT_TEXC_INT (1)
216 /* @brief Indicate whether the LPADC STAT register has trigger completion interrupt function (bitfield STAT[TCOMP_INT]). */
217 #define FSL_FEATURE_LPADC_HAS_STAT_TCOMP_INT (1)
218 /* @brief Indicate whether the LPADC STAT register has calibration ready function (bitfield STAT[CAL_RDY]). */
219 #define FSL_FEATURE_LPADC_HAS_STAT_CAL_RDY (0)
220 /* @brief Indicate whether the LPADC STAT register has ADC active function (bitfield STAT[ADC_ACTIVE]). */
221 #define FSL_FEATURE_LPADC_HAS_STAT_ADC_ACTIVE (1)
222 /* @brief Indicate whether the LPADC IE register has trigger exception interrupt enable function (bitfield IE[TEXC_IE]). */
223 #define FSL_FEATURE_LPADC_HAS_IE_TEXC_IE (1)
224 /* @brief Indicate whether the LPADC IE register has trigger completion interrupt enable function (bitfield IE[TCOMP_IE]). */
225 #define FSL_FEATURE_LPADC_HAS_IE_TCOMP_IE (1)
226 /* @brief Indicate whether the LPADC CFG register has trigger resume/restart enable function (bitfield CFG[TRES]). */
227 #define FSL_FEATURE_LPADC_HAS_CFG_TRES (1)
228 /* @brief Indicate whether the LPADC CFG register has trigger command resume/restart enable function (bitfield CFG[TCMDRES]). */
229 #define FSL_FEATURE_LPADC_HAS_CFG_TCMDRES (1)
230 /* @brief Indicate whether the LPADC CFG register has high priority trigger exception disable function (bitfield CFG[HPT_EXDI]). */
231 #define FSL_FEATURE_LPADC_HAS_CFG_HPT_EXDI (1)
232 /* @brief Indicate LPADC CFG register TPRICTRL bitfield width. */
233 #define FSL_FEATURE_LPADC_CFG_TPRICTRL_BITFIELD_WIDTH (2)
234 
235 /* CACHE64_CTRL module features */
236 
237 /* @brief Cache Line size in byte. */
238 #define FSL_FEATURE_CACHE64_CTRL_LINESIZE_BYTE (32)
239 
240 /* CACHE64_POLSEL module features */
241 
242 /* No feature definitions */
243 
244 /* CASPER module features */
245 
246 /* @brief Base address of the CASPER dedicated RAM. */
247 #define FSL_FEATURE_CASPER_RAM_BASE_ADDRESS (0x40202000u)
248 
249 /* CRC module features */
250 
251 /* @brief Has data register with name CRC */
252 #define FSL_FEATURE_CRC_HAS_CRC_REG (0)
253 
254 /* CTIMER module features */
255 
256 /* @brief CTIMER has no capture channel. */
257 #define FSL_FEATURE_CTIMER_HAS_NO_INPUT_CAPTURE (0)
258 /* @brief CTIMER has no capture 2 interrupt. */
259 #define FSL_FEATURE_CTIMER_HAS_NO_IR_CR2INT (0)
260 /* @brief CTIMER capture 3 interrupt. */
261 #define FSL_FEATURE_CTIMER_HAS_IR_CR3INT (1)
262 /* @brief Has CTIMER CCR_CAP2 (register bits CCR[CAP2RE][CAP2FE][CAP2I]. */
263 #define FSL_FEATURE_CTIMER_HAS_NO_CCR_CAP2 (0)
264 /* @brief Has CTIMER CCR_CAP3 (register bits CCR[CAP3RE][CAP3FE][CAP3I]). */
265 #define FSL_FEATURE_CTIMER_HAS_CCR_CAP3 (1)
266 /* @brief CTIMER Has register MSR */
267 #define FSL_FEATURE_CTIMER_HAS_MSR (1)
268 
269 /* DMA module features */
270 
271 /* @brief Number of channels */
272 #define FSL_FEATURE_DMA_NUMBER_OF_CHANNELSn(x) (37)
273 /* @brief Number of all DMA channels */
274 #define FSL_FEATURE_DMA_ALL_CHANNELS (74)
275 /* @brief Max Number of DMA channels */
276 #define FSL_FEATURE_DMA_MAX_CHANNELS (37)
277 /* @brief Align size of DMA descriptor */
278 #define FSL_FEATURE_DMA_DESCRIPTOR_ALIGN_SIZE (1024)
279 /* @brief DMA head link descriptor table align size */
280 #define FSL_FEATURE_DMA_LINK_DESCRIPTOR_ALIGN_SIZE (16U)
281 
282 /* DMIC module features */
283 
284 /* @brief Number of channels */
285 #define FSL_FEATURE_DMIC_CHANNEL_NUM (8)
286 /* @brief DMIC channel support stereo data */
287 #define FSL_FEATURE_DMIC_IO_HAS_STEREO_2_4_6 (1)
288 /* @brief DMIC does not support bypass channel clock */
289 #define FSL_FEATURE_DMIC_IO_HAS_NO_BYPASS (1)
290 /* @brief DMIC channel FIFO register support sign extended */
291 #define FSL_FEATURE_DMIC_CHANNEL_HAS_SIGNEXTEND (1)
292 /* @brief DMIC has no IOCFG register */
293 #define FSL_FEATURE_DMIC_HAS_NO_IOCFG (1)
294 /* @brief DMIC has decimator reset function */
295 #define FSL_FEATURE_DMIC_HAS_DECIMATOR_RESET_FUNC (1)
296 /* @brief DMIC has global channel synchronization function */
297 #define FSL_FEATURE_DMIC_HAS_GLOBAL_SYNC_FUNC (1)
298 
299 /* FLEXCOMM module features */
300 
301 /* @brief FLEXCOMM0 USART INDEX 0 */
302 #define FSL_FEATURE_FLEXCOMM0_USART_INDEX (0)
303 /* @brief FLEXCOMM1 USART INDEX 1 */
304 #define FSL_FEATURE_FLEXCOMM1_USART_INDEX (1)
305 /* @brief FLEXCOMM2 USART INDEX 2 */
306 #define FSL_FEATURE_FLEXCOMM2_USART_INDEX (2)
307 /* @brief FLEXCOMM3 USART INDEX 3 */
308 #define FSL_FEATURE_FLEXCOMM3_USART_INDEX (3)
309 /* @brief FLEXCOMM4 USART INDEX 4 */
310 #define FSL_FEATURE_FLEXCOMM4_USART_INDEX (4)
311 /* @brief FLEXCOMM5 USART INDEX 5 */
312 #define FSL_FEATURE_FLEXCOMM5_USART_INDEX (5)
313 /* @brief FLEXCOMM6 USART INDEX 6 */
314 #define FSL_FEATURE_FLEXCOMM6_USART_INDEX (6)
315 /* @brief FLEXCOMM7 USART INDEX 7 */
316 #define FSL_FEATURE_FLEXCOMM7_USART_INDEX (7)
317 /* @brief FLEXCOMM14 SPI(HS_SPI) INDEX 14 */
318 #define FSL_FEATURE_FLEXCOMM14_SPI_INDEX (14)
319 /* @brief FLEXCOMM15 I2C INDEX 15 */
320 #define FSL_FEATURE_FLEXCOMM15_I2C_INDEX (15)
321 /* @brief FLEXCOMM16 SPI(HS_SPI) INDEX 16 */
322 #define FSL_FEATURE_FLEXCOMM16_SPI_INDEX (16)
323 /* @brief FLEXCOMM8 USART INDEX 8 */
324 #define FSL_FEATURE_FLEXCOMM8_USART_INDEX (8)
325 /* @brief FLEXCOMM9 USART INDEX 9 */
326 #define FSL_FEATURE_FLEXCOMM9_USART_INDEX (9)
327 /* @brief FLEXCOMM10 USART INDEX 10 */
328 #define FSL_FEATURE_FLEXCOMM10_USART_INDEX (10)
329 /* @brief FLEXCOMM11 USART INDEX 11 */
330 #define FSL_FEATURE_FLEXCOMM11_USART_INDEX (11)
331 /* @brief FLEXCOMM12 USART INDEX 12 */
332 #define FSL_FEATURE_FLEXCOMM12_USART_INDEX (12)
333 /* @brief FLEXCOMM13 USART INDEX 13 */
334 #define FSL_FEATURE_FLEXCOMM13_USART_INDEX (13)
335 /* @brief FLEXCOMM0 SPI INDEX 0 */
336 #define FSL_FEATURE_FLEXCOMM0_SPI_INDEX (0)
337 /* @brief FLEXCOMM1 SPI INDEX 1 */
338 #define FSL_FEATURE_FLEXCOMM1_SPI_INDEX (1)
339 /* @brief FLEXCOMM2 SPI INDEX 2 */
340 #define FSL_FEATURE_FLEXCOMM2_SPI_INDEX (2)
341 /* @brief FLEXCOMM3 SPI INDEX 3 */
342 #define FSL_FEATURE_FLEXCOMM3_SPI_INDEX (3)
343 /* @brief FLEXCOMM4 SPI INDEX 4 */
344 #define FSL_FEATURE_FLEXCOMM4_SPI_INDEX (4)
345 /* @brief FLEXCOMM5 SPI INDEX 5 */
346 #define FSL_FEATURE_FLEXCOMM5_SPI_INDEX (5)
347 /* @brief FLEXCOMM6 SPI INDEX 6 */
348 #define FSL_FEATURE_FLEXCOMM6_SPI_INDEX (6)
349 /* @brief FLEXCOMM7 SPI INDEX 7 */
350 #define FSL_FEATURE_FLEXCOMM7_SPI_INDEX (7)
351 /* @brief I2S has DMIC interconnection */
352 #define FSL_FEATURE_FLEXCOMM_INSTANCE_I2S_HAS_DMIC_INTERCONNECTIONn(x) \
353     (((x) == FLEXCOMM14) ? (0) : \
354     (((x) == FLEXCOMM15) ? (0) : \
355     (((x) == FLEXCOMM16) ? (0) : \
356     (((x) == FLEXCOMM0) ? (1) : \
357     (((x) == FLEXCOMM1) ? (0) : \
358     (((x) == FLEXCOMM2) ? (0) : \
359     (((x) == FLEXCOMM3) ? (0) : \
360     (((x) == FLEXCOMM4) ? (0) : \
361     (((x) == FLEXCOMM5) ? (0) : \
362     (((x) == FLEXCOMM6) ? (0) : \
363     (((x) == FLEXCOMM7) ? (0) : \
364     (((x) == FLEXCOMM8) ? (0) : \
365     (((x) == FLEXCOMM9) ? (0) : \
366     (((x) == FLEXCOMM10) ? (0) : \
367     (((x) == FLEXCOMM11) ? (0) : \
368     (((x) == FLEXCOMM12) ? (0) : \
369     (((x) == FLEXCOMM13) ? (0) : (-1))))))))))))))))))
370 /* @brief FLEXCOMM8 SPI INDEX 8 */
371 #define FSL_FEATURE_FLEXCOMM8_SPI_INDEX (8)
372 /* @brief FLEXCOMM9 SPI INDEX 9 */
373 #define FSL_FEATURE_FLEXCOMM9_SPI_INDEX (9)
374 /* @brief FLEXCOMM10 SPI INDEX 10 */
375 #define FSL_FEATURE_FLEXCOMM10_SPI_INDEX (10)
376 /* @brief FLEXCOMM11 SPI INDEX 11 */
377 #define FSL_FEATURE_FLEXCOMM11_SPI_INDEX (11)
378 /* @brief FLEXCOMM12 SPI INDEX 12 */
379 #define FSL_FEATURE_FLEXCOMM12_SPI_INDEX (12)
380 /* @brief FLEXCOMM13 SPI INDEX 13 */
381 #define FSL_FEATURE_FLEXCOMM13_SPI_INDEX (13)
382 /* @brief FLEXCOMM0 I2C INDEX 0 */
383 #define FSL_FEATURE_FLEXCOMM0_I2C_INDEX (0)
384 /* @brief FLEXCOMM1 I2C INDEX 1 */
385 #define FSL_FEATURE_FLEXCOMM1_I2C_INDEX (1)
386 /* @brief FLEXCOMM2 I2C INDEX 2 */
387 #define FSL_FEATURE_FLEXCOMM2_I2C_INDEX (2)
388 /* @brief FLEXCOMM3 I2C INDEX 3 */
389 #define FSL_FEATURE_FLEXCOMM3_I2C_INDEX (3)
390 /* @brief FLEXCOMM4 I2C INDEX 4 */
391 #define FSL_FEATURE_FLEXCOMM4_I2C_INDEX (4)
392 /* @brief FLEXCOMM5 I2C INDEX 5 */
393 #define FSL_FEATURE_FLEXCOMM5_I2C_INDEX (5)
394 /* @brief FLEXCOMM6 I2C INDEX 6 */
395 #define FSL_FEATURE_FLEXCOMM6_I2C_INDEX (6)
396 /* @brief FLEXCOMM7 I2C INDEX 7 */
397 #define FSL_FEATURE_FLEXCOMM7_I2C_INDEX (7)
398 /* @brief FLEXCOMM8 I2C INDEX 8 */
399 #define FSL_FEATURE_FLEXCOMM8_I2C_INDEX (8)
400 /* @brief FLEXCOMM9 I2C INDEX 9 */
401 #define FSL_FEATURE_FLEXCOMM9_I2C_INDEX (9)
402 /* @brief FLEXCOMM10 I2C INDEX 10 */
403 #define FSL_FEATURE_FLEXCOMM10_I2C_INDEX (10)
404 /* @brief FLEXCOMM11 I2C INDEX 11 */
405 #define FSL_FEATURE_FLEXCOMM11_I2C_INDEX (11)
406 /* @brief FLEXCOMM12 I2C INDEX 12 */
407 #define FSL_FEATURE_FLEXCOMM12_I2C_INDEX (12)
408 /* @brief FLEXCOMM13 I2C INDEX 13 */
409 #define FSL_FEATURE_FLEXCOMM13_I2C_INDEX (13)
410 /* @brief FLEXCOMM0 I2S INDEX 0 */
411 #define FSL_FEATURE_FLEXCOMM0_I2S_INDEX (0)
412 /* @brief FLEXCOMM1 I2S INDEX 1 */
413 #define FSL_FEATURE_FLEXCOMM1_I2S_INDEX (1)
414 /* @brief FLEXCOMM2 I2S INDEX 2 */
415 #define FSL_FEATURE_FLEXCOMM2_I2S_INDEX (2)
416 /* @brief FLEXCOMM3 I2S INDEX 3 */
417 #define FSL_FEATURE_FLEXCOMM3_I2S_INDEX (3)
418 /* @brief FLEXCOMM4 I2S INDEX 4 */
419 #define FSL_FEATURE_FLEXCOMM4_I2S_INDEX (4)
420 /* @brief FLEXCOMM5 I2S INDEX 5 */
421 #define FSL_FEATURE_FLEXCOMM5_I2S_INDEX (5)
422 /* @brief FLEXCOMM6 I2S INDEX 6 */
423 #define FSL_FEATURE_FLEXCOMM6_I2S_INDEX (6)
424 /* @brief FLEXCOMM7 I2S INDEX 7 */
425 #define FSL_FEATURE_FLEXCOMM7_I2S_INDEX (7)
426 /* @brief FLEXCOMM8 I2S INDEX 8 */
427 #define FSL_FEATURE_FLEXCOMM8_I2S_INDEX (8)
428 /* @brief FLEXCOMM9 I2S INDEX 9 */
429 #define FSL_FEATURE_FLEXCOMM9_I2S_INDEX (9)
430 /* @brief FLEXCOMM10 I2S INDEX 10 */
431 #define FSL_FEATURE_FLEXCOMM10_I2S_INDEX (10)
432 /* @brief FLEXCOMM11 I2S INDEX 11 */
433 #define FSL_FEATURE_FLEXCOMM11_I2S_INDEX (11)
434 /* @brief FLEXCOMM12 I2S INDEX 12 */
435 #define FSL_FEATURE_FLEXCOMM12_I2S_INDEX (12)
436 /* @brief FLEXCOMM13 I2S INDEX 13 */
437 #define FSL_FEATURE_FLEXCOMM13_I2S_INDEX (13)
438 
439 /* FLEXIO module features */
440 
441 /* @brief FLEXIO support reset from RSTCTL */
442 #define FSL_FEATURE_FLEXIO_HAS_RESET (1)
443 /* @brief Has Shifter Status Register (FLEXIO_SHIFTSTAT) */
444 #define FSL_FEATURE_FLEXIO_HAS_SHIFTER_STATUS (1)
445 /* @brief Has Pin Data Input Register (FLEXIO_PIN) */
446 #define FSL_FEATURE_FLEXIO_HAS_PIN_STATUS (1)
447 /* @brief Has pin input output related registers */
448 #define FSL_FEATURE_FLEXIO_HAS_PIN_REGISTER (1)
449 /* @brief Has Shifter Buffer N Nibble Byte Swapped Register (FLEXIO_SHIFTBUFNBSn) */
450 #define FSL_FEATURE_FLEXIO_HAS_SHFT_BUFFER_NIBBLE_BYTE_SWAP (1)
451 /* @brief Has Shifter Buffer N Half Word Swapped Register (FLEXIO_SHIFTBUFHWSn) */
452 #define FSL_FEATURE_FLEXIO_HAS_SHFT_BUFFER_HALF_WORD_SWAP (1)
453 /* @brief Has Shifter Buffer N Nibble Swapped Register (FLEXIO_SHIFTBUFNISn) */
454 #define FSL_FEATURE_FLEXIO_HAS_SHFT_BUFFER_NIBBLE_SWAP (1)
455 /* @brief Supports Shifter State Mode (FLEXIO_SHIFTCTLn[SMOD]) */
456 #define FSL_FEATURE_FLEXIO_HAS_STATE_MODE (1)
457 /* @brief Supports Shifter Logic Mode (FLEXIO_SHIFTCTLn[SMOD]) */
458 #define FSL_FEATURE_FLEXIO_HAS_LOGIC_MODE (1)
459 /* @brief Supports paralle width (FLEXIO_SHIFTCFGn[PWIDTH]) */
460 #define FSL_FEATURE_FLEXIO_HAS_PARALLEL_WIDTH (1)
461 /* @brief Reset value of the FLEXIO_VERID register */
462 #define FSL_FEATURE_FLEXIO_VERID_RESET_VALUE (0x2010003)
463 /* @brief Reset value of the FLEXIO_PARAM register */
464 #define FSL_FEATURE_FLEXIO_PARAM_RESET_VALUE (0x10100808)
465 /* @brief Represent the bit width of the TIMDCE field (FLEXIO_TIMCFGLn[TIMDEC]) */
466 #define FSL_FEATURE_FLEXIO_TIMCFG_TIMDCE_FIELD_WIDTH (3)
467 
468 /* FLEXSPI module features */
469 
470 /* @brief FlexSPI AHB buffer count */
471 #define FSL_FEATURE_FLEXSPI_AHB_BUFFER_COUNTn(x) (8)
472 /* @brief FlexSPI0 and FlexSPI1 have shared IRQ */
473 #define FSL_FEATURE_FLEXSPI_HAS_SHARED_IRQ0_IRQ1 (1)
474 /* @brief FlexSPI has no MCR0 ARDFEN bit */
475 #define FSL_FEATURE_FLEXSPI_HAS_NO_MCR0_ARDFEN (1)
476 /* @brief FlexSPI has no MCR0 ATDFEN bit */
477 #define FSL_FEATURE_FLEXSPI_HAS_NO_MCR0_ATDFEN (1)
478 /* @brief FlexSPI DMA needs multiple DES to transfer */
479 #define FSL_FEATURE_FLEXSPI_DMA_MULTIPLE_DES (1)
480 /* @brief FlexSPI uses min DQS delay */
481 #define FSL_FEATURE_FLEXSPI_DQS_DELAY_MIN (1)
482 /* @brief FlexSPI has no MCR0 COMBINATIONEN bit */
483 #define FSL_FEATURE_FLEXSPI_HAS_NO_MCR0_COMBINATIONEN (1)
484 /* @brief FLEXSPI has no IP parallel mode. */
485 #define FSL_FEATURE_FLEXSPI_HAS_NO_IP_PARALLEL_MODE (0)
486 /* @brief FLEXSPI has no AHB parallel mode. */
487 #define FSL_FEATURE_FLEXSPI_HAS_NO_AHB_PARALLEL_MODE (0)
488 /* @brief FLEXSPI support address shift. */
489 #define FSL_FEATURE_FLEXSPI_SUPPORT_ADDRESS_SHIFT (0)
490 /* @brief FlexSPI has no FLSHCR4 WMENB bit */
491 #define FSL_FEATURE_FLEXSPI_HAS_NO_FLSHCR4_WMENB (1)
492 /* @brief FlexSPI has no STS0 DATALEARNPHASEB bit */
493 #define FSL_FEATURE_FLEXSPI_HAS_NO_STS0_DATALEARNPHASEB (1)
494 /* @brief FlexSPI has no MCR2 SCKBDIFFOPT bit */
495 #define FSL_FEATURE_FLEXSPI_HAS_NO_MCR2_SCKBDIFFOPT (1)
496 /* @brief Has Errata 051426 */
497 #define FSL_FEATURE_FLEXSPI_HAS_ERRATA_051426 (1)
498 /* @brief FlexSPI AHB RX buffer size (byte) */
499 #define FSL_FEATURE_FLEXSPI_AHB_RX_BUFFER_SIZEn(x) \
500     (((x) == FLEXSPI0) ? (1024) : \
501     (((x) == FLEXSPI1) ? (2048) : (-1)))
502 
503 /* GPIO module features */
504 
505 /* @brief GPIO has interrupts */
506 #define FSL_FEATURE_GPIO_HAS_INTERRUPT (1)
507 /* @brief GPIO DIRSET and DIRCLR register. */
508 #define FSL_FEATURE_GPIO_DIRSET_AND_DIRCLR (1)
509 
510 /* HASHCRYPT module features */
511 
512 /* @brief hashcrypt has reload feature */
513 #define FSL_FEATURE_HASHCRYPT_HAS_RELOAD_FEATURE (1)
514 
515 /* I2S module features */
516 
517 /* @brief I2S support dual channel transfer. */
518 #define FSL_FEATURE_I2S_SUPPORT_SECONDARY_CHANNEL (1)
519 /* @brief I2S has DMIC interconnection. */
520 #define FSL_FEATURE_FLEXCOMM_I2S_HAS_DMIC_INTERCONNECTION (1)
521 
522 /* I3C module features */
523 
524 /* @brief Has TERM bitfile in MERRWARN register. */
525 #define FSL_FEATURE_I3C_HAS_NO_MERRWARN_TERM (0)
526 /* @brief SOC has no reset driver. */
527 #define FSL_FEATURE_I3C_HAS_NO_RESET (0)
528 /* @brief Use fixed BAMATCH count, do not provide editable BAMATCH. */
529 #define FSL_FEATURE_I3C_HAS_NO_SCONFIG_BAMATCH (0)
530 /* @brief Register SCONFIG do not have IDRAND bitfield. */
531 #define FSL_FEATURE_I3C_HAS_NO_SCONFIG_IDRAND (0)
532 /* @brief Register SCONFIG has HDROK bitfield. */
533 #define FSL_FEATURE_I3C_HAS_HDROK (0)
534 /* @brief SOC doesn't support slave IBI/MR/HJ. */
535 #define FSL_FEATURE_I3C_HAS_NO_SLAVE_IBI_MR_HJ (0)
536 /* @brief Has ERRATA_051617. */
537 #define FSL_FEATURE_I3C_HAS_ERRATA_051617 (1)
538 /* @brief Has ERRATA_052123. */
539 #define FSL_FEATURE_I3C_HAS_ERRATA_052123 (1)
540 /* @brief Has no the master write data register for DMA. */
541 #define FSL_FEATURE_I3C_HAS_NO_MASTER_DMA_WDATA_REG (0)
542 
543 /* INPUTMUX module features */
544 
545 /* @brief Inputmux has DMA Request Enable */
546 #define FSL_FEATURE_INPUTMUX_HAS_SIGNAL_ENA (1)
547 /* @brief Inputmux has channel mux control */
548 #define FSL_FEATURE_INPUTMUX_HAS_CHANNEL_MUX (1)
549 
550 /* LCDIF module features */
551 
552 /* @brief Support D/CX Pin polarity. */
553 #define FSL_FEATURE_LCDIF_HAS_DBIX_POLARITY (1)
554 /* @brief Has DBI Type C Option. */
555 #define FSL_FEATURE_LCDIF_HAS_TYPEC (0)
556 
557 /* MIPI_DSI_HOST module features */
558 
559 /* @brief Does not have DPHY PLL */
560 #define FSL_FEATURE_MIPI_DSI_HOST_NO_DPHY_PLL (1)
561 /* @brief Support TX ULPS */
562 #define FSL_FEATURE_MIPI_DSI_HOST_HAS_ULPS (0)
563 /* @brief Has control register to enable or disable TX ULPS */
564 #define FSL_FEATURE_MIPI_DSI_HOST_HAS_ULPS_CTRL (0)
565 /* @brief Has pixel-link to DPI remap */
566 #define FSL_FEATURE_MIPI_DSI_HOST_HAS_PXL2DPI (0)
567 
568 /* MRT module features */
569 
570 /* @brief number of channels. */
571 #define FSL_FEATURE_MRT_NUMBER_OF_CHANNELS (4)
572 
573 /* MU module features */
574 
575 /* @brief MU side for current core */
576 #define FSL_FEATURE_MU_SIDE_A (1)
577 /* @brief MU Has register CCR */
578 #define FSL_FEATURE_MU_HAS_CCR (0)
579 /* @brief MU Has register SR[RS], BSR[ARS] */
580 #define FSL_FEATURE_MU_HAS_SR_RS (1)
581 /* @brief MU Has register CR[RDIE], CR[RAIE], SR[RDIP], SR[RAIP] */
582 #define FSL_FEATURE_MU_HAS_RESET_INT (1)
583 /* @brief MU Has register SR[MURIP] */
584 #define FSL_FEATURE_MU_HAS_SR_MURIP (0)
585 /* @brief brief MU Has register SR[HRIP] */
586 #define FSL_FEATURE_MU_HAS_SR_HRIP (0)
587 /* @brief brief MU does not support enable clock of the other core, CR[CLKE] or CCR[CLKE]. */
588 #define FSL_FEATURE_MU_NO_CLKE (1)
589 /* @brief brief MU does not support NMI, CR[NMI]. */
590 #define FSL_FEATURE_MU_NO_NMI (1)
591 /* @brief brief MU does not support hold the other core reset. CR[RSTH] or CCR[RSTH]. */
592 #define FSL_FEATURE_MU_NO_RSTH (1)
593 /* @brief brief MU does not supports MU reset, CR[MUR]. */
594 #define FSL_FEATURE_MU_NO_MUR (0)
595 /* @brief brief MU does not supports hardware reset, CR[HR] or CCR[HR]. */
596 #define FSL_FEATURE_MU_NO_HR (1)
597 /* @brief brief MU supports mask the hardware reset. CR[HRM] or CCR[HRM]. */
598 #define FSL_FEATURE_MU_HAS_HRM (0)
599 
600 /* OTFAD module features */
601 
602 /* @brief OTFAD has Security Violation Mode (SVM) */
603 #define FSL_FEATURE_OTFAD_HAS_SVM_MODE (0)
604 /* @brief OTFAD has Key Blob Processing */
605 #define FSL_FEATURE_OTFAD_HAS_KEYBLOB_PROCESSING (0)
606 /* @brief OTFAD has interrupt request enable */
607 #define FSL_FEATURE_OTFAD_HAS_HAS_IRQ_ENABLE (0)
608 /* @brief OTFAD has Force Error */
609 #define FSL_FEATURE_OTFAD_HAS_FORCE_ERR (0)
610 
611 /* PINT module features */
612 
613 /* @brief Number of connected outputs */
614 #define FSL_FEATURE_PINT_NUMBER_OF_CONNECTED_OUTPUTS (8)
615 
616 /* PMC module features */
617 
618 /* @brief Has no OS Timer control register in PMC. */
619 #define FSL_FEATURE_PMC_HAS_NO_OSTIMER_REG (1)
620 
621 /* PUF module features */
622 
623 /* @brief PUF need to setup SRAM manually */
624 #define FSL_FEATURE_PUF_PWR_HAS_MANUAL_SLEEP_CONTROL (1)
625 /* @brief PUF has SHIFT_STATUS register. */
626 #define FSL_FEATURE_PUF_HAS_SHIFT_STATUS (0)
627 /* @brief PUF has IDXBLK_SHIFT register. */
628 #define FSL_FEATURE_PUF_HAS_IDXBLK_SHIFT (0)
629 
630 /* RTC module features */
631 
632 /* @brief RTC has no reset control */
633 #define FSL_FEATURE_RTC_HAS_NO_RESET (1)
634 /* @brief Has SUBSEC Register (register SUBSEC) */
635 #define FSL_FEATURE_RTC_HAS_SUBSEC (1)
636 
637 /* SCT module features */
638 
639 /* @brief Number of events */
640 #define FSL_FEATURE_SCT_NUMBER_OF_EVENTS (16)
641 /* @brief Number of states */
642 #define FSL_FEATURE_SCT_NUMBER_OF_STATES (32)
643 /* @brief Number of match capture */
644 #define FSL_FEATURE_SCT_NUMBER_OF_MATCH_CAPTURE (16)
645 /* @brief Number of outputs */
646 #define FSL_FEATURE_SCT_NUMBER_OF_OUTPUTS (10)
647 
648 /* SECGPIO module features */
649 
650 /* @brief GPIO has interrupts */
651 #define FSL_FEATURE_SECGPIO_HAS_INTERRUPT (1)
652 /* @brief GPIO DIRSET and DIRCLR register. */
653 #define FSL_FEATURE_SECGPIO_DIRSET_AND_DIRCLR (1)
654 
655 /* SEMA42 module features */
656 
657 /* @brief Gate counts */
658 #define FSL_FEATURE_SEMA42_GATE_COUNT (16)
659 
660 /* SPI module features */
661 
662 /* @brief SSEL pin count. */
663 #define FSL_FEATURE_SPI_SSEL_COUNT (4)
664 
665 /* TRNG module features */
666 
667 /* @brief Need configure default frequency minimum value */
668 #define FSL_FEATURE_TRNG_FORCE_USER_CONFIG_DEFAULT_FREQUENCY_MINIMUM (1)
669 /* @brief The user configured frequency minimum value */
670 #define FSL_FEATURE_TRNG_USER_CONFIG_DEFAULT_FREQUENCY_MINIMUM_VALUE (0)
671 
672 /* USBHSD module features */
673 
674 /* @brief Size of the USB dedicated RAM */
675 #define FSL_FEATURE_USBHSD_USB_RAM (0x00004000)
676 /* @brief Base address of the USB dedicated RAM */
677 #define FSL_FEATURE_USBHSD_USB_RAM_BASE_ADDRESS (0x40140000)
678 /* @brief USBHSD version */
679 #define FSL_FEATURE_USBHSD_VERSION (300)
680 /* @brief Number of the endpoint in USB HS */
681 #define FSL_FEATURE_USBHSD_EP_NUM (6)
682 /* @brief The controller doesn't exit HS mode automatically after vbus becomes invalid */
683 #define FSL_FEATURE_USBHSD_HAS_EXIT_HS_ISSUE (1)
684 
685 /* USBHSH module features */
686 
687 /* @brief Size of the USB dedicated RAM */
688 #define FSL_FEATURE_USBHSH_USB_RAM (0x00004000)
689 /* @brief Base address of the USB dedicated RAM */
690 #define FSL_FEATURE_USBHSH_USB_RAM_BASE_ADDRESS (0x40140000)
691 /* @brief USBHSH version */
692 #define FSL_FEATURE_USBHSH_VERSION (300)
693 /* @brief USBHSH has packet turnaround time-out register */
694 #define FSL_FEATURE_USBHSH_HAS_TURNAROUND_TIMEOUT (0)
695 
696 /* USBPHY module features */
697 
698 /* @brief USBPHY contain DCD analog module */
699 #define FSL_FEATURE_USBPHY_HAS_DCD_ANALOG (1)
700 /* @brief USBPHY has register TRIM_OVERRIDE_EN */
701 #define FSL_FEATURE_USBPHY_HAS_TRIM_OVERRIDE_EN (1)
702 /* @brief USBPHY is 28FDSOI */
703 #define FSL_FEATURE_USBPHY_28FDSOI (0)
704 
705 /* USDHC module features */
706 
707 /* @brief Has external DMA support (VEND_SPEC[EXT_DMA_EN]) */
708 #define FSL_FEATURE_USDHC_HAS_EXT_DMA (0)
709 /* @brief Has HS400 mode (MIX_CTRL[HS400_MODE]) */
710 #define FSL_FEATURE_USDHC_HAS_HS400_MODE (1)
711 /* @brief Has SDR50 support (HOST_CTRL_CAP[SDR50_SUPPORT]) */
712 #define FSL_FEATURE_USDHC_HAS_SDR50_MODE (1)
713 /* @brief Has SDR104 support (HOST_CTRL_CAP[SDR104_SUPPORT]) */
714 #define FSL_FEATURE_USDHC_HAS_SDR104_MODE (1)
715 /* @brief USDHC has reset control */
716 #define FSL_FEATURE_USDHC_HAS_RESET (1)
717 /* @brief USDHC has no bitfield WTMK_LVL[WR_BRST_LEN] and WTMK_LVL[RD_BRST_LEN] */
718 #define FSL_FEATURE_USDHC_HAS_NO_RW_BURST_LEN (0)
719 /* @brief If USDHC instance support 8 bit width */
720 #define FSL_FEATURE_USDHC_INSTANCE_SUPPORT_8_BIT_WIDTHn(x) (1)
721 /* @brief If USDHC instance support HS400 mode */
722 #define FSL_FEATURE_USDHC_INSTANCE_SUPPORT_HS400_MODEn(x) \
723     (((x) == USDHC0) ? (1) : \
724     (((x) == USDHC1) ? (0) : (-1)))
725 /* @brief If USDHC instance support 1v8 signal */
726 #define FSL_FEATURE_USDHC_INSTANCE_SUPPORT_1V8_SIGNALn(x) (1)
727 /* @brief Has no retuning time counter (HOST_CTRL_CAP[TIME_COUNT_RETURNING]) */
728 #define FSL_FEATURE_USDHC_REGISTER_HOST_CTRL_CAP_HAS_NO_RETUNING_TIME_COUNTER (0)
729 /* @brief Has no VSELECT bit in VEND_SPEC register */
730 #define FSL_FEATURE_USDHC_HAS_NO_VOLTAGE_SELECT (0)
731 /* @brief Has no VS18 bit in HOST_CTRL_CAP register */
732 #define FSL_FEATURE_USDHC_HAS_NO_VS18 (0)
733 
734 /* UTICK module features */
735 
736 /* @brief UTICK does not support power down configure. */
737 #define FSL_FEATURE_UTICK_HAS_NO_PDCFG (1)
738 
739 /* WWDT module features */
740 
741 /* @brief WWDT does not support oscillator lock. */
742 #define FSL_FEATURE_WWDT_HAS_NO_OSCILLATOR_LOCK (0)
743 /* @brief WWDT does not support power down configure. */
744 #define FSL_FEATURE_WWDT_HAS_NO_PDCFG (1)
745 
746 #endif /* _MIMXRT555S_FEATURES_H_ */
747 
748