[asan] Add exception handler to map memory on demand on Win64.
Memory will be committed on demand when exception happens while accessing
shadow memeory region.
Details
Diff Detail
- Repository
- rL LLVM
Event Timeline
| lib/asan/asan_win.cc | ||
|---|---|---|
| 227 ↗ | (On Diff #62554) | Does this can be done into: InitializeExceptionHandlerOnWindows64 | 
| 244 ↗ | (On Diff #62554) | no { } here | 
| 265 ↗ | (On Diff #62554) | 'auto' here won't comply with the common coding style in llvm. | 
| 271 ↗ | (On Diff #62554) | ditto 'auto' | 
| 280 ↗ | (On Diff #62554) | rewrite the following list has a single line. if (AddVectoredExceptionHandler(TRUE, &ShadowExceptionHandler) != nullptr) or if (!AddVectoredExceptionHandler(TRUE, &ShadowExceptionHandler)) | 
| lib/asan/asan_win.cc | ||
|---|---|---|
| 257 ↗ | (On Diff #62593) | As I get it, for the shadow memory this should never happens??? | 
| lib/asan/asan_internal.h | ||
|---|---|---|
| 65 ↗ | (On Diff #62593) | I'm not a fan of these #ifdef Should we use something similar than: void InitializePlatformInterceptors(); | 
| lib/asan/asan_internal.h | ||
|---|---|---|
| 65 ↗ | (On Diff #62593) | Sounds reasonable. Could be called InitializePlatformExceptionHandlers() ? | 
| lib/asan/asan_win.cc | ||
|---|---|---|
| 223–231 ↗ | (On Diff #62741) | Use GetPageSizeCached() and GetMmapGranularity() instead. | 
| 249–250 ↗ | (On Diff #62741) | Use RoundDownTo instead of the bitmath | 
| 257 ↗ | (On Diff #62741) | Yeah, what's the story here? We're going with up-front reservation first, and that succeeds in Win8.1+, right? | 
| 260–261 ↗ | (On Diff #62741) | RoundDownTo | 
| lib/asan/asan_win.cc | ||
|---|---|---|
| 257 ↗ | (On Diff #62961) | This is cut and paste from a small test harness I wrote. Because of the page table overhead on Win7, I was tinkering with not even reserving the shadow at all, and had added this support. I think it simpler if we just say only Win8+ is recommended for x64, and document the page table overhead for Win7. This is better than the potential correctness problem that can result if somebody else gets memory where we think we have the shadow. | 
| lib/asan/asan_win.cc | ||
|---|---|---|
| 257 ↗ | (On Diff #62961) | Yes. This piece of code was ported from a test program (credits to chrisha). I thought for a while and it should be not useful in the case of windows 10, apart from being defensive code. For window 7, I am not quite sure what's the behavior. One thing that I would like to test is, VirtualAlloc() seems to have alignment requirement of allocation granularity for any flag involving MEM_RESERVE, if I understand correctly. For MEM_COMMIT only flag, address only have to be aligned with page size. | 
drive-by
| lib/asan/asan_win.cc | ||
|---|---|---|
| 262 ↗ | (On Diff #63446) | Change this for a CHECK(...) | 
| lib/sanitizer_common/sanitizer_win.cc | ||
| 171 ↗ | (On Diff #63446) | IIRC, this function is used at other place. (MmapFixedNoReserve). | 
| 178 ↗ | (On Diff #63446) | nit: execption -> exeception | 
| lib/sanitizer_common/sanitizer_win.cc | ||
|---|---|---|
| 171 ↗ | (On Diff #63447) | I see, this function also used in dfsan, esan etc. The name is already confusing.. It says "NoReserve" yet we are passing MEM_RESERVE flag.. | 
This CL is not compiling.
Please fix:
../llvm/llvm/projects/compiler-rt/lib/asan/asan_win.cc:232: Lines should be <= 80 characters long [whitespace/line_length] [2] ../llvm/llvm/projects/compiler-rt/lib/asan/asan_win.cc:249: Lines should be <= 80 characters long [whitespace/line_length] [2]
and this
projects/compiler-rt/lib/asan/CMakeFiles/RTAsan_dynamic.x86_64.dir/asan_rtl.cc.o: In function `AsanInitInternal': /usr/local/google/home/etienneb/llvm/llvm/projects/compiler-rt/lib/asan/asan_rtl.cc:423: undefined reference to `__asan::InitializePlatformExceptionHandlers()' collect2: error: ld returned 1 exit status
FYI, this broke tsan. Only asan installs vectored SEH handler. I fixed it in:
http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/sanitizer_common/sanitizer_win.cc?r1=276112&r2=276111&pathrev=276112