Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(496)

Unified Diff: llvm/lib/Target/X86/X86NaClRewritePass.cpp

Issue 10808110: Fix cases where fast instruction selection generated both base and index registers (Closed)
Patch Set: Created 8 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« llvm/lib/Target/X86/X86FastISel.cpp ('K') | « llvm/lib/Target/X86/X86FastISel.cpp ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: llvm/lib/Target/X86/X86NaClRewritePass.cpp
===================================================================
--- a/llvm/lib/Target/X86/X86NaClRewritePass.cpp
+++ b/llvm/lib/Target/X86/X86NaClRewritePass.cpp
@@ -536,9 +536,22 @@
assert(Scale.getImm() == 1);
AddrReg = 0;
} else {
- assert(!BaseReg.getReg() && "Unexpected relative register pair");
- BaseReg.setReg(UseZeroBasedSandbox ? 0 : X86::R15);
- AddrReg = IndexReg.getReg();
+ // @LOCALMOD-START
Derek Schuff 2012/07/24 21:07:47 no need for LOCALMODs here, this entire file is a
Karl 2012/07/24 22:05:30 Done.
+ if (!BaseReg.getReg()) {
+ // No base, fill in relative.
+ BaseReg.setReg(UseZeroBasedSandbox ? 0 : X86::R15);
+ AddrReg = IndexReg.getReg();
+ } else if (!UseZeroBasedSandbox) {
+ // Switch base and index registers if index register is undefined.
+ // That is do conversions like "mov d(%r,0,0) -> mov d(%r15, %r, 1)".
+ assert (!IndexReg.getReg()
+ && "Unexpected index and base register");
+ IndexReg.setReg(BaseReg.getReg());
+ Scale.setImm(1);
+ BaseReg.setReg(X86::R15);
+ AddrReg = IndexReg.getReg();
+ }
jvoung - send to chromium... 2012/07/24 21:08:35 } else { // Original behavior the zero-based san
Karl 2012/07/24 22:05:30 Done.
+ // @LOCALMOD-END
}
if (AddrReg) {
« llvm/lib/Target/X86/X86FastISel.cpp ('K') | « llvm/lib/Target/X86/X86FastISel.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698