blob: 5d5ca570c9901895c135fda0e855a58390c1af67 [file] [log] [blame]
Evgeniy Stepanov67227162012-12-25 11:53:51 +00001//===-- msan.h --------------------------------------------------*- C++ -*-===//
Evgeniy Stepanovc5033782012-12-11 12:27:27 +00002//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This file is a part of MemorySanitizer.
11//
12// Private MSan header.
13//===----------------------------------------------------------------------===//
14
15#ifndef MSAN_H
16#define MSAN_H
17
Sergey Matveev6eff11e2013-05-06 13:15:14 +000018#include "sanitizer_common/sanitizer_flags.h"
Evgeniy Stepanovc5033782012-12-11 12:27:27 +000019#include "sanitizer_common/sanitizer_internal_defs.h"
20#include "sanitizer_common/sanitizer_stacktrace.h"
Evgeniy Stepanoveac7f932013-01-29 14:33:29 +000021#include "msan_interface_internal.h"
Evgeniy Stepanovc5033782012-12-11 12:27:27 +000022#include "msan_flags.h"
23
Evgeniy Stepanovc7af8782013-04-05 12:03:47 +000024#ifndef MSAN_REPLACE_OPERATORS_NEW_AND_DELETE
25# define MSAN_REPLACE_OPERATORS_NEW_AND_DELETE 1
26#endif
27
Evgeniy Stepanovc5033782012-12-11 12:27:27 +000028#define MEM_TO_SHADOW(mem) (((uptr)mem) & ~0x400000000000ULL)
29#define MEM_TO_ORIGIN(mem) (MEM_TO_SHADOW(mem) + 0x200000000000ULL)
30#define MEM_IS_APP(mem) ((uptr)mem >= 0x600000000000ULL)
31#define MEM_IS_SHADOW(mem) ((uptr)mem >= 0x200000000000ULL && \
32 (uptr)mem <= 0x400000000000ULL)
33
34const int kMsanParamTlsSizeInWords = 100;
35const int kMsanRetvalTlsSizeInWords = 100;
36
37namespace __msan {
38extern int msan_inited;
39extern bool msan_init_is_running;
Evgeniy Stepanov9b52ce92013-01-10 11:17:55 +000040extern int msan_report_count;
Evgeniy Stepanovc5033782012-12-11 12:27:27 +000041
42bool ProtectRange(uptr beg, uptr end);
43bool InitShadow(bool prot1, bool prot2, bool map_shadow, bool init_origins);
44char *GetProcSelfMaps();
45void InitializeInterceptors();
46
47void *MsanReallocate(StackTrace *stack, void *oldp, uptr size,
48 uptr alignment, bool zeroise);
49void MsanDeallocate(void *ptr);
50void InstallTrapHandler();
Evgeniy Stepanov9b52ce92013-01-10 11:17:55 +000051void InstallAtExitHandler();
Evgeniy Stepanovc5033782012-12-11 12:27:27 +000052void ReplaceOperatorsNewAndDelete();
53
Kostya Serebryanyec87e782013-02-13 07:19:47 +000054void EnterSymbolizer();
55void ExitSymbolizer();
56bool IsInSymbolizer();
57
Reid Kleckner063dfe32013-03-06 16:11:58 +000058struct SymbolizerScope {
59 SymbolizerScope() { EnterSymbolizer(); }
60 ~SymbolizerScope() { ExitSymbolizer(); }
61};
62
Reid Klecknerc9d382b2013-03-11 18:07:42 +000063void EnterLoader();
64void ExitLoader();
65
Evgeniy Stepanovc5033782012-12-11 12:27:27 +000066void MsanDie();
67void PrintWarning(uptr pc, uptr bp);
68void PrintWarningWithOrigin(uptr pc, uptr bp, u32 origin);
69
Evgeniy Stepanov76dc3a82013-02-19 12:43:18 +000070void GetStackTrace(StackTrace *stack, uptr max_s, uptr pc, uptr bp,
71 bool fast);
Evgeniy Stepanovc5033782012-12-11 12:27:27 +000072
Evgeniy Stepanov367dc642012-12-26 09:32:05 +000073void ReportUMR(StackTrace *stack, u32 origin);
74void ReportExpectedUMRNotFound(StackTrace *stack);
Evgeniy Stepanov9b52ce92013-01-10 11:17:55 +000075void ReportAtExitStatistics();
Evgeniy Stepanov367dc642012-12-26 09:32:05 +000076
Alexey Samsonoved4594b2013-06-27 07:50:56 +000077// Unpoison first n function arguments.
78void UnpoisonParam(uptr n);
Evgeniy Stepanovc4179812013-08-27 12:59:39 +000079void UnpoisonThreadLocalState();
Reid Klecknerc9d382b2013-03-11 18:07:42 +000080
Evgeniy Stepanovc5033782012-12-11 12:27:27 +000081#define GET_MALLOC_STACK_TRACE \
82 StackTrace stack; \
83 stack.size = 0; \
84 if (__msan_get_track_origins() && msan_inited) \
Sergey Matveev6eff11e2013-05-06 13:15:14 +000085 GetStackTrace(&stack, common_flags()->malloc_context_size, \
Evgeniy Stepanov76dc3a82013-02-19 12:43:18 +000086 StackTrace::GetCurrentPc(), GET_CURRENT_FRAME(), \
Sergey Matveev6eff11e2013-05-06 13:15:14 +000087 common_flags()->fast_unwind_on_malloc)
Evgeniy Stepanovc5033782012-12-11 12:27:27 +000088
Evgeniy Stepanovcb22c672013-08-27 14:08:15 +000089class ScopedThreadLocalStateBackup {
90public:
91 ScopedThreadLocalStateBackup() { Backup(); }
92 ~ScopedThreadLocalStateBackup() { Restore(); }
93 void Backup();
94 void Restore();
95private:
96 u64 va_arg_overflow_size_tls;
97};
Evgeniy Stepanovc5033782012-12-11 12:27:27 +000098} // namespace __msan
99
Evgeniy Stepanov44b77c22013-08-02 14:26:58 +0000100#define MSAN_MALLOC_HOOK(ptr, size) \
101 if (&__msan_malloc_hook) __msan_malloc_hook(ptr, size)
102#define MSAN_FREE_HOOK(ptr) \
103 if (&__msan_free_hook) __msan_free_hook(ptr)
104
Evgeniy Stepanovc5033782012-12-11 12:27:27 +0000105#endif // MSAN_H