diff options
author | Chris Lattner <sabre@nondot.org> | 2009-01-12 02:41:37 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-01-12 02:41:37 +0000 |
commit | eb0b9814d278f05bc9545f0b4e6e8c0f2322610b (patch) | |
tree | bd1286f5ee5e7c217f27ff19cde3b96cf305243f | |
parent | 92cb855bb224b61b67742ed20cb54faeba26f818 (diff) | |
download | external_llvm-eb0b9814d278f05bc9545f0b4e6e8c0f2322610b.zip external_llvm-eb0b9814d278f05bc9545f0b4e6e8c0f2322610b.tar.gz external_llvm-eb0b9814d278f05bc9545f0b4e6e8c0f2322610b.tar.bz2 |
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
-rw-r--r-- | lib/Analysis/BasicAliasAnalysis.cpp | 4 | ||||
-rw-r--r-- | utils/TableGen/IntrinsicEmitter.cpp | 29 |
2 files changed, 22 insertions, 11 deletions
diff --git a/lib/Analysis/BasicAliasAnalysis.cpp b/lib/Analysis/BasicAliasAnalysis.cpp index 9608a28..92cff8e 100644 --- a/lib/Analysis/BasicAliasAnalysis.cpp +++ b/lib/Analysis/BasicAliasAnalysis.cpp @@ -69,10 +69,6 @@ static bool AddressMightEscape(const Value *V) { if (cast<CallInst>(I)->paramHasAttr(UI.getOperandNo(), Attribute::NoCapture)) continue; - - // FIXME: MemIntrinsics should have their operands marked nocapture! - if (isa<MemIntrinsic>(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 34bf768..eda55e1 100644 --- a/utils/TableGen/IntrinsicEmitter.cpp +++ b/utils/TableGen/IntrinsicEmitter.cpp @@ -423,8 +423,7 @@ EmitAttributes(const std::vector<CodeGenIntrinsic> &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<CodeGenIntrinsic> &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:: |