From c1d86cda8c00163874a3d13b64888c842459de75 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Thu, 3 May 2007 22:21:59 +0000 Subject: the type field for a store is the type of the pointer, not the value. With this fix I can round trip treeaadd, only losing calling conv info. llvm-svn: 36706 --- llvm/lib/Bitcode/Reader/BitcodeReader.cpp | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) (limited to 'llvm/lib/Bitcode/Reader/BitcodeReader.cpp') diff --git a/llvm/lib/Bitcode/Reader/BitcodeReader.cpp b/llvm/lib/Bitcode/Reader/BitcodeReader.cpp index 1ab9f54d5bf..8396d442fc5 100644 --- a/llvm/lib/Bitcode/Reader/BitcodeReader.cpp +++ b/llvm/lib/Bitcode/Reader/BitcodeReader.cpp @@ -1351,9 +1351,10 @@ bool BitcodeReader::ParseFunctionBody(Function *F) { case bitc::FUNC_CODE_INST_STORE: { // STORE:[ptrty,val,ptr, align, vol] if (Record.size() < 5) return Error("Invalid LOAD record"); - const Type *OpTy = getTypeByID(Record[0]); - Value *Op = getFnValueByID(Record[1], OpTy); - Value *Ptr = getFnValueByID(Record[2], PointerType::get(OpTy)); + const PointerType *OpTy = + dyn_cast_or_null(getTypeByID(Record[0])); + Value *Op = getFnValueByID(Record[1], OpTy ? OpTy->getElementType() : 0); + Value *Ptr = getFnValueByID(Record[2], OpTy); if (!OpTy || !Op || !Ptr) return Error("Invalid STORE record"); I = new StoreInst(Op, Ptr, (1 << Record[3]) >> 1, Record[4]); -- cgit v1.2.3