mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-22 23:24:59 +00:00
Move the personality function from LandingPadInst to Function
The personality routine currently lives in the LandingPadInst. This isn't desirable because: - All LandingPadInsts in the same function must have the same personality routine. This means that each LandingPadInst beyond the first has an operand which produces no additional information. - There is ongoing work to introduce EH IR constructs other than LandingPadInst. Moving the personality routine off of any one particular Instruction and onto the parent function seems a lot better than have N different places a personality function can sneak onto an exceptional function. Differential Revision: http://reviews.llvm.org/D10429 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@239940 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -153,18 +153,16 @@ Value *PHINode::hasConstantValue() const {
|
||||
// LandingPadInst Implementation
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
LandingPadInst::LandingPadInst(Type *RetTy, Value *PersonalityFn,
|
||||
unsigned NumReservedValues, const Twine &NameStr,
|
||||
Instruction *InsertBefore)
|
||||
: Instruction(RetTy, Instruction::LandingPad, nullptr, 0, InsertBefore) {
|
||||
init(PersonalityFn, 1 + NumReservedValues, NameStr);
|
||||
LandingPadInst::LandingPadInst(Type *RetTy, unsigned NumReservedValues,
|
||||
const Twine &NameStr, Instruction *InsertBefore)
|
||||
: Instruction(RetTy, Instruction::LandingPad, nullptr, 0, InsertBefore) {
|
||||
init(NumReservedValues, NameStr);
|
||||
}
|
||||
|
||||
LandingPadInst::LandingPadInst(Type *RetTy, Value *PersonalityFn,
|
||||
unsigned NumReservedValues, const Twine &NameStr,
|
||||
BasicBlock *InsertAtEnd)
|
||||
: Instruction(RetTy, Instruction::LandingPad, nullptr, 0, InsertAtEnd) {
|
||||
init(PersonalityFn, 1 + NumReservedValues, NameStr);
|
||||
LandingPadInst::LandingPadInst(Type *RetTy, unsigned NumReservedValues,
|
||||
const Twine &NameStr, BasicBlock *InsertAtEnd)
|
||||
: Instruction(RetTy, Instruction::LandingPad, nullptr, 0, InsertAtEnd) {
|
||||
init(NumReservedValues, NameStr);
|
||||
}
|
||||
|
||||
LandingPadInst::LandingPadInst(const LandingPadInst &LP)
|
||||
@@ -180,28 +178,22 @@ LandingPadInst::LandingPadInst(const LandingPadInst &LP)
|
||||
setCleanup(LP.isCleanup());
|
||||
}
|
||||
|
||||
LandingPadInst *LandingPadInst::Create(Type *RetTy, Value *PersonalityFn,
|
||||
unsigned NumReservedClauses,
|
||||
LandingPadInst *LandingPadInst::Create(Type *RetTy, unsigned NumReservedClauses,
|
||||
const Twine &NameStr,
|
||||
Instruction *InsertBefore) {
|
||||
return new LandingPadInst(RetTy, PersonalityFn, NumReservedClauses, NameStr,
|
||||
InsertBefore);
|
||||
return new LandingPadInst(RetTy, NumReservedClauses, NameStr, InsertBefore);
|
||||
}
|
||||
|
||||
LandingPadInst *LandingPadInst::Create(Type *RetTy, Value *PersonalityFn,
|
||||
unsigned NumReservedClauses,
|
||||
LandingPadInst *LandingPadInst::Create(Type *RetTy, unsigned NumReservedClauses,
|
||||
const Twine &NameStr,
|
||||
BasicBlock *InsertAtEnd) {
|
||||
return new LandingPadInst(RetTy, PersonalityFn, NumReservedClauses, NameStr,
|
||||
InsertAtEnd);
|
||||
return new LandingPadInst(RetTy, NumReservedClauses, NameStr, InsertAtEnd);
|
||||
}
|
||||
|
||||
void LandingPadInst::init(Value *PersFn, unsigned NumReservedValues,
|
||||
const Twine &NameStr) {
|
||||
void LandingPadInst::init(unsigned NumReservedValues, const Twine &NameStr) {
|
||||
ReservedSpace = NumReservedValues;
|
||||
setNumHungOffUseOperands(1);
|
||||
setNumHungOffUseOperands(0);
|
||||
allocHungoffUses(ReservedSpace);
|
||||
Op<0>() = PersFn;
|
||||
setName(NameStr);
|
||||
setCleanup(false);
|
||||
}
|
||||
@@ -211,7 +203,7 @@ void LandingPadInst::init(Value *PersFn, unsigned NumReservedValues,
|
||||
void LandingPadInst::growOperands(unsigned Size) {
|
||||
unsigned e = getNumOperands();
|
||||
if (ReservedSpace >= e + Size) return;
|
||||
ReservedSpace = (e + Size / 2) * 2;
|
||||
ReservedSpace = (std::max(e, 1U) + Size / 2) * 2;
|
||||
growHungoffUses(ReservedSpace);
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user