diff --git a/lib/Target/CBackend/CBackend.cpp b/lib/Target/CBackend/CBackend.cpp index 4c361527e2c..bdef34d7ebd 100644 --- a/lib/Target/CBackend/CBackend.cpp +++ b/lib/Target/CBackend/CBackend.cpp @@ -187,7 +187,7 @@ namespace { // emit it inline where it would go. if (I.getType() == Type::VoidTy || !I.hasOneUse() || isa(I) || isa(I) || isa(I) || - isa(I) || isa(I)) + isa(I) || isa(I) || isa(I)) // Don't inline a load across a store or other bad things! return false; @@ -251,6 +251,8 @@ namespace { void visitStoreInst (StoreInst &I); void visitGetElementPtrInst(GetElementPtrInst &I); void visitVAArgInst (VAArgInst &I); + + void visitInsertElementInst(InsertElementInst &I); void visitInstruction(Instruction &I) { cerr << "C Writer does not know about " << I; @@ -3022,6 +3024,20 @@ void CWriter::visitVAArgInst(VAArgInst &I) { Out << ");\n "; } +void CWriter::visitInsertElementInst(InsertElementInst &I) { + const Type *EltTy = I.getType()->getElementType(); + writeOperand(I.getOperand(0)); + Out << ";\n "; + Out << "(("; + printType(Out, PointerType::getUnqual(EltTy)); + Out << ")(&" << GetValueName(&I) << "))["; + writeOperand(I.getOperand(1)); + Out << "] = ("; + writeOperand(I.getOperand(2)); + Out << ")"; +} + + //===----------------------------------------------------------------------===// // External Interface declaration //===----------------------------------------------------------------------===//