binutils-gdb/ld/testsuite/ld-ifunc/pr29216.c
H.J. Lu 98a1627f19 x86: Properly handle IFUNC function pointer reference
Update

commit 68c4956b14
Author: H.J. Lu <hjl.tools@gmail.com>
Date:   Tue Apr 26 09:08:54 2022 -0700

    x86: Properly handle function pointer reference

to properly handle IFUNC function pointer reference.  Since IFUNC symbol
value is only known at run-time, set pointer_equality_needed for IFUNC
function pointer reference in PDE so that it will be resolved to its PLT
entry directly.

bfd/

	PR ld/29216
	* elf32-i386.c (elf_i386_scan_relocs): Set pointer_equality_needed
	for IFUNC function pointer reference in PDE.
	* elf64-x86-64.c (elf_x86_64_scan_relocs): Likewise.

ld/

	PR ld/29216
	* testsuite/ld-ifunc/ifunc.exp: Run PR ld/29216 test.
	* testsuite/ld-ifunc/pr29216.c: New file.
2022-05-31 16:28:06 -07:00

63 lines
786 B
C

#include <stdio.h>
static int
one (void)
{
return -30;
}
int foo (void) __attribute__ ((ifunc ("resolve_foo")));
void *
resolve_foo (void)
{
return (void *) one;
}
typedef int (*foo_p) (void);
foo_p foo_ptr = foo;
foo_p
__attribute__ ((noinline))
get_foo_p (void)
{
return foo_ptr;
}
foo_p
__attribute__ ((noinline))
get_foo (void)
{
return foo;
}
int
main (void)
{
foo_p p;
p = get_foo ();
if (p != foo)
__builtin_abort ();
if ((*p) () != -30)
__builtin_abort ();
p = get_foo_p ();
if (p != foo)
__builtin_abort ();
if ((*p) () != -30)
__builtin_abort ();
if (foo_ptr != foo)
__builtin_abort ();
if ((*foo_ptr) () != -30)
__builtin_abort ();
if (foo () != -30)
__builtin_abort ();
printf ("PASS\n");
return 0;
}