AM273x MCU+ SDK  09.02.00
bootloader_soc.h File Reference

Go to the source code of this file.

Data Structures

struct  Bootloader_CoreBootInfo
 Data structure containing information about a core specific to the AM273x SOC. More...
 
struct  Bootloader_socCoreOpModeConfig
 Data structure containing information about the operating mode specific to the SOC. More...
 

Macros

#define BOOTLOADER_SOC_EFUSE_REG_ROW11   (0x030E0424)
 eFUSE information for identifying different SOC variants More...
 
#define BOOTLOADER_SOC_DSP_PART_MASK   (0x70U)
 
#define BOOTLOADER_SOC_DSP_PART_450MHZ   (0x00)
 
#define BOOTLOADER_SOC_DSP_PART_480MHZ   (0x10)
 
#define BOOTLOADER_SOC_DSP_PART_500MHZ   (0x20)
 
#define BOOTLOADER_SOC_DSP_PART_550MHZ   (0x30)
 
#define BOOTLOADER_SOC_DSP_PART_600MHZ   (0x40)
 
#define BOOTLOADER_SOC_DSP_PART_DITHER   (0x50)
 
#define BOOTLOADER_SOC_DSP_PART_300MHZ   (0x60)
 
#define BOOTLOADER_SOC_R5_FREQ_MASK   (uint32_t)(1U << 21U)
 
#define BOOTLOADER_SOC_R5_PART_400MHZ   (0x00000000)
 
#define BOOTLOADER_SOC_R5_PART_200MHZ   (uint32_t)(1U << 21U)
 
#define BOOTLOADER_SOC_EFUSE_DUAL_CORE_DIS_MASK   (uint32_t)(1U << 14U)
 
#define BOOTLOADER_SOC_VARIANT_DUAL_R5F   (0x00000000)
 
#define BOOTLOADER_SOC_VARIANT_SINGLE_R5F   (uint32_t)(1U << 14U)
 
Device Types

#define BOOTLOADER_DEVTYPE_HSSE   (0x0AU)
 device type HSSE More...
 
#define BOOTLOADER_DEVTYPE_HSFS   (0xAAU)
 device type HSFS More...
 
#define BOOTLOADER_DEVTYPE_GP   (0x03U)
 device type GP
More...
 
#define BOOTLOADER_CLIENT_ID   (0x02)
 hsmclient ID for bootloader More...
 

Functions

int32_t Bootloader_socCpuRequest (uint32_t cpuId)
 Request for a particular CPU in the AM64x SOC. More...
 
int32_t Bootloader_socCpuRelease (uint32_t cpuId)
 Release a particular CPU in the AM64x SOC. More...
 
int32_t Bootloader_socCpuSetClock (uint32_t cpuId, uint32_t cpuHz)
 Set the clock of a particular CPU in the AM64x SOC. More...
 
uint64_t Bootloader_socCpuGetClock (uint32_t cpuId)
 Get the clock of a particular CPU in the AM64x SOC. More...
 
uint32_t Bootloader_socCpuGetClkDefault (uint32_t cpuId)
 Get the default clock of a particular CPU in the AM64x SOC. More...
 
int32_t Bootloader_socCpuPowerOnReset (uint32_t cpuId, void *socCoreOpMode)
 Do power-on-reset of a particular CPU in the AM64x SOC. More...
 
int32_t Bootloader_socCpuResetRelease (uint32_t cpuId, uintptr_t entryPoint)
 Release a particular CPU in the AM64x SOC from reset. More...
 
int32_t Bootloader_socCpuResetReleaseSelf (void)
 Release self CPU in the AM64x SOC from reset. More...
 
int32_t Bootloader_socCpuSetEntryPoint (uint32_t cpuId, uintptr_t entryPoint)
 Set entry point for self CPU in the AM64x SOC from reset. More...
 
uint32_t Bootloader_socTranslateSectionAddr (uint32_t cslCoreId, uint32_t addr)
 Translate a CPU address to the SOC address wherever applicable. More...
 
