summaryrefslogtreecommitdiff
path: root/src/env
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2015-04-13 20:13:10 -0400
committerRich Felker <dalias@aerifal.cx>2015-04-13 20:19:58 -0400
commit1ef849c6ec6a4e30badc844371cdf1b9eedfba57 (patch)
treeee862bff7b135ea2a46d7bf068643f232bddc64b /src/env
parent19a1fe670acb3ab9ead0fe31859ca7d4fe40dd54 (diff)
downloadmusl-1ef849c6ec6a4e30badc844371cdf1b9eedfba57.tar.gz
musl-1ef849c6ec6a4e30badc844371cdf1b9eedfba57.tar.bz2
musl-1ef849c6ec6a4e30badc844371cdf1b9eedfba57.tar.xz
musl-1ef849c6ec6a4e30badc844371cdf1b9eedfba57.zip
allow libc itself to be built with stack protector enabled
this was already essentially possible as a result of the previous commits changing the dynamic linker/thread pointer bootstrap process. this commit mainly adds build system infrastructure: configure no longer attempts to disable stack protector. instead it simply determines how so the makefile can disable stack protector for a few translation units used during early startup. stack protector is also disabled for memcpy and memset since compilers (incorrectly) generate calls to them on some archs to implement struct initialization and assignment, and such calls may creep into early initialization. no explicit attempt to enable stack protector is made by configure at this time; any stack protector option supported by the compiler can be passed to configure in CFLAGS, and if the compiler uses stack protector by default, this default is respected.
Diffstat (limited to 'src/env')
-rw-r--r--src/env/__stack_chk_fail.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/src/env/__stack_chk_fail.c b/src/env/__stack_chk_fail.c
index cc55460b..1b6a9f82 100644
--- a/src/env/__stack_chk_fail.c
+++ b/src/env/__stack_chk_fail.c
@@ -16,3 +16,13 @@ void __stack_chk_fail(void)
{
a_crash();
}
+
+#ifdef SHARED
+
+__attribute__((__visibility__("hidden")))
+void __stack_chk_fail_local(void)
+{
+ a_crash();
+}
+
+#endif