From: Chris Lattner Date: Mon, 12 Jan 2009 02:41:37 +0000 (+0000) Subject: make tblgen autogenerate the nocapture intrinsics for X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=d4a2700fdc5bc8ac50084fcb39155e01e86168d5;p=oota-llvm.git make tblgen autogenerate the nocapture intrinsics for llvm.memcpy/memset/memmove. This allows removal of some hackish code from basicaa. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@62071 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/BasicAliasAnalysis.cpp b/lib/Analysis/BasicAliasAnalysis.cpp index 9608a28edd8..92cff8ea969 100644 --- a/lib/Analysis/BasicAliasAnalysis.cpp +++ b/lib/Analysis/BasicAliasAnalysis.cpp @@ -69,10 +69,6 @@ static bool AddressMightEscape(const Value *V) { if (cast(I)->paramHasAttr(UI.getOperandNo(), Attribute::NoCapture)) continue; - - // FIXME: MemIntrinsics should have their operands marked nocapture! - if (isa(I)) - continue; // next use return true; case Instruction::Invoke: // If the argument to the call has the nocapture attribute, then the call diff --git a/utils/TableGen/IntrinsicEmitter.cpp b/utils/TableGen/IntrinsicEmitter.cpp index 34bf7688904..eda55e1430f 100644 --- a/utils/TableGen/IntrinsicEmitter.cpp +++ b/utils/TableGen/IntrinsicEmitter.cpp @@ -423,8 +423,7 @@ EmitAttributes(const std::vector &Ints, std::ostream &OS) { OS << " break;\n"; OS << " }\n"; OS << " AttributeWithIndex AWI[" << MaxArgAttrs+1 << "];\n"; - OS << " AWI[0] = AttributeWithIndex::get(~0, Attr);\n"; - OS << " unsigned NumAttrs = 1;\n"; + OS << " unsigned NumAttrs = 0;\n"; OS << " switch (id) {\n"; OS << " default: break;\n"; @@ -441,17 +440,33 @@ EmitAttributes(const std::vector &Ints, std::ostream &OS) { unsigned NumArgsWithAttrs = 0; - // FIXME: EMIT ATTRS - + while (!ArgAttrs.empty()) { + unsigned ArgNo = ArgAttrs[0].first; + + OS << " AWI[" << NumArgsWithAttrs++ << "] = AttributeWithIndex::get(" + << ArgNo+1 << ", 0"; + + while (!ArgAttrs.empty() && ArgAttrs[0].first == ArgNo) { + switch (ArgAttrs[0].second) { + default: assert(0 && "Unknown arg attribute"); + case CodeGenIntrinsic::NoCapture: + OS << "|Attribute::NoCapture"; + break; + } + ArgAttrs.erase(ArgAttrs.begin()); + } + OS << ");\n"; + } - OS << " NumAttrs = " << NumArgsWithAttrs+1 << ";\n"; + OS << " NumAttrs = " << NumArgsWithAttrs << ";\n"; OS << " break;\n"; } OS << " }\n"; - OS << " return AttrListPtr::get(AWI, NumAttrs);\n"; + OS << " AWI[NumAttrs] = AttributeWithIndex::get(~0, Attr);\n"; + OS << " return AttrListPtr::get(AWI, NumAttrs+1);\n"; OS << "}\n"; - OS << "#endif\n\n"; + OS << "#endif // GET_INTRINSIC_ATTRIBUTES\n\n"; } void IntrinsicEmitter::