mirror of
https://github.com/drasko/open-ameba.git
synced 2024-11-25 15:34:18 +00:00
update & add lib_mdns + src boot
This commit is contained in:
parent
e3bed82651
commit
b5acfc0868
4 changed files with 412 additions and 86 deletions
|
@ -1,4 +1,5 @@
|
||||||
/*
|
/*
|
||||||
|
* BootLoader
|
||||||
* startup.o sdk-ameba-rtl8710af-v3.5a_without_NDA_GCC_V1.0.0
|
* startup.o sdk-ameba-rtl8710af-v3.5a_without_NDA_GCC_V1.0.0
|
||||||
* pvvx 2016
|
* pvvx 2016
|
||||||
*/
|
*/
|
||||||
|
@ -15,54 +16,73 @@
|
||||||
#include "hal_peri_on.h"
|
#include "hal_peri_on.h"
|
||||||
#include "wifi_conf.h"
|
#include "wifi_conf.h"
|
||||||
|
|
||||||
|
#ifndef USE_SRC_ONLY_BOOT
|
||||||
|
#define USE_SRC_ONLY_BOOT 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if USE_SRC_ONLY_BOOT
|
||||||
|
#define rtl_memset _memset
|
||||||
|
#define rtl_strcmp _strcmp
|
||||||
|
#define rtl_memcpy _memcpy
|
||||||
|
#endif
|
||||||
|
|
||||||
#define VREG32(addr) ((u32)(*((volatile u32*)(addr))))
|
#define VREG32(addr) ((u32)(*((volatile u32*)(addr))))
|
||||||
|
|
||||||
typedef void (*START_FUNC)(void);
|
typedef void (*START_FUNC)(void);
|
||||||
|
|
||||||
#define DEFAULT_BAUDRATE UART_BAUD_RATE_38400
|
#define DEFAULT_BAUDRATE UART_BAUD_RATE_38400
|
||||||
|
#define StartupSpicBitMode SpicDualBitMode // SpicOneBitMode //
|
||||||
|
#define StartupSpicBaudRate 0
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
// Function declarations
|
// Function declarations
|
||||||
extern void HalWdgIntrHandle(void);
|
void PreProcessForVendor(void); // image1
|
||||||
extern VOID UartLogIrqHandle(VOID * Data);
|
void RtlBootToSram(void); // image1
|
||||||
|
u32 StartupHalLogUartInit(u32 uart_irq); // image1
|
||||||
|
void StartupHalInitPlatformLogUart(void); // image1
|
||||||
|
int IsForceLoadDefaultImg2(void); // image1
|
||||||
|
void StartupHalSpicInit(int InitBaudRate); // image1
|
||||||
|
int _GetChipId(void); // image1
|
||||||
|
void RtlConsolRam(void); // image1
|
||||||
|
extern VOID UartLogIrqHandle(VOID * Data); // in ROM
|
||||||
extern int RtlConsolRom(int); // in ROM
|
extern int RtlConsolRom(int); // in ROM
|
||||||
extern PHAL_GPIO_ADAPTER _pHAL_Gpio_Adapter;
|
extern PHAL_GPIO_ADAPTER _pHAL_Gpio_Adapter;
|
||||||
extern int wifi_off(void); // in wifi_conf.c
|
|
||||||
extern VOID SpicUserReadRtl8195A(IN u32 Length, IN u32 addr, IN u8 * data,
|
extern VOID SpicUserReadRtl8195A(IN u32 Length, IN u32 addr, IN u8 * data,
|
||||||
IN u8 BitMode);
|
IN u8 BitMode);
|
||||||
|
#if !USE_SRC_ONLY_BOOT
|
||||||
|
void InfraStart(void);
|
||||||
|
extern void HalWdgIntrHandle(void);
|
||||||
|
extern int wifi_off(void); // in wifi_conf.c
|
||||||
extern void xPortPendSVHandler(void);
|
extern void xPortPendSVHandler(void);
|
||||||
extern void xPortSysTickHandler(void);
|
extern void xPortSysTickHandler(void);
|
||||||
extern void vPortSVCHandler(void);
|
extern void vPortSVCHandler(void);
|
||||||
extern void ShowRamBuildInfo(void); // app_start.c: VOID ShowRamBuildInfo(VOID)
|
extern void ShowRamBuildInfo(void); // app_start.c: VOID ShowRamBuildInfo(VOID)
|
||||||
|
|
||||||
void HalNMIHandler_Patch(void);
|
void HalNMIHandler_Patch(void);
|
||||||
u32 StartupHalLogUartInit(u32 uart_irq);
|
void SDIO_Device_Off(void);
|
||||||
void StartupHalInitPlatformLogUart(void);
|
|
||||||
void RtlBootToSram(void);
|
|
||||||
int IsForceLoadDefaultImg2(void);
|
|
||||||
void StartupHalSpicInit(int InitBaudRate);
|
|
||||||
void PreProcessForVendor(void);
|
|
||||||
void HalHardFaultHandler_Patch_c(u32 HardDefaultArg);
|
|
||||||
void VectorTableOverrideRtl8195A(u32 StackP);
|
void VectorTableOverrideRtl8195A(u32 StackP);
|
||||||
void SYSPlatformInit(void);
|
void SYSPlatformInit(void);
|
||||||
void InfraStart(void);
|
void HalHardFaultHandler_Patch_c(u32 HardDefaultArg);
|
||||||
void SDIO_Device_Off(void);
|
|
||||||
int _GetChipId(int x, u32 chid);
|
|
||||||
void __HalReInitPlatformLogUart(void);
|
void __HalReInitPlatformLogUart(void);
|
||||||
void _ReloadImg(void);
|
void _ReloadImg(void);
|
||||||
void _ReloadImg_user_define(void);
|
void _ReloadImg_user_define(void);
|
||||||
void _CPUResetHandler(void);
|
void _CPUResetHandler(void);
|
||||||
void _CPUReset(void);
|
void _CPUReset(void);
|
||||||
void HalHardFaultHandler_user_define(u32 HardDefaultArg);
|
void HalHardFaultHandler_user_define(u32 HardDefaultArg);
|
||||||
|
#endif
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
// Data declarations
|
// Data declarations
|
||||||
extern u32 * NewVectorTable; // LD: NewVectorTable = 0x10000000;
|
|
||||||
extern START_FUNC __image2_entry_func__;
|
extern START_FUNC __image2_entry_func__;
|
||||||
extern u8 __image2_validate_code__;
|
extern u8 __image2_validate_code__;
|
||||||
extern u8 __image1_bss_start__, __image1_bss_end__;
|
extern u8 __image1_bss_start__, __image1_bss_end__;
|
||||||
extern u8 __rom_bss_start__, __rom_bss_end__;
|
extern u8 __rom_bss_start__, __rom_bss_end__;
|
||||||
|
//extern u32 STACK_TOP;
|
||||||
|
#define STACK_TOP 0x1FFFFFFC
|
||||||
|
|
||||||
|
#if !USE_SRC_ONLY_BOOT
|
||||||
|
extern u32 * NewVectorTable; // LD: NewVectorTable = 0x10000000;
|
||||||
extern u8 __bss_start__, __bss_end__;
|
extern u8 __bss_start__, __bss_end__;
|
||||||
|
#endif
|
||||||
|
|
||||||
typedef struct __RAM_IMG2_VALID_PATTEN__ {
|
typedef struct __RAM_IMG2_VALID_PATTEN__ {
|
||||||
char rtkwin[7];
|
char rtkwin[7];
|
||||||
|
@ -85,19 +105,26 @@ RAM_START_FUNCTION __attribute__((section(".start.ram.data.d"))) gRamPatchFun1 =
|
||||||
RAM_START_FUNCTION __attribute__((section(".start.ram.data.e"))) gRamPatchFun2 =
|
RAM_START_FUNCTION __attribute__((section(".start.ram.data.e"))) gRamPatchFun2 =
|
||||||
{ RtlBootToSram + 1 };
|
{ RtlBootToSram + 1 };
|
||||||
|
|
||||||
|
#if !USE_SRC_ONLY_BOOT
|
||||||
RAM_START_FUNCTION __attribute__((section(".image2.ram.data"))) gImage2EntryFun0 =
|
RAM_START_FUNCTION __attribute__((section(".image2.ram.data"))) gImage2EntryFun0 =
|
||||||
{ InfraStart + 1 };
|
{ InfraStart + 1 };
|
||||||
|
#else
|
||||||
|
RAM_START_FUNCTION __attribute__((section(".image2.ram.data"))) gImage2EntryFun0 =
|
||||||
|
{ 1 };
|
||||||
|
#endif // !USE_SRC_ONLY_BOOT
|
||||||
_RAM_IMG2_VALID_PATTEN __attribute__((section(".image2.validate.rodata"))) RAM_IMG2_VALID_PATTEN =
|
_RAM_IMG2_VALID_PATTEN __attribute__((section(".image2.validate.rodata"))) RAM_IMG2_VALID_PATTEN =
|
||||||
{ { IMG2_SIGN_TXT }, { 0xff, 0, 1, 1, 0, 0x95, 0x81, 1, 1, 0, 0, 0, 0 } }; // "RTKWin"
|
{ { IMG2_SIGN_TXT }, { 0xff, 0, 1, 1, 0, 0x95, 0x81, 1, 1, 0, 0, 0, 0 } }; // "RTKWin"
|
||||||
|
|
||||||
HAL_GPIO_ADAPTER __attribute__((section(".hal.ram.data"))) gBoot_Gpio_Adapter;
|
HAL_GPIO_ADAPTER __attribute__((section(".hal.ram.data"))) gBoot_Gpio_Adapter;
|
||||||
|
|
||||||
|
#if !USE_SRC_ONLY_BOOT
|
||||||
//----- HalNMIHandler_Patch
|
//----- HalNMIHandler_Patch
|
||||||
void HalNMIHandler_Patch(void) {
|
void HalNMIHandler_Patch(void) {
|
||||||
DBG_8195A_HAL("RTL8195A[HAL]: %s:NMI Error!\n", "HalNMIHandler_Patch");
|
DBG_8195A_HAL("RTL8195A[HAL]: %s:NMI Error!\n", "HalNMIHandler_Patch");
|
||||||
if ( HAL_READ32(VENDOR_REG_BASE, 0) < 0)
|
if ( HAL_READ32(VENDOR_REG_BASE, 0) < 0)
|
||||||
HalWdgIntrHandle(); // ROM: HalWdgIntrHandle = 0x3485;
|
HalWdgIntrHandle(); // ROM: HalWdgIntrHandle = 0x3485;
|
||||||
}
|
}
|
||||||
|
#endif // !USE_SRC_ONLY_BOOT
|
||||||
|
|
||||||
//----- StartupHalLogUartInit
|
//----- StartupHalLogUartInit
|
||||||
u32 __attribute__((section(".hal.ram.text"))) StartupHalLogUartInit(u32 uart_irq) {
|
u32 __attribute__((section(".hal.ram.text"))) StartupHalLogUartInit(u32 uart_irq) {
|
||||||
|
@ -138,11 +165,34 @@ void __attribute__((section(".hal.ram.text"))) StartupHalInitPlatformLogUart(
|
||||||
StartupHalLogUartInit(IER_ERBFI | IER_ELSI);
|
StartupHalLogUartInit(IER_ERBFI | IER_ELSI);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern volatile u8 * pUartLogCtl;
|
||||||
|
extern int UartLogCmdExecute(volatile u8 *);
|
||||||
|
|
||||||
|
void __attribute__((section(".hal.ram.text"))) RtlConsolRam(void)
|
||||||
|
{
|
||||||
|
DiagPrintf("\r\nRTL Console ROM: Start - press 'ESC' key, Help '?'\r\n");
|
||||||
|
// __asm__ __volatile__ ("cpsid f\n");
|
||||||
|
|
||||||
|
while(pUartLogCtl[5] != 1);
|
||||||
|
pUartLogCtl[3] = 0;
|
||||||
|
pUartLogCtl[6] = 1;
|
||||||
|
DiagPrintf("\r<RTL>");
|
||||||
|
__asm__ __volatile__ ("cpsie f\n");
|
||||||
|
while(1) {
|
||||||
|
while(pUartLogCtl[4] != 1 );
|
||||||
|
UartLogCmdExecute(pUartLogCtl);
|
||||||
|
DiagPrintf("\r<RTL>");
|
||||||
|
pUartLogCtl[4] = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extern SPIC_INIT_PARA SpicInitParaAllClk[3][CPU_CLK_TYPE_NO];
|
||||||
|
|
||||||
//----- RtlBootToSram
|
//----- RtlBootToSram
|
||||||
void __attribute__((section(".hal.ram.text"))) RtlBootToSram(void) {
|
void __attribute__((section(".hal.ram.text"))) RtlBootToSram(void) {
|
||||||
TIMER_ADAPTER tim_adapter;
|
TIMER_ADAPTER tim_adapter;
|
||||||
|
|
||||||
memset(&__rom_bss_start__, 0, &__rom_bss_end__ - &__rom_bss_start__);
|
// memset(&__rom_bss_start__, 0, &__rom_bss_end__ - &__rom_bss_start__);
|
||||||
|
|
||||||
HAL_PERI_ON_WRITE32(REG_PESOC_CLK_CTRL,
|
HAL_PERI_ON_WRITE32(REG_PESOC_CLK_CTRL,
|
||||||
HAL_PERI_ON_READ32(REG_PESOC_CLK_CTRL) | BIT_SOC_SLPCK_VENDOR_REG_EN | BIT_SOC_ACTCK_VENDOR_REG_EN); // 40000230 |= 0x40u; 40000230 |= 0x80u;
|
HAL_PERI_ON_READ32(REG_PESOC_CLK_CTRL) | BIT_SOC_SLPCK_VENDOR_REG_EN | BIT_SOC_ACTCK_VENDOR_REG_EN); // 40000230 |= 0x40u; 40000230 |= 0x80u;
|
||||||
|
@ -152,7 +202,7 @@ void __attribute__((section(".hal.ram.text"))) RtlBootToSram(void) {
|
||||||
HAL_PERI_ON_WRITE32(REG_CPU_PERIPHERAL_CTRL,
|
HAL_PERI_ON_WRITE32(REG_CPU_PERIPHERAL_CTRL,
|
||||||
HAL_PERI_ON_READ32(REG_CPU_PERIPHERAL_CTRL) | BIT_SPI_FLSH_PIN_EN | BIT_LOG_UART_PIN_EN); // 400002C0 |= 0x100000u;
|
HAL_PERI_ON_READ32(REG_CPU_PERIPHERAL_CTRL) | BIT_SPI_FLSH_PIN_EN | BIT_LOG_UART_PIN_EN); // 400002C0 |= 0x100000u;
|
||||||
|
|
||||||
VectorTableInitRtl8195A(0x1FFFFFFC);
|
VectorTableInitRtl8195A(STACK_TOP); // 0x1FFFFFFC
|
||||||
|
|
||||||
HAL_PERI_ON_WRITE32(REG_SOC_FUNC_EN,
|
HAL_PERI_ON_WRITE32(REG_SOC_FUNC_EN,
|
||||||
HAL_PERI_ON_READ32(REG_SOC_FUNC_EN) | BIT_SOC_FLASH_EN); // 40000210 |= 0x10u;
|
HAL_PERI_ON_READ32(REG_SOC_FUNC_EN) | BIT_SOC_FLASH_EN); // 40000210 |= 0x10u;
|
||||||
|
@ -200,13 +250,15 @@ void __attribute__((section(".hal.ram.text"))) RtlBootToSram(void) {
|
||||||
tim_adapter.TimerId = 1;
|
tim_adapter.TimerId = 1;
|
||||||
HalTimerInitRtl8195a((PTIMER_ADAPTER) &tim_adapter);
|
HalTimerInitRtl8195a((PTIMER_ADAPTER) &tim_adapter);
|
||||||
|
|
||||||
SpicInitRtl8195A(1, 1); // InitBaudRate 1, SpicBitMode 1
|
SpicInitRtl8195A(StartupSpicBaudRate, StartupSpicBitMode); // InitBaudRate 1, SpicBitMode 1
|
||||||
SpicFlashInitRtl8195A(1); // SpicBitMode 1
|
SpicFlashInitRtl8195A(StartupSpicBitMode); // SpicBitMode 1
|
||||||
DBG_8195A("===== Enter Image 1.5 ====\nImg2 Sign: %s, InfaStart @ 0x%08x\n",
|
DBG_8195A("==*== Enter Image 1.5 ====\nImg2 Sign: %s, InfaStart @ 0x%08x\n",
|
||||||
&__image2_validate_code__, __image2_entry_func__);
|
&__image2_validate_code__, __image2_entry_func__);
|
||||||
if (strcmp((const char * )&__image2_validate_code__, IMG2_SIGN_TXT)) {
|
if (strcmp((const char * )&__image2_validate_code__, IMG2_SIGN_TXT)) {
|
||||||
DBG_MISC_ERR("Invalid Image2 Signature!\n");
|
DBG_MISC_ERR("Invalid Image2 Signature!\n");
|
||||||
RtlConsolRom(10000); // ROM: RtlConsolRom = 0xedcd;
|
RtlConsolRam();
|
||||||
|
// __asm__ __volatile__ ("cpsie f\n");
|
||||||
|
// RtlConsolRom(10000); // ROM: RtlConsolRom = 0xedcd;
|
||||||
}
|
}
|
||||||
__image2_entry_func__();
|
__image2_entry_func__();
|
||||||
}
|
}
|
||||||
|
@ -215,51 +267,56 @@ void __attribute__((section(".hal.ram.text"))) RtlBootToSram(void) {
|
||||||
void __attribute__((section(".hal.ram.text"))) SYSCpuClkConfig(int ChipID, int SysCpuClk) {
|
void __attribute__((section(".hal.ram.text"))) SYSCpuClkConfig(int ChipID, int SysCpuClk) {
|
||||||
int flg = 0;
|
int flg = 0;
|
||||||
DBG_SPIF_INFO("%s(0x%x)\n", "SYSCpuClkConfig", SysCpuClk);
|
DBG_SPIF_INFO("%s(0x%x)\n", "SYSCpuClkConfig", SysCpuClk);
|
||||||
if (HAL_SYS_CTRL_READ32(REG_SYS_CLK_CTRL0) & BIT4) {
|
if(HAL_PERI_ON_READ32(REG_SOC_FUNC_EN) & BIT_SOC_FLASH_EN){
|
||||||
SpicWaitWipRtl8195A(); // extern u32 SpicWaitWipRtl8195A(VOID);
|
SpicWaitWipRtl8195A(); //_SpicWaitWipDoneRefinedRtl8195A(); ???
|
||||||
flg = 1;
|
flg = 1;
|
||||||
}
|
}
|
||||||
if (ChipID == CHIP_ID_8710AF && (!SysCpuClk)) SysCpuClk = 1;
|
// if (ChipID == CHIP_ID_8710AF && (!SysCpuClk)) SysCpuClk = 1;
|
||||||
HalCpuClkConfig(SysCpuClk);
|
HalCpuClkConfig(SysCpuClk);
|
||||||
HalDelayUs(1000);
|
HalDelayUs(1000);
|
||||||
StartupHalInitPlatformLogUart();
|
StartupHalInitPlatformLogUart();
|
||||||
if (flg) SpicOneBitCalibrationRtl8195A(SysCpuClk); // extern u32 SpicOneBitCalibrationRtl8195A(IN u8 SysCpuClk);
|
if (flg) {
|
||||||
|
// SpicOneBitCalibrationRtl8195A(SysCpuClk); // extern u32 SpicOneBitCalibrationRtl8195A(IN u8 SysCpuClk);
|
||||||
|
// Disable SPI_FLASH User Mode
|
||||||
|
HAL_SPI_WRITE32(REG_SPIC_SSIENR, 0);
|
||||||
|
HAL_SPI_WRITE32(REG_SPIC_VALID_CMD,
|
||||||
|
(HAL_SPI_READ32(REG_SPIC_VALID_CMD)|(FLASH_VLD_DUAL_CMDS)));
|
||||||
|
SpicCalibrationRtl8195A(StartupSpicBitMode, 0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//----- IsForceLoadDefaultImg2
|
//----- IsForceLoadDefaultImg2
|
||||||
int __attribute__((section(".hal.ram.text"))) IsForceLoadDefaultImg2(void) {
|
int __attribute__((section(".hal.ram.text"))) IsForceLoadDefaultImg2(void) {
|
||||||
u8 gpio_pin[4];
|
u8 gpio_pin[4];
|
||||||
HAL_GPIO_PIN GPIO_Pin;
|
HAL_GPIO_PIN GPIO_Pin;
|
||||||
|
HAL_GPIO_PIN_STATE flg;
|
||||||
*((u32 *) &gpio_pin) = *(u32 *) (SPI_FLASH_BASE + FLASH_SYSTEM_DATA_ADDR + 0x08); // config data + 8
|
|
||||||
int i = 0;
|
|
||||||
_pHAL_Gpio_Adapter = (int) &gBoot_Gpio_Adapter;
|
|
||||||
int result = 0;
|
int result = 0;
|
||||||
do {
|
|
||||||
|
*((u32 *) &gpio_pin) = HAL_READ32(SPI_FLASH_BASE, FLASH_SYSTEM_DATA_ADDR + 0x08); // config data + 8
|
||||||
|
_pHAL_Gpio_Adapter = (int) &gBoot_Gpio_Adapter;
|
||||||
|
for(int i = 0; i < 2; i++) {
|
||||||
u8 x = gpio_pin[i];
|
u8 x = gpio_pin[i];
|
||||||
if (x != 0xff) {
|
if (x != 0xff) {
|
||||||
GPIO_Pin.pin_name = HAL_GPIO_GetIPPinName_8195a(x & 0x7F);
|
GPIO_Pin.pin_name = HAL_GPIO_GetIPPinName_8195a(x & 0x7F);
|
||||||
u32 flg;
|
|
||||||
if (x & 0x80) {
|
if (x & 0x80) {
|
||||||
GPIO_Pin.pin_mode = DIN_PULL_LOW;
|
GPIO_Pin.pin_mode = DIN_PULL_LOW;
|
||||||
flg = 1;
|
flg = GPIO_PIN_HIGH;
|
||||||
} else {
|
} else {
|
||||||
GPIO_Pin.pin_mode = DIN_PULL_HIGH;
|
GPIO_Pin.pin_mode = DIN_PULL_HIGH;
|
||||||
flg = 0;
|
flg = GPIO_PIN_LOW;
|
||||||
}
|
}
|
||||||
HAL_GPIO_Init_8195a(&GPIO_Pin);
|
HAL_GPIO_Init_8195a(&GPIO_Pin);
|
||||||
result = ((HAL_GPIO_ReadPin_8195a(&GPIO_Pin) - flg) <= 0);
|
result |= HAL_GPIO_ReadPin_8195a(&GPIO_Pin) == flg;
|
||||||
HAL_GPIO_DeInit_8195a(&GPIO_Pin);
|
HAL_GPIO_DeInit_8195a(&GPIO_Pin);
|
||||||
}
|
}
|
||||||
++i;
|
}
|
||||||
} while (i < 2);
|
|
||||||
_pHAL_Gpio_Adapter->IrqHandle.IrqFun = NULL;
|
_pHAL_Gpio_Adapter->IrqHandle.IrqFun = NULL;
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
//----- GetChipId
|
//----- GetChipId
|
||||||
int __attribute__((section(".hal.ram.text"))) _GetChipId(int x, u32 chid) {
|
int __attribute__((section(".hal.ram.text"))) _GetChipId() {
|
||||||
u8 chip_id = chid;
|
u8 chip_id = CHIP_ID_8195AM;
|
||||||
if (HALEFUSEOneByteReadROM(HAL_SYS_CTRL_READ32(REG_SYS_EFUSE_CTRL), 0xF8,
|
if (HALEFUSEOneByteReadROM(HAL_SYS_CTRL_READ32(REG_SYS_EFUSE_CTRL), 0xF8,
|
||||||
&chip_id, L25EOUTVOLTAGE) != 1)
|
&chip_id, L25EOUTVOLTAGE) != 1)
|
||||||
DBG_MISC_INFO("Get Chip ID Failed\r");
|
DBG_MISC_INFO("Get Chip ID Failed\r");
|
||||||
|
@ -269,16 +326,16 @@ int __attribute__((section(".hal.ram.text"))) _GetChipId(int x, u32 chid) {
|
||||||
//----- StartupHalSpicInit
|
//----- StartupHalSpicInit
|
||||||
void __attribute__((section(".hal.ram.text"))) StartupHalSpicInit(
|
void __attribute__((section(".hal.ram.text"))) StartupHalSpicInit(
|
||||||
int InitBaudRate) {
|
int InitBaudRate) {
|
||||||
HAL_SYS_CTRL_WRITE32(REG_SYS_CLK_CTRL0,
|
HAL_PERI_ON_WRITE32(REG_SOC_FUNC_EN,
|
||||||
HAL_SYS_CTRL_READ32(REG_SYS_CLK_CTRL0) | BIT4);
|
HAL_PERI_ON_READ32(REG_SOC_FUNC_EN) | BIT4); // HAL_SYS_CTRL_READ32
|
||||||
HAL_PERI_ON_WRITE32(REG_PESOC_CLK_CTRL,
|
HAL_PERI_ON_WRITE32(REG_PESOC_CLK_CTRL,
|
||||||
HAL_PERI_ON_READ32(REG_PESOC_CLK_CTRL) | BIT_SOC_ACTCK_FLASH_EN);
|
HAL_PERI_ON_READ32(REG_PESOC_CLK_CTRL) | BIT_SOC_ACTCK_FLASH_EN);
|
||||||
HAL_PERI_ON_WRITE32(REG_PESOC_CLK_CTRL,
|
HAL_PERI_ON_WRITE32(REG_PESOC_CLK_CTRL,
|
||||||
HAL_PERI_ON_READ32(REG_PESOC_CLK_CTRL) | BIT_SOC_SLPCK_FLASH_EN);
|
HAL_PERI_ON_READ32(REG_PESOC_CLK_CTRL) | BIT_SOC_SLPCK_FLASH_EN);
|
||||||
HalPinCtrlRtl8195A(SPI_FLASH,
|
HalPinCtrlRtl8195A(SPI_FLASH,
|
||||||
((HAL_SYS_CTRL_READ32(REG_SYS_SYSTEM_CFG1) & 0xF0000000)
|
((HAL_SYS_CTRL_READ32(REG_SYS_SYSTEM_CFG1) & 0xF0000000)
|
||||||
- 0x30000000 <= 0), 1);
|
== 0x30000000), 1);
|
||||||
SpicInitRtl8195A(InitBaudRate, 0);
|
SpicInitRtl8195A(InitBaudRate, StartupSpicBitMode);
|
||||||
}
|
}
|
||||||
|
|
||||||
//----- PreProcessForVendor
|
//----- PreProcessForVendor
|
||||||
|
@ -291,19 +348,19 @@ void __attribute__((section(".hal.ram.text"))) PreProcessForVendor(void) {
|
||||||
HALEFUSEOneByteReadROM(HAL_SYS_CTRL_READ32(REG_SYS_EFUSE_CTRL), 0xD3,
|
HALEFUSEOneByteReadROM(HAL_SYS_CTRL_READ32(REG_SYS_EFUSE_CTRL), 0xD3,
|
||||||
&efuse0xD3_data, L25EOUTVOLTAGE);
|
&efuse0xD3_data, L25EOUTVOLTAGE);
|
||||||
if (efuse0xD3_data & 1) v16 = HalPinCtrlRtl8195A(JTAG, 0, 1);
|
if (efuse0xD3_data & 1) v16 = HalPinCtrlRtl8195A(JTAG, 0, 1);
|
||||||
int chip_id = _GetChipId(v16, efuse0xD3_data << 31);
|
int chip_id = _GetChipId();
|
||||||
int flash_enable = HAL_PERI_ON_READ32(REG_SOC_FUNC_EN) & BIT_SOC_FLASH_EN; // v6 = ...
|
int flash_enable = HAL_PERI_ON_READ32(REG_SOC_FUNC_EN) & BIT_SOC_FLASH_EN; // v6 = ...
|
||||||
int x_enable = 0;
|
int spic_init = 0;
|
||||||
if (flash_enable) {
|
if (flash_enable) {
|
||||||
entry_func = &__image2_entry_func__;
|
entry_func = &__image2_entry_func__;
|
||||||
flash_enable = 1;
|
flash_enable = 1;
|
||||||
x_enable = 1;
|
spic_init = 1;
|
||||||
} else {
|
} else {
|
||||||
memcpy(&Image2Addr, (const void *) 0x1006FFFC, 4); // ???
|
memcpy(&Image2Addr, (const void *) 0x1006FFFC, 4); // ???
|
||||||
entry_func = Image2Addr;
|
entry_func = Image2Addr;
|
||||||
if (chip_id != CHIP_ID_8711AN) { // 0xFB
|
if (chip_id != CHIP_ID_8711AN) { // 0xFB
|
||||||
StartupHalSpicInit(1); // BaudRate 1
|
StartupHalSpicInit(StartupSpicBaudRate); // BaudRate 1
|
||||||
x_enable = 1;
|
spic_init = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
DBG_8195A("BOOT from Flash: %s\n", (flash_enable) ? "YES" : "NO");
|
DBG_8195A("BOOT from Flash: %s\n", (flash_enable) ? "YES" : "NO");
|
||||||
|
@ -311,28 +368,34 @@ void __attribute__((section(".hal.ram.text"))) PreProcessForVendor(void) {
|
||||||
&__image1_bss_end__ - &__image1_bss_start__);
|
&__image1_bss_end__ - &__image1_bss_start__);
|
||||||
HalDelayUs(1000);
|
HalDelayUs(1000);
|
||||||
int sdr_enable = 0;
|
int sdr_enable = 0;
|
||||||
|
// if ((HAL_PERI_ON_READ32(REG_SOC_FUNC_EN) << 10) < 0 ) v1 = 0; // BIT(21)
|
||||||
|
|
||||||
#ifdef CONFIG_SDR_EN
|
#ifdef CONFIG_SDR_EN
|
||||||
if (chip_id > CHIP_ID_8711AF) {
|
if (chip_id > CHIP_ID_8711AF || chip_id == CHIP_ID_8710AM) {
|
||||||
SdrCtrlInit();
|
SdrCtrlInit();
|
||||||
sdr_enable = 1;
|
sdr_enable = 1;
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
HAL_PERI_ON_WRITE32(REG_SOC_FUNC_EN, HAL_PERI_ON_READ32(REG_SOC_FUNC_EN) | BIT(21));
|
||||||
|
}
|
||||||
#else
|
#else
|
||||||
// SdrPowerOff();
|
// SdrPowerOff();
|
||||||
SDR_PIN_FCTRL(OFF);
|
SDR_PIN_FCTRL(OFF);
|
||||||
LDO25M_CTRL(OFF);
|
LDO25M_CTRL(OFF);
|
||||||
HAL_WRITE32(PERI_ON_BASE, REG_SOC_FUNC_EN, HAL_READ32(PERI_ON_BASE, REG_SOC_FUNC_EN) | BIT(21));
|
HAL_PERI_ON_WRITE32(REG_SOC_FUNC_EN, HAL_PERI_ON_READ32(REG_SOC_FUNC_EN) | BIT(21));
|
||||||
#endif
|
#endif
|
||||||
ConfigDebugErr = -1;
|
ConfigDebugErr = -1;
|
||||||
ConfigDebugWarn = 0;
|
ConfigDebugWarn = -1;
|
||||||
ConfigDebugInfo = 0;
|
ConfigDebugInfo = -1;
|
||||||
|
|
||||||
if (x_enable) SpicNVMCalLoadAll();
|
if (spic_init) SpicNVMCalLoadAll();
|
||||||
SYSCpuClkConfig(chip_id, 0);
|
SYSCpuClkConfig(chip_id, 0);
|
||||||
StartupHalInitPlatformLogUart();
|
StartupHalInitPlatformLogUart(); // double !?
|
||||||
|
__asm__ __volatile__ ("cpsie f\n");
|
||||||
DBG_8195A("===== Enter Image 1 ====\n");
|
DBG_8195A("===== Enter Image 1 ====\n");
|
||||||
if (x_enable) {
|
if (spic_init) {
|
||||||
SpicReadIDRtl8195A();
|
SpicReadIDRtl8195A();
|
||||||
SpicFlashInitRtl8195A(SpicDualBitMode); // SpicBitMode 1
|
SpicFlashInitRtl8195A(StartupSpicBitMode); // SpicBitMode 1
|
||||||
}
|
}
|
||||||
#ifdef CONFIG_SDR_EN
|
#ifdef CONFIG_SDR_EN
|
||||||
if (sdr_enable) SdrControllerInit();
|
if (sdr_enable) SdrControllerInit();
|
||||||
|
@ -374,7 +437,7 @@ LABEL_41: if (IsForceLoadDefaultImg2()) {
|
||||||
run_image = v16;
|
run_image = v16;
|
||||||
if (run_image == -1) {
|
if (run_image == -1) {
|
||||||
DiagPrintf("Fatal: no fw\n");
|
DiagPrintf("Fatal: no fw\n");
|
||||||
while (1) RtlConsolRom(1000);
|
RtlConsolRam();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -383,7 +446,7 @@ LABEL_41: if (IsForceLoadDefaultImg2()) {
|
||||||
run_image = v17;
|
run_image = v17;
|
||||||
if (run_image == -1) {
|
if (run_image == -1) {
|
||||||
DiagPrintf("Fatal: no fw\n");
|
DiagPrintf("Fatal: no fw\n");
|
||||||
while (1) RtlConsolRom(1000);
|
RtlConsolRam();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -397,35 +460,35 @@ LABEL_55: prdflash = run_image + SPI_FLASH_BASE;
|
||||||
u32 Image2Addr = *prdflash;
|
u32 Image2Addr = *prdflash;
|
||||||
DBG_8195A("Flash Image2: Addr 0x%x, Len %d, Load to SRAM 0x%x\n",
|
DBG_8195A("Flash Image2: Addr 0x%x, Len %d, Load to SRAM 0x%x\n",
|
||||||
run_image, img_size, Image2Addr);
|
run_image, img_size, Image2Addr);
|
||||||
SpicUserReadFourByteRtl8195A(img_size,
|
/// memcpy(Image2Addr, run_image + SPI_FLASH_BASE + 16, img_size);
|
||||||
run_image + 16, Image2Addr, 1);
|
SpicUserReadFourByteRtl8195A(img_size, run_image + 16, Image2Addr, StartupSpicBitMode); // SpicDualBitMode
|
||||||
prdflash = run_image + img_size + SPI_FLASH_BASE
|
prdflash = run_image + img_size + SPI_FLASH_BASE
|
||||||
+ 16;
|
+ 16;
|
||||||
u32 sdram_image_size = *prdflash++; // +0x10
|
u32 sdram_image_size = *prdflash++; // +0x10
|
||||||
u32 sdram_load_addr = *prdflash; // +0x14
|
u32 sdram_load_addr = *prdflash; // +0x14
|
||||||
if ((sdram_image_size - 1)
|
DBG_8195A("Image3 length: 0x%x, Image3 Addr: 0x%x\n",
|
||||||
<= 0xFFFFFFFD && *((u32 *)(sdram_load_addr)) == SDR_SDRAM_BASE) { // sdram_load_addr
|
sdram_image_size, sdram_load_addr);
|
||||||
|
if ((sdram_image_size - 1) <= 0xFFFFFFFD
|
||||||
|
&& *((u32 *)(sdram_load_addr)) == SDR_SDRAM_BASE) { // sdram_load_addr
|
||||||
if (!sdr_enable) {
|
if (!sdr_enable) {
|
||||||
DBG_MISC_ERR("FW/HW conflict. No DRAM on board.\n");
|
DBG_MISC_ERR("FW/HW conflict. No DRAM on board.\n");
|
||||||
while (1) RtlConsolRom(1000);
|
RtlConsolRam();
|
||||||
}
|
}
|
||||||
DBG_8195A("Image3 length: 0x%x, Image3 Addr: 0x%x\n",
|
DBG_8195A("Image3 length: 0x%x, Image3 Addr: 0x%x\n",
|
||||||
sdram_image_size, sdram_load_addr);
|
sdram_image_size, sdram_load_addr);
|
||||||
SpicUserReadRtl8195A(sdram_image_size,
|
SpicUserReadRtl8195A(sdram_image_size, run_image + img_size + 32, SDR_SDRAM_BASE, StartupSpicBitMode);
|
||||||
run_image + img_size + 32,
|
|
||||||
SDR_SDRAM_BASE, SpicDualBitMode);
|
|
||||||
} else DBG_8195A("No Image3\n");
|
} else DBG_8195A("No Image3\n");
|
||||||
|
|
||||||
entry_func = Image2Addr; ///+ 16;
|
entry_func = *(u32 *)Image2Addr;
|
||||||
DBG_8195A("Img2 Sign: %s, InfaStart @ 0x%08x \n",
|
DBG_8195A("Img2 Sign: %s, InfaStart @ 0x%08x \n",
|
||||||
(const char * )(Image2Addr + 4),
|
(const char * )(Image2Addr + 4),
|
||||||
*(u32 *)Image2Addr);
|
entry_func); // *(u32 *)Image2Addr);
|
||||||
if (strcmp((const char * )(Image2Addr + 4),
|
if (strcmp((const char * )(Image2Addr + 4),
|
||||||
IMG2_SIGN_TXT)) {
|
IMG2_SIGN_TXT)) {
|
||||||
DBG_MISC_ERR("Invalid Image2 Signature\n");
|
DBG_MISC_ERR("Invalid Image2 Signature\n");
|
||||||
while (1) RtlConsolRom(1000);
|
RtlConsolRam();
|
||||||
}
|
}
|
||||||
entry_func();
|
(void) (entry_func)();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
pstr = "load NEW fw %d\n";
|
pstr = "load NEW fw %d\n";
|
||||||
|
@ -441,11 +504,12 @@ LABEL_55: prdflash = run_image + SPI_FLASH_BASE;
|
||||||
} // if (flash_enable)
|
} // if (flash_enable)
|
||||||
if (strcmp((const char * )(Image2Addr + 4), IMG2_SIGN_TXT)) {
|
if (strcmp((const char * )(Image2Addr + 4), IMG2_SIGN_TXT)) {
|
||||||
DBG_MISC_ERR("Invalid Image2 Signature\n", 2 * ConfigDebugErr);
|
DBG_MISC_ERR("Invalid Image2 Signature\n", 2 * ConfigDebugErr);
|
||||||
while (1) RtlConsolRom(1000);
|
RtlConsolRam();
|
||||||
}
|
}
|
||||||
(void) (entry_func)();
|
(void) (entry_func)();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if !USE_SRC_ONLY_BOOT
|
||||||
//----- HalHardFaultHandler_Patch_c
|
//----- HalHardFaultHandler_Patch_c
|
||||||
void HalHardFaultHandler_Patch_c(u32 HardDefaultArg) {
|
void HalHardFaultHandler_Patch_c(u32 HardDefaultArg) {
|
||||||
u32 v1;
|
u32 v1;
|
||||||
|
@ -499,8 +563,7 @@ void __attribute__((section(".infra.ram.start"))) InfraStart(void) {
|
||||||
En32KCalibration();
|
En32KCalibration();
|
||||||
InitSoCPM();
|
InitSoCPM();
|
||||||
SDIO_Device_Off();
|
SDIO_Device_Off();
|
||||||
VectorTableInitForOSRtl8195A(&vPortSVCHandler, &xPortPendSVHandler,
|
VectorTableInitForOSRtl8195A(&vPortSVCHandler, &xPortPendSVHandler, &xPortSysTickHandler);
|
||||||
&xPortSysTickHandler);
|
|
||||||
if (clk) SpicDisableRtl8195A();
|
if (clk) SpicDisableRtl8195A();
|
||||||
_AppStart();
|
_AppStart();
|
||||||
}
|
}
|
||||||
|
@ -548,8 +611,8 @@ void _ReloadImg(void) {
|
||||||
u32 * prdflash = (u32 *) (img1size + SPI_FLASH_BASE + 8);
|
u32 * prdflash = (u32 *) (img1size + SPI_FLASH_BASE + 8);
|
||||||
u32 sign1 = *prdflash++; // v4 = *(u32 *)(img2addr + SPI_FLASH_BASE + 8);
|
u32 sign1 = *prdflash++; // v4 = *(u32 *)(img2addr + SPI_FLASH_BASE + 8);
|
||||||
u32 sign2 = *prdflash; // v5 = *(u32 *)(img2addr + SPI_FLASH_BASE + 12);
|
u32 sign2 = *prdflash; // v5 = *(u32 *)(img2addr + SPI_FLASH_BASE + 12);
|
||||||
if (sign1 == 0x35393138) {
|
if (sign1 == IMG_SIGN1_RUN) {
|
||||||
if (sign2 == 0x31313738) {
|
if (sign2 == IMG_SIGN2_RUN) {
|
||||||
img_addr1 = img2addr;
|
img_addr1 = img2addr;
|
||||||
LABEL_11: img_addr2 = -1;
|
LABEL_11: img_addr2 = -1;
|
||||||
goto LABEL_16;
|
goto LABEL_16;
|
||||||
|
@ -557,7 +620,7 @@ LABEL_11: img_addr2 = -1;
|
||||||
LABEL_14: img_addr1 = -1;
|
LABEL_14: img_addr1 = -1;
|
||||||
goto LABEL_11;
|
goto LABEL_11;
|
||||||
}
|
}
|
||||||
if (sign1 != 0x35393130 || sign2 != 0x31313738) goto LABEL_14;
|
if (sign1 != IMG_SIGN1_SWP || sign2 != IMG_SIGN2_RUN) goto LABEL_14;
|
||||||
img_addr2 = img2addr;
|
img_addr2 = img2addr;
|
||||||
img_addr1 = -1;
|
img_addr1 = -1;
|
||||||
LABEL_16: ota_addr = *(u32 *) (SPI_FLASH_BASE + 0x9000);
|
LABEL_16: ota_addr = *(u32 *) (SPI_FLASH_BASE + 0x9000);
|
||||||
|
@ -573,25 +636,24 @@ LABEL_21: ota_addr = -1;
|
||||||
prdflash = (u32 *) (ota_addr + SPI_FLASH_BASE + 8);
|
prdflash = (u32 *) (ota_addr + SPI_FLASH_BASE + 8);
|
||||||
sign1 = *prdflash++; // v9 = *(u32 *)(ota_addr + SPI_FLASH_BASE + 8);
|
sign1 = *prdflash++; // v9 = *(u32 *)(ota_addr + SPI_FLASH_BASE + 8);
|
||||||
sign2 = *prdflash; // v11 = *(u32 *)(ota_addr + SPI_FLASH_BASE + 12);
|
sign2 = *prdflash; // v11 = *(u32 *)(ota_addr + SPI_FLASH_BASE + 12);
|
||||||
if (sign1 == 0x35393138) {
|
if (sign1 == IMG_SIGN1_RUN) {
|
||||||
sign1 = 0x31313738;
|
sign1 = IMG_SIGN2_RUN;
|
||||||
if (sign2 == 0x31313738) {
|
if (sign2 == IMG_SIGN2_RUN) {
|
||||||
img_addr1 = ota_addr;
|
img_addr1 = ota_addr;
|
||||||
goto LABEL_33;
|
goto LABEL_33;
|
||||||
}
|
}
|
||||||
goto LABEL_22;
|
goto LABEL_22;
|
||||||
}
|
}
|
||||||
if (sign1 != 0x35393130 || (sign1 = 0x31313738, sign2 != 0x31313738)) {
|
if (sign1 != IMG_SIGN1_SWP || (sign1 = IMG_SIGN2_RUN, sign2 != IMG_SIGN2_RUN)) {
|
||||||
LABEL_22: if (img_addr1 == -1) {
|
LABEL_22: if (img_addr1 == -1) {
|
||||||
if (img_addr2 == -1) {
|
if (img_addr2 == -1) {
|
||||||
DBG_MISC_ERR("Fatal:no fw\n", ota_addr,
|
DBG_MISC_ERR("Fatal:no fw\n", ota_addr,
|
||||||
2 * ConfigDebugErr);
|
2 * ConfigDebugErr);
|
||||||
while (1)
|
RtlConsolRam();
|
||||||
RtlConsolRom(1000);
|
|
||||||
}
|
}
|
||||||
img_addr1 = img_addr2;
|
img_addr1 = img_addr2;
|
||||||
pstr = "load OLD fw %d\n";
|
LABEL_28: pstr = "load OLD fw %d\n";
|
||||||
LABEL_28: if (ConfigDebugErr & _DBG_MISC_) {
|
if (ConfigDebugErr & _DBG_MISC_) {
|
||||||
LABEL_36: DiagPrintf(pstr,
|
LABEL_36: DiagPrintf(pstr,
|
||||||
((unsigned int) (img_addr1 - ota_addr) <= 0));
|
((unsigned int) (img_addr1 - ota_addr) <= 0));
|
||||||
}
|
}
|
||||||
|
@ -638,7 +700,7 @@ void _CPUResetHandler(void) {
|
||||||
ConfigDebugErr = -1;
|
ConfigDebugErr = -1;
|
||||||
|
|
||||||
HalCpuClkConfig(0);
|
HalCpuClkConfig(0);
|
||||||
VectorTableInitRtl8195A(0x1FFFFFFC);
|
VectorTableInitRtl8195A(STACK_TOP); // 0x1FFFFFFC
|
||||||
HAL_PERI_ON_WRITE32(REG_SOC_FUNC_EN,
|
HAL_PERI_ON_WRITE32(REG_SOC_FUNC_EN,
|
||||||
HAL_PERI_ON_READ32(REG_SOC_FUNC_EN) & BIT23);
|
HAL_PERI_ON_READ32(REG_SOC_FUNC_EN) & BIT23);
|
||||||
HAL_PERI_ON_WRITE32(REG_SOC_FUNC_EN,
|
HAL_PERI_ON_WRITE32(REG_SOC_FUNC_EN,
|
||||||
|
@ -666,4 +728,4 @@ void _CPUReset(void) // __noreturn
|
||||||
void HalHardFaultHandler_user_define(u32 HardDefaultArg) {
|
void HalHardFaultHandler_user_define(u32 HardDefaultArg) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
#endif // !USE_SRC_ONLY_BOOT
|
||||||
|
|
|
@ -0,0 +1,239 @@
|
||||||
|
|
||||||
|
|
||||||
|
ENTRY(Reset_Handler)
|
||||||
|
|
||||||
|
INCLUDE "export-rom_v03.txt"
|
||||||
|
|
||||||
|
|
||||||
|
MEMORY
|
||||||
|
{
|
||||||
|
TCM (rwx) : ORIGIN = 0x1FFF0000, LENGTH = 65536
|
||||||
|
ROM_USED_RAM (rwx) : ORIGIN = 0x10000bc8, LENGTH = 21560 /* end 0x10006000 */
|
||||||
|
RECY_RAM (rwx) : ORIGIN = 0x10002100, LENGTH = 16128 /* end 0x10006000 */
|
||||||
|
BD_RAM (rwx) : ORIGIN = 0x10006000, LENGTH = 434176
|
||||||
|
//RECY_RAM (rwx) : ORIGIN = 0x10002100, LENGTH = 7936 /* end 0x10004000 */
|
||||||
|
//BD_RAM (rwx) : ORIGIN = 0x10004000, LENGTH = 442368
|
||||||
|
SDRAM_RAM (rwx) : ORIGIN = 0x30000000, LENGTH = 2M
|
||||||
|
}
|
||||||
|
|
||||||
|
EXTERN(PreProcessForVendor)
|
||||||
|
EXTERN(RtlBootToSram)
|
||||||
|
|
||||||
|
SECTIONS
|
||||||
|
{
|
||||||
|
__rom_bss_start__ = 0x10000300;
|
||||||
|
__rom_bss_end__ = 0x10000bc8;
|
||||||
|
|
||||||
|
.ram.start.table :
|
||||||
|
{
|
||||||
|
__ram_image1_text_start__ = .;
|
||||||
|
__ram_start_table_start__ = .;
|
||||||
|
KEEP(*(SORT(.start.ram.data*)))
|
||||||
|
KEEP(*(.image1.validate.rodata*))
|
||||||
|
__ram_start_table_end__ = .;
|
||||||
|
|
||||||
|
} > ROM_USED_RAM
|
||||||
|
|
||||||
|
/* Add . to assign the start address of the section,
|
||||||
|
* to prevent the change of the start address by ld doing section alignment */
|
||||||
|
|
||||||
|
|
||||||
|
/* these 4 sections is used by ROM global variable */
|
||||||
|
/* Don't move them and never add RAM code variable to these sections */
|
||||||
|
.ram_image1.text :
|
||||||
|
{
|
||||||
|
__image1_validate_code__ = .;
|
||||||
|
*(.infra.ram.data*)
|
||||||
|
*(.infra.ram.text*)
|
||||||
|
*(.hal.ram.text*)
|
||||||
|
*(.hal.flash.text)
|
||||||
|
*(.hal.sdrc.text)
|
||||||
|
*(.text*)
|
||||||
|
*(.sdram.text*)
|
||||||
|
*(.rodata*)
|
||||||
|
*(.infra.ram.start*)
|
||||||
|
*(.data*)
|
||||||
|
*(.hal.ram.data*)
|
||||||
|
*(.hal.gpio.data*)
|
||||||
|
*(.hal.flash.data*)
|
||||||
|
*(.hal.sdrc.data*)
|
||||||
|
__ram_image1_data_end__ = .;
|
||||||
|
__image1_bss_start__ = .;
|
||||||
|
.ram.bss$$Base = .;
|
||||||
|
*(.bss*)
|
||||||
|
*(COMMON)
|
||||||
|
__image1_bss_end__ = .;
|
||||||
|
__ram_image1_text_end__ = .;
|
||||||
|
} > ROM_USED_RAM
|
||||||
|
|
||||||
|
.tcm :
|
||||||
|
{
|
||||||
|
__tcm_start__ = .;
|
||||||
|
*(.tcm.heap)
|
||||||
|
__tcm_end__ = .;
|
||||||
|
} > TCM
|
||||||
|
/*
|
||||||
|
OVERLAY 0x1FFF0000:
|
||||||
|
{
|
||||||
|
.valid
|
||||||
|
{
|
||||||
|
*mem.o (.bss*)
|
||||||
|
*memp.o (.bss*)
|
||||||
|
*(.tcm.heap)
|
||||||
|
}
|
||||||
|
.dummy
|
||||||
|
{
|
||||||
|
__ram_image1_text_start__ = .;
|
||||||
|
__ram_start_table_start__ = .;
|
||||||
|
KEEP(*(SORT(.start.ram.data*)))
|
||||||
|
__ram_start_table_end__ = .;
|
||||||
|
__image1_validate_code__ = .;
|
||||||
|
KEEP(*(.image1.validate.rodata*))
|
||||||
|
KEEP(*(.infra.ram.data*))
|
||||||
|
KEEP(*(.timer.ram.data*))
|
||||||
|
KEEP(*(.cutb.ram.data*))
|
||||||
|
KEEP(*(.cutc.ram.data*))
|
||||||
|
KEEP(*(.hal.ram.data*))
|
||||||
|
__image1_bss_start__ = .;
|
||||||
|
.ram_image1.bss$$Base = .;
|
||||||
|
__image1_bss_end__ = .;
|
||||||
|
.ram_image1.bss$$Limit = .;
|
||||||
|
__ram_image1_data_end__ = .;
|
||||||
|
|
||||||
|
*(.hal.ram.text*)
|
||||||
|
*(.infra.ram.text*)
|
||||||
|
}
|
||||||
|
} > TCM
|
||||||
|
*/
|
||||||
|
.image2.start.table :
|
||||||
|
{
|
||||||
|
__ram_image2_text_start__ = .;
|
||||||
|
__image2_entry_func__ = .;
|
||||||
|
.image2.start.table1$$Base = .;
|
||||||
|
*(SORT(.image2.ram.data*))
|
||||||
|
__image2_validate_code__ = .;
|
||||||
|
*(.image2.validate.rodata*)
|
||||||
|
*(.custom.validate.rodata*)
|
||||||
|
} > BD_RAM
|
||||||
|
|
||||||
|
.ram_image2.text :
|
||||||
|
{
|
||||||
|
*(.infra.ram.start*)
|
||||||
|
*(.mon.ram.text*)
|
||||||
|
*(.hal.flash.text*)
|
||||||
|
*(.hal.sdrc.text*)
|
||||||
|
*(.hal.gpio.text*)
|
||||||
|
*(.fwu.text*)
|
||||||
|
*(.text*)
|
||||||
|
*(.sdram.text*)
|
||||||
|
*(.p2p.text*)
|
||||||
|
*(.wps.text*)
|
||||||
|
*(.websocket.text*)
|
||||||
|
} > BD_RAM
|
||||||
|
|
||||||
|
.ram_image2.rodata :
|
||||||
|
{
|
||||||
|
*(.rodata*)
|
||||||
|
*(.fwu.rodata*)
|
||||||
|
*(.sdram.rodata*)
|
||||||
|
*(.p2p.rodata*)
|
||||||
|
*(.wps.rodata*)
|
||||||
|
*(.websocket.rodata*)
|
||||||
|
} > BD_RAM
|
||||||
|
|
||||||
|
.ram.data :
|
||||||
|
{
|
||||||
|
__data_start__ = .;
|
||||||
|
*(.data*)
|
||||||
|
*(.sdram.data*)
|
||||||
|
*(.p2p.data*)
|
||||||
|
*(.wps.data*)
|
||||||
|
*(.websocket.data*)
|
||||||
|
__data_end__ = .;
|
||||||
|
__ram_image2_text_end__ = .;
|
||||||
|
} > BD_RAM
|
||||||
|
|
||||||
|
.ram.bss :
|
||||||
|
{
|
||||||
|
__bss_start__ = .;
|
||||||
|
.ram.bss$$Base = .;
|
||||||
|
*(.hal.flash.data*)
|
||||||
|
*(.hal.sdrc.data*)
|
||||||
|
*(.hal.gpio.data*)
|
||||||
|
*(.fwu.data*)
|
||||||
|
*(.bss*)
|
||||||
|
*(COMMON)
|
||||||
|
*(.bdsram.data*)
|
||||||
|
*(.sdram.bss*)
|
||||||
|
*(.p2p.bss*)
|
||||||
|
*(.wps.bss*)
|
||||||
|
*(.websocket.bss*)
|
||||||
|
__bss_end__ = .;
|
||||||
|
.ram.bss$$Limit = .;
|
||||||
|
} > BD_RAM
|
||||||
|
|
||||||
|
.bf_data :
|
||||||
|
{
|
||||||
|
__buffer_data_start__ = .;
|
||||||
|
*(.bfsram.data*)
|
||||||
|
__buffer_data_end__ = .;
|
||||||
|
|
||||||
|
} > BD_RAM
|
||||||
|
/*
|
||||||
|
.bf_data2 :
|
||||||
|
{
|
||||||
|
__buffer_data_start2__ = .;
|
||||||
|
__buffer_data_end2__ = .;
|
||||||
|
|
||||||
|
} > RECY_RAM
|
||||||
|
*/
|
||||||
|
.sdr_text :
|
||||||
|
{
|
||||||
|
__sdram_data_start__ = .;
|
||||||
|
} > SDRAM_RAM
|
||||||
|
|
||||||
|
.sdr_rodata :
|
||||||
|
{
|
||||||
|
} > SDRAM_RAM
|
||||||
|
|
||||||
|
.sdr_data :
|
||||||
|
{
|
||||||
|
__sdram_data_end__ = .;
|
||||||
|
} > SDRAM_RAM
|
||||||
|
|
||||||
|
.sdr_bss :
|
||||||
|
{
|
||||||
|
__sdram_bss_start__ = .;
|
||||||
|
__sdram_bss_end__ = .;
|
||||||
|
} > SDRAM_RAM
|
||||||
|
|
||||||
|
.heap :
|
||||||
|
{
|
||||||
|
__end__ = .;
|
||||||
|
end = __end__;
|
||||||
|
*(.heap*)
|
||||||
|
__HeapLimit = .;
|
||||||
|
} > BD_RAM
|
||||||
|
|
||||||
|
/* .stack_dummy section doesn't contains any symbols. It is only
|
||||||
|
* used for linker to calculate size of stack sections, and assign
|
||||||
|
* values to stack symbols later */
|
||||||
|
.stack_dummy :
|
||||||
|
{
|
||||||
|
*(.stack)
|
||||||
|
} > BD_RAM
|
||||||
|
|
||||||
|
/* Set stack top to end of RAM, and stack limit move down by
|
||||||
|
* size of stack_dummy section */
|
||||||
|
__StackTop = ORIGIN(BD_RAM) + LENGTH(BD_RAM);
|
||||||
|
__StackLimit = __StackTop - SIZEOF(.stack_dummy);
|
||||||
|
PROVIDE(__stack = __StackTop);
|
||||||
|
|
||||||
|
/* Check if data + heap + stack exceeds RAM limit */
|
||||||
|
ASSERT(__StackLimit >= __HeapLimit, "region RAM overflowed with stack")
|
||||||
|
|
||||||
|
.boot.head :
|
||||||
|
{
|
||||||
|
KEEP(*(.loader.head*))
|
||||||
|
}
|
||||||
|
}
|
Binary file not shown.
|
@ -17,6 +17,31 @@
|
||||||
|
|
||||||
#define STACKSIZE 2048
|
#define STACKSIZE 2048
|
||||||
|
|
||||||
|
void test_sha1(void)
|
||||||
|
{
|
||||||
|
const unsigned char *sha1_text[3] = {
|
||||||
|
"",
|
||||||
|
"abc",
|
||||||
|
"abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq"
|
||||||
|
};
|
||||||
|
const uint8_t sha1_test_digest[3][20] = {
|
||||||
|
{ 0xda,0x39,0xa3,0xee, 0x5e,0x6b,0x4b,0x0d, 0x32,0x55,0xbf,0xef, 0x95,0x60,0x18,0x90, 0xaf,0xd8,0x07,0x09 },
|
||||||
|
{ 0xa9,0x99,0x3e,0x36, 0x47,0x06,0x81,0x6a, 0xba,0x3e,0x25,0x71, 0x78,0x50,0xc2,0x6c, 0x9c,0xd0,0xd8,0x9d },
|
||||||
|
{ 0x84,0x98,0x3e,0x44, 0x1c,0x3b,0xd2,0x6e, 0xba,0xae,0x4a,0xa1, 0xf9,0x51,0x29,0xe5, 0xe5,0x46,0x70,0xf1 }
|
||||||
|
};
|
||||||
|
uint32_t i;
|
||||||
|
uint8_t digest[20];
|
||||||
|
int ret;
|
||||||
|
for (i=0; i<3; i++)
|
||||||
|
{
|
||||||
|
memset((void*)digest, 0, sizeof(digest));
|
||||||
|
ret = rtl_crypto_sha1(sha1_text[i], strlen(sha1_text[i]), digest);
|
||||||
|
if ( rtl_memcmpb((void*)digest, (void*)&sha1_test_digest[i][0], 20) == 0 )
|
||||||
|
DiagPrintf("SHA1 test result is correct, ret=%d\r\n", ret);
|
||||||
|
else
|
||||||
|
DiagPrintf("SHA test result is WRONG!!, ret=%d\r\n", ret);
|
||||||
|
}
|
||||||
|
}
|
||||||
//static const u8 plaintext[] = "The quick brown fox jumps over the lazy dog";
|
//static const u8 plaintext[] = "The quick brown fox jumps over the lazy dog";
|
||||||
//static const u8 md5_digest[] = "\x9e\x10\x7d\x9d\x37\x2b\xb6\x82"
|
//static const u8 md5_digest[] = "\x9e\x10\x7d\x9d\x37\x2b\xb6\x82"
|
||||||
// "\x6b\xd8\x1d\x35\x42\xa4\x19\xd6";
|
// "\x6b\xd8\x1d\x35\x42\xa4\x19\xd6";
|
||||||
|
|
Loading…
Reference in a new issue