Re: using -fsplit-stack

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Fri, Nov 30, 2012 at 6:13 AM, mathieu lacage
<mathieu.lacage@xxxxxxxxxxxx> wrote:
>
> $ gcc -fsplit-stack ./test.c -o test
> $ ./test
> hello 0x7fbecfd58960
> Segmentation fault (core dumped)

You neglected to say which version of GCC you are using.

I tried your test case with both GCC mainline and the GCC 4.7 branch,
and it worked fine.  But I am using the gold linker, not GNU ld.


> Obviously, the same test will also segfault without -fsplit-stack but
> now, it segfaults with an interesting backtrace:

I don't really see why this test will segfault without using
-fsplit-stack.  For me it works fine without -fsplit-stack, which is
what I would expect.


> Program received signal SIGSEGV, Segmentation fault.
> 0x00007ffff7de3af5 in do_lookup_x (new_hash=2090266759,
> old_hash=0x7ffff6e7b110, result=0x7ffff6e7b0e0, scope=0x7ffff7ffe5a0,
> i=0, flags=1,
>     skip=0x0, undef_map=0x7ffff7ffa9a8) at dl-lookup.c:82
> 82      dl-lookup.c: No such file or directory.
> (gdb) bt
> #0  0x00007ffff7de3af5 in do_lookup_x (new_hash=2090266759,
> old_hash=0x7ffff6e7b110, result=0x7ffff6e7b0e0, scope=0x7ffff7ffe5a0,
> i=0, flags=1,
>     skip=0x0, undef_map=0x7ffff7ffa9a8) at dl-lookup.c:82
> #1  0x00007ffff7de4533 in _dl_lookup_symbol_x (undef_name=0x7ffff7816f25
> "free", undef_map=0x7ffff7ffa9a8, ref=0x7ffff6e7b170,
>     symbol_scope=0x7ffff7ffad00, version=0x7ffff7fd9180, type_class=1,
> flags=1, skip_map=0x0) at dl-lookup.c:739
> #2  0x00007ffff7de8784 in _dl_fixup (l=<optimized out>,
> reloc_arg=<optimized out>) at ../elf/dl-runtime.c:119
> '#3  0x00007ffff7def245 in _dl_runtime_resolve ()
> at ../sysdeps/x86_64/dl-trampoline.S:42
> #4  0x00007ffff784dac4 in _IO_vfprintf_internal (s=<optimized out>,
> format=<optimized out>, ap=<optimized out>) at vfprintf.c:2052
> #5  0x00007ffff78588d9 in __printf (format=<optimized out>) at
> printf.c:35
> #6  0x0000000000400d21 in main ()
>
> It looks like printf cannot find free anymore. Strange.

That is a crash inside the dynamic linker.  I'm not sure why it happened.


> 1) I have disassembled the generated code and I see one symbol that
> appears to be related to this:__morestack
> Is there documentation somewhere on the exact semantics that is supposed
> to be provided by this function ? Are there other functions that the
> stack-split code will potentially call ?

The detailed documentation on that internal function are in the source
code.  libgcc/config/i386/morestack.S.

That function and __morestack_non_split are the only ones that your
application will call directly.  There are various other functions
involved that are called, directly or indirectly, by __morestack.

> 2) What is the story about interaction with code that is not compiled
> with stack-split code ? i.e., can I call non-stack-split code from
> stack-split code and vice-versa ?

Yes, provided you are using gold.

> gold -lc ./test.o -o test
> gold: error: ./test.o: could not convert call to '__morestack' to
> '__morestack_non_split'
> ./test.o:test.c:function main: error: undefined reference to
> '__morestack'

You neglected to say which version of gold you are using.  In any
case, note that you should not invoke gold directly.  You should
arrange for the GCC driver to invoke it on your behalf.  Otherwise you
won't get the right files.  The way to do this is to install gold
under the name "ld" in some directory DIR, and pass the option -BDIR
to gcc.  You can use gcc -Wl,-debug to see precisely which linker gcc
is running, and make sure that it is gold and not GNU ld.

> But, anyway, I can't see how that link-time code change would work for
> libraries. Say, binary A links to B and C. A and B  are stack-split. C
> is not. What is the linker going to do ?.

The linker adjusts the code on a function by function basis, based on
whether the function calls a non-split-stack function or not.  The
general scheme is outlined on the wiki page:
http://gcc.gnu.org/wiki/SplitStacks .

> What happens at runtime ? Does the loader perform a similar check ? (if
> so, which loader/version ?

The loader does not know anything about split stacks, and it doesn't
need to know.

> 3) gdb: Does gcc generate the right kind of dwarf information for gdb to
> understand how to unwind a stack-split stack ?

Yes.


> 4) Any data on CPU/memory performance for using -fsplit-stack ? i.e.,
> what would be the downsides of compiling everything with this feature
> on ?

I don't have any precise measurements.  The cost of code that does not
split the stack is low: a few additional instructions per function
call.  This is unlikely to make any difference except perhaps in a
program that is heavily CPU bound and makes lots of function calls in
tight loops.  However, actually splitting the stack is relatively
expensive because it requires a couple of system calls.  That can add
up pretty quickly if you have a tight loop that winds up needing to
split the stack to an unfortunate coincidence of available stack space
and the stack requirements of the function being called.

Ian


[Index of Archives]     [Linux C Programming]     [Linux Kernel]     [eCos]     [Fedora Development]     [Fedora Announce]     [Autoconf]     [The DWARVES Debugging Tools]     [Yosemite Campsites]     [Yosemite News]     [Linux GCC]

  Powered by Linux