diff options
| author | Chris Lattner <sabre@nondot.org> | 2004-07-15 00:58:53 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2004-07-15 00:58:53 +0000 |
| commit | 33930ad7bdfbc4c351e5677d1102c3af24787c6e (patch) | |
| tree | cdfee884203d2a2808c7029a301b49800379eac3 /llvm/lib/Target | |
| parent | 969d6fbcee30a3e82e102beb53d14e7c3cbc8bb6 (diff) | |
| download | bcm5719-llvm-33930ad7bdfbc4c351e5677d1102c3af24787c6e.tar.gz bcm5719-llvm-33930ad7bdfbc4c351e5677d1102c3af24787c6e.zip | |
Improve codegen for the LLVM offsetof/sizeof "operator". Before we compiled
this LLVM function:
int %foo() {
ret int cast (int** getelementptr (int** null, int 1) to int)
}
into:
foo:
mov %EAX, 0
lea %EAX, DWORD PTR [%EAX + 4]
ret
now we compile it into:
foo:
mov %EAX, 4
ret
This sequence is frequently generated by the MSIL front-end, and soon the malloc lowering pass and
Java front-ends as well..
-Chris
llvm-svn: 14834
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/X86/InstSelectSimple.cpp | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/llvm/lib/Target/X86/InstSelectSimple.cpp b/llvm/lib/Target/X86/InstSelectSimple.cpp index 5cabd485bd0..68a602b3143 100644 --- a/llvm/lib/Target/X86/InstSelectSimple.cpp +++ b/llvm/lib/Target/X86/InstSelectSimple.cpp @@ -3663,6 +3663,21 @@ void ISel::emitGEPOperation(MachineBasicBlock *MBB, if (ConstantPointerRef *CPR = dyn_cast<ConstantPointerRef>(Src)) Src = CPR->getValue(); + // If this is a getelementptr null, with all constant integer indices, just + // replace it with TargetReg = 42. + if (isa<ConstantPointerNull>(Src)) { + User::op_iterator I = IdxBegin; + for (; I != IdxEnd; ++I) + if (!isa<ConstantInt>(*I)) + break; + if (I == IdxEnd) { // All constant indices + unsigned Offset = TD.getIndexedOffset(Src->getType(), + std::vector<Value*>(IdxBegin, IdxEnd)); + BuildMI(*MBB, IP, X86::MOV32ri, 1, TargetReg).addImm(Offset); + return; + } + } + std::vector<Value*> GEPOps; GEPOps.resize(IdxEnd-IdxBegin+1); GEPOps[0] = Src; |