uint32_t Bootloader_socRprcToCslCoreId (uint32_t rprcCoreId)
 Obtain the CSL core ID of a CPU from its RPRC core ID. More...
 
uint32_t * Bootloader_socGetSelfCpuList (void)
 Get the list of self cpus in the SOC. More...
 
char * Bootloader_socGetCoreName (uint32_t cpuId)
 Get the name of a core. More...
 
int32_t Bootloader_socMemInitCpu (uint32_t cpuId)
 Initialize the core memories of a specific core. More...
 
int32_t Bootloader_socSecHandover (void)
 API to trigger the security handover from SYSFW. More...
 
void Bootloader_socConfigurePll (void)
 
int32_t Bootloader_socAuthImage (uint32_t certLoadAddr)
 API to authenticate (and decrypt if needed) an appimage using SYSFW. More...
 
uint32_t Bootloader_socIsAuthRequired (void)
 API to check if authentication is required for the device. Checks the SYS_STATUS register to see if device is GP, HS-FS, HS-SE etc. More...
 
void Bootloader_socLoadHsmRtFw (HsmClient_t *gHSMClient, const uint8_t *HsmRtFw, uint32_t hsmRTSize)
 API to load hsm runtime firmware. More...
 
void Bootloader_socGetBootSeqOid (uint8_t *boot_seq_oid)
 API to get boot sequence oid. More...
 
uint32_t Bootloader_socGetCoreVariant (void)
 API to check R5F core variant of the SOC - whether it's a dual core or a single core variant. More...
 

Macro Definition Documentation

◆ BOOTLOADER_DEVTYPE_HSSE

#define BOOTLOADER_DEVTYPE_HSSE   (0x0AU)

device type HSSE

◆ BOOTLOADER_DEVTYPE_HSFS

#define BOOTLOADER_DEVTYPE_HSFS   (0xAAU)

device type HSFS

◆ BOOTLOADER_DEVTYPE_GP

#define BOOTLOADER_DEVTYPE_GP   (0x03U)

device type GP

◆ BOOTLOADER_CLIENT_ID

#define BOOTLOADER_CLIENT_ID   (0x02)

hsmclient ID for bootloader

◆ BOOTLOADER_SOC_EFUSE_REG_ROW11

#define BOOTLOADER_SOC_EFUSE_REG_ROW11   (0x030E0424)

eFUSE information for identifying different SOC variants

◆ BOOTLOADER_SOC_DSP_PART_MASK

#define BOOTLOADER_SOC_DSP_PART_MASK   (0x70U)

◆ BOOTLOADER_SOC_DSP_PART_450MHZ

#define BOOTLOADER_SOC_DSP_PART_450MHZ   (0x00)

◆ BOOTLOADER_SOC_DSP_PART_480MHZ

#define BOOTLOADER_SOC_DSP_PART_480MHZ   (0x10)

◆ BOOTLOADER_SOC_DSP_PART_500MHZ

#define BOOTLOADER_SOC_DSP_PART_500MHZ   (0x20)

◆ BOOTLOADER_SOC_DSP_PART_550MHZ

#define BOOTLOADER_SOC_DSP_PART_550MHZ   (0x30)

◆ BOOTLOADER_SOC_DSP_PART_600MHZ

#define BOOTLOADER_SOC_DSP_PART_600MHZ   (0x40)

◆ BOOTLOADER_SOC_DSP_PART_DITHER

#define BOOTLOADER_SOC_DSP_PART_DITHER   (0x50)

◆ BOOTLOADER_SOC_DSP_PART_300MHZ

#define BOOTLOADER_SOC_DSP_PART_300MHZ   (0x60)

◆ BOOTLOADER_SOC_R5_FREQ_MASK

#define BOOTLOADER_SOC_R5_FREQ_MASK   (uint32_t)(1U << 21U)

◆ BOOTLOADER_SOC_R5_PART_400MHZ

#define BOOTLOADER_SOC_R5_PART_400MHZ   (0x00000000)

◆ BOOTLOADER_SOC_R5_PART_200MHZ

#define BOOTLOADER_SOC_R5_PART_200MHZ   (uint32_t)(1U << 21U)

◆ BOOTLOADER_SOC_EFUSE_DUAL_CORE_DIS_MASK

#define BOOTLOADER_SOC_EFUSE_DUAL_CORE_DIS_MASK   (uint32_t)(1U << 14U)

◆ BOOTLOADER_SOC_VARIANT_DUAL_R5F

#define BOOTLOADER_SOC_VARIANT_DUAL_R5F   (0x00000000)

◆ BOOTLOADER_SOC_VARIANT_SINGLE_R5F

#define BOOTLOADER_SOC_VARIANT_SINGLE_R5F   (uint32_t)(1U << 14U)

Function Documentation

◆ Bootloader_socCpuRequest()

int32_t Bootloader_socCpuRequest ( uint32_t  cpuId)

Request for a particular CPU in the AM64x SOC.

This API internally makes Sciclient calls to request control of the CPU

Parameters
cpuId[in] The CSL ID of the core
Returns
SystemP_SUCCESS on success, else failure

◆ Bootloader_socCpuRelease()

int32_t Bootloader_socCpuRelease ( uint32_t  cpuId)

Release a particular CPU in the AM64x SOC.

This API internally makes Sciclient calls to release control of the CPU

Parameters
cpuId[in] The CSL ID of the core
Returns
SystemP_SUCCESS on success, else failure

◆ Bootloader_socCpuSetClock()

int32_t Bootloader_socCpuSetClock ( uint32_t  cpuId,
uint32_t  cpuHz 
)

Set the clock of a particular CPU in the AM64x SOC.

This API internally makes Sciclient calls to set CPU clock

Parameters
cpuId[in] The CSL ID of the core
cpuHz[in] Desired clock frequency of the CPU in Hertz
Returns
SystemP_SUCCESS on success, else failure

◆ Bootloader_socCpuGetClock()

uint64_t Bootloader_socCpuGetClock ( uint32_t  cpuId)

Get the clock of a particular CPU in the AM64x SOC.

This API internally makes Sciclient calls to get the current clock frequency of CPU

Parameters
cpuId[in] The CSL ID of the core
Returns
Current clock speed of the CPU

◆ Bootloader_socCpuGetClkDefault()

uint32_t Bootloader_socCpuGetClkDefault ( uint32_t  cpuId)

Get the default clock of a particular CPU in the AM64x SOC.

This API queries and internal lookup table to fetch the default clock speed at which a particular CPU should run.

Parameters
cpuId[in] The CSL ID of the core
Returns
Default clock speed of the CPU

◆ Bootloader_socCpuPowerOnReset()

int32_t Bootloader_socCpuPowerOnReset ( uint32_t  cpuId,
void *  socCoreOpMode 
)

Do power-on-reset of a particular CPU in the AM64x SOC.

This API is called only when booting a non-self CPU.

Parameters
cpuId[in] The CSL ID of the core
socCoreOpModeLockstep/Dual core mode as per setting in syscfg.
Returns
SystemP_SUCCESS on success, else failure

◆ Bootloader_socCpuResetRelease()

int32_t Bootloader_socCpuResetRelease ( uint32_t  cpuId,
uintptr_t  entryPoint 
)

Release a particular CPU in the AM64x SOC from reset.

This API is called only when booting a non-self CPU. There is a different API Bootloader_socCpuResetReleaseSelf in the case of a self CPU

Parameters
cpuId[in] The CSL ID of the core
entryPoint[in] The entryPoint of the CPU, from where it should start execution
Returns
SystemP_SUCCESS on success, else failure

◆ Bootloader_socCpuResetReleaseSelf()

int32_t Bootloader_socCpuResetReleaseSelf ( void  )

Release self CPU in the AM64x SOC from reset.

