aboutsummaryrefslogtreecommitdiff
path: root/newlib
diff options
context:
space:
mode:
authorThomas Schwinge <thomas@codesourcery.com>2022-10-11 23:34:19 +0200
committerThomas Schwinge <thomas@codesourcery.com>2023-01-19 21:51:09 +0100
commit3b58032de14f7a08b1c60ee9fc4857c5fbfc8e57 (patch)
treecd4caa57628bffde4391951bf9e3b5a428d5d343 /newlib
parent52cb9370044d11a29ae0dc1120ffdf246f5abc20 (diff)
downloadnewlib-3b58032de14f7a08b1c60ee9fc4857c5fbfc8e57.zip
newlib-3b58032de14f7a08b1c60ee9fc4857c5fbfc8e57.tar.gz
newlib-3b58032de14f7a08b1c60ee9fc4857c5fbfc8e57.tar.bz2
nvptx: Don't use global constructor for SSP setup
Given that nvptx newlib currently restricts itself to ELIX level 1, this is not already a problem. However, in the following we'd like to lift that restriction, and then run into: [...]/newlib/libc/ssp/stack_protector.c: In function ‘__stack_chk_init’: [...]/newlib/libc/ssp/stack_protector.c:31:1: sorry, unimplemented: global constructors not supported on this target 31 | } | ^ GCC patch "nvptx: Support global constructors/destructors via 'collect2'" has been posted, but not yet accepted. Until that is resolved, use the same manual SSP setup as for GCN.
Diffstat (limited to 'newlib')
-rw-r--r--newlib/libc/ssp/stack_protector.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/newlib/libc/ssp/stack_protector.c b/newlib/libc/ssp/stack_protector.c
index cd51543..5e9d75f 100644
--- a/newlib/libc/ssp/stack_protector.c
+++ b/newlib/libc/ssp/stack_protector.c
@@ -5,8 +5,8 @@
#include <string.h>
#include <unistd.h>
-#if defined(__AMDGCN__)
-/* GCN does not support constructors, yet. */
+#if defined(__AMDGCN__) || defined(__nvptx__)
+/* Global constructors not supported on this target, yet. */
uintptr_t __stack_chk_guard = 0x00000aff; /* 0, 0, '\n', 255 */
#else