blob: 2105791a032db86bf666399428f888bfc6cc77f1 [file] [log] [blame]
Evgeniy Stepanov97edeb32012-12-25 11:53:51 +00001//===-- msan.h --------------------------------------------------*- C++ -*-===//
Evgeniy Stepanov78c56c32012-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 Matveev0b4bf4d2013-05-06 13:15:14 +000018#include "sanitizer_common/sanitizer_flags.h"
Evgeniy Stepanov78c56c32012-12-11 12:27:27 +000019#include "sanitizer_common/sanitizer_internal_defs.h"
20#include "sanitizer_common/sanitizer_stacktrace.h"
Evgeniy Stepanov12c46932013-01-29 14:33:29 +000021#include "msan_interface_internal.h"
Evgeniy Stepanov78c56c32012-12-11 12:27:27 +000022#include "msan_flags.h"
23
Evgeniy Stepanova8974002013-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 Stepanov450eee62013-10-24 11:56:03 +000028#define MEM_TO_SHADOW(mem) (((uptr)mem) & ~0x400000000000ULL)
29#define SHADOW_TO_ORIGIN(shadow) (((uptr)shadow) + 0x200000000000ULL)
30#define MEM_TO_ORIGIN(mem) (SHADOW_TO_ORIGIN(MEM_TO_SHADOW(mem)))
31#define MEM_IS_APP(mem) ((uptr)mem >= 0x600000000000ULL)
32#define MEM_IS_SHADOW(mem) \
33 ((uptr)mem >= 0x200000000000ULL && (uptr)mem <= 0x400000000000ULL)
Evgeniy Stepanov78c56c32012-12-11 12:27:27 +000034
35const int kMsanParamTlsSizeInWords = 100;
36const int kMsanRetvalTlsSizeInWords = 100;
37
38namespace __msan {
39extern int msan_inited;
40extern bool msan_init_is_running;
Evgeniy Stepanov99bf1d72013-01-10 11:17:55 +000041extern int msan_report_count;
Evgeniy Stepanov78c56c32012-12-11 12:27:27 +000042
43bool ProtectRange(uptr beg, uptr end);
44bool InitShadow(bool prot1, bool prot2, bool map_shadow, bool init_origins);
45char *GetProcSelfMaps();
46void InitializeInterceptors();
47
Evgeniy Stepanov7c6bd402013-10-22 14:31:30 +000048void MsanAllocatorThreadFinish();
Evgeniy Stepanov78c56c32012-12-11 12:27:27 +000049void *MsanReallocate(StackTrace *stack, void *oldp, uptr size,
50 uptr alignment, bool zeroise);
Evgeniy Stepanoveffdc7e2013-09-16 11:03:31 +000051void MsanDeallocate(StackTrace *stack, void *ptr);
Evgeniy Stepanov78c56c32012-12-11 12:27:27 +000052void InstallTrapHandler();
Evgeniy Stepanov99bf1d72013-01-10 11:17:55 +000053void InstallAtExitHandler();
Evgeniy Stepanov78c56c32012-12-11 12:27:27 +000054void ReplaceOperatorsNewAndDelete();
55
Stephen Hines2d1fdb22014-05-28 23:58:16 -070056const char *GetStackOriginDescr(u32 id, uptr *pc);
Evgeniy Stepanov6f346052013-09-13 12:49:13 +000057
Kostya Serebryany70c6e3f2013-02-13 07:19:47 +000058void EnterSymbolizer();
59void ExitSymbolizer();
60bool IsInSymbolizer();
61
Reid Kleckner93c26022013-03-06 16:11:58 +000062struct SymbolizerScope {
63 SymbolizerScope() { EnterSymbolizer(); }
64 ~SymbolizerScope() { ExitSymbolizer(); }
65};
66
Reid Kleckner0f92deb2013-03-11 18:07:42 +000067void EnterLoader();
68void ExitLoader();
69
Evgeniy Stepanov78c56c32012-12-11 12:27:27 +000070void MsanDie();
71void PrintWarning(uptr pc, uptr bp);
72void PrintWarningWithOrigin(uptr pc, uptr bp, u32 origin);
73
Evgeniy Stepanovefbc4352013-02-19 12:43:18 +000074void GetStackTrace(StackTrace *stack, uptr max_s, uptr pc, uptr bp,
Alexey Samsonovf16dc422013-11-07 07:28:33 +000075 bool request_fast_unwind);
Evgeniy Stepanov78c56c32012-12-11 12:27:27 +000076
Evgeniy Stepanovdb010da2012-12-26 09:32:05 +000077void ReportUMR(StackTrace *stack, u32 origin);
78void ReportExpectedUMRNotFound(StackTrace *stack);
Stephen Hines2d1fdb22014-05-28 23:58:16 -070079void ReportStats();
Evgeniy Stepanov99bf1d72013-01-10 11:17:55 +000080void ReportAtExitStatistics();
Stephen Hines2d1fdb22014-05-28 23:58:16 -070081void DescribeMemoryRange(const void *x, uptr size);
82void ReportUMRInsideAddressRange(const char *what, const void *start, uptr size,
83 uptr offset);
Evgeniy Stepanovdb010da2012-12-26 09:32:05 +000084
Alexey Samsonovc2918bf2013-06-27 07:50:56 +000085// Unpoison first n function arguments.
86void UnpoisonParam(uptr n);
Evgeniy Stepanov91659d52013-08-27 12:59:39 +000087void UnpoisonThreadLocalState();
Reid Kleckner0f92deb2013-03-11 18:07:42 +000088
Stephen Hines2d1fdb22014-05-28 23:58:16 -070089u32 GetOriginIfPoisoned(uptr a, uptr size);
90void SetOriginIfPoisoned(uptr addr, uptr src_shadow, uptr size, u32 src_origin);
91void CopyOrigin(void *dst, const void *src, uptr size, StackTrace *stack);
92void MovePoison(void *dst, const void *src, uptr size, StackTrace *stack);
93void CopyPoison(void *dst, const void *src, uptr size, StackTrace *stack);
94
95// Returns a "chained" origin id, pointing to the given stack trace followed by
96// the previous origin id.
97u32 ChainOrigin(u32 id, StackTrace *stack);
98
Evgeniy Stepanov78c56c32012-12-11 12:27:27 +000099#define GET_MALLOC_STACK_TRACE \
100 StackTrace stack; \
101 stack.size = 0; \
102 if (__msan_get_track_origins() && msan_inited) \
Sergey Matveev0b4bf4d2013-05-06 13:15:14 +0000103 GetStackTrace(&stack, common_flags()->malloc_context_size, \
Evgeniy Stepanovefbc4352013-02-19 12:43:18 +0000104 StackTrace::GetCurrentPc(), GET_CURRENT_FRAME(), \
Sergey Matveev0b4bf4d2013-05-06 13:15:14 +0000105 common_flags()->fast_unwind_on_malloc)
Evgeniy Stepanov78c56c32012-12-11 12:27:27 +0000106
Stephen Hines2d1fdb22014-05-28 23:58:16 -0700107#define GET_STORE_STACK_TRACE_PC_BP(pc, bp) \
108 StackTrace stack; \
109 stack.size = 0; \
110 if (__msan_get_track_origins() > 1 && msan_inited) \
111 GetStackTrace(&stack, common_flags()->malloc_context_size, pc, bp, \
112 common_flags()->fast_unwind_on_malloc)
113
114#define GET_FATAL_STACK_TRACE_PC_BP(pc, bp) \
115 StackTrace stack; \
116 stack.size = 0; \
117 if (msan_inited) \
118 GetStackTrace(&stack, kStackTraceMax, pc, bp, \
119 common_flags()->fast_unwind_on_fatal)
120
121#define GET_STORE_STACK_TRACE \
122 GET_STORE_STACK_TRACE_PC_BP(StackTrace::GetCurrentPc(), GET_CURRENT_FRAME())
123
Evgeniy Stepanov0e38a672013-08-27 14:08:15 +0000124class ScopedThreadLocalStateBackup {
Alexey Samsonovc1548202013-08-28 11:26:09 +0000125 public:
Evgeniy Stepanov0e38a672013-08-27 14:08:15 +0000126 ScopedThreadLocalStateBackup() { Backup(); }
127 ~ScopedThreadLocalStateBackup() { Restore(); }
128 void Backup();
129 void Restore();
Alexey Samsonovc1548202013-08-28 11:26:09 +0000130 private:
Evgeniy Stepanov0e38a672013-08-27 14:08:15 +0000131 u64 va_arg_overflow_size_tls;
132};
Stephen Hines2d1fdb22014-05-28 23:58:16 -0700133
134extern void (*death_callback)(void);
135
136void MsanTSDInit(void (*destructor)(void *tsd));
137void *MsanTSDGet();
138void MsanTSDSet(void *tsd);
139void MsanTSDDtor(void *tsd);
140
Evgeniy Stepanov78c56c32012-12-11 12:27:27 +0000141} // namespace __msan
142
Evgeniy Stepanov5c48a8c2013-08-02 14:26:58 +0000143#define MSAN_MALLOC_HOOK(ptr, size) \
144 if (&__msan_malloc_hook) __msan_malloc_hook(ptr, size)
145#define MSAN_FREE_HOOK(ptr) \
146 if (&__msan_free_hook) __msan_free_hook(ptr)
147
Evgeniy Stepanov78c56c32012-12-11 12:27:27 +0000148#endif // MSAN_H