From 7c627e76321ce59dc3a418832c568bf0c2ff422c Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Mon, 12 Nov 2001 21:48:38 +0000 Subject: Fix bug in new assertion llvm-svn: 1279 --- llvm/lib/Bytecode/Reader/InstructionReader.cpp | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) (limited to 'llvm/lib/Bytecode/Reader') diff --git a/llvm/lib/Bytecode/Reader/InstructionReader.cpp b/llvm/lib/Bytecode/Reader/InstructionReader.cpp index 6587ab21458..8dc9b8d565a 100644 --- a/llvm/lib/Bytecode/Reader/InstructionReader.cpp +++ b/llvm/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: { -- cgit v1.2.3