diff options
| author | Chris Lattner <sabre@nondot.org> | 2005-01-18 02:25:52 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2005-01-18 02:25:52 +0000 | 
| commit | d7f93950aa7813a43d23f0cccd9417651e22672c (patch) | |
| tree | d2aa0831974b748f5f4369b6757744fd4ebd8ef5 /llvm/lib | |
| parent | 2b4b79581da4a673c7d49078172674cdf307f0a1 (diff) | |
| download | bcm5719-llvm-d7f93950aa7813a43d23f0cccd9417651e22672c.tar.gz bcm5719-llvm-d7f93950aa7813a43d23f0cccd9417651e22672c.zip | |
Rely on the code in MatchAddress to do this work.  Otherwise we fail to
match (X+Y)+(Z << 1), because we match the X+Y first, consuming the index
register, then there is no place to put the Z.
llvm-svn: 19652
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Target/X86/X86ISelPattern.cpp | 24 | 
1 files changed, 13 insertions, 11 deletions
| diff --git a/llvm/lib/Target/X86/X86ISelPattern.cpp b/llvm/lib/Target/X86/X86ISelPattern.cpp index 4dc29ea6fd5..47aa527c7ac 100644 --- a/llvm/lib/Target/X86/X86ISelPattern.cpp +++ b/llvm/lib/Target/X86/X86ISelPattern.cpp @@ -1579,18 +1579,20 @@ unsigned ISel::SelectExpr(SDOperand N) {      // See if we can codegen this as an LEA to fold operations together.      if (N.getValueType() == MVT::i32) { +      ExprMap.erase(N);        X86ISelAddressMode AM; -      if (!MatchAddress(Op0, AM) && !MatchAddress(Op1, AM)) { -	// If this is not just an add, emit the LEA.  For a simple add (like -	// reg+reg or reg+imm), we just emit an add.  It might be a good idea to -	// leave this as LEA, then peephole it to 'ADD' after two address elim -	// happens. -        if (AM.Scale != 1 || AM.BaseType == X86ISelAddressMode::FrameIndexBase|| -            AM.GV || (AM.Base.Reg.Val && AM.IndexReg.Val && AM.Disp)) { -          X86AddressMode XAM = SelectAddrExprs(AM); -          addFullAddress(BuildMI(BB, X86::LEA32r, 4, Result), XAM); -          return Result; -        } +      MatchAddress(N, AM); +      ExprMap[N] = Result; + +      // If this is not just an add, emit the LEA.  For a simple add (like +      // reg+reg or reg+imm), we just emit an add.  It might be a good idea to +      // leave this as LEA, then peephole it to 'ADD' after two address elim +      // happens. +      if (AM.Scale != 1 || AM.BaseType == X86ISelAddressMode::FrameIndexBase|| +          AM.GV || (AM.Base.Reg.Val && AM.IndexReg.Val && AM.Disp)) { +        X86AddressMode XAM = SelectAddrExprs(AM); +        addFullAddress(BuildMI(BB, X86::LEA32r, 4, Result), XAM); +        return Result;        }      } | 

