712ec27916
Add the GOT base for R_386_GOT32/R_386_GOT32X relocations against IFUNC symbols if there is no base register and disallow them for PIC. bfd/ PR ld/20244 * elf32-i386.c (elf_i386_relocate_section): Add the .got.plt section address for R_386_GOT32/R_386_GOT32X relocations against IFUNC symbols if there is no base register and return error for PIC. ld/ PR ld/20244 * testsuite/ld-i386/i386.exp: Run pr20244-2a, pr20244-2b, pr20244-2c and pr20244-2d. * testsuite/ld-i386/no-plt.exp: Run pr20244-3a and pr20244-3b. * testsuite/ld-i386/pr20244-2.s: New file. * testsuite/ld-i386/pr20244-2a.d: Likewise. * testsuite/ld-i386/pr20244-2b.d: Likewise. * testsuite/ld-i386/pr20244-2c.d: Likewise. * testsuite/ld-i386/pr20244-2d.d: Likewise. * testsuite/ld-i386/pr20244-3a.c: Likewise. * testsuite/ld-i386/pr20244-3b.S: Likewise. * testsuite/ld-i386/pr20244-3c.S: Likewise. * testsuite/ld-i386/pr20244-3d.S: Likewise.
45 lines
934 B
ArmAsm
45 lines
934 B
ArmAsm
.text
|
|
.p2align 4,,15
|
|
.type implementation1, @function
|
|
implementation1:
|
|
movl $1, %eax
|
|
ret
|
|
.size implementation1, .-implementation1
|
|
.p2align 4,,15
|
|
.type implementation2, @function
|
|
implementation2:
|
|
movl $2, %eax
|
|
ret
|
|
.size implementation2, .-implementation2
|
|
.p2align 4,,15
|
|
.type resolver2, @function
|
|
resolver2:
|
|
movl implementation2@GOT, %eax
|
|
ret
|
|
.size resolver2, .-resolver2
|
|
.type func2, @gnu_indirect_function
|
|
.set func2,resolver2
|
|
.p2align 4,,15
|
|
.type resolver1, @function
|
|
resolver1:
|
|
movl implementation1@GOT, %eax
|
|
ret
|
|
.size resolver1, .-resolver1
|
|
.globl func1
|
|
.type func1, @gnu_indirect_function
|
|
.set func1,resolver1
|
|
.p2align 4,,15
|
|
.globl get_func2
|
|
.type get_func2, @function
|
|
get_func2:
|
|
movl func2@GOT, %eax
|
|
ret
|
|
.size get_func2, .-get_func2
|
|
.p2align 4,,15
|
|
.globl call_func2
|
|
.type call_func2, @function
|
|
call_func2:
|
|
jmp *func2@GOT
|
|
.size call_func2, .-call_func2
|
|
.section .note.GNU-stack,"",@progbits
|