#include <dlfcn.h> #include <mcheck.h> #include <stdio.h> #include <stdlib.h> typedef int (*fn)(void); #define CHUNKS 1024 #define REPEAT 64 int main (void) { void *h1; void *h2; fn **foopp; fn bar, baz; int i, j; int n; void *allocs[REPEAT][CHUNKS]; mtrace (); /* Open the two objects. */ h1 = dlopen ("reldep6mod3.so", RTLD_LAZY); if (h1 == NULL) { printf ("cannot open reldep6mod3.so: %s\n", dlerror ()); exit (1); } foopp = dlsym (h1, "foopp"); if (foopp == NULL) { printf ("cannot get address of \"foopp\": %s\n", dlerror ()); exit (1); } n = (**foopp) (); if (n != 20) { printf ("(**foopp)() return %d, not return 20\n", n); exit (1); } h2 = dlopen ("reldep6mod4.so", RTLD_LAZY); if (h2 == NULL) { printf ("cannot open reldep6mod4.so: %s\n", dlerror ()); exit (1); } if (dlclose (h1) != 0) { printf ("closing h1 failed: %s\n", dlerror ()); exit (1); } /* Clobber memory. */ for (i = 0; i < REPEAT; ++i) for (j = 0; j < CHUNKS; ++j) allocs[i][j] = calloc (1, j + 1); bar = dlsym (h2, "bar"); if (bar == NULL) { printf ("cannot get address of \"bar\": %s\n", dlerror ()); exit (1); } if (bar () != 40) { printf ("bar() did not return 40\n"); exit (1); } baz = dlsym (h2, "baz"); if (baz == NULL) { printf ("cannot get address of \"baz\": %s\n", dlerror ()); exit (1); } if (baz () != 31) { printf ("baz() did not return 31\n"); exit (1); } for (i = 0; i < REPEAT; ++i) for (j = 0; j < CHUNKS; ++j) free (allocs[i][j]); if (dlclose (h2) != 0) { printf ("closing h2 failed: %s\n", dlerror ()); exit (1); } return 0; }