2011-06-11 13:26:42 +02:00
|
|
|
//
|
|
|
|
// Copyright (c) 2011, ARM Limited. All rights reserved.
|
|
|
|
//
|
|
|
|
// This program and the accompanying materials
|
|
|
|
// are licensed and made available under the terms and conditions of the BSD License
|
|
|
|
// which accompanies this distribution. The full text of the license may be found at
|
|
|
|
// http://opensource.org/licenses/bsd-license.php
|
|
|
|
//
|
|
|
|
// THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
//
|
|
|
|
//
|
2011-02-01 06:41:42 +01:00
|
|
|
|
|
|
|
#include <AsmMacroIoLib.h>
|
|
|
|
#include <Base.h>
|
|
|
|
#include <Library/PcdLib.h>
|
|
|
|
#include <Library/ArmPlatformLib.h>
|
2011-06-11 13:26:42 +02:00
|
|
|
#include <Drivers/PL354Smc.h>
|
2011-02-01 06:41:42 +01:00
|
|
|
#include <AutoGen.h>
|
|
|
|
|
|
|
|
.text
|
|
|
|
.align 3
|
|
|
|
|
|
|
|
GCC_ASM_EXPORT(ArmPlatformIsMemoryInitialized)
|
|
|
|
GCC_ASM_EXPORT(ArmPlatformInitializeBootMemory)
|
2011-06-11 13:26:42 +02:00
|
|
|
.extern ASM_PFX(SMCInitializeNOR)
|
|
|
|
.extern ASM_PFX(SMCInitializeSRAM)
|
|
|
|
.extern ASM_PFX(SMCInitializePeripherals)
|
|
|
|
.extern ASM_PFX(SMCInitializeVRAM)
|
2011-02-01 06:41:42 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
Called at the early stage of the Boot phase to know if the memory has already been initialized
|
|
|
|
|
|
|
|
Running the code from the reset vector does not mean we start from cold boot. In some case, we
|
|
|
|
can go through this code with the memory already initialized.
|
|
|
|
Because this function is called at the early stage, the implementation must not use the stack.
|
|
|
|
Its implementation must probably done in assembly to ensure this requirement.
|
|
|
|
|
|
|
|
@return Return the condition value into the 'Z' flag
|
|
|
|
|
|
|
|
**/
|
|
|
|
ASM_PFX(ArmPlatformIsMemoryInitialized):
|
|
|
|
// Check if the memory has been already mapped, if so skipped the memory initialization
|
|
|
|
LoadConstantToReg (ARM_VE_SYS_CFGRW1_REG ,r0)
|
|
|
|
ldr r0, [r0, #0]
|
|
|
|
|
|
|
|
// 0x40000000 = Value of Physical Configuration Switch SW[0]
|
|
|
|
and r0, r0, #0x40000000
|
|
|
|
tst r0, #0x40000000
|
|
|
|
bx lr
|
|
|
|
|
|
|
|
/**
|
|
|
|
Initialize the memory where the initial stacks will reside
|
|
|
|
|
|
|
|
This memory can contain the initial stacks (Secure and Secure Monitor stacks).
|
|
|
|
In some platform, this region is already initialized and the implementation of this function can
|
|
|
|
do nothing. This memory can also represent the Secure RAM.
|
|
|
|
This function is called before the satck has been set up. Its implementation must ensure the stack
|
|
|
|
pointer is not used (probably required to use assembly language)
|
|
|
|
|
|
|
|
**/
|
|
|
|
ASM_PFX(ArmPlatformInitializeBootMemory):
|
|
|
|
mov r5, lr
|
2011-06-11 13:26:42 +02:00
|
|
|
|
|
|
|
//
|
2011-02-01 06:41:42 +01:00
|
|
|
// Initialize PL354 SMC
|
2011-06-11 13:26:42 +02:00
|
|
|
//
|
2011-02-01 06:41:42 +01:00
|
|
|
LoadConstantToReg (ARM_VE_SMC_CTRL_BASE, r1)
|
2011-06-11 13:26:42 +02:00
|
|
|
|
|
|
|
// NOR Flash 0
|
|
|
|
LoadConstantToReg (PL354_SMC_DIRECT_CMD_ADDR_CS(0,0), r2)
|
|
|
|
blx ASM_PFX(SMCInitializeNOR)
|
|
|
|
|
|
|
|
// NOR Flash 1
|
|
|
|
LoadConstantToReg (PL354_SMC_DIRECT_CMD_ADDR_CS(1,0), r2)
|
|
|
|
blx ASM_PFX(SMCInitializeNOR)
|
|
|
|
|
|
|
|
// Setup SRAM
|
|
|
|
blx ASM_PFX(SMCInitializeSRAM)
|
|
|
|
|
|
|
|
// Memory Mapped Peripherals
|
|
|
|
blx ASM_PFX(SMCInitializePeripherals)
|
|
|
|
|
|
|
|
// Initialize VRAM
|
|
|
|
//TODO: Check if we really must inititialize Video SRAM in UEFI. Does Linux can do it ? Does the Video driver can do it ?
|
|
|
|
// It will be faster (only initialize if required) and easier (remove assembly code because of a stack available) to move this initialization.
|
2011-06-03 11:41:49 +02:00
|
|
|
LoadConstantToReg (VRAM_MOTHERBOARD_BASE, r2)
|
2011-06-11 13:26:42 +02:00
|
|
|
blx ASM_PFX(SMCInitializeVRAM)
|
|
|
|
|
2011-02-01 06:41:42 +01:00
|
|
|
bx r5
|
|
|
|
|
|
|
|
.end
|