Read and write getresult.

llvm-svn: 47471
This commit is contained in:
Devang Patel 2008-02-22 02:49:49 +00:00
parent 997b3a65ca
commit 49cfe7018f
3 changed files with 17 additions and 1 deletions

View File

@ -201,7 +201,8 @@ namespace bitc {
// This store code encodes the pointer type, rather than the value type // This store code encodes the pointer type, rather than the value type
// this is so information only available in the pointer type (e.g. address // this is so information only available in the pointer type (e.g. address
// spaces) is retained. // spaces) is retained.
FUNC_CODE_INST_STORE2 = 24 // STORE: [ptrty,ptr,val, align, vol] FUNC_CODE_INST_STORE2 = 24, // STORE: [ptrty,ptr,val, align, vol]
FUNC_CODE_INST_GETRESULT = 25 // GETRESULT: [ty, opval, n]
}; };
} // End bitc namespace } // End bitc namespace
} // End llvm namespace } // End llvm namespace

View File

@ -1325,6 +1325,16 @@ bool BitcodeReader::ParseFunctionBody(Function *F) {
I = new ICmpInst((ICmpInst::Predicate)Record[OpNum], LHS, RHS); I = new ICmpInst((ICmpInst::Predicate)Record[OpNum], LHS, RHS);
break; break;
} }
case bitc::FUNC_CODE_INST_GETRESULT: { // GETRESULT: [ty, val, n]
if (Record.size() != 2)
return Error("Invalid GETRESULT record");
unsigned OpNum = 0;
Value *Op;
getValueTypePair(Record, OpNum, NextValueNo, Op);
unsigned Index = Record[1];
I = new GetResultInst(Op, Index);
break;
}
case bitc::FUNC_CODE_INST_RET: // RET: [opty,opval<optional>] case bitc::FUNC_CODE_INST_RET: // RET: [opty,opval<optional>]
if (Record.empty()) { if (Record.empty()) {

View File

@ -744,6 +744,11 @@ static void WriteInstruction(const Instruction &I, unsigned InstID,
Vals.push_back(VE.getValueID(I.getOperand(1))); Vals.push_back(VE.getValueID(I.getOperand(1)));
Vals.push_back(cast<CmpInst>(I).getPredicate()); Vals.push_back(cast<CmpInst>(I).getPredicate());
break; break;
case Instruction::GetResult:
Code = bitc::FUNC_CODE_INST_GETRESULT;
PushValueAndType(I.getOperand(0), InstID, Vals, VE);
Vals.push_back(Log2_32(cast<GetResultInst>(I).getIndex())+1);
break;
case Instruction::Ret: case Instruction::Ret:
Code = bitc::FUNC_CODE_INST_RET; Code = bitc::FUNC_CODE_INST_RET;