[PATCH] [asan-asm-instrumentation] Added comment describing how asm instrumentation works.
Evgeniy Stepanov
eugenis at google.com
Fri Oct 24 10:16:16 PDT 2014
================
Comment at: lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp:46
@@ +45,3 @@
+// of the instuction opcode - if an instruction has a memory operand
+// (for instance, movq (%rsi, %rcx, 8), %rax) - it's a strong signal
+// that it should be instrumented. But there're also exist instructions
----------------
That's not how the code works, is it? We look at the opcode to find the access size.
================
Comment at: lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp:68
@@ +67,3 @@
+// JZ .Done # when shadow equals to zero, everything is fine
+// MOV AddressReg, RDI
+// # Call __asan_report function with AddressReg as an argument
----------------
Why not do LEA MemOp, RDI and use the same register for AddressReg and ShadowReg, spilling 1 register instead of 2?
================
Comment at: lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp:93
@@ +92,3 @@
+// * Debug info (usually, DWARF) should be adjusted, because when
+// inline assembly is in a leaf function, RSP is usually used as a
+// frame register. So, we need to select some register as a frame
----------------
This is not really about leaf functions, but rather about the -fno-omit-frame-pointer setting, the presence of dynamic allocas, etc. It just happens.
http://reviews.llvm.org/D5970
More information about the llvm-commits
mailing list