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