From 77a316ad2bd41d16417a4571e84125b978957fa3 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Mon, 12 Nov 2001 21:48:38 +0000 Subject: [PATCH] Fix bug in new assertion git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@1279 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Bytecode/Reader/InstructionReader.cpp | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/lib/Bytecode/Reader/InstructionReader.cpp b/lib/Bytecode/Reader/InstructionReader.cpp index 6587ab21458..8dc9b8d565a 100644 --- a/lib/Bytecode/Reader/InstructionReader.cpp +++ b/lib/Bytecode/Reader/InstructionReader.cpp @@ -376,14 +376,17 @@ bool BytecodeParser::ParseInstruction(const uchar *&Buf, const uchar *EndBuf, delete Raw.VarArgs; break; } - assert(LoadInst::getIndexedType(Raw.Ty, Idx) && - "Bad indices for GEP or Load!"); - if (Raw.Opcode == Instruction::Load) + + if (Raw.Opcode == Instruction::Load) { + assert(MemAccessInst::getIndexedType(Raw.Ty, Idx) && + "Bad indices for GEP or Load!"); Res = new LoadInst(getValue(Raw.Ty, Raw.Arg1), Idx); - else if (Raw.Opcode == Instruction::GetElementPtr) + } else if (Raw.Opcode == Instruction::GetElementPtr) Res = new GetElementPtrInst(getValue(Raw.Ty, Raw.Arg1), Idx); else abort(); + if (!MemAccessInst::getIndexedType(Raw.Ty, Idx)) + cerr << Res; return false; } case Instruction::Store: {