diff options
| author | Chris Lattner <sabre@nondot.org> | 2004-05-07 19:55:55 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2004-05-07 19:55:55 +0000 |
| commit | cecf3f94a4f2bbe9bed37e1ee5248f3b2de230fc (patch) | |
| tree | 746ae828a84153cc30b962f801461c4d5bc8f8aa /llvm/lib/Target | |
| parent | cf5822a2be568c2f67aeab8f51721c133bdea0b7 (diff) | |
| download | bcm5719-llvm-cecf3f94a4f2bbe9bed37e1ee5248f3b2de230fc.tar.gz bcm5719-llvm-cecf3f94a4f2bbe9bed37e1ee5248f3b2de230fc.zip | |
Make comparisons against the null pointer as efficient as integer comparisons
against zero. In particular, don't emit:
mov %ESI, 0
cmp %ECX, %ESI
instead, emit:
test %ECX, %ECX
llvm-svn: 13407
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/X86/InstSelectSimple.cpp | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/llvm/lib/Target/X86/InstSelectSimple.cpp b/llvm/lib/Target/X86/InstSelectSimple.cpp index da2175bbd43..4597a824738 100644 --- a/llvm/lib/Target/X86/InstSelectSimple.cpp +++ b/llvm/lib/Target/X86/InstSelectSimple.cpp @@ -829,7 +829,14 @@ unsigned ISel::EmitComparison(unsigned OpNum, Value *Op0, Value *Op1, unsigned Op0r = getReg(Op0, MBB, IP); // Special case handling of: cmp R, i - if (ConstantInt *CI = dyn_cast<ConstantInt>(Op1)) { + if (isa<ConstantPointerNull>(Op1)) { + if (OpNum < 2) // seteq/setne -> test + BuildMI(*MBB, IP, X86::TEST32rr, 2).addReg(Op0r).addReg(Op0r); + else + BuildMI(*MBB, IP, X86::CMP32ri, 2).addReg(Op0r).addImm(0); + return OpNum; + + } else if (ConstantInt *CI = dyn_cast<ConstantInt>(Op1)) { if (Class == cByte || Class == cShort || Class == cInt) { unsigned Op1v = CI->getRawValue(); |