Returns
SystemP_SUCCESS on success, else failure

◆ Bootloader_socCpuSetEntryPoint()

int32_t Bootloader_socCpuSetEntryPoint ( uint32_t  cpuId,
uintptr_t  entryPoint 
)

Set entry point for self CPU in the AM64x SOC from reset.

This API need not be called when booting a non-self CPU. The entry point can be specified in the Bootloader_socCpuResetRelease function itself

Parameters
cpuId[in] The CSL ID of the core
entryPoint[in] The entryPoint of the CPU, from where it should start execution
Returns
SystemP_SUCCESS on success, else failure

◆ Bootloader_socTranslateSectionAddr()

uint32_t Bootloader_socTranslateSectionAddr ( uint32_t  cslCoreId,
uint32_t  addr 
)

Translate a CPU address to the SOC address wherever applicable.

This API need not be called when booting a non-self CPU. The entry point can be specified in the Bootloader_socCpuResetRelease function itself

Parameters
cslCoreId[in] The CSL ID of the core
addr[in] The CPU addr
Returns
SystemP_SUCCESS on success, else failure

◆ Bootloader_socRprcToCslCoreId()

uint32_t Bootloader_socRprcToCslCoreId ( uint32_t  rprcCoreId)

Obtain the CSL core ID of a CPU from its RPRC core ID.

Parameters
rprcCoreId[in] The RPRC ID of the core
Returns
CSL core ID of a CPU

◆ Bootloader_socGetSelfCpuList()

uint32_t* Bootloader_socGetSelfCpuList ( void  )

Get the list of self cpus in the SOC.

Returns
List of self cpus ending with an invalid core id

◆ Bootloader_socGetCoreName()

char* Bootloader_socGetCoreName ( uint32_t  cpuId)

Get the name of a core.

Parameters
cpuId[in] The CSL ID of the core
Returns
Name of the CPU

◆ Bootloader_socMemInitCpu()

int32_t Bootloader_socMemInitCpu ( uint32_t  cpuId)

Initialize the core memories of a specific core.

Parameters
cpuId[in] The CSL ID of the core
Returns
SystemP_SUCCESS on success, else failure

◆ Bootloader_socSecHandover()

int32_t Bootloader_socSecHandover ( void  )

API to trigger the security handover from SYSFW.

Returns
SystemP_SUCCESS on success, else failure

◆ Bootloader_socConfigurePll()

void Bootloader_socConfigurePll ( void  )

◆ Bootloader_socAuthImage()

int32_t Bootloader_socAuthImage ( uint32_t  certLoadAddr)

API to authenticate (and decrypt if needed) an appimage using SYSFW.

Parameters
certLoadAddr[in] The SOC address pointing to the certificate+appimage
Returns
SystemP_SUCCESS on success, else failure

◆ Bootloader_socIsAuthRequired()

uint32_t Bootloader_socIsAuthRequired ( void  )

API to check if authentication is required for the device. Checks the SYS_STATUS register to see if device is GP, HS-FS, HS-SE etc.

Returns
TRUE (1U) if authentication required, FALSE (0U) if not.

◆ Bootloader_socLoadHsmRtFw()

void Bootloader_socLoadHsmRtFw ( HsmClient_t gHSMClient,
const uint8_t *  HsmRtFw,
uint32_t  hsmRTSize 
)

API to load hsm runtime firmware.

◆ Bootloader_socGetBootSeqOid()

void Bootloader_socGetBootSeqOid ( uint8_t *  boot_seq_oid)

API to get boot sequence oid.

Parameters
boot_seq_oid[in] pointer to integer array for populating boot sequence oid

◆ Bootloader_socGetCoreVariant()

uint32_t Bootloader_socGetCoreVariant ( void  )

API to check R5F core variant of the SOC - whether it's a dual core or a single core variant.

Returns
BOOTLOADER_SOC_VARIANT_DUAL_R5F or BOOTLOADER_SOC_VARIANT_SINGLE_R5F