many times, can't understand it even though I read it :)
In https://chromium.googlesource.com/external/github.com/ARM-software/arm-trusted-firmware/+/v0.4-rc1/docs/firmware-design.md#bl1, it says,
Whenever a CPU is released from reset, BL1 needs to distinguish between a warm boot and a cold boot. This is done using a platform-specific mechanism. The ARM FVPs implement a simple power controller at 0x1c100000. The PSYS register (0x10) is used to distinguish between a cold and warm boot. This information is contained in the PSYS.WK[25:24] field. Additionally, a per-CPU mailbox is maintained in trusted DRAM (0x00600000), to which BL1 writes an entrypoint. Each CPU jumps to this entrypoint upon warm boot. During cold boot, BL1 places the secondary CPUs in a safe platform-specific state while the primary CPU executes the remaining cold boot path as described in the following sections.
0x1c100000
PSYS
0x10
PSYS.WK[25:24]
0x00600000
is the PSYS register (at 0x10) of the 'simple power controller at 0x1c100000'? (I guess so, it would have been better if it said 'The PSYS register (0x10) of the controller ~')
and how is the PSYS.WK[25:24] determined? looks like it is some preset value by hard reset but is not reset by software reset. is it correct?
also, it said there is a 'per-cpu' mailbox at 0x00600000. then all the cpu jumps to the address written in 0x00600000? how is it called 'per-cpu' mailbox? (I would use 0x00600000 for core 0, 0x00600008 for core 1, etc..)
> is the PSYS register (at 0x10) of the 'simple power controller at 0x1c100000'? (I guess so, it would have been better if it said 'The PSYS register (0x10) of the controller ~')
It is the wording stuff.
> and how is the PSYS.WK[25:24] determined? looks like it is some preset value by hard reset but is not reset by software reset. is it correct?
PSYS.WK should be connected to some RTL signals to indicate the cold boot or warm boot in FVP.
For real hardware platform, Armv8-A will use AA64nAA32 signal as the aarch64/aarch32 type selection. RMR_ELx is the cold / warm boot selection.
> also, it said there is a 'per-cpu' mailbox at 0x00600000. then all the cpu jumps to the address written in 0x00600000? how is it called 'per-cpu' mailbox? (I would use 0x00600000 for core 0, 0x00600008 for core 1, etc..)
Each CPU has its own 0x00600000 address. Those addresses are banked so that they are "per-cpu".
Hi, Zhifei, you said : "Each CPU has its own 0x00600000 address. Those addresses are banked so that they are "per-cpu".". Is the memory also banked? or is it just per-core register appearting at 0x00600000?
In the given context, per-CPU means that each CPU will observe an 0x00600000 address, which is a per-core register appearing at 0x006000000. If the memory address is located in external DDR RAM, it is shared by all the CPUs.
Please note, this is the processor platform specific ( it said there is a 'per-cpu' mailbox at 0x00600000)
Hi Zhifei Yang
Are you still looing for help with this, or did you manage to find the solution?
I believed I already answered the questions..