diff options
author | Robert Bocchino <bocchino@illinois.edu> | 2006-01-17 20:06:35 +0000 |
---|---|---|
committer | Robert Bocchino <bocchino@illinois.edu> | 2006-01-17 20:06:35 +0000 |
commit | c744cbe160ac8802907637611e86132bc5a6c437 (patch) | |
tree | 73699fde17efdcd32c990d9986dbfffe3a2a1db2 /llvm/lib/Bytecode/Reader/Reader.cpp | |
parent | fdf9e41848452925e425f88007959b1ccbdcbfb0 (diff) | |
download | bcm5719-llvm-c744cbe160ac8802907637611e86132bc5a6c437.tar.gz bcm5719-llvm-c744cbe160ac8802907637611e86132bc5a6c437.zip |
Reader support for the insertelement operation.
llvm-svn: 25404
Diffstat (limited to 'llvm/lib/Bytecode/Reader/Reader.cpp')
-rw-r--r-- | llvm/lib/Bytecode/Reader/Reader.cpp | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/llvm/lib/Bytecode/Reader/Reader.cpp b/llvm/lib/Bytecode/Reader/Reader.cpp index 8abf68c32ca..2ec670e6621 100644 --- a/llvm/lib/Bytecode/Reader/Reader.cpp +++ b/llvm/lib/Bytecode/Reader/Reader.cpp @@ -725,6 +725,17 @@ void BytecodeReader::ParseInstruction(std::vector<unsigned> &Oprnds, getValue(Type::UIntTyID, Oprnds[1])); break; } + case Instruction::InsertElement: { + const PackedType *PackedTy = dyn_cast<PackedType>(InstTy); + if (!PackedTy || Oprnds.size() != 3) + throw std::string("Invalid insertelement instruction!"); + Result = + new InsertElementInst(getValue(iType, Oprnds[0]), + getValue(getTypeSlot(PackedTy->getElementType()), + Oprnds[1]), + getValue(Type::UIntTyID, Oprnds[2])); + break; + } case Instruction::Cast: Result = new CastInst(getValue(iType, Oprnds[0]), getSanitizedType(Oprnds[1])); @@ -1455,6 +1466,13 @@ Constant *BytecodeReader::ParseConstantValue(unsigned TypeID) { Constant* Result = ConstantExpr::getExtractElement(ArgVec[0], ArgVec[1]); if (Handler) Handler->handleConstantExpression(Opcode, ArgVec, Result); return Result; + } else if (Opcode == Instruction::InsertElement) { + if (ArgVec.size() != 3) + error("InsertElement instruction must have three arguments."); + Constant* Result = + ConstantExpr::getInsertElement(ArgVec[0], ArgVec[1], ArgVec[2]); + if (Handler) Handler->handleConstantExpression(Opcode, ArgVec, Result); + return Result; } else { // All other 2-operand expressions Constant* Result = ConstantExpr::get(Opcode, ArgVec[0], ArgVec[1]); if (Handler) Handler->handleConstantExpression(Opcode, ArgVec, Result); |