[PATCH 07/17] arm: Replace 'adrl' in EFI crt0
Sam Edwards
cfsworks at gmail.com
Tue Feb 25 03:16:02 CET 2025
On Mon, Feb 24, 2025 at 12:42 AM Heinrich Schuchardt <xypron.glpk at gmx.de> wrote:
>
> On 2/24/25 06:55, Sam Edwards wrote:
> > LLVM's IAS does not (and cannot easily) support the 'adrl'
> > pseudoinstruction, and ARM developers generally do not consider it
> > portable across assembler implementations either.
> >
> > Instead, expand it into the two subtract instructions it would emit
> > anyway. An explanation of the math follows:
> >
> > The .+8 and .+4 refer to the same memory location; this is because the
>
Hey there Heinrich,
> Are we sure that we never generate thumb instructions here?
Completely positive; the stmfd/ldmfd (at least) instructions do not
have THUMB encodings, so this file can only assemble for ARM.
>
> > .+4 expression occurs in a subsequent instruction, 4 bytes after the
> > first. This memory location is the value of the PC register when it is
> > read by the first sub instruction. Thus, both inner parenthesized
> > expressions evaluate to the same result: PC's offset relative to
> > image_base. The subtract instructions then remove one byte each
> > (low, then high) of the total offset, thereby getting the absolute
> > address of image_base loaded in r0.
> >
> > Signed-off-by: Sam Edwards <CFSworks at gmail.com>
> > ---
> > arch/arm/lib/crt0_arm_efi.S | 3 ++-
> > 1 file changed, 2 insertions(+), 1 deletion(-)
> >
> > diff --git a/arch/arm/lib/crt0_arm_efi.S b/arch/arm/lib/crt0_arm_efi.S
> > index 91b0fe12c51..235b3a0c48f 100644
> > --- a/arch/arm/lib/crt0_arm_efi.S
> > +++ b/arch/arm/lib/crt0_arm_efi.S
> > @@ -149,7 +149,8 @@ _start:
> > adr r1, .L_DYNAMIC
> > ldr r0, [r1]
> > add r1, r0, r1
> > - adrl r0, image_base
> > + sub r0, pc, #((.+8-image_base) & 0xff)
> > + sub r0, r0, #((.+4-image_base) & 0xff00)
>
> These are the instructions resulting from building qemu_arm_defconfig:
>
> sub r0, pc, #24
> sub r0, r0, #16, 24 @ 0x1000
>
> The last instruction subtracts 0x1000000.
I'd have to see the machine code to be sure, but it looks like that's
the 12-bit immediate value encoding of:
(16 >>> 24)
...which would equal 0x1000, as suggested by the disassembler comment.
Cheers,
Sam
>
> I can't see how your instructions would be doing the same.
>
> Best regards
>
> Heinrich
>
> > bl _relocate
> > teq r0, #0
> > bne 0f
>
More information about the U-Boot
mailing list