i386: Don't allow GOTOFF relocation against IFUNC symbol for PIC
authorH.J. Lu <hjl.tools@gmail.com>
Thu, 21 Jul 2022 17:35:58 +0000 (10:35 -0700)
committerH.J. Lu <hjl.tools@gmail.com>
Thu, 21 Jul 2022 18:40:27 +0000 (11:40 -0700)
We can't use the PLT entry as the function address for PIC since the PIC
register may not be set up properly for indirect call.

bfd/

PR ld/27998
* elf32-i386.c (elf_i386_relocate_section): Don't allow GOTOFF
relocation against IFUNC symbol for PIC.

ld/

PR ld/27998
* testsuite/ld-i386/pr27998a.d: Replace -shared with -e bar.
* testsuite/ld-i386/pr27998b.d: Expect a linker error.
* testsuite/ld-ifunc/ifunc-2-i386-now.d: Updated.
* testsuite/ld-ifunc/ifunc-2-local-i386-now.d: Likewise.
* testsuite/ld-ifunc/ifunc-2-i386.s: Replace @GOTOFF with @GOT.
* testsuite/ld-ifunc/ifunc-2-local-i386.s: Likewise.

bfd/elf32-i386.c
ld/testsuite/ld-i386/pr27998a.d
ld/testsuite/ld-i386/pr27998b.d
ld/testsuite/ld-ifunc/ifunc-2-i386-now.d
ld/testsuite/ld-ifunc/ifunc-2-i386.s
ld/testsuite/ld-ifunc/ifunc-2-local-i386-now.d
ld/testsuite/ld-ifunc/ifunc-2-local-i386.s

index cfb0085b245a6535c20609c1fb2a3d6264dcd9b0..52b1db4454687f982fd3d952edad1072b5091630 100644 (file)
@@ -2460,6 +2460,11 @@ elf_i386_relocate_section (bfd *output_bfd,
              goto do_relocation;
 
            case R_386_GOTOFF:
+             /* NB: We can't use the PLT entry as the function address
+                for PIC since the PIC register may not be set up
+                properly for indirect call. */
+             if (bfd_link_pic (info))
+               goto bad_ifunc_reloc;
              relocation -= (gotplt->output_section->vma
                             + gotplt->output_offset);
              goto do_relocation;
index ca3c9205fa6120bac31c7e373ca91f91bd27237a..a8019730ec1fbb985fbd962f7ee84c61221cb743 100644 (file)
@@ -1,5 +1,5 @@
 #as: --32
-#ld: -shared -melf_i386
+#ld: -e bar -melf_i386
 #readelf: -r --wide
 
 Relocation section '.rel.plt' at offset 0x[0-9a-f]+ contains 1 entry:
index ca3c9205fa6120bac31c7e373ca91f91bd27237a..8f81edbe8dfc577bd66d147cbc6dae430a66c2bd 100644 (file)
@@ -1,7 +1,3 @@
 #as: --32
 #ld: -shared -melf_i386
-#readelf: -r --wide
-
-Relocation section '.rel.plt' at offset 0x[0-9a-f]+ contains 1 entry:
- Offset     Info    Type                Sym. Value  Symbol's Name
-[0-9a-f]+ +[0-9a-f]+ +R_386_IRELATIVE +
+#error: relocation R_386_GOTOFF against STT_GNU_IFUNC symbol `foo' isn't supported
index a5c56b5a8e39a22da3582c42319a86cbb1578c12..8d9e8dc988f438f0f847adeceb10d972b2e720a8 100644 (file)
@@ -31,6 +31,6 @@ Disassembly of section .text:
  +[a-f0-9]+:   5b                      pop    %ebx
  +[a-f0-9]+:   81 c3 9e 10 00 00       add    \$0x109e,%ebx
  +[a-f0-9]+:   e8 de ff ff ff          call   100 <\*ABS\*@plt>
- +[a-f0-9]+:   8d 83 4c ef ff ff       lea    -0x10b4\(%ebx\),%eax
+ +[a-f0-9]+:   8b 83 0c 00 00 00       mov    0xc\(%ebx\),%eax
  +[a-f0-9]+:   c3                      ret
 #pass
index e84d6b7b5cc05a74d953d24e925f285c2af9f468..1acf6847e0bde9f86b8cd1ac4c804f20e69108f4 100644 (file)
@@ -16,6 +16,6 @@ bar:
        popl    %ebx
        addl    $_GLOBAL_OFFSET_TABLE_+[.-.L6], %ebx
        call    __GI_foo@PLT
-       leal    __GI_foo@GOTOFF(%ebx), %eax
+       movl    __GI_foo@GOT(%ebx), %eax
        ret
        .size   bar, .-bar
index ff494decbdd69c9fe0baa143c627ce091d9acb01..9da37e51db722fb445cf3aa787067558b23d0ee3 100644 (file)
@@ -31,6 +31,6 @@ Disassembly of section .text:
  +[a-f0-9]+:   5b                      pop    %ebx
  +[a-f0-9]+:   81 c3 9e 10 00 00       add    \$0x109e,%ebx
  +[a-f0-9]+:   e8 de ff ff ff          call   f0 <\*ABS\*@plt>
- +[a-f0-9]+:   8d 83 4c ef ff ff       lea    -0x10b4\(%ebx\),%eax
+ +[a-f0-9]+:   8b 83 0c 00 00 00       mov    0xc\(%ebx\),%eax
  +[a-f0-9]+:   c3                      ret
 #pass
index a69e060ddc0bad362e2cd15a65851ccba4918697..54e0e179551b60a83dce84b4b5187bfda14ec0aa 100644 (file)
@@ -13,6 +13,6 @@ bar:
        popl    %ebx
        addl    $_GLOBAL_OFFSET_TABLE_+[.-.L6], %ebx
        call    __GI_foo@PLT
-       leal    __GI_foo@GOTOFF(%ebx), %eax
+       movl    __GI_foo@GOT(%ebx), %eax
        ret
        .size   bar, .-bar