I reported this behaviour to the gcc team, but they told me it's rather
related to binutils. So I wanted to leave a note here.

Reference to the gcc ticket:
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=107971

During development of a project I noticed that linking a object created
from assembler to another object created from C code results in a
binary with executable stack.

There is also no warning that the stack is executable during the
process. From the documentation it reads as if there should be one: 

"On the other hand the linker will normally warn if the stack is made
executable"

Ref:
https://sourceware.org/binutils/docs-2.39/ld/Options.html#index-_002d_002dwarn_002dexecstack

In my case the executable stack caused some totally unrelated issues
which were very difficult to debug.

I attached a testcase which demonstrates the issue. The testcase uses
gcc for linking but using ld directly has the same result.

Even if this is intended behaviour, the mentioned warning that the
stack is now executable would be nice to have.

Thanks,
Alex

Attachment: testcase.tgz
Description: testcase.tgz

Reply via email to