1 //===-- hwasan_thread.h -----------------------------------------*- C++ -*-===//
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
7 //===----------------------------------------------------------------------===//
9 // This file is a part of HWAddressSanitizer.
11 //===----------------------------------------------------------------------===//
13 #ifndef HWASAN_THREAD_H
14 #define HWASAN_THREAD_H
16 #include "hwasan_allocator.h"
17 #include "sanitizer_common/sanitizer_common.h"
18 #include "sanitizer_common/sanitizer_ring_buffer.h"
22 typedef __sanitizer::CompactRingBuffer
<uptr
> StackAllocationsRingBuffer
;
26 // These are optional parameters that can be passed to Init.
29 void Init(uptr stack_buffer_start
, uptr stack_buffer_size
,
30 const InitState
*state
= nullptr);
32 void InitStackAndTls(const InitState
*state
= nullptr);
34 // Must be called from the thread itself.
35 void InitStackRingBuffer(uptr stack_buffer_start
, uptr stack_buffer_size
);
37 inline void EnsureRandomStateInited() {
38 if (UNLIKELY(!random_state_inited_
))
44 uptr
stack_top() { return stack_top_
; }
45 uptr
stack_bottom() { return stack_bottom_
; }
46 uptr
stack_size() { return stack_top() - stack_bottom(); }
47 uptr
tls_begin() { return tls_begin_
; }
48 uptr
tls_end() { return tls_end_
; }
49 DTLS
*dtls() { return dtls_
; }
50 bool IsMainThread() { return unique_id_
== 0; }
52 bool AddrIsInStack(uptr addr
) {
53 return addr
>= stack_bottom_
&& addr
< stack_top_
;
56 AllocatorCache
*allocator_cache() { return &allocator_cache_
; }
57 HeapAllocationsRingBuffer
*heap_allocations() { return heap_allocations_
; }
58 StackAllocationsRingBuffer
*stack_allocations() { return stack_allocations_
; }
60 tag_t
GenerateRandomTag(uptr num_bits
= kTagBits
);
62 void DisableTagging() { tagging_disabled_
++; }
63 void EnableTagging() { tagging_disabled_
--; }
65 u32
unique_id() const { return unique_id_
; }
67 if (announced_
) return;
72 tid_t
os_id() const { return os_id_
; }
73 void set_os_id(tid_t os_id
) { os_id_
= os_id
; }
75 uptr
&vfork_spill() { return vfork_spill_
; }
78 // NOTE: There is no Thread constructor. It is allocated
79 // via mmap() and *must* be valid in zero-initialized state.
80 void ClearShadowForThreadStackAndTLS();
81 void Print(const char *prefix
);
82 void InitRandomState();
93 AllocatorCache allocator_cache_
;
94 HeapAllocationsRingBuffer
*heap_allocations_
;
95 StackAllocationsRingBuffer
*stack_allocations_
;
97 u32 unique_id_
; // counting from zero.
101 u32 tagging_disabled_
; // if non-zero, malloc uses zero tag in this thread.
105 bool random_state_inited_
; // Whether InitRandomState() has been called.
107 friend struct ThreadListHead
;
110 Thread
*GetCurrentThread();
111 uptr
*GetCurrentThreadLongPtr();
113 // Used to handle fork().
114 void EnsureMainThreadIDIsCorrect();
116 struct ScopedTaggingDisabler
{
117 ScopedTaggingDisabler() { GetCurrentThread()->DisableTagging(); }
118 ~ScopedTaggingDisabler() { GetCurrentThread()->EnableTagging(); }
121 } // namespace __hwasan
123 #endif // HWASAN_THREAD_H