From 595b477915ad972b19db5a9ce8de5d31f5aa6410 Mon Sep 17 00:00:00 2001 From: Reid Spencer Date: Mon, 4 Dec 2006 05:23:49 +0000 Subject: [PATCH] For PR950: Implement read/write of ICmp and FCmp constant expressions git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@32172 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Bytecode/Reader/Reader.cpp | 16 ++++++++++------ lib/Bytecode/Writer/Writer.cpp | 2 ++ 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/lib/Bytecode/Reader/Reader.cpp b/lib/Bytecode/Reader/Reader.cpp index 9286279216e..3cc3b1d362b 100644 --- a/lib/Bytecode/Reader/Reader.cpp +++ b/lib/Bytecode/Reader/Reader.cpp @@ -1355,14 +1355,18 @@ Value *BytecodeReader::ParseConstantPoolValue(unsigned TypeID) { return Result; } else if (Opcode == Instruction::ICmp) { if (ArgVec.size() != 2) - error("Invalid ICmp constant expr arguments"); - unsigned short pred = read_vbr_uint(); - return ConstantExpr::getICmp(pred, ArgVec[0], ArgVec[1]); + error("Invalid ICmp constant expr arguments."); + unsigned predicate = read_vbr_uint(); + Constant *Result = ConstantExpr::getICmp(predicate, ArgVec[0], ArgVec[1]); + if (Handler) Handler->handleConstantExpression(Opcode, ArgVec, Result); + return Result; } else if (Opcode == Instruction::FCmp) { if (ArgVec.size() != 2) - error("Invalid FCmp constant expr arguments"); - unsigned short pred = read_vbr_uint(); - return ConstantExpr::getFCmp(pred, ArgVec[0], ArgVec[1]); + error("Invalid FCmp constant expr arguments."); + unsigned predicate = read_vbr_uint(); + Constant *Result = ConstantExpr::getFCmp(predicate, ArgVec[0], ArgVec[1]); + 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); diff --git a/lib/Bytecode/Writer/Writer.cpp b/lib/Bytecode/Writer/Writer.cpp index 127a3bac003..fdd0f3ca427 100644 --- a/lib/Bytecode/Writer/Writer.cpp +++ b/lib/Bytecode/Writer/Writer.cpp @@ -303,6 +303,8 @@ void BytecodeWriter::outputConstant(const Constant *CPV) { Slot = Table.getSlot((*OI)->getType()); output_typeid((unsigned)Slot); } + if (CE->isCompare()) + output_vbr((unsigned)CE->getPredicate()); return; } else if (isa(CPV)) { output_vbr(1U); // 1 -> UndefValue constant.