mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2026-04-20 00:20:11 +00:00
Merging r168354, r168355 and r168379 into the 3.2 release branch.
Set of Attributes patches. Merging r168354: Make the AttrListPtr object a part of the LLVMContext. When code deletes the context, the AttributeImpls that the AttrListPtr points to are now invalid. Therefore, instead of keeping a separate managed static for the AttrListPtrs that's reference counted, move it into the LLVMContext and delete it when deleting the AttributeImpls. Merging r168355: Merging r168379 git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_32@168457 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -2794,7 +2794,7 @@ bool LLParser::ParseFunctionHeader(Function *&Fn, bool isDefine) {
|
||||
Attributes::get(RetType->getContext(),
|
||||
FuncAttrs)));
|
||||
|
||||
AttrListPtr PAL = AttrListPtr::get(Attrs);
|
||||
AttrListPtr PAL = AttrListPtr::get(Context, Attrs);
|
||||
|
||||
if (PAL.getParamAttributes(1).hasAttribute(Attributes::StructRet) &&
|
||||
!RetType->isVoidTy())
|
||||
@@ -3351,7 +3351,7 @@ bool LLParser::ParseInvoke(Instruction *&Inst, PerFunctionState &PFS) {
|
||||
FnAttrs)));
|
||||
|
||||
// Finish off the Attributes and check them
|
||||
AttrListPtr PAL = AttrListPtr::get(Attrs);
|
||||
AttrListPtr PAL = AttrListPtr::get(Context, Attrs);
|
||||
|
||||
InvokeInst *II = InvokeInst::Create(Callee, NormalBB, UnwindBB, Args);
|
||||
II->setCallingConv(CC);
|
||||
@@ -3753,7 +3753,7 @@ bool LLParser::ParseCall(Instruction *&Inst, PerFunctionState &PFS,
|
||||
FnAttrs)));
|
||||
|
||||
// Finish off the Attributes and check them
|
||||
AttrListPtr PAL = AttrListPtr::get(Attrs);
|
||||
AttrListPtr PAL = AttrListPtr::get(Context, Attrs);
|
||||
|
||||
CallInst *CI = CallInst::Create(Callee, Args);
|
||||
CI->setTailCall(isTail);
|
||||
|
||||
Reference in New Issue
Block a user