diff options
author | Derek Schuff <dschuff@google.com> | 2017-04-12 16:03:00 +0000 |
---|---|---|
committer | Derek Schuff <dschuff@google.com> | 2017-04-12 16:03:00 +0000 |
commit | 0db0ca3837b72531fce531a58703c384c5bde953 (patch) | |
tree | e7e92aefe52e24feb02269ab8f0ab3dc438af89e /llvm/lib/Target | |
parent | 58e08064436841d42d485fd210130a22445ff9b8 (diff) | |
download | bcm5719-llvm-0db0ca3837b72531fce531a58703c384c5bde953.tar.gz bcm5719-llvm-0db0ca3837b72531fce531a58703c384c5bde953.zip |
[WebAssembly] Update use of Attributes after r299875
This fixes the failing WebAssemblyLowerEmscriptenEHSjLj tests
llvm-svn: 300072
Diffstat (limited to 'llvm/lib/Target')
-rw-r--r-- | llvm/lib/Target/WebAssembly/WebAssemblyLowerEmscriptenEHSjLj.cpp | 31 |
1 files changed, 14 insertions, 17 deletions
diff --git a/llvm/lib/Target/WebAssembly/WebAssemblyLowerEmscriptenEHSjLj.cpp b/llvm/lib/Target/WebAssembly/WebAssemblyLowerEmscriptenEHSjLj.cpp index 16e7ffa58c0..e1b2f79c81c 100644 --- a/llvm/lib/Target/WebAssembly/WebAssemblyLowerEmscriptenEHSjLj.cpp +++ b/llvm/lib/Target/WebAssembly/WebAssemblyLowerEmscriptenEHSjLj.cpp @@ -435,26 +435,23 @@ Value *WebAssemblyLowerEmscriptenEHSjLj::wrapInvoke(CallOrInvoke *CI) { // Because we added the pointer to the callee as first argument, all // argument attribute indices have to be incremented by one. - SmallVector<AttributeList, 8> AttributesVec; - const AttributeList &InvokePAL = CI->getAttributes(); - CallSite::arg_iterator AI = CI->arg_begin(); - unsigned i = 1; // Argument attribute index starts from 1 - for (unsigned e = CI->getNumArgOperands(); i <= e; ++AI, ++i) { - if (InvokePAL.hasAttributes(i)) { - AttrBuilder B(InvokePAL, i); - AttributesVec.push_back(AttributeList::get(C, i + 1, B)); - } - } + SmallVector<AttributeSet, 8> AttributesVec; + const AttributeList &InvokeAL = CI->getAttributes(); + // Add any return attributes. - if (InvokePAL.hasAttributes(AttributeList::ReturnIndex)) - AttributesVec.push_back( - AttributeList::get(C, InvokePAL.getRetAttributes())); + AttributesVec.push_back(InvokeAL.getRetAttributes()); + // No attributes for the callee pointer. + AttributesVec.push_back(AttributeSet()); + // Copy the argument attributes from the original + for (unsigned i = 1, e = CI->getNumArgOperands(); i <= e; ++i) { + AttributesVec.push_back(InvokeAL.getParamAttributes(i)); + } + // Add any function attributes. - if (InvokePAL.hasAttributes(AttributeList::FunctionIndex)) - AttributesVec.push_back(AttributeList::get(C, InvokePAL.getFnAttributes())); + AttributesVec.push_back(InvokeAL.getFnAttributes()); // Reconstruct the AttributesList based on the vector we constructed. - AttributeList NewCallPAL = AttributeList::get(C, AttributesVec); - NewCall->setAttributes(NewCallPAL); + AttributeList NewCallAL = AttributeList::get(C, AttributesVec); + NewCall->setAttributes(NewCallAL); CI->replaceAllUsesWith(NewCall); |