]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
gcc: xtensa: enable address sanitizer
authorMax Filippov <jcmvbkbc@gmail.com>
Tue, 5 Dec 2017 14:17:35 +0000 (14:17 +0000)
committerMax Filippov <jcmvbkbc@gcc.gnu.org>
Tue, 5 Dec 2017 14:17:35 +0000 (14:17 +0000)
gcc/
2017-12-05  Max Filippov  <jcmvbkbc@gmail.com>

* config/xtensa/xtensa.c (xtensa_asan_shadow_offset): New
function.
(TARGET_ASAN_SHADOW_OFFSET): New macro definition.
* config/xtensa/xtensa.h (FRAME_GROWS_DOWNWARD): Set to 1 if
ASAN is enabled.

From-SVN: r255420

gcc/ChangeLog
gcc/config/xtensa/xtensa.c
gcc/config/xtensa/xtensa.h

index 4ddc4801cc24a4904d76bfb5b04da354bb85b114..9097671c09aa30af225a0f0dfbbba027b8be3668 100644 (file)
@@ -1,3 +1,11 @@
+2017-12-05  Max Filippov  <jcmvbkbc@gmail.com>
+
+       * config/xtensa/xtensa.c (xtensa_asan_shadow_offset): New
+       function.
+       (TARGET_ASAN_SHADOW_OFFSET): New macro definition.
+       * config/xtensa/xtensa.h (FRAME_GROWS_DOWNWARD): Set to 1 if
+       ASAN is enabled.
+
 2017-12-05  Richard Biener   <rguenther@suse.de>
 
        * timevar.def (TV_TREE_RECIP, TV_TREE_SINCOS, TV_TREE_WIDEN_MUL):
index 1e73b2f4405da25a9766e4271483ca2b9033f159..92b9a600df823486d96e1add406263ff333fc394 100644 (file)
@@ -183,6 +183,7 @@ static bool xtensa_hard_regno_mode_ok (unsigned int, machine_mode);
 static bool xtensa_modes_tieable_p (machine_mode, machine_mode);
 static HOST_WIDE_INT xtensa_constant_alignment (const_tree, HOST_WIDE_INT);
 static HOST_WIDE_INT xtensa_starting_frame_offset (void);
+static unsigned HOST_WIDE_INT xtensa_asan_shadow_offset (void);
 
 \f
 
@@ -325,6 +326,9 @@ static HOST_WIDE_INT xtensa_starting_frame_offset (void);
 #undef TARGET_STARTING_FRAME_OFFSET
 #define TARGET_STARTING_FRAME_OFFSET xtensa_starting_frame_offset
 
+#undef TARGET_ASAN_SHADOW_OFFSET
+#define TARGET_ASAN_SHADOW_OFFSET xtensa_asan_shadow_offset
+
 struct gcc_target targetm = TARGET_INITIALIZER;
 
 \f
@@ -4413,4 +4417,12 @@ xtensa_starting_frame_offset (void)
   return crtl->outgoing_args_size;
 }
 
+/* Implement TARGET_ASAN_SHADOW_OFFSET.  */
+
+static unsigned HOST_WIDE_INT
+xtensa_asan_shadow_offset (void)
+{
+  return HOST_WIDE_INT_UC (0x10000000);
+}
+
 #include "gt-xtensa.h"
index b4cf53708b3eb4a60846cf24003ae7b82f9aee99..1602fae3d9ea792b8da79017689372b1537624a2 100644 (file)
@@ -430,7 +430,8 @@ enum reg_class
 
 #define STACK_GROWS_DOWNWARD 1
 
-#define FRAME_GROWS_DOWNWARD flag_stack_protect
+#define FRAME_GROWS_DOWNWARD (flag_stack_protect \
+                             || (flag_sanitize & SANITIZE_ADDRESS) != 0)
 
 /* The ARG_POINTER and FRAME_POINTER are not real Xtensa registers, so
    they are eliminated to either the stack pointer or hard frame pointer.  */