diff options
author | Chris Lattner <sabre@nondot.org> | 2008-03-02 03:57:08 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-03-02 03:57:08 +0000 |
commit | 689d830b6d51ac586ce77e5de1e414f5cd4527c3 (patch) | |
tree | 7856da9114b5339419fc0615d4816cb36ed7241a /llvm/lib/Target/CBackend | |
parent | d9cc003b0dc3c4999bee3a53f93dc574d8b8d673 (diff) | |
download | bcm5719-llvm-689d830b6d51ac586ce77e5de1e414f5cd4527c3.tar.gz bcm5719-llvm-689d830b6d51ac586ce77e5de1e414f5cd4527c3.zip |
implement extractelement.
llvm-svn: 47812
Diffstat (limited to 'llvm/lib/Target/CBackend')
-rw-r--r-- | llvm/lib/Target/CBackend/CBackend.cpp | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/llvm/lib/Target/CBackend/CBackend.cpp b/llvm/lib/Target/CBackend/CBackend.cpp index bdef34d7ebd..5e98798b397 100644 --- a/llvm/lib/Target/CBackend/CBackend.cpp +++ b/llvm/lib/Target/CBackend/CBackend.cpp @@ -191,8 +191,10 @@ namespace { // Don't inline a load across a store or other bad things! return false; - // Must not be used in inline asm - if (I.hasOneUse() && isInlineAsm(*I.use_back())) return false; + // Must not be used in inline asm or extractelement. + if (I.hasOneUse() && + (isInlineAsm(*I.use_back()) || isa<ExtractElementInst>(I))) + return false; // Only inline instruction it if it's use is in the same BB as the inst. return I.getParent() == cast<Instruction>(I.use_back())->getParent(); @@ -253,6 +255,7 @@ namespace { void visitVAArgInst (VAArgInst &I); void visitInsertElementInst(InsertElementInst &I); + void visitExtractElementInst(ExtractElementInst &I); void visitInstruction(Instruction &I) { cerr << "C Writer does not know about " << I; @@ -3037,6 +3040,18 @@ void CWriter::visitInsertElementInst(InsertElementInst &I) { Out << ")"; } +void CWriter::visitExtractElementInst(ExtractElementInst &I) { + // We know that our operand is not inlined. + Out << "(("; + const Type *EltTy = + cast<VectorType>(I.getOperand(0)->getType())->getElementType(); + printType(Out, PointerType::getUnqual(EltTy)); + Out << ")(&" << GetValueName(I.getOperand(0)) << "))["; + writeOperand(I.getOperand(1)); + Out << "]"; +} + + //===----------------------------------------------------------------------===// // External Interface declaration |