Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/sys Expand the support of __no[sanitizer] attributes



details:   https://anonhg.NetBSD.org/src/rev/84d683943b54
branches:  trunk
changeset: 1008397:84d683943b54
user:      kamil <kamil%NetBSD.org@localhost>
date:      Sat Mar 21 22:45:47 2020 +0000

description:
Expand the support of __no[sanitizer] attributes

Add support for RUMPKERNEL that can reuse these attributes in the same code.
These macros are not intended to be used by userland and are still disabled
there. They are a NetBSD specific extension.

Add proper support for clang and GCC.

Set __no[sanitizer] only under a sanitizer, as otherwise there are build
warnings about unused compiler attributes.

Reviewed by <maxv>

diffstat:

 sys/sys/cdefs.h |  23 ++++++++++++-----------
 1 files changed, 12 insertions(+), 11 deletions(-)

diffs (59 lines):

diff -r 7a9ba98917ba -r 84d683943b54 sys/sys/cdefs.h
--- a/sys/sys/cdefs.h   Sat Mar 21 20:20:59 2020 +0000
+++ b/sys/sys/cdefs.h   Sat Mar 21 22:45:47 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cdefs.h,v 1.150 2019/12/08 11:48:15 maxv Exp $ */
+/*     $NetBSD: cdefs.h,v 1.151 2020/03/21 22:45:47 kamil Exp $        */
 
 /* * Copyright (c) 1991, 1993
  *     The Regents of the University of California.  All rights reserved.
@@ -38,9 +38,6 @@
 
 #ifdef _KERNEL_OPT
 #include "opt_diagnostic.h"
-#include "opt_kasan.h"
-#include "opt_kcsan.h"
-#include "opt_kmsan.h"
 #endif
 
 /*
@@ -336,28 +333,32 @@
 #define        __unreachable() do {} while (/*CONSTCOND*/0)
 #endif
 
-#if defined(_KERNEL)
-#if __GNUC_PREREQ__(4, 9) && defined(KASAN)
+#if defined(_KERNEL) || defined(_RUMPKERNEL)
+#if defined(__clang__) && __has_feature(address_sanitizer)
+#define        __noasan        __attribute__((no_sanitize("kernel-address", "address")))
+#elif __GNUC_PREREQ__(4, 9) && defined(__SANITIZE_ADDRESS__)
 #define        __noasan        __attribute__((no_sanitize_address))
 #else
 #define        __noasan        /* nothing */
 #endif
 
-#if __GNUC_PREREQ__(4, 9) && defined(KCSAN)
+#if defined(__clang__) && __has_feature(thread_sanitizer)
+#define        __nocsan        __attribute__((no_sanitize("thread")))
+#elif __GNUC_PREREQ__(4, 9) && defined(__SANITIZE_THREAD__)
 #define        __nocsan        __attribute__((no_sanitize_thread))
 #else
 #define        __nocsan        /* nothing */
 #endif
 
-#if defined(__clang__) && defined(KMSAN)
-#define        __nomsan        __attribute__((no_sanitize("kernel-memory")))
+#if defined(__clang__) && __has_feature(memory_sanitizer)
+#define        __nomsan        __attribute__((no_sanitize("kernel-memory", "memory")))
 #else
 #define        __nomsan        /* nothing */
 #endif
 
-#if defined(__clang__)
+#if defined(__clang__) && __has_feature(undefined_behavior_sanitizer)
 #define __noubsan      __attribute__((no_sanitize("undefined")))
-#elif __GNUC_PREREQ__(4, 9)
+#elif __GNUC_PREREQ__(4, 9) && defined(__SANITIZE_UNDEFINED__)
 #define __noubsan      __attribute__((no_sanitize_undefined))
 #else
 #define __noubsan      /* nothing */



Home | Main Index | Thread Index | Old Index