xref: /freebsd/contrib/llvm-project/compiler-rt/include/sanitizer/hwasan_interface.h (revision f126890ac5386406dadf7c4cfa9566cbb56537c5)
1 //===-- sanitizer/hwasan_interface.h ----------------------------*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 //
9 // This file is a part of HWAddressSanitizer.
10 //
11 // Public interface header.
12 //===----------------------------------------------------------------------===//
13 #ifndef SANITIZER_HWASAN_INTERFACE_H
14 #define SANITIZER_HWASAN_INTERFACE_H
15 
16 #include <sanitizer/common_interface_defs.h>
17 
18 #ifdef __cplusplus
19 extern "C" {
20 #endif
21   // Libc hook for program startup in statically linked executables.
22   // Initializes enough of the runtime to run instrumented code. This function
23   // should only be called in statically linked executables because it modifies
24   // the GOT, which won't work in regular binaries because RELRO will already
25   // have been applied by the time the function is called. This also means that
26   // the function should be called before libc applies RELRO.
27   // Does not call libc unless there is an error.
28   // Can be called multiple times.
29   void __hwasan_init_static(void);
30 
31   // This function may be optionally provided by user and should return
32   // a string containing HWASan runtime options. See asan_flags.h for details.
33   const char* __hwasan_default_options(void);
34 
35   void __hwasan_enable_allocator_tagging(void);
36   void __hwasan_disable_allocator_tagging(void);
37 
38   // Mark region of memory with the given tag. Both address and size need to be
39   // 16-byte aligned.
40   void __hwasan_tag_memory(const volatile void *p, unsigned char tag,
41                            size_t size);
42 
43   /// Set pointer tag. Previous tag is lost.
44   void *__hwasan_tag_pointer(const volatile void *p, unsigned char tag);
45 
46   // Set memory tag from the current SP address to the given address to zero.
47   // This is meant to annotate longjmp and other non-local jumps.
48   // This function needs to know the (almost) exact destination frame address;
49   // clearing shadow for the entire thread stack like __asan_handle_no_return
50   // does would cause false reports.
51   void __hwasan_handle_longjmp(const void *sp_dst);
52 
53   // Set memory tag for the part of the current thread stack below sp_dst to
54   // zero. Call this in vfork() before returning in the parent process.
55   void __hwasan_handle_vfork(const void *sp_dst);
56 
57   // Libc hook for thread creation. Should be called in the child thread before
58   // any instrumented code.
59   void __hwasan_thread_enter();
60 
61   // Libc hook for thread destruction. No instrumented code should run after
62   // this call.
63   void __hwasan_thread_exit();
64 
65   // Print shadow and origin for the memory range to stderr in a human-readable
66   // format.
67   void __hwasan_print_shadow(const volatile void *x, size_t size);
68 
69   // Print one-line report about the memory usage of the current process.
70   void __hwasan_print_memory_usage();
71 
72   /* Returns the offset of the first byte in the memory range that can not be
73    * accessed through the pointer in x, or -1 if the whole range is good. */
74   intptr_t __hwasan_test_shadow(const volatile void *x, size_t size);
75 
76   /* Sets the callback function to be called during HWASan error reporting. */
77   void __hwasan_set_error_report_callback(void (*callback)(const char *));
78 
79   int __sanitizer_posix_memalign(void **memptr, size_t alignment, size_t size);
80   void * __sanitizer_memalign(size_t alignment, size_t size);
81   void * __sanitizer_aligned_alloc(size_t alignment, size_t size);
82   void * __sanitizer___libc_memalign(size_t alignment, size_t size);
83   void * __sanitizer_valloc(size_t size);
84   void * __sanitizer_pvalloc(size_t size);
85   void __sanitizer_free(void *ptr);
86   void __sanitizer_cfree(void *ptr);
87   size_t __sanitizer_malloc_usable_size(const void *ptr);
88   struct mallinfo __sanitizer_mallinfo();
89   int __sanitizer_mallopt(int cmd, int value);
90   void __sanitizer_malloc_stats(void);
91   void * __sanitizer_calloc(size_t nmemb, size_t size);
92   void * __sanitizer_realloc(void *ptr, size_t size);
93   void * __sanitizer_reallocarray(void *ptr, size_t nmemb, size_t size);
94   void * __sanitizer_malloc(size_t size);
95 #ifdef __cplusplus
96 }  // extern "C"
97 #endif
98 
99 #endif  // SANITIZER_HWASAN_INTERFACE_H
100