[PATCH] arm/start.S: Do not use a scratch register to hold the stack pointer
Sebastian Huber
sebastian.huber at embedded-brains.de
Fri Jul 26 05:42:50 UTC 2019
On 26/07/2019 07:37, Chris Johns wrote:
> On 26/7/19 3:06 pm, Sebastian Huber wrote:
>> Hello Chris,
>>
>> I am not sure, if using r8 is the right thing to do since r8..r14 are banked in
>> FIQ mode.
>
> The ARM docs I referenced say the register is general purpose. There is other
> docs they say something else?
This is a standard ARM feature, see for example "B1.3.2
ARM core registers" in the ARMv7-AR reference manual.
>
> This is early boot code who why would FIQ banks be an issue? Which BSPs would
> that effect?
You set the stack in FIQ mode in start.S:
/* Initialize stack pointer registers for the various modes */
/* Enter FIQ mode and set up the FIQ stack pointer */
mov r0, #(ARM_PSR_M_FIQ | ARM_PSR_I | ARM_PSR_F)
msr cpsr, r0
ldr r1, =bsp_stack_fiq_size
mov sp, r8
sub r8, r8, r1
#ifdef BSP_START_NEEDS_REGISTER_INITIALIZATION
bl bsp_start_init_registers_banked_fiq
#endif
>
>> I think the bsp_start_arm_drop_hyp_mode needs to be changed to not
>> touch r3, it can use r1 instead.
>
> That is a bad idea. The registers are documented as scratch and it's use here
> across a call is wrong.
We are here in the low level startup code, so we have to be a bit
flexible if it comes to the ABI. We should move these low level
functions to start.S.
--
Sebastian Huber, embedded brains GmbH
Address : Dornierstr. 4, D-82178 Puchheim, Germany
Phone : +49 89 189 47 41-16
Fax : +49 89 189 47 41-09
E-Mail : sebastian.huber at embedded-brains.de
PGP : Public key available on request.
Diese Nachricht ist keine geschäftliche Mitteilung im Sinne des EHUG.
More information about the devel
mailing list