[PATCH] arm64/vdso: Discard .note.gnu.property sections in vDSO

Szabolcs Nagy szabolcs.nagy at arm.com
Fri Apr 30 09:16:33 BST 2021


The 04/29/2021 11:52, Bill Wendling wrote:
> $ readelf -lW arch/arm64/kernel/vdso/vdso.so
> 
> Elf file type is DYN (Shared object file)
> Entry point 0x300
> There are 4 program headers, starting at offset 64
> 
> Program Headers:
>   Type           Offset   VirtAddr           PhysAddr
> FileSiz  MemSiz   Flg Align
>   LOAD           0x000000 0x0000000000000000 0x0000000000000000
> 0x000968 0x000968 R E 0x8
>   DYNAMIC        0x0008a8 0x00000000000008a8 0x00000000000008a8
> 0x0000c0 0x0000c0 R   0x8
>   NOTE           0x000288 0x0000000000000288 0x0000000000000288
> 0x000074 0x000074 R   0x8
>   GNU_EH_FRAME   0x0008a4 0x00000000000008a4 0x00000000000008a4
> 0x000000 0x000000 R E 0x1

this is wrong because the abi specifically says properties
are in PT_GNU_PROPERTY, not in PT_NOTE.

so the original patch that removes them from notes is fine,
but ideally they should be readded under PT_GNU_PROPERTY.

(x86 needs it there too, but also needs it under PT_NOTE for
historical reasons. ideally the section would have been named
other than .note and was not marked as SHF_NOTE, because
properties are merged completely differently by the linker
than notes, so now linkers have to special case it by section
name. properties should have been designed like the
 .ARM.attributes section except that is not in a load segment
and thus has no runtime semantics while the key feature of
properties is the runtime semantics. however accessing the
program headers of the vdso is not trivial at runtime from
user code so dropping the properties might work too, but can
bite us in the future depending on how they evolve: the ld.so
can look at vdso program headers.)



More information about the linux-arm-kernel mailing list