/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* vim: set ts=8 sts=2 et sw=2 tw=80: */ /* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
/* * Provides a common interface to the ASan (AddressSanitizer) and Valgrind * functions used to mark memory in certain ways. In detail, the following * three macros are provided: * * MOZ_MAKE_MEM_NOACCESS - Mark memory as unsafe to access (e.g. freed) * MOZ_MAKE_MEM_UNDEFINED - Mark memory as accessible, with content undefined * MOZ_MAKE_MEM_DEFINED - Mark memory as accessible, with content defined * * With Valgrind in use, these directly map to the three respective Valgrind * macros. With ASan in use, the NOACCESS macro maps to poisoning the memory, * while the UNDEFINED/DEFINED macros unpoison memory. * * With no memory checker available, all macros expand to the empty statement.
*/
# include "mozilla/Attributes.h" # include "mozilla/Types.h"
# ifdef _MSC_VER // In clang-cl based ASAN, we link against the memory poisoning functions // statically. # define MOZ_ASAN_VISIBILITY # else # define MOZ_ASAN_VISIBILITY MOZ_EXPORT # endif
extern"C" { /* These definitions are usually provided through the * sanitizer/asan_interface.h header installed by ASan.
*/ void MOZ_ASAN_VISIBILITY __asan_poison_memory_region(voidconstvolatile* addr,
size_t size); void MOZ_ASAN_VISIBILITY
__asan_unpoison_memory_region(voidconstvolatile* addr, size_t size);
/* * These definitions are usually provided through the * sanitizer/lsan_interface.h header installed by LSan.
*/ void MOZ_EXPORT __lsan_ignore_object(constvoid* p);
} #elifdefined(MOZ_MSAN) # include <stddef.h>
# include "mozilla/Types.h"
extern"C" { /* These definitions are usually provided through the * sanitizer/msan_interface.h header installed by MSan.
*/ void MOZ_EXPORT __msan_poison(voidconstvolatile* addr, size_t size); void MOZ_EXPORT __msan_unpoison(voidconstvolatile* addr, size_t size);
# define MOZ_MAKE_MEM_NOACCESS(addr, size) \ do { \
} while (0) # define MOZ_MAKE_MEM_UNDEFINED(addr, size) \ do { \
} while (0) # define MOZ_MAKE_MEM_DEFINED(addr, size) \ do { \
} while (0)
#endif
/* * MOZ_LSAN_INTENTIONAL_LEAK(X) is a macro to tell LeakSanitizer that X * points to a value that will intentionally never be deallocated during * the execution of the process. * * Additional uses of this macro should be reviewed by people * conversant in leak-checking and/or MFBT peers.
*/ #ifdefined(MOZ_ASAN) # define MOZ_LSAN_INTENTIONALLY_LEAK_OBJECT(X) __lsan_ignore_object(X) #else # define MOZ_LSAN_INTENTIONALLY_LEAK_OBJECT(X) /* nothing */ #endif// defined(MOZ_ASAN)
#endif/* mozilla_MemoryChecking_h */
¤ Dauer der Verarbeitung: 0.10 Sekunden
(vorverarbeitet)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung ist noch experimentell.