mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-02 09:49:09 +00:00
use ArgOperand API
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@107282 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e1c2b9cc3d
commit
e767e6bbb7
@ -215,18 +215,18 @@ void llvm::AddCatchInfo(const CallInst &I, MachineModuleInfo *MMI,
|
|||||||
// Gather all the type infos for this landing pad and pass them along to
|
// Gather all the type infos for this landing pad and pass them along to
|
||||||
// MachineModuleInfo.
|
// MachineModuleInfo.
|
||||||
std::vector<const GlobalVariable *> TyInfo;
|
std::vector<const GlobalVariable *> TyInfo;
|
||||||
unsigned N = I.getNumOperands();
|
unsigned N = I.getNumArgOperands();
|
||||||
|
|
||||||
for (unsigned i = N - 1; i > 2; --i) {
|
for (unsigned i = N - 1; i > 1; --i) {
|
||||||
if (const ConstantInt *CI = dyn_cast<ConstantInt>(I.getOperand(i))) {
|
if (const ConstantInt *CI = dyn_cast<ConstantInt>(I.getArgOperand(i))) {
|
||||||
unsigned FilterLength = CI->getZExtValue();
|
unsigned FilterLength = CI->getZExtValue();
|
||||||
unsigned FirstCatch = i + FilterLength + !FilterLength;
|
unsigned FirstCatch = i + FilterLength + !FilterLength;
|
||||||
assert (FirstCatch <= N && "Invalid filter length");
|
assert(FirstCatch <= N && "Invalid filter length");
|
||||||
|
|
||||||
if (FirstCatch < N) {
|
if (FirstCatch < N) {
|
||||||
TyInfo.reserve(N - FirstCatch);
|
TyInfo.reserve(N - FirstCatch);
|
||||||
for (unsigned j = FirstCatch; j < N; ++j)
|
for (unsigned j = FirstCatch; j < N; ++j)
|
||||||
TyInfo.push_back(ExtractTypeInfo(I.getOperand(j)));
|
TyInfo.push_back(ExtractTypeInfo(I.getArgOperand(j)));
|
||||||
MMI->addCatchTypeInfo(MBB, TyInfo);
|
MMI->addCatchTypeInfo(MBB, TyInfo);
|
||||||
TyInfo.clear();
|
TyInfo.clear();
|
||||||
}
|
}
|
||||||
@ -238,7 +238,7 @@ void llvm::AddCatchInfo(const CallInst &I, MachineModuleInfo *MMI,
|
|||||||
// Filter.
|
// Filter.
|
||||||
TyInfo.reserve(FilterLength - 1);
|
TyInfo.reserve(FilterLength - 1);
|
||||||
for (unsigned j = i + 1; j < FirstCatch; ++j)
|
for (unsigned j = i + 1; j < FirstCatch; ++j)
|
||||||
TyInfo.push_back(ExtractTypeInfo(I.getOperand(j)));
|
TyInfo.push_back(ExtractTypeInfo(I.getArgOperand(j)));
|
||||||
MMI->addFilterTypeInfo(MBB, TyInfo);
|
MMI->addFilterTypeInfo(MBB, TyInfo);
|
||||||
TyInfo.clear();
|
TyInfo.clear();
|
||||||
}
|
}
|
||||||
@ -247,10 +247,10 @@ void llvm::AddCatchInfo(const CallInst &I, MachineModuleInfo *MMI,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (N > 3) {
|
if (N > 2) {
|
||||||
TyInfo.reserve(N - 3);
|
TyInfo.reserve(N - 2);
|
||||||
for (unsigned j = 3; j < N; ++j)
|
for (unsigned j = 2; j < N; ++j)
|
||||||
TyInfo.push_back(ExtractTypeInfo(I.getOperand(j)));
|
TyInfo.push_back(ExtractTypeInfo(I.getArgOperand(j)));
|
||||||
MMI->addCatchTypeInfo(MBB, TyInfo);
|
MMI->addCatchTypeInfo(MBB, TyInfo);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user