[llvm] r320864 - [X86] Use AND32ri8 instead of AND64ri8 in Asan code in EmitCallAsanReport for 32-bit mode.
Craig Topper via llvm-commits
llvm-commits at lists.llvm.org
Fri Dec 15 13:18:06 PST 2017
Author: ctopper
Date: Fri Dec 15 13:18:06 2017
New Revision: 320864
URL: http://llvm.org/viewvc/llvm-project?rev=320864&view=rev
Log:
[X86] Use AND32ri8 instead of AND64ri8 in Asan code in EmitCallAsanReport for 32-bit mode.
This seemed to work due to a quirk in the X86 MC encoder that didn't emit a REX byte that the AND64ri8 implies when in 32-bit mode. This made the encoding the same as AND32ri8. I tried to add an assert to catch the dropped REX prefix that caught this.
Modified:
llvm/trunk/lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp
Modified: llvm/trunk/lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp?rev=320864&r1=320863&r2=320864&view=diff
==============================================================================
--- llvm/trunk/lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp (original)
+++ llvm/trunk/lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp Fri Dec 15 13:18:06 2017
@@ -610,7 +610,7 @@ private:
EmitInstruction(Out, MCInstBuilder(X86::CLD));
EmitInstruction(Out, MCInstBuilder(X86::MMX_EMMS));
- EmitInstruction(Out, MCInstBuilder(X86::AND64ri8)
+ EmitInstruction(Out, MCInstBuilder(X86::AND32ri8)
.addReg(X86::ESP)
.addReg(X86::ESP)
.addImm(-16));
More information about the llvm-commits
mailing list