diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2016-10-09 19:13:37 +0200 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2016-10-09 19:13:37 +0200 |
commit | 86af500777f45066aa6a6817d4b695cf4b626c38 (patch) | |
tree | 759cff5e6e285f430b2abf576fe0a3577cab5f52 /sysdeps/x86_64/tst-split-dynreloc.c | |
parent | fdb93243abfa5db1e79860a4595bbd9065b05aae (diff) | |
parent | 7bb5f8a836b916d6ebf7b6921b136e99cea2442d (diff) |
Merge commit 'refs/top-bases/cvs/exc2signal-template' into cvs/exc2signal-template
Diffstat (limited to 'sysdeps/x86_64/tst-split-dynreloc.c')
-rw-r--r-- | sysdeps/x86_64/tst-split-dynreloc.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/sysdeps/x86_64/tst-split-dynreloc.c b/sysdeps/x86_64/tst-split-dynreloc.c new file mode 100644 index 0000000000..2f9e9b9477 --- /dev/null +++ b/sysdeps/x86_64/tst-split-dynreloc.c @@ -0,0 +1,28 @@ +/* This test will be used to create an executable with a specific + section layout in which .rela.dyn and .rela.plt are not contiguous. + For x86 case, readelf will report something like: + + ... + [10] .rela.dyn RELA + [11] .bar PROGBITS + [12] .rela.plt RELA + ... + + This is important as this case was not correctly handled by dynamic + linker in the bind-now case, and the second section was never + processed. */ + +#include <stdio.h> + +const int __attribute__ ((section(".bar"))) bar = 0x12345678; +static const char foo[] = "foo"; + +static int +do_test (void) +{ + printf ("%s %d\n", foo, bar); + return 0; +} + +#define TEST_FUNCTION do_test () +#include "../test-skeleton.c" |