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:
Gabor Greif 2010-06-30 13:45:50 +00:00
parent e1c2b9cc3d
commit e767e6bbb7

View File

@ -215,10 +215,10 @@ 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");
@ -226,7 +226,7 @@ void llvm::AddCatchInfo(const CallInst &I, MachineModuleInfo *MMI,
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);
} }
} }