implement extractelement.
authorChris Lattner <sabre@nondot.org>
Sun, 2 Mar 2008 03:57:08 +0000 (03:57 +0000)
committerChris Lattner <sabre@nondot.org>
Sun, 2 Mar 2008 03:57:08 +0000 (03:57 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@47812 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/CBackend/CBackend.cpp

index bdef34d7ebd817be01705e9d95aa70ea12bd9ee8..5e98798b397753cc932c2d5af7792f1915e392fa 100644 (file)
@@ -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