1 /*
2 * Copyright (c) 2020 - 2024 Renesas Electronics Corporation and/or its affiliates
3 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 */
6 
7 #ifndef BSP_FEATURE_H
8 #define BSP_FEATURE_H
9 
10 /***********************************************************************************************************************
11  * Includes   <System Includes> , "Project Includes"
12  **********************************************************************************************************************/
13 #include "bsp_feature_gen.h"
14 
15 /***********************************************************************************************************************
16  * Macro definitions
17  **********************************************************************************************************************/
18 
19 /** The main oscillator drive value is based upon the oscillator frequency selected in the configuration */
20 #if (BSP_CFG_XTAL_HZ > (9999999))
21  #define CGC_MAINCLOCK_DRIVE    (0x00U)
22 #else
23  #define CGC_MAINCLOCK_DRIVE    (0x01U)
24 #endif
25 
26 /***********************************************************************************************************************
27  * Typedef definitions
28  **********************************************************************************************************************/
29 
30 /***********************************************************************************************************************
31  * Exported global variables (to be accessed by other files)
32  **********************************************************************************************************************/
33 
34 /***********************************************************************************************************************
35  * Private global variables and functions
36  **********************************************************************************************************************/
37 
38 #define BSP_FEATURE_ACMPHS_MIN_WAIT_TIME_US                  (0) // Feature not available on this MCU
39 #define BSP_FEATURE_ACMPHS_VREF                              (0) // Feature not available on this MCU
40 
41 #define BSP_FEATURE_ACMPLP_HAS_COMPSEL_REGISTERS             (0)
42 #define BSP_FEATURE_ACMPLP_MIN_WAIT_TIME_US                  (100U)
43 
44 #define BSP_FEATURE_ADC_ADDITION_SUPPORTED                   (1U)
45 #define BSP_FEATURE_ADC_B_TSN_CALIBRATION32_MASK             (0U)
46 #define BSP_FEATURE_ADC_B_TSN_SLOPE                          (0U)
47 #define BSP_FEATURE_ADC_B_UNIT_0_CHANNELS                    (0U)
48 #define BSP_FEATURE_ADC_B_UNIT_1_CHANNELS                    (0U)
49 #define BSP_FEATURE_ADC_CALIBRATION_REG_AVAILABLE            (0U)
50 #define BSP_FEATURE_ADC_CLOCK_SOURCE                         (FSP_PRIV_CLOCK_PCLKD)
51 #define BSP_FEATURE_ADC_D_CHANNELS                           (0) // Feature not available on this MCU
52 #define BSP_FEATURE_ADC_D_SCAN_MODE_CHANNELS                 (0) // Feature not available on this MCU
53 #define BSP_FEATURE_ADC_GROUP_B_SENSORS_ALLOWED              (0U)
54 #define BSP_FEATURE_ADC_HAS_ADBUF                            (0U)
55 #define BSP_FEATURE_ADC_HAS_ADCER_ADPRC                      (0U)
56 #define BSP_FEATURE_ADC_HAS_ADCER_ADRFMT                     (1U)
57 #define BSP_FEATURE_ADC_HAS_ADHVREFCNT                       (1U)
58 #define BSP_FEATURE_ADC_HAS_PGA                              (0U)
59 #define BSP_FEATURE_ADC_HAS_SAMPLE_HOLD_REG                  (0U)
60 #define BSP_FEATURE_ADC_HAS_VREFAMPCNT                       (0U)
61 #define BSP_FEATURE_ADC_MAX_RESOLUTION_BITS                  (12U)
62 #define BSP_FEATURE_ADC_SENSORS_EXCLUSIVE                    (1U)
63 #define BSP_FEATURE_ADC_SENSOR_MIN_SAMPLING_TIME             (5000U)
64 #define BSP_FEATURE_ADC_TSN_CALIBRATION32_AVAILABLE          (0U)
65 #define BSP_FEATURE_ADC_TSN_CALIBRATION32_MASK               (0U)
66 #define BSP_FEATURE_ADC_TSN_CALIBRATION_AVAILABLE            (1U)
67 #define BSP_FEATURE_ADC_TSN_CONTROL_AVAILABLE                (0U)
68 #define BSP_FEATURE_ADC_TSN_SLOPE                            (-3300)
69 #define BSP_FEATURE_ADC_UNIT_0_CHANNELS                      (0x1F7FFF) // 0 to 14, 16 (ADCTDR) 17 to 20 in unit 0
70 #define BSP_FEATURE_ADC_UNIT_1_CHANNELS                      (0)
71 #define BSP_FEATURE_ADC_VALID_UNIT_MASK                      (1U)
72 
73 #define BSP_FEATURE_AGT_AGTW_CHANNEL_COUNT                   (0)
74 #define BSP_FEATURE_AGT_AGT_CHANNEL_COUNT                    (2)
75 #define BSP_FEATURE_AGT_USE_AGTIOSEL_ALT                     (0) // Indicates use of AGTIOSEL_ALT instead of AGTIOSEL
76 #define BSP_FEATURE_AGT_VALID_CHANNEL_MASK                   (0x03)
77 
78 #define BSP_FEATURE_BSP_FLASH_CACHE                          (0)
79 #define BSP_FEATURE_BSP_FLASH_CACHE_DISABLE_OPM              (0U)
80 #define BSP_FEATURE_BSP_FLASH_PREFETCH_BUFFER                (1)
81 #define BSP_FEATURE_BSP_HAS_CANFD_CLOCK                      (0) // Feature not available on this MCU
82 #define BSP_FEATURE_BSP_HAS_CEC_CLOCK                        (0) // Feature not available on this MCU
83 #define BSP_FEATURE_BSP_HAS_CLOCK_SUPPLY_TYPEB               (1U)
84 #define BSP_FEATURE_BSP_HAS_CODE_SYSTEM_CACHE                (0)
85 #define BSP_FEATURE_BSP_HAS_DCDC_REGULATOR                   (1U)
86 #define BSP_FEATURE_BSP_HAS_DTCM                             (0) // Feature not available on this MCU
87 #define BSP_FEATURE_BSP_HAS_GPT_CLOCK                        (0) // Mutually exclusive with USB60 Clock
88 #define BSP_FEATURE_BSP_HAS_GRAPHICS_DOMAIN                  (0)
89 #define BSP_FEATURE_BSP_HAS_I3C_CLOCK                        (0)
90 #define BSP_FEATURE_BSP_HAS_IIC_CLOCK                        (0U)
91 #define BSP_FEATURE_BSP_HAS_ITCM                             (0) // Feature not available on this MCU
92 #define BSP_FEATURE_BSP_HAS_LCD_CLOCK                        (0)
93 #define BSP_FEATURE_BSP_HAS_OCTASPI_CLOCK                    (0U)
94 #define BSP_FEATURE_BSP_HAS_OFS2                             (0)
95 #define BSP_FEATURE_BSP_HAS_OFS3                             (0)
96 #define BSP_FEATURE_BSP_HAS_SCE5                             (0) // Feature not available on this MCU
97 #define BSP_FEATURE_BSP_HAS_SCE_ON_RA2                       (1)
98 #define BSP_FEATURE_BSP_HAS_SCISPI_CLOCK                     (0) // Feature not available on this MCU
99 #define BSP_FEATURE_BSP_HAS_SCI_CLOCK                        (0)
100 #define BSP_FEATURE_BSP_HAS_SDADC_CLOCK                      (0)
101 #define BSP_FEATURE_BSP_HAS_SECURITY_MPU                     (1U)
102 #define BSP_FEATURE_BSP_HAS_SPI_CLOCK                        (0)
103 #define BSP_FEATURE_BSP_HAS_SP_MON                           (1U)
104 #define BSP_FEATURE_BSP_HAS_SYRACCR                          (0U)
105 #define BSP_FEATURE_BSP_HAS_TZFSAR                           (0)
106 #define BSP_FEATURE_BSP_HAS_USB60_CLOCK_REQ                  (0U) // Feature not available on this MCU
107 #define BSP_FEATURE_BSP_HAS_USBCKDIVCR                       (0U)
108 #define BSP_FEATURE_BSP_HAS_USB_CLOCK_DIV                    (0U)
109 #define BSP_FEATURE_BSP_HAS_USB_CLOCK_REQ                    (0U) // On the RA6M4 there is a request bit that must be set before changing USB clock settings.
110 #define BSP_FEATURE_BSP_HAS_USB_CLOCK_SEL                    (0U)
111 #define BSP_FEATURE_BSP_HAS_USB_CLOCK_SEL_ALT                (0U)
112 #define BSP_FEATURE_BSP_MCU_INFO_POINTER_LOCATION            (0U)
113 #define BSP_FEATURE_BSP_MPU_REGION0_MASK                     (0x000FFFFFU)
114 #define BSP_FEATURE_BSP_MSTP_GPT_MSTPD5_MAX_CH               (3U) // Largest channel number associated with lower MSTP bit for GPT on this MCU.
115 #define BSP_FEATURE_BSP_MSTP_HAS_MSTPCRE                     (0U)
116 #define BSP_FEATURE_BSP_NUM_PMSAR                            (0U)
117 #define BSP_FEATURE_BSP_OFS1_HOCOFRQ_MASK                    (0xFFFF8FFFU)
118 #define BSP_FEATURE_BSP_OFS1_HOCOFRQ_OFFSET                  (12U)
119 #define BSP_FEATURE_BSP_OFS_HAS_SECURITY_ATTRIBUTION         (0U)
120 #define BSP_FEATURE_BSP_OSIS_PADDING                         (1)
121 #define BSP_FEATURE_BSP_POWER_CHANGE_MSTP_REQUIRED           (0U)
122 #define BSP_FEATURE_BSP_RESET_TRNG                           (1U)
123 #define BSP_FEATURE_BSP_SYS_CLOCK_FREQ_FIVE_ROM_WAITS        (0U) // The maximum frequency allowed without having five ROM wait cycles (Set to zero if this is not an option).
124 #define BSP_FEATURE_BSP_SYS_CLOCK_FREQ_FOUR_ROM_WAITS        (0U) // The maximum frequency allowed without having four ROM wait cycles (Set to zero if this is not an option).
125 #define BSP_FEATURE_BSP_SYS_CLOCK_FREQ_NO_RAM_WAITS          (0U) // The maximum frequency allowed without having RAM wait state enabled in SRAMWTSC.
126 #define BSP_FEATURE_BSP_SYS_CLOCK_FREQ_ONE_ROM_WAITS         (0U) // The maximum frequency allowed without having one ROM wait cycle.
127 #define BSP_FEATURE_BSP_SYS_CLOCK_FREQ_THREE_ROM_WAITS       (0U) // The maximum frequency allowed without having three ROM wait cycles (Set to zero if this is not an option).
128 #define BSP_FEATURE_BSP_SYS_CLOCK_FREQ_TWO_ROM_WAITS         (0U) // The maximum frequency allowed without having two ROM wait cycles.
129 #define BSP_FEATURE_BSP_UNIQUE_ID_OFFSET                     (0U)
130 #define BSP_FEATURE_BSP_UNIQUE_ID_POINTER                    (0x01001C00U)
131 #define BSP_FEATURE_BSP_VBATT_HAS_VBTCR1_BPWSWSTP            (0U)
132 
133 #define BSP_FEATURE_CANFD_FD_SUPPORT                         (0U)
134 #define BSP_FEATURE_CANFD_LITE                               (0U)
135 #define BSP_FEATURE_CANFD_NUM_CHANNELS                       (0U) // Feature not available on this MCU
136 #define BSP_FEATURE_CANFD_NUM_INSTANCES                      (0U)
137 
138 #define BSP_FEATURE_CAN_CHECK_PCLKB_RATIO                    (1U)
139 #define BSP_FEATURE_CAN_CLOCK                                (FSP_PRIV_CLOCK_ICLK)
140 #define BSP_FEATURE_CAN_MCLOCK_ONLY                          (1U)
141 #define BSP_FEATURE_CAN_NUM_CHANNELS                         (1U)
142 
143 #define BSP_FEATURE_CGC_EXECUTE_FROM_LOCO                    (1)
144 #define BSP_FEATURE_CGC_HAS_BCLK                             (0U)
145 #define BSP_FEATURE_CGC_HAS_CPUCLK                           (0U)
146 #define BSP_FEATURE_CGC_HAS_FCLK                             (0U)
147 #define BSP_FEATURE_CGC_HAS_FLDWAITR                         (1U)
148 #define BSP_FEATURE_CGC_HAS_FLL                              (0U)
149 #define BSP_FEATURE_CGC_HAS_FLWT                             (0U)
150 #define BSP_FEATURE_CGC_HAS_HOCOWTCR                         (0U)
151 #define BSP_FEATURE_CGC_HAS_MEMWAIT                          (1U)
152 #define BSP_FEATURE_CGC_HAS_PCLKA                            (0U)
153 #define BSP_FEATURE_CGC_HAS_PCLKB                            (1U)
154 #define BSP_FEATURE_CGC_HAS_PCLKC                            (0U)
155 #define BSP_FEATURE_CGC_HAS_PCLKD                            (1U)
156 #define BSP_FEATURE_CGC_HAS_PCLKE                            (0U)
157 #define BSP_FEATURE_CGC_HAS_PLL                              (0U)
158 #define BSP_FEATURE_CGC_HAS_PLL2                             (0U) // On the RA6M4 there is another PLL that can be used as a clock source for USB and OCTASPI.
159 #define BSP_FEATURE_CGC_HAS_SOPCCR                           (1U)
160 #define BSP_FEATURE_CGC_HAS_SOSC                             (1U)
161 #define BSP_FEATURE_CGC_HAS_SRAMPRCR2                        (0U) // On the RA6M4 there is another register to enable write access for SRAMWTSC.
162 #define BSP_FEATURE_CGC_HAS_SRAMWTSC                         (0U)
163 #define BSP_FEATURE_CGC_HOCOSF_BEFORE_OPCCR                  (1U)
164 #define BSP_FEATURE_CGC_HOCOWTCR_64MHZ_ONLY                  (0U)
165 #define BSP_FEATURE_CGC_HOCOWTCR_SCI_SNOOZE_VALUE            (0)
166 #define BSP_FEATURE_CGC_HOCOWTCR_VALUE                       (6U)
167 #define BSP_FEATURE_CGC_ICLK_DIV_RESET                       (BSP_CLOCKS_SYS_CLOCK_DIV_16)
168 #define BSP_FEATURE_CGC_LOCO_STABILIZATION_MAX_US            (100U)
169 #define BSP_FEATURE_CGC_LOW_SPEED_MAX_FREQ_HZ                (2000000U)  // This MCU does have Low Speed Mode, up to 2 MHz
170 #define BSP_FEATURE_CGC_LOW_VOLTAGE_MAX_FREQ_HZ              (0U)        // This MCU does not have Low Voltage Mode
171 #define BSP_FEATURE_CGC_MIDDLE_SPEED_MAX_FREQ_HZ             (24000000U) // This MCU does have Middle Speed Mode, up to 24 MHz
172 #define BSP_FEATURE_CGC_MOCO_STABILIZATION_MAX_US            (1U)
173 #define BSP_FEATURE_CGC_MODRV_MASK                           (R_SYSTEM_MOMCR_MODRV1_Msk)
174 #define BSP_FEATURE_CGC_MODRV_SHIFT                          (R_SYSTEM_MOMCR_MODRV1_Pos)
175 #define BSP_FEATURE_CGC_PLL_HOCO_MAX_CPUCLK_HZ               (0U)
176 #define BSP_FEATURE_CGC_PLL1_NUM_OUTPUT_CLOCKS               (0U)
177 #define BSP_FEATURE_CGC_PLL2_NUM_OUTPUT_CLOCKS               (0U)
178 #define BSP_FEATURE_CGC_PLL_OUT_MAX_HZ                       (0U) // Feature not available on this MCU
179 #define BSP_FEATURE_CGC_PLL_OUT_MIN_HZ                       (0U) // Feature not available on this MCU
180 #define BSP_FEATURE_CGC_PLL_SRC_MAX_HZ                       (0U) // Feature not available on this MCU
181 #define BSP_FEATURE_CGC_PLL_SRC_MIN_HZ                       (0U) // Feature not available on this MCU
182 #define BSP_FEATURE_CGC_PLL2_OUT_MAX_HZ                      (0U) // Feature not available on this MCU
183 #define BSP_FEATURE_CGC_PLL2_OUT_MIN_HZ                      (0U) // Feature not available on this MCU
184 #define BSP_FEATURE_CGC_PLL2_SRC_MAX_HZ                      (0U) // Feature not available on this MCU
185 #define BSP_FEATURE_CGC_PLL2_SRC_MIN_HZ                      (0U) // Feature not available on this MCU
186 #define BSP_FEATURE_CGC_PLLCCR_TYPE                          (0U)
187 #define BSP_FEATURE_CGC_PLLCCR_VCO_MAX_HZ                    (0U)
188 #define BSP_FEATURE_CGC_PLLCCR_WAIT_US                       (0U) // This MCU does not have PLL
189 #define BSP_FEATURE_CGC_REGISTER_SET_B                       (0)
190 #define BSP_FEATURE_CGC_SCKDIVCR_BCLK_MATCHES_PCLKB          (0U)
191 #define BSP_FEATURE_CGC_SODRV_MASK                           (0x03U)
192 #define BSP_FEATURE_CGC_SODRV_SHIFT                          (0x0U)
193 #define BSP_FEATURE_CGC_SRAMPRCR_KW_OFFSET                   (1)
194 #define BSP_FEATURE_CGC_SRAMPRCR_KW_VALUE                    (0x78)
195 #define BSP_FEATURE_CGC_STARTUP_OPCCR_MODE                   (1)
196 #define BSP_FEATURE_CGC_HAS_OSTDCSE                          (0) // Feature not available on this MCU
197 #define BSP_FEATURE_CGC_OSCILLATON_STOP_DETECT               (1)
198 #define BSP_FEATURE_CGC_STARTUP_SCKDIVCR                     (0x04000404)
199 #define BSP_FEATURE_CGC_STARTUP_SCKDIVCR2                    (0x00)
200 #define BSP_FEATURE_CGC_STARTUP_SCKSCR                       (0x01)
201 
202 #define BSP_FEATURE_CRC_HAS_SNOOP                            (1U)
203 #define BSP_FEATURE_CRC_SNOOP_ADDRESS_TYPE_TDR               (0x3U)
204 #define BSP_FEATURE_CRC_HAS_CRCCR0_LMS                       (1)
205 #define BSP_FEATURE_CRC_POLYNOMIAL_MASK                      (0x3EU)
206 
207 #define BSP_FEATURE_CRYPTO_HAS_AES                           (1)
208 #define BSP_FEATURE_CRYPTO_HAS_AES_WRAPPED                   (0)
209 #define BSP_FEATURE_CRYPTO_HAS_CTR_DRBG                      (0)
210 #define BSP_FEATURE_CRYPTO_HAS_ECC                           (0)
211 #define BSP_FEATURE_CRYPTO_HAS_ECC_WRAPPED                   (0)
212 #define BSP_FEATURE_CRYPTO_HAS_HASH                          (0)
213 #define BSP_FEATURE_CRYPTO_HAS_NEW_PROCS                     (0) // Feature not available on this MCU
214 #define BSP_FEATURE_CRYPTO_HAS_RSA                           (0)
215 #define BSP_FEATURE_CRYPTO_HAS_RSA_WRAPPED                   (0)
216 #define BSP_FEATURE_CRYPTO_AES_IP_VERSION                    (1)
217 #define BSP_FEATURE_CRYPTO_HAS_SCE5                          (0)
218 #define BSP_FEATURE_CRYPTO_HAS_SCE5B                         (0)
219 #define BSP_FEATURE_CRYPTO_HAS_SCE7                          (0)
220 #define BSP_FEATURE_CRYPTO_HAS_SCE9                          (0) // Feature not available on this MCU
221 
222 #define BSP_FEATURE_CTSU_CTSUCHAC_REGISTER_COUNT             (4U)
223 #define BSP_FEATURE_CTSU_CTSUCHTRC_REGISTER_COUNT            (4U)
224 #define BSP_FEATURE_CTSU_HAS_TXVSEL                          (1)
225 #define BSP_FEATURE_CTSU_VERSION                             (2)
226 
227 #define BSP_FEATURE_DAC8_HAS_CHARGEPUMP                      (0)  // Feature not available on this MCU
228 #define BSP_FEATURE_DAC8_HAS_DA_AD_SYNCHRONIZE               (0)  // Feature not available on this MCU
229 #define BSP_FEATURE_DAC8_HAS_REALTIME_MODE                   (0)  // Feature not available on this MCU
230 #define BSP_FEATURE_DAC8_MAX_CHANNELS                        (0)  // Feature not available on this MCU
231 
232 #define BSP_FEATURE_DAC_AD_SYNC_UNIT_MASK                    (0U) // Feature not available on this MCU
233 #define BSP_FEATURE_DAC_HAS_CHARGEPUMP                       (0U)
234 #define BSP_FEATURE_DAC_HAS_DAVREFCR                         (1U)
235 #define BSP_FEATURE_DAC_HAS_DA_AD_SYNCHRONIZE                (1U)
236 #define BSP_FEATURE_DAC_HAS_INTERNAL_OUTPUT                  (0U)
237 #define BSP_FEATURE_DAC_HAS_OUTPUT_AMPLIFIER                 (0U)
238 #define BSP_FEATURE_DAC_MAX_CHANNELS                         (1U)
239 
240 #define BSP_FEATURE_DMAC_HAS_DELSR                           (0U)
241 #define BSP_FEATURE_DMAC_HAS_REPEAT_BLOCK_MODE               (0U)
242 #define BSP_FEATURE_DMAC_MAX_CHANNEL                         (0) // Feature not available on this MCU
243 
244 #define BSP_FEATURE_DOC_VERSION                              (1U)
245 
246 #define BSP_FEATURE_DWT_CYCCNT                               (0U)
247 
248 #define BSP_FEATURE_ELC_PERIPHERAL_MASK                      (0x0004D30FU) // Deprecated (Removing in FSP v6.0)
249 #define BSP_FEATURE_ELC_VERSION                              (1U)
250 
251 #define BSP_FEATURE_ETHER_FIFO_DEPTH                         (0)           // Feature not available on this MCU
252 #define BSP_FEATURE_ETHER_MAX_CHANNELS                       (0)           // Feature not available on this MCU
253 #define BSP_FEATURE_ETHER_SUPPORTS_TZ_SECURE                 (0)           // Feature not available on this MCU
254 
255 #define BSP_FEATURE_FLASH_CODE_FLASH_START                   (0x0U)
256 #define BSP_FEATURE_FLASH_DATA_FLASH_START                   (0x40100000U)
257 #define BSP_FEATURE_FLASH_HP_CF_DUAL_BANK_START              (0)           // Feature not available on this MCU
258 #define BSP_FEATURE_FLASH_HP_CF_REGION0_BLOCK_SIZE           (0)           // Feature not available on this MCU
259 #define BSP_FEATURE_FLASH_HP_CF_REGION0_SIZE                 (0)           // Feature not available on this MCU
260 #define BSP_FEATURE_FLASH_HP_CF_REGION1_BLOCK_SIZE           (0)           // Feature not available on this MCU
261 #define BSP_FEATURE_FLASH_HP_CF_WRITE_SIZE                   (0)           // Feature not available on this MCU
262 #define BSP_FEATURE_FLASH_HP_DF_BLOCK_SIZE                   (0)           // Feature not available on this MCU
263 #define BSP_FEATURE_FLASH_HP_DF_WRITE_SIZE                   (0)           // Feature not available on this MCU
264 #define BSP_FEATURE_FLASH_HP_HAS_FMEPROT                     (0)           // Feature not available on this MCU
265 #define BSP_FEATURE_FLASH_HP_SUPPORTS_DUAL_BANK              (0)
266 #define BSP_FEATURE_FLASH_HP_VERSION                         (0)           // Feature not available on this MCU
267 #define BSP_FEATURE_FLASH_LP_AWS_FAW_MASK                    (0x7FFU)
268 #define BSP_FEATURE_FLASH_LP_AWS_FAW_SHIFT                   (11)
269 #define BSP_FEATURE_FLASH_LP_CF_BLOCK_SIZE                   (0x800U)
270 #define BSP_FEATURE_FLASH_LP_CF_WRITE_SIZE                   (4)
271 #define BSP_FEATURE_FLASH_LP_DF_BLOCK_SIZE                   (0x400U)
272 #define BSP_FEATURE_FLASH_LP_DF_WRITE_SIZE                   (1)
273 #define BSP_FEATURE_FLASH_LP_FLASH_CLOCK_SRC                 ((fsp_priv_clock_t) FSP_PRIV_CLOCK_ICLK) // RA2L1 Flash uses ICLK
274 #define BSP_FEATURE_FLASH_LP_SUPPORTS_DUAL_BANK              (0)                                      // Feature not available on this MCU
275 #define BSP_FEATURE_FLASH_LP_VERSION                         (4)
276 #define BSP_FEATURE_FLASH_SUPPORTS_ACCESS_WINDOW             (1)
277 #define BSP_FEATURE_FLASH_SUPPORTS_ID_CODE                   (1)
278 
279 #define BSP_FEATURE_GPT_32BIT_CHANNEL_MASK                   (0xF)
280 #define BSP_FEATURE_GPT_CLOCK_DIVIDER_STEP_SIZE              (4U)
281 #define BSP_FEATURE_GPT_CLOCK_DIVIDER_VALUE_7_9_VALID        (0U)
282 #define BSP_FEATURE_GPT_EVENT_COUNT_CHANNEL_MASK             (BSP_FEATURE_GPT_VALID_CHANNEL_MASK)
283 #define BSP_FEATURE_GPT_ODC_FRANGE_FREQ_MIN                  (0U) // Feature not available on this MCU
284 #define BSP_FEATURE_GPT_ODC_FREQ_MAX                         (0U) // Feature not available on this MCU
285 #define BSP_FEATURE_GPT_ODC_FREQ_MIN                         (0U) // Feature not available on this MCU
286 #define BSP_FEATURE_GPT_ODC_VALID_CHANNEL_MASK               (0U) // Feature not available on this MCU
287 #define BSP_FEATURE_GPT_TPCS_SHIFT                           (1U)
288 #define BSP_FEATURE_GPT_VALID_CHANNEL_MASK                   (0x3FF)
289 
290 #define BSP_FEATURE_I3C_MAX_DEV_COUNT                        (0U) // Feature not available on this MCU
291 #define BSP_FEATURE_I3C_NTDTBP0_DEPTH                        (0U) // Feature not available on this MCU
292 #define BSP_FEATURE_I3C_NUM_CHANNELS                         (0U) // Feature not available on this MCU
293 #define BSP_FEATURE_I3C_MSTP_OFFSET                          (0U) // Feature not available on this MCU
294 
295 #define BSP_FEATURE_ICU_HAS_FILTER                           (1U)
296 #define BSP_FEATURE_ICU_HAS_IELSR                            (1U)
297 #define BSP_FEATURE_ICU_HAS_INTERRUPT_GROUPS                 (1U)
298 #define BSP_FEATURE_ICU_HAS_WUPEN1                           (0U)
299 #define BSP_FEATURE_ICU_SBYEDCR_MASK                         (0U) // Feature not available on this MCU
300 #define BSP_FEATURE_ICU_IRQ_CHANNELS_MASK                    (0xFFU)
301 #define BSP_FEATURE_ICU_WUPEN_MASK                           (0xF38F00FFU)
302 #define BSP_FEATURE_ICU_FIXED_IELSR_COUNT                    (0U)
303 
304 #define BSP_FEATURE_IIC_BUS_FREE_TIME_MULTIPLIER             (0U)
305 #define BSP_FEATURE_IIC_B_FAST_MODE_PLUS                     (0) // Feature not available on this MCU
306 #define BSP_FEATURE_IIC_B_VALID_CHANNEL_MASK                 (0) // Feature not available on this MCU
307 #define BSP_FEATURE_IIC_FAST_MODE_PLUS                       (0U)
308 #define BSP_FEATURE_IIC_VALID_CHANNEL_MASK                   (0x03)
309 #define BSP_FEATURE_IIC_VERSION                              (0) // Feature not available on this MCU
310 
311 #define BSP_FEATURE_IOPORT_ELC_PORTS                         (0x0006U)
312 #define BSP_FEATURE_IOPORT_HAS_ETHERNET                      (0U)
313 #define BSP_FEATURE_IOPORT_VERSION                           (1U)
314 
315 #define BSP_FEATURE_IWDT_CLOCK_FREQUENCY                     (15000UL)
316 #define BSP_FEATURE_IWDT_SUPPORTS_REGISTER_START_MODE        (0U)
317 
318 #define BSP_FEATURE_KINT_HAS_MSTP                            (0U)
319 
320 #define BSP_FEATURE_LPM_CHANGE_MSTP_ARRAY                    (0) // Feature not available on this MCU
321 #define BSP_FEATURE_LPM_CHANGE_MSTP_REQUIRED                 (0U)
322 #define BSP_FEATURE_LPM_DPSIEGR_MASK                         (0) // Feature not available on this MCU
323 #define BSP_FEATURE_LPM_DPSIER_MASK                          (0) // Feature not available on this MCU
324 #define BSP_FEATURE_LPM_HAS_DEEP_SLEEP                       (0U)
325 #define BSP_FEATURE_LPM_HAS_DEEP_STANDBY                     (0U)
326 #define BSP_FEATURE_LPM_HAS_DPSBYCR_DEEPCUT                  (0U)
327 #define BSP_FEATURE_LPM_HAS_DPSBYCR_DPSBY                    (0U)
328 #define BSP_FEATURE_LPM_HAS_DPSBYCR_SRKEEP                   (0U)
329 #define BSP_FEATURE_LPM_HAS_LDO_CONTROL                      (0U)
330 #define BSP_FEATURE_LPM_HAS_LPSCR                            (0U)
331 #define BSP_FEATURE_LPM_HAS_PDRAMSCR                         (0U)
332 #define BSP_FEATURE_LPM_HAS_SBYCR_OPE                        (0U)
333 #define BSP_FEATURE_LPM_HAS_SBYCR_SSBY                       (1U)
334 #define BSP_FEATURE_LPM_HAS_SNOOZE                           (1U)
335 #define BSP_FEATURE_LPM_HAS_SNZEDCR1                         (0U)
336 #define BSP_FEATURE_LPM_HAS_SNZREQCR1                        (0U)
337 #define BSP_FEATURE_LPM_HAS_STCONR                           (0U)
338 #define BSP_FEATURE_LPM_HAS_HOCO_STARTUP_SPEED_MODE          (0U) // Feature not available on this MCU
339 #define BSP_FEATURE_LPM_HAS_STANDBY_SOSC_SELECT              (0U) // Feature not available on this MCU
340 #define BSP_FEATURE_LPM_HAS_FLASH_MODE_SELECT                (0U) // Feature not available on this MCU
341 #define BSP_FEATURE_LPM_SNOOZE_REQUEST_DTCST_DTCST           (0U) // Feature not available on this MCU
342 #define BSP_FEATURE_LPM_SBYCR_WRITE1_B14                     (0)
343 #define BSP_FEATURE_LPM_SNZEDCR_MASK                         (0x0000009FU)
344 #define BSP_FEATURE_LPM_SNZREQCR_MASK                        (0x738200FFU)
345 #define BSP_FEATURE_LPM_STANDBY_MOCO_REQUIRED                (0U)
346 
347 #define BSP_FEATURE_LVD_HAS_DIGITAL_FILTER                   (0U)
348 #define BSP_FEATURE_LVD_HAS_EXT_MONITOR                      (0U)
349 #define BSP_FEATURE_LVD_HAS_LVDLVLR                          (1U)
350 #define BSP_FEATURE_LVD_MONITOR_1_HI_THRESHOLD               (LVD_THRESHOLD_MONITOR_1_LEVEL_4_29V) // 4.29V
351 #define BSP_FEATURE_LVD_MONITOR_1_LOW_THRESHOLD              (LVD_THRESHOLD_MONITOR_1_LEVEL_1_65V) // 1.65V
352 #define BSP_FEATURE_LVD_MONITOR_2_HI_THRESHOLD               (LVD_THRESHOLD_MONITOR_2_LEVEL_4_29V) // 4.29V
353 #define BSP_FEATURE_LVD_MONITOR_2_LOW_THRESHOLD              (LVD_THRESHOLD_MONITOR_2_LEVEL_3_84V) // 3.84V
354 #define BSP_FEATURE_LVD_MONITOR_1_STABILIZATION_TIME_US      (300U)                                // LVD1 operation stabilization time after LVD1 is enabled
355 #define BSP_FEATURE_LVD_MONITOR_2_STABILIZATION_TIME_US      (1200U)                               // LVD2 operation stabilization time after LVD2 is enabled
356 #define BSP_FEATURE_LVD_SUPPORT_RESET_ON_RISING_EDGE         (0U)
357 #define BSP_FEATURE_LVD_VERSION                              (1U)
358 
359 #define BSP_FEATURE_MACL_SUPPORTED                           (0U)
360 
361 #define BSP_FEATURE_OPAMP_BASE_ADDRESS                       (0U) // Feature not available on this MCU
362 #define BSP_FEATURE_OPAMP_HAS_MIDDLE_SPEED                   (0U) // Feature not available on this MCU
363 #define BSP_FEATURE_OPAMP_HAS_SWITCHES                       (0U) // Feature not available on this MCU
364 #define BSP_FEATURE_OPAMP_HAS_THIRD_CHANNEL                  (0U) // Feature not available on this MCU
365 #define BSP_FEATURE_OPAMP_MIN_WAIT_TIME_HS_US                (0U) // Feature not available on this MCU
366 #define BSP_FEATURE_OPAMP_MIN_WAIT_TIME_LP_US                (0U) // Feature not available on this MCU
367 #define BSP_FEATURE_OPAMP_MIN_WAIT_TIME_MS_US                (0U) // Feature not available on this MCU
368 #define BSP_FEATURE_OPAMP_TRIM_CAPABLE                       (0U) // Feature not available on this MCU
369 #define BSP_FEATURE_OPAMP_VARIANT_CHANNEL_MASK               (0U) // Feature not available on this MCU
370 
371 #define BSP_FEATURE_OSPI_DEVICE_0_START_ADDRESS              (0x0U)
372 #define BSP_FEATURE_OSPI_DEVICE_1_START_ADDRESS              (0x0U)
373 
374 #define BSP_FEATURE_POEG_CHANNEL_MASK                        (0x3U)
375 
376 #define BSP_FEATURE_QSPI_DEVICE_START_ADDRESS                (0x0U)
377 
378 #define BSP_FEATURE_RTC_IS_AVAILABLE                         (1U)
379 #define BSP_FEATURE_RTC_IS_IRTC                              (0U)
380 #define BSP_FEATURE_RTC_HAS_ROPSEL                           (1U)
381 #define BSP_FEATURE_RTC_HAS_TCEN                             (0U)
382 #define BSP_FEATURE_RTC_RTCCR_CHANNELS                       (0U)
383 #define BSP_FEATURE_SYSC_HAS_VBTICTLR                        (0U)
384 
385 #define BSP_FEATURE_SAU_UART_VALID_CHANNEL_MASK              (0U) // Feature not available on this MCU
386 
387 #define BSP_FEATURE_SCI_ADDRESS_MATCH_CHANNELS               (BSP_FEATURE_SCI_CHANNELS)
388 #define BSP_FEATURE_SCI_CHANNELS                             (0x20FU)
389 #define BSP_FEATURE_SCI_CLOCK                                (FSP_PRIV_CLOCK_PCLKB)
390 #define BSP_FEATURE_SCI_SPI_SCKSEL_VALUE                     (0U) // Feature not available on this MCU
391 #define BSP_FEATURE_SCI_UART_CSTPEN_CHANNELS                 (0x0U)
392 #define BSP_FEATURE_SCI_UART_FIFO_CHANNELS                   (0x1U)
393 #define BSP_FEATURE_SCI_UART_FIFO_DEPTH                      (16U)
394 #define BSP_FEATURE_SCI_VERSION                              (1U)
395 #define BSP_FEATURE_SCI_LIN_CHANNELS                         (0U) // Feature not available on this MCU
396 
397 #define BSP_FEATURE_SDHI_CLOCK                               (0)  // Feature not available on this MCU
398 #define BSP_FEATURE_SDHI_HAS_CARD_DETECTION                  (0)  // Feature not available on this MCU
399 #define BSP_FEATURE_SDHI_MIN_CLOCK_DIVISION_SHIFT            (0)  // Feature not available on this MCU
400 #define BSP_FEATURE_SDHI_SUPPORTS_8_BIT_MMC                  (0)  // Feature not available on this MCU
401 #define BSP_FEATURE_SDHI_VALID_CHANNEL_MASK                  (0)  // Feature not available on this MCU
402 
403 #define BSP_FEATURE_SDRAM_START_ADDRESS                      (0)  // Feature not available on this MCU
404 
405 #define BSP_FEATURE_SLCDC_HAS_8_TIME_SLICE                   (0)  // Feature not available on this MCU
406 #define BSP_FEATURE_SLCDC_HAS_INTERNAL_VOLT_GEN              (0)  // Feature not available on this MCU
407 #define BSP_FEATURE_SLCDC_MAX_NUM_SEG                        (0)  // Feature not available on this MCU
408 #define BSP_FEATURE_SLCDC_HAS_VL1SEL                         (0)  // Feature not available on this MCU
409 #define BSP_FEATURE_SLCDC_CONTRAST_MAX_4BIAS                 (0)  // Feature not available on this MCU
410 #define BSP_FEATURE_SLCDC_CONTRAST_MAX                       (0)  // Feature not available on this MCU
411 
412 #define BSP_FEATURE_SPI_CLK                                  (FSP_PRIV_CLOCK_PCLKB)
413 #define BSP_FEATURE_SPI_HAS_SPCR3                            (0U)
414 #define BSP_FEATURE_SPI_HAS_SSL_LEVEL_KEEP                   (0U)
415 #define BSP_FEATURE_SPI_MAX_CHANNEL                          (2U)
416 #define BSP_FEATURE_SPI_SSL_LEVEL_KEEP_VALID_CHANNEL_MASK    (0x0U)
417 
418 #define BSP_FEATURE_SRAM_SRAMWTSC_WAIT_CYCLE_ENABLE          (0)    // Feature not available on this MCU
419 
420 #define BSP_FEATURE_SSI_FIFO_NUM_STAGES                      (0)    // Feature not available on this MCU
421 #define BSP_FEATURE_SSI_VALID_CHANNEL_MASK                   (0)    // Feature not available on this MCU
422 
423 #define BSP_FEATURE_TAU_CLOCK_SOURCE                         (NULL) // Feature not available on this MCU
424 #define BSP_FEATURE_TAU_VALID_CHANNEL_MASK                   (0)    // Feature not available on this MCU
425 
426 #define BSP_FEATURE_TML_MAX_CLOCK_DIVIDER                    (0U)   // Feature not available on this MCU
427 #define BSP_FEATURE_TML_NUM_CHANNELS                         (0)    // Feature not available on this MCU
428 #define BSP_FEATURE_TML_VALID_CHANNEL_MASK                   (0U)   // Feature not available on this MCU
429 
430 #define BSP_FEATURE_TFU_SUPPORTED                            (0U)   // Trigonometric Function Unit (TFU) not available on this MCU
431 
432 #define BSP_FEATURE_TRNG_HAS_MODULE_STOP                     (1U)
433 #define BSP_FEATURE_TZ_NS_OFFSET                             (0U)
434 #define BSP_FEATURE_TZ_HAS_TRUSTZONE                         (0U)
435 #define BSP_FEATURE_TZ_HAS_DLM                               (0U)
436 #define BSP_FEATURE_TZ_VERSION                               (0U)
437 
438 #define BSP_FEATURE_ULPT_MAX_CHANNEL_NUM                     (0)
439 #define BSP_FEATURE_ULPT_VALID_CHANNEL_MASK                  (0U)
440 
441 #define BSP_FEATURE_USB_NUM_IP                               (0U)
442 #define BSP_FEATURE_USB_HAS_USBHS                            (0U)
443 
444 #endif
445