 |
AM263Px MCU+ SDK
10.01.00
|
|
Go to the documentation of this file.
33 #ifndef SOC_RCM_AM263PX_H_
34 #define SOC_RCM_AM263PX_H_
54 #define SOC_RCM_FREQ_MHZ2HZ(x) ((x) * 1000 * 1000)
55 #define SOC_RCM_FREQ_HZ2MHZ(x) ((x) / (1000 * 1000))
62 typedef enum SOC_WarmResetCause_e
117 typedef enum SOC_WarmResetSource_e
161 typedef enum SOC_RcmWarm_ResetTime123_e
236 typedef enum SOC_RcmResetCause_e
295 typedef enum SOC_Rcmr5fssNum_e
313 typedef enum SOC_RcmPeripheralId_e
471 typedef enum SOC_RcmPeripheralClockSource_e
529 typedef enum SOC_RcmPllFoutFreqId_e
551 typedef enum SOC_RcmXtalFreqId_e
559 typedef enum SOC_RcmPllId_e
576 typedef enum SOC_RcmPllHSDIVOutId_e
597 typedef struct SOC_RcmClkSrcInfo_s
603 typedef struct SOC_RcmXTALInfo_s
609 typedef struct SOC_RcmADPLLJConfig_s
619 #define RCM_PLL_HSDIV_OUTPUT_ENABLE_0 (1U << 0U)
620 #define RCM_PLL_HSDIV_OUTPUT_ENABLE_1 (1U << 1U)
621 #define RCM_PLL_HSDIV_OUTPUT_ENABLE_2 (1U << 2U)
622 #define RCM_PLL_HSDIV_OUTPUT_ENABLE_3 (1U << 3U)
623 #define RCM_PLL_HSDIV_OUTPUT_ENABLE_ALL (RCM_PLL_HSDIV_OUTPUT_ENABLE_0 | \
624 RCM_PLL_HSDIV_OUTPUT_ENABLE_1 | \
625 RCM_PLL_HSDIV_OUTPUT_ENABLE_2 | \
626 RCM_PLL_HSDIV_OUTPUT_ENABLE_3)
628 #define RCM_PLL_HSDIV_OUTPUT_IDX0 (0)
629 #define RCM_PLL_HSDIV_OUTPUT_IDX1 (1)
630 #define RCM_PLL_HSDIV_OUTPUT_IDX2 (2)
631 #define RCM_PLL_HSDIV_OUTPUT_IDX3 (3)
632 #define RCM_PLL_HSDIV_OUTPUT_COUNT (RCM_PLL_HSDIV_OUTPUT_IDX3 + 1)
634 typedef struct SOC_RcmPllHsDivOutConfig_s
SOC_Rcmr5fssNum
Definition: soc_rcm.h:296
@ RCM_PLLHSDIV_OUT_NONE
Value specifying invalid/no HSDIVIDER ID.
Definition: soc_rcm.h:593
@ SOC_RcmPeripheralId_LIN0_UART0
Value specifying LIN0_UART0.
Definition: soc_rcm.h:426
@ SOC_RcmPeripheralId_MCAN5
Value specifying MCAN5.
Definition: soc_rcm.h:454
void SOC_rcmR5SS1PowerOnReset(void)
Reset R5SS1 Core.
@ RCM_PLLHSDIV_OUT_1
Value specifying HSDIVIDER 1.
Definition: soc_rcm.h:585
@ SOC_RcmPeripheralId_MCSPI7
Value specifying MCSPI7.
Definition: soc_rcm.h:398
@ SOC_RcmResetCause_MMR_CPU0_VIM0_RESET
Value specifying R5 Core A Subsytem Reset.
Definition: soc_rcm.h:253
@ SOC_WARM_RESET_PAD_TIME_1024US
Delay Value specifying in time 1024us.
Definition: soc_rcm.h:210
@ SOC_RcmPeripheralId_WDT2
Value specifying WDT2.
Definition: soc_rcm.h:362
void SOC_configureWarmResetInputFallDelay(uint16_t inpFallDelayValue)
Program output delay on warm reset Pad 3.
@ RCM_PLLID_CORE
Definition: soc_rcm.h:561
@ SOC_RcmResetCause_MMR_CPU0_RESET
Value specifying R5 Core A (core only) Reset.
Definition: soc_rcm.h:261
void SOC_rcmCoreApllHSDivConfig(SOC_RcmPllFoutFreqId outFreqId, SOC_RcmPllHsDivOutConfig *hsDivCfg)
Configure CORE PLL HSDIVIDERS.
@ RCM_PLLID_PER
Definition: soc_rcm.h:562
int32_t SOC_rcmEnablePeripheralClock(SOC_RcmPeripheralId periphId, uint32_t enable)
Enable/disable module clock (IP clock configuration)
void SOC_rcmCoreR5FUnhalt(uint32_t cpuId)
Unhalt R5 cores.
uint32_t SOC_rcmCoreApllRelockPreRequisite(void)
Pre-requisite sequence to Re-configure CORE PLL.
@ SOC_WarmResetSource_TSENSE1
Value specifying Temperature Sensor 1.
Definition: soc_rcm.h:134
@ r5fss1
Value specifying Warm Reset.
Definition: soc_rcm.h:304
@ SOC_RcmPeripheralId_RTI1
Value specifying RTI1.
Definition: soc_rcm.h:342
Definition: soc_rcm.h:610
@ SOC_RcmPeripheralId_MCSPI2
Value specifying MCSPI2.
Definition: soc_rcm.h:378
SOC_RcmPeripheralClockSource
Definition: soc_rcm.h:472
uint32_t FracM
Definition: soc_rcm.h:614
@ SOC_WARM_RESET_PAD_TIME_128US
Delay Value specifying in time 128us.
Definition: soc_rcm.h:198
void SOC_rcmsetTraceClock(uint32_t traceFreqHz)
Set Trace clock frequency.
@ SOC_RcmPeripheralId_MCSPI0
Value specifying MCSPI0.
Definition: soc_rcm.h:370
@ RCM_PLL_FOUT_FREQID_CLK_800MHZ
Value specifying PLL output frequency 800MHz.
Definition: soc_rcm.h:542
void SOC_rcmStartMemInitTCMA(uint32_t cpuId)
Start memory initialization for R5 TCMA.
@ SOC_WARM_RESET_PAD_TIME_512US
Delay Value specifying in time 512us.
Definition: soc_rcm.h:206
uint32_t M
Definition: soc_rcm.h:613
@ SOC_WARM_RESET_PAD_TIME_4US
Delay Value specifying in time 4us.
Definition: soc_rcm.h:178
void SOC_configureWarmResetInputRiseDelay(uint16_t inpRiseDelayValue)
Program input rise delay on warm reset Pad 2.
@ SOC_WARM_RESET_PAD_TIME_2048US
Delay Value specifying in time 2048us.
Definition: soc_rcm.h:214
@ SOC_RcmPeripheralClockSource_DPLL_CORE_HSDIV0_CLKOUT0
Value specifying PLL Core Clock Out 0 (400 Mhz)
Definition: soc_rcm.h:504
uint32_t Fout
Definition: soc_rcm.h:615
@ SOC_WARM_RESET_PAD_TIME_2US
Delay Value specifying in time 2us.
Definition: soc_rcm.h:174
@ SOC_WarmResetCause_MSS_WDT0
Value specifying MSS WDT0.
Definition: soc_rcm.h:71
void SOC_rcmSetR5ClockSource(uint32_t r5ClkSrc)
Set R5 clock source.
@ SOC_WarmResetCause_EXT_PAD_RESET
Value specifying External Pad Reset.
Definition: soc_rcm.h:91
@ SOC_WarmResetCause_MSS_WDT3
Value specifying MSS WDT3.
Definition: soc_rcm.h:83
@ SOC_RcmPeripheralId_LIN4_UART4
Value specifying LIN4_UART4.
Definition: soc_rcm.h:442
@ SOC_RcmResetCause_POWER_ON_RESET
Value specifying Power ON Reset.
Definition: soc_rcm.h:241
void SOC_rcmWaitMemInitTCMB(uint32_t cpuId)
Wait memory initialization to complete for R5 TCMB.
SOC_RcmPeripheralId
Definition: soc_rcm.h:314
@ SOC_RcmPeripheralClockSource_XTALCLK
Value specifying Crystal Clock.
Definition: soc_rcm.h:476
void SOC_rcmStartMemInitTCMB(uint32_t cpuId)
Start memory initialization for R5 TCMB.
@ SOC_WARM_RESET_PAD_TIME_8US
Delay Value specifying in time 8us.
Definition: soc_rcm.h:182
@ SOC_RcmResetCause_RST_CAUSE_UNKNOWN
Value specifying R5 Reset due to Unknown reason.
Definition: soc_rcm.h:285
void SOC_rcmsetClkoutClock(uint32_t clkout0FreqHz, uint32_t clkout1FreqHz)
Set CLKOUT clock frequency.
@ SOC_RcmPeripheralId_WDT1
Value specifying WDT1.
Definition: soc_rcm.h:358
@ SOC_WARM_RESET_PAD_TIME_32US
Delay Value specifying in time 32us.
Definition: soc_rcm.h:190
@ SOC_WarmResetCause_TOP_RCM_WARM_RESET_REQ
Value specifying Software Warm Reset.
Definition: soc_rcm.h:87
@ SOC_RcmPeripheralId_GPMC
Value specifying GPMC.
Definition: soc_rcm.h:414
@ SOC_RcmPeripheralClockSource_DPLL_PER_HSDIV0_CLKOUT0
Value specifying PLL Core Clock Out 0 (160 Mhz)
Definition: soc_rcm.h:516
void SOC_configureWarmResetOutputDelay(uint16_t opDelayValue)
Program output delay on warm reset Pad 1.
@ SOC_RcmPeripheralClockSource_SYS_CLK
Value specifying System Clock (200Mhz)
Definition: soc_rcm.h:480
@ SOC_WARM_RESET_PAD_TIME_1US
Delay Value specifying in time 1us.
Definition: soc_rcm.h:170
@ SOC_RcmPeripheralId_MCSPI1
Value specifying MCSPI1.
Definition: soc_rcm.h:374
@ SOC_WarmResetSource_TSENSE0
Value specifying Temperature Sensor 0.
Definition: soc_rcm.h:130
Definition: soc_rcm.h:635
@ SOC_RcmPeripheralId_MCSPI3
Value specifying MCSPI3.
Definition: soc_rcm.h:382
@ SOC_WarmResetSource_WDOG2
Value specifying Watchdog 2.
Definition: soc_rcm.h:146
@ SOC_RcmPeripheralId_WDT3
Value specifying WDT3.
Definition: soc_rcm.h:366
SOC_RcmPllHSDIVOutId
Definition: soc_rcm.h:577
@ SOC_RcmPeripheralId_MCSPI6
Value specifying MCSPI6.
Definition: soc_rcm.h:394
SOC_RcmXtalFreqId
Definition: soc_rcm.h:552
int32_t SOC_rcmSetPeripheralClock(SOC_RcmPeripheralId periphId, SOC_RcmPeripheralClockSource clkSource, uint32_t freqHz)
Set module clock (IP clock configuration)
Definition: soc_rcm.h:604
SOC_RcmPllId pllId
Definition: soc_rcm.h:599
SOC_RcmResetCause SOC_rcmGetResetCause(SOC_Rcmr5fssNum r5fssNum)
Get R5FSS reset cause.
@ SOC_RcmPeripheralId_MCAN4
Value specifying MCAN4.
Definition: soc_rcm.h:450
void SOC_rcmsetR5SysClock(uint32_t cr5FreqHz, uint32_t sysClkFreqHz, uint32_t cpuId)
Set R5FSS and Sysclk frequency (Root clock configuration)
@ SOC_WARM_RESET_PAD_TIME_8192US
Delay Value specifying in time 8192us.
Definition: soc_rcm.h:222
uint32_t Finp
Definition: soc_rcm.h:605
@ SOC_WARM_RESET_PAD_TIME_16384US
Delay Value specifying in time 16384us.
Definition: soc_rcm.h:226
@ SOC_WARM_RESET_PAD_TIME_500NS
Delay Value specifying in time 500ns.
Definition: soc_rcm.h:166
@ SOC_RcmPeripheralId_I2C
Value specifying I2C.
Definition: soc_rcm.h:422
@ SOC_RcmPeripheralId_MCAN2
Value specifying MCAN2.
Definition: soc_rcm.h:326
@ SOC_RcmResetCause_FSM_TRIGGER_RESET
Value specifying R5 Reset due to FSM Trigger.
Definition: soc_rcm.h:277
uint32_t SOC_rcmIsR5FInLockStepMode(uint32_t r5fClusterGroupId)
Return R5SS status operating in lockstep or dual core mode.
SOC_RcmResetCause
Definition: soc_rcm.h:237
@ RCM_PLLID_WUCPUCLK
Definition: soc_rcm.h:564
@ SOC_RcmPeripheralId_LIN5_UART5
Value specifying LIN5_UART5.
Definition: soc_rcm.h:446
void SOC_clearWarmResetCause(void)
Clear Reset Cause register.
@ SOC_RcmResetCause_DBG_CPU1_RESET
Value specifying R5 Core B Debug Reset.
Definition: soc_rcm.h:273
@ SOC_WarmResetCause_TEMP_SENSOR1_RESET
Value specifying Temperature Sensor1 Reset.
Definition: soc_rcm.h:107
void SOC_rcmMemInitMailboxMemory(void)
Wait memory initialization to complete for Mailbox memory.
@ SOC_RcmResetCause_DBG_CPU0_RESET
Value specifying R5 Core A Debug Reset.
Definition: soc_rcm.h:269
@ SOC_RcmPeripheralId_MCAN0
Value specifying MCAN0.
Definition: soc_rcm.h:318
@ SOC_RcmPeripheralId_MCAN6
Value specifying MCAN6.
Definition: soc_rcm.h:458
@ RCM_PLLID_RCCLK32K
Definition: soc_rcm.h:565
@ SOC_WarmResetSource_WDOG0
Value specifying Watchdog 0.
Definition: soc_rcm.h:138
@ RCM_PLLID_RCCLK10M
Definition: soc_rcm.h:566
@ SOC_WARM_RESET_PAD_TIME_16US
Delay Value specifying in time 16us.
Definition: soc_rcm.h:186
@ RCM_XTAL_FREQID_CLK_25MHZ
Value specifying XTAL frequency 25MHZ.
Definition: soc_rcm.h:556
void SOC_rcmR5SS1TriggerReset(void)
Trigger R5SS1 core reset.
@ RCM_PLLHSDIV_OUT_0
Value specifying HSDIVIDER 0.
Definition: soc_rcm.h:581
uint32_t hsdivOutEnMask
Definition: soc_rcm.h:636
@ SOC_WarmResetCause_HSM_WDT
Value specifying HSM WDT.
Definition: soc_rcm.h:95
@ SOC_RcmPeripheralId_MCSPI5
Value specifying MCSPI5.
Definition: soc_rcm.h:390
Definition: soc_rcm.h:598
void SOC_rcmR5ConfigLockStep(uint32_t cpuId)
Configure R5 in lock step mode.
@ SOC_RcmPeripheralId_RTI0
Value specifying RTI0.
Definition: soc_rcm.h:338
void SOC_rcmR5SS0TriggerReset(void)
Trigger R5 core reset.
bool div2flag
Definition: soc_rcm.h:606
void SOC_rcmPerApllConfig(SOC_RcmPllFoutFreqId outFreqId, SOC_RcmPllHsDivOutConfig *hsDivCfg)
Configure PER PLL.
void SOC_rcmWaitMemInitTCMA(uint32_t cpuId)
Wait memory initialization to complete for R5 TCMA.
int32_t SOC_rcmSetR5Clock(uint32_t r5FreqHz, uint32_t sysClkFreqHz, uint32_t cpuId)
Set R5SS0/R5SS1 and SysClk frequency.
@ SOC_RcmPeripheralClockSource_RCCLK32K
Value specifying RC clock (32KHz)
Definition: soc_rcm.h:496
@ SOC_WARM_RESET_PAD_TIME_64US
Delay Value specifying in time 64us.
Definition: soc_rcm.h:194
@ SOC_RcmPeripheralId_MCSPI4
Value specifying MCSPI4.
Definition: soc_rcm.h:386
@ SOC_WarmResetCause_MSS_WDT2
Value specifying MSS WDT2.
Definition: soc_rcm.h:79
@ SOC_RcmPeripheralClockSource_EXT_REFCLK
Value specifying external reference clock.
Definition: soc_rcm.h:488
@ SOC_RcmPeripheralId_ICSSM0_UART0
Value specifying ICSSM0_UART0.
Definition: soc_rcm.h:406
@ SOC_WarmResetCause_MSS_WDT1
Value specifying MSS WDT1.
Definition: soc_rcm.h:75
@ SOC_WARM_RESET_PAD_TIME_256US
Delay Value specifying in time 256us.
Definition: soc_rcm.h:202
@ SOC_RcmPeripheralId_MCAN3
Value specifying MCAN3.
Definition: soc_rcm.h:330
uint32_t Finp
Definition: soc_rcm.h:616
SOC_RcmPllId
Definition: soc_rcm.h:560
@ RCM_PLL_FOUT_FREQID_CLK_2000MHZ
Value specifying PLL output frequency 2000MHz.
Definition: soc_rcm.h:534
SOC_RcmWarm_ResetTime123
Definition: soc_rcm.h:162
@ SOC_RcmPeripheralId_LIN3_UART3
Value specifying LIN3_UART3.
Definition: soc_rcm.h:438
@ SOC_WarmResetCause_POWER_ON_RESET
Value specifying Power ON Reset.
Definition: soc_rcm.h:67
@ SOC_RcmPeripheralClockSource_WUCPUCLK
Value specifying wake up clock.
Definition: soc_rcm.h:484
@ SOC_RcmPeripheralId_RTI3
Value specifying RTI3.
Definition: soc_rcm.h:350
void SOC_rcmR5SS0PowerOnReset(void)
Reset R5SS0 Core.
@ SOC_RcmPeripheralClockSource_DPLL_PER_HSDIV0_CLKOUT1
Value specifying PLL Core Clock Out 1 (192 Mhz)
Definition: soc_rcm.h:520
@ SOC_RcmPeripheralId_LIN1_UART1
Value specifying LIN1_UART1.
Definition: soc_rcm.h:430
@ SOC_RcmPeripheralId_MCAN1
Value specifying MCAN1.
Definition: soc_rcm.h:322
void SOC_generateSwWarmReset(void)
Generate SW WARM reset.
@ SOC_WarmResetSource_WDOG1
Value specifying Watchdog 1.
Definition: soc_rcm.h:142
@ SOC_RcmPeripheralId_RTI2
Value specifying RTI2.
Definition: soc_rcm.h:346
@ SOC_WarmResetCause_TEMP_SENSOR0_RESET
Value specifying Temperature Sensor0 Reset.
Definition: soc_rcm.h:103
uint32_t N
Definition: soc_rcm.h:611
@ SOC_RcmResetCause_STC_RESET
Value specifying STC Reset.
Definition: soc_rcm.h:249
@ SOC_RcmPeripheralClockSource_DPLL_CORE_HSDIV0_CLKOUT1
Value specifying PLL Core Clock Out 1 (500 Mhz)
Definition: soc_rcm.h:508
@ RCM_PLL_FOUT_FREQID_CLK_1920MHZ
Value specifying PLL output frequency 1920MHz.
Definition: soc_rcm.h:538
@ SOC_RcmResetCause_WARM_RESET
Value specifying Warm Reset.
Definition: soc_rcm.h:245
@ SOC_RcmPeripheralId_MMC0
Value specifying MMC0.
Definition: soc_rcm.h:402
SOC_WarmResetSource
Definition: soc_rcm.h:118
void SOC_rcmR5ConfigDualCore(uint32_t cpuId)
Configure R5 in dual core mode.
void SOC_rcmMemInitL2Memory(void)
Wait memory initialization to complete for L2 Bank2 and Bank3 memory.
@ SOC_RcmPeripheralId_OSPI0
Value specifying OSPI0.
Definition: soc_rcm.h:334
@ SOC_WARM_RESET_PAD_TIME_4096US
Delay Value specifying in time 4096us.
Definition: soc_rcm.h:218
SOC_WarmResetCause
Definition: soc_rcm.h:63
@ SOC_RcmResetCause_MMR_CPU1_VIM1_RESET
Value specifying R5 Core B Subsytem Reset.
Definition: soc_rcm.h:257
@ SOC_RcmPeripheralId_MCAN7
Value specifying MCAN7.
Definition: soc_rcm.h:462
@ SOC_WarmResetSource_DEBUGSS
Value specifying DebugSS.
Definition: soc_rcm.h:126
SOC_RcmPllHSDIVOutId hsDivOut
Definition: soc_rcm.h:600
@ SOC_WarmResetCause_DBG_RESET
Value specifying Debugger Reset.
Definition: soc_rcm.h:99
@ RCM_PLLID_EXTREFCLK
Definition: soc_rcm.h:567
SOC_WarmResetCause SOC_getWarmResetCause(void)
Returns cause of WARM reset.
@ SOC_RcmPeripheralId_LIN2_UART2
Value specifying LIN2_UART2.
Definition: soc_rcm.h:434
SOC_RcmPllFoutFreqId
Definition: soc_rcm.h:530
@ RCM_PLLID_XTALCLK
Definition: soc_rcm.h:563
@ SOC_WarmResetSource_WDOG3
Value specifying Watchdog 3.
Definition: soc_rcm.h:150
uint32_t M2
Definition: soc_rcm.h:612
@ r5fss0
Value specifying Power ON Reset.
Definition: soc_rcm.h:300
@ SOC_RcmResetCause_MMR_CPU1_RESET
Value specifying R5 Core B (core only) Reset.
Definition: soc_rcm.h:265
@ RCM_PLLHSDIV_OUT_2
Value specifying HSDIVIDER 2.
Definition: soc_rcm.h:589
@ SOC_RcmPeripheralId_WDT0
Value specifying WDT0.
Definition: soc_rcm.h:354
uint32_t SOC_rcmGetR5Clock(uint32_t cpuId)
Get R5SS0/1 frequency.
@ SOC_RcmPeripheralId_CONTROLSS_PLL
Value specifying CONTROLSS_PLL.
Definition: soc_rcm.h:418
@ SOC_WarmResetSource_PAD_BYPASS
Value specifying Pad Warm Reset pin.
Definition: soc_rcm.h:122
@ SOC_RcmPeripheralId_CPTS
Value specifying CPTS.
Definition: soc_rcm.h:410
void SOC_configureWarmResetSource(uint32_t source)
Configure WARM reset source.
@ SOC_RcmPeripheralClockSource_CTPS_GENF0
Value specifying CPTS GENF0 clock.
Definition: soc_rcm.h:500
#define RCM_PLL_HSDIV_OUTPUT_COUNT
Definition: soc_rcm.h:632
@ SOC_RcmPeripheralClockSource_DPLL_CORE_HSDIV0_CLKOUT2
Value specifying PLL Core Clock Out 2 (400 Mhz)
Definition: soc_rcm.h:512
void SOC_rcmCoreApllConfig(SOC_RcmPllFoutFreqId outFreqId, SOC_RcmPllHsDivOutConfig *hsDivCfg)
Configure CORE PLL.
@ SOC_RcmResetCause_POR_RST_CTRL0
Value specifying R5 Reset due to write to debug POR RST CTRL Reg.
Definition: soc_rcm.h:281
@ SOC_RcmPeripheralClockSource_RCCLK10M
Value specifying RC clock (10MHz)
Definition: soc_rcm.h:492