2021-09-01 06:35:08 +08:00
|
|
|
//===-- dfsan_thread.h ------------------------------------------*- C++ -*-===//
|
2021-02-04 03:41:58 +08:00
|
|
|
//
|
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file is a part of DataFlowSanitizer.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef DFSAN_THREAD_H
|
|
|
|
#define DFSAN_THREAD_H
|
|
|
|
|
2021-05-01 05:19:45 +08:00
|
|
|
#include "dfsan_allocator.h"
|
2021-02-04 03:41:58 +08:00
|
|
|
#include "sanitizer_common/sanitizer_common.h"
|
|
|
|
|
|
|
|
namespace __dfsan {
|
|
|
|
|
|
|
|
class DFsanThread {
|
|
|
|
public:
|
|
|
|
// NOTE: There is no DFsanThread constructor. It is allocated
|
|
|
|
// via mmap() and *must* be valid in zero-initialized state.
|
|
|
|
|
|
|
|
static DFsanThread *Create(void *start_routine_trampoline,
|
2021-03-10 14:31:56 +08:00
|
|
|
thread_callback_t start_routine, void *arg,
|
|
|
|
bool track_origins = false);
|
2021-02-04 03:41:58 +08:00
|
|
|
static void TSDDtor(void *tsd);
|
|
|
|
void Destroy();
|
|
|
|
|
|
|
|
void Init(); // Should be called from the thread itself.
|
|
|
|
thread_return_t ThreadStart();
|
|
|
|
|
|
|
|
uptr stack_top();
|
|
|
|
uptr stack_bottom();
|
2021-05-01 05:19:45 +08:00
|
|
|
uptr tls_begin() { return tls_begin_; }
|
|
|
|
uptr tls_end() { return tls_end_; }
|
2021-02-04 03:41:58 +08:00
|
|
|
bool IsMainThread() { return start_routine_ == nullptr; }
|
|
|
|
|
|
|
|
bool InSignalHandler() { return in_signal_handler_; }
|
|
|
|
void EnterSignalHandler() { in_signal_handler_++; }
|
|
|
|
void LeaveSignalHandler() { in_signal_handler_--; }
|
|
|
|
|
2021-05-01 05:19:45 +08:00
|
|
|
DFsanThreadLocalMallocStorage &malloc_storage() { return malloc_storage_; }
|
|
|
|
|
2021-02-04 03:41:58 +08:00
|
|
|
int destructor_iterations_;
|
|
|
|
|
|
|
|
private:
|
|
|
|
void SetThreadStackAndTls();
|
2021-05-01 05:19:45 +08:00
|
|
|
void ClearShadowForThreadStackAndTLS();
|
2021-02-04 03:41:58 +08:00
|
|
|
struct StackBounds {
|
|
|
|
uptr bottom;
|
|
|
|
uptr top;
|
|
|
|
};
|
|
|
|
StackBounds GetStackBounds() const;
|
|
|
|
|
|
|
|
bool AddrIsInStack(uptr addr);
|
|
|
|
|
|
|
|
void *start_routine_trampoline_;
|
|
|
|
thread_callback_t start_routine_;
|
|
|
|
void *arg_;
|
2021-03-10 14:31:56 +08:00
|
|
|
bool track_origins_;
|
2021-02-04 03:41:58 +08:00
|
|
|
|
|
|
|
StackBounds stack_;
|
|
|
|
|
2021-05-01 05:19:45 +08:00
|
|
|
uptr tls_begin_;
|
|
|
|
uptr tls_end_;
|
|
|
|
|
2021-02-04 03:41:58 +08:00
|
|
|
unsigned in_signal_handler_;
|
2021-05-01 05:19:45 +08:00
|
|
|
|
|
|
|
DFsanThreadLocalMallocStorage malloc_storage_;
|
2021-02-04 03:41:58 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
DFsanThread *GetCurrentThread();
|
|
|
|
void SetCurrentThread(DFsanThread *t);
|
|
|
|
void DFsanTSDInit(void (*destructor)(void *tsd));
|
|
|
|
void DFsanTSDDtor(void *tsd);
|
|
|
|
|
|
|
|
} // namespace __dfsan
|
|
|
|
|
|
|
|
#endif // DFSAN_THREAD_H
|