Blame elf/ifuncmain3.c

Packit Service 82fcde
/* Test STT_GNU_IFUNC symbols with dlopen:
Packit Service 82fcde
Packit Service 82fcde
   1. Direct function call.
Packit Service 82fcde
   2. Function pointer.
Packit Service 82fcde
   3. Visibility with override.
Packit Service 82fcde
 */
Packit Service 82fcde
Packit Service 82fcde
#include <dlfcn.h>
Packit Service 82fcde
#include <stdlib.h>
Packit Service 82fcde
#include <stdio.h>
Packit Service 82fcde
Packit Service 82fcde
typedef int (*foo_p) (void);
Packit Service 82fcde
Packit Service 82fcde
int
Packit Service 82fcde
__attribute__ ((noinline))
Packit Service 82fcde
foo (void)
Packit Service 82fcde
{
Packit Service 82fcde
  return -30;
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
int
Packit Service 82fcde
__attribute__ ((noinline))
Packit Service 82fcde
foo_hidden (void)
Packit Service 82fcde
{
Packit Service 82fcde
  return -20;
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
int
Packit Service 82fcde
__attribute__ ((noinline))
Packit Service 82fcde
foo_protected (void)
Packit Service 82fcde
{
Packit Service 82fcde
  return -40;
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
int
Packit Service 82fcde
main (void)
Packit Service 82fcde
{
Packit Service 82fcde
  foo_p p;
Packit Service 82fcde
  foo_p (*f) (void);
Packit Service 82fcde
  int *ret;
Packit Service 82fcde
Packit Service 82fcde
  void *h = dlopen ("ifuncmod3.so", RTLD_LAZY);
Packit Service 82fcde
  if (h == NULL)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("cannot load: %s\n", dlerror ());
Packit Service 82fcde
      return 1;
Packit Service 82fcde
    }
Packit Service 82fcde
Packit Service 82fcde
  p = dlsym (h, "foo");
Packit Service 82fcde
  if (p == NULL)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("symbol not found: %s\n", dlerror ());
Packit Service 82fcde
      return 1;
Packit Service 82fcde
    }
Packit Service 82fcde
  if ((*p) () != -1)
Packit Service 82fcde
    abort ();
Packit Service 82fcde
Packit Service 82fcde
  f = dlsym (h, "get_foo_p");
Packit Service 82fcde
  if (f == NULL)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("symbol not found: %s\n", dlerror ());
Packit Service 82fcde
      return 1;
Packit Service 82fcde
    }
Packit Service 82fcde
Packit Service 82fcde
  ret = dlsym (h, "ret_foo");
Packit Service 82fcde
  if (ret == NULL)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("symbol not found: %s\n", dlerror ());
Packit Service 82fcde
      return 1;
Packit Service 82fcde
    }
Packit Service 82fcde
Packit Service 82fcde
  p = (*f) ();
Packit Service 82fcde
  if (p != foo)
Packit Service 82fcde
    abort ();
Packit Service 82fcde
  if (foo () != -30)
Packit Service 82fcde
    abort ();
Packit Service 82fcde
  if (*ret != -30 || (*p) () != *ret)
Packit Service 82fcde
    abort ();
Packit Service 82fcde
Packit Service 82fcde
  f = dlsym (h, "get_foo_hidden_p");
Packit Service 82fcde
  if (f == NULL)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("symbol not found: %s\n", dlerror ());
Packit Service 82fcde
      return 1;
Packit Service 82fcde
    }
Packit Service 82fcde
Packit Service 82fcde
  ret = dlsym (h, "ret_foo_hidden");
Packit Service 82fcde
  if (ret == NULL)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("symbol not found: %s\n", dlerror ());
Packit Service 82fcde
      return 1;
Packit Service 82fcde
    }
Packit Service 82fcde
Packit Service 82fcde
  p = (*f) ();
Packit Service 82fcde
  if (foo_hidden () != -20)
Packit Service 82fcde
    abort ();
Packit Service 82fcde
  if (*ret != 1 || (*p) () != *ret)
Packit Service 82fcde
    abort ();
Packit Service 82fcde
Packit Service 82fcde
  f = dlsym (h, "get_foo_protected_p");
Packit Service 82fcde
  if (f == NULL)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("symbol not found: %s\n", dlerror ());
Packit Service 82fcde
      return 1;
Packit Service 82fcde
    }
Packit Service 82fcde
Packit Service 82fcde
  ret = dlsym (h, "ret_foo_protected");
Packit Service 82fcde
  if (ret == NULL)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("symbol not found: %s\n", dlerror ());
Packit Service 82fcde
      return 1;
Packit Service 82fcde
    }
Packit Service 82fcde
Packit Service 82fcde
  p = (*f) ();
Packit Service 82fcde
  if (p == foo_protected)
Packit Service 82fcde
    abort ();
Packit Service 82fcde
  if (foo_protected () != -40)
Packit Service 82fcde
    abort ();
Packit Service 82fcde
  if (*ret != 0 || (*p) () != *ret)
Packit Service 82fcde
    abort ();
Packit Service 82fcde
Packit Service 82fcde
  if (dlclose (h) != 0)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("cannot close: %s\n", dlerror ());
Packit Service 82fcde
      return 1;
Packit Service 82fcde
    }
Packit Service 82fcde
Packit Service 82fcde
  return 0;
Packit Service 82fcde
}