mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-12 12:16:04 +08:00
fca8e23c31
This patch makes the elf64bpf emulation to use it's own linker script, based on elf.sc. At the moment, the only change is that the BPF executable doesn't define an entry symbol (BPF programs feature several entry points scattered in several sections.) This is a step towards the goal of generating proper ELF executables that would be loaded by the kernel's libbpf. We are not there yet: BPF "programs" should still be linked with -r. This change removes a warning while linking executables, decreases the number of unsupported tests in the target from 47 to 29, and increases the number of expected passes from 104 to 145. Regtested in x86_64 for all targets. No regressions. ld/ChangeLog: 2019-08-07 Jose E. Marchesi <jose.marchesi@oracle.com> * scripttempl/elf64bpf.sc: Adapted from elf.sc. * emulparams/elf64bpf.sh (SCRIPT_NAME): Use elf64bpf. (EMBEDDED): Define. * testsuite/ld-bpf/call-1.d: Do not expect a warning regarding an undefined entry symbol. * testsuite/ld-bpf/jump-1.d: Likewise. * testsuite/ld-undefined/undefined.exp: Do not pass '-e entry' to ld in BPF targets, and do not expect line number information. * testsuite/ld-srec/srec.exp (run_srec_test): xfail s-record tests in BPF targets.
23 lines
560 B
Makefile
23 lines
560 B
Makefile
#as: --EL
|
|
#source: foo.s
|
|
#source: bar.s
|
|
#objdump: -dr
|
|
#ld: -EL
|
|
#name: CALL with disp32 reloc
|
|
|
|
.*: +file format .*bpf.*
|
|
|
|
Disassembly of section .text:
|
|
|
|
[0-9a-f]+ <.*>:
|
|
*[0-9a-f]+: b7 01 00 00 01 00 00 00 mov %r1,1
|
|
*[0-9a-f]+: b7 02 00 00 02 00 00 00 mov %r2,2
|
|
*[0-9a-f]+: b7 03 00 00 03 00 00 00 mov %r3,3
|
|
*[0-9a-f]+: 85 10 00 00 01 00 00 00 call 1
|
|
*[0-9a-f]+: 95 00 00 00 00 00 00 00 exit
|
|
|
|
[0-9a-f]+ <bar>:
|
|
*[0-9a-f]+: bf 21 00 00 00 00 00 00 mov %r1,%r2
|
|
*[0-9a-f]+: bf 13 00 00 00 00 00 00 mov %r3,%r1
|
|
*[0-9a-f]+: 95 00 00 00 00 00 00 00 exit
|