Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/external/gpl3 Use the proper stack aligment for the architec...
details: https://anonhg.NetBSD.org/src/rev/41705d7a807e
branches: trunk
changeset: 838436:41705d7a807e
user: christos <christos%NetBSD.org@localhost>
date: Thu Jan 17 20:36:51 2019 +0000
description:
Use the proper stack aligment for the architecture. Fixes broken asan
tests on i386.
diffstat:
external/gpl3/gcc.old/dist/libsanitizer/asan/asan_thread.cc | 9 ++++++++-
external/gpl3/gcc/dist/libsanitizer/asan/asan_thread.cc | 9 ++++++++-
2 files changed, 16 insertions(+), 2 deletions(-)
diffs (52 lines):
diff -r 19a6d22052af -r 41705d7a807e external/gpl3/gcc.old/dist/libsanitizer/asan/asan_thread.cc
--- a/external/gpl3/gcc.old/dist/libsanitizer/asan/asan_thread.cc Thu Jan 17 19:26:03 2019 +0000
+++ b/external/gpl3/gcc.old/dist/libsanitizer/asan/asan_thread.cc Thu Jan 17 20:36:51 2019 +0000
@@ -9,6 +9,10 @@
//
// Thread-related code.
//===----------------------------------------------------------------------===//
+
+#define __EXPOSE_STACK
+#include <sys/param.h>
+
#include "asan_allocator.h"
#include "asan_interceptors.h"
#include "asan_poisoning.h"
@@ -221,7 +225,10 @@
access->frame_descr = (const char *)((uptr*)bottom)[1];
return true;
}
- uptr aligned_addr = addr & ~(SANITIZER_WORDSIZE/8 - 1); // align addr.
+#ifndef STACK_ALIGNBYTES
+# define STACK_ALIGNBYTES (~(SANITIZER_WORDSIZE/8 - 1))
+#endif
+ uptr aligned_addr = addr & STACK_ALIGNBYTES; // align addr.
u8 *shadow_ptr = (u8*)MemToShadow(aligned_addr);
u8 *shadow_bottom = (u8*)MemToShadow(bottom);
diff -r 19a6d22052af -r 41705d7a807e external/gpl3/gcc/dist/libsanitizer/asan/asan_thread.cc
--- a/external/gpl3/gcc/dist/libsanitizer/asan/asan_thread.cc Thu Jan 17 19:26:03 2019 +0000
+++ b/external/gpl3/gcc/dist/libsanitizer/asan/asan_thread.cc Thu Jan 17 20:36:51 2019 +0000
@@ -9,6 +9,10 @@
//
// Thread-related code.
//===----------------------------------------------------------------------===//
+
+#define __EXPOSE_STACK
+#include <sys/param.h>
+
#include "asan_allocator.h"
#include "asan_interceptors.h"
#include "asan_poisoning.h"
@@ -221,7 +225,10 @@
access->frame_descr = (const char *)((uptr*)bottom)[1];
return true;
}
- uptr aligned_addr = addr & ~(SANITIZER_WORDSIZE/8 - 1); // align addr.
+#ifndef STACK_ALIGNBYTES
+# define STACK_ALIGNBYTES (~(SANITIZER_WORDSIZE/8 - 1))
+#endif
+ uptr aligned_addr = addr & STACK_ALIGNBYTES; // align addr.
u8 *shadow_ptr = (u8*)MemToShadow(aligned_addr);
u8 *shadow_bottom = (u8*)MemToShadow(bottom);
Home |
Main Index |
Thread Index |
Old Index