summaryrefslogtreecommitdiff
path: root/utils/TableGen/IntrinsicEmitter.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-01-12 01:27:55 +0000
committerChris Lattner <sabre@nondot.org>2009-01-12 01:27:55 +0000
commit10dae94be2ccb187bd4e3da53771be54057acd6c (patch)
tree944617a5c0b004f4e5be94123994f22e859a4ea4 /utils/TableGen/IntrinsicEmitter.cpp
parent048ffb239c282277959463c61200b86e2380cb84 (diff)
downloadllvm-10dae94be2ccb187bd4e3da53771be54057acd6c.tar.gz
llvm-10dae94be2ccb187bd4e3da53771be54057acd6c.tar.bz2
llvm-10dae94be2ccb187bd4e3da53771be54057acd6c.tar.xz
add scaffolding to emit argument attributes. No functionality
change. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@62067 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils/TableGen/IntrinsicEmitter.cpp')
-rw-r--r--utils/TableGen/IntrinsicEmitter.cpp33
1 files changed, 31 insertions, 2 deletions
diff --git a/utils/TableGen/IntrinsicEmitter.cpp b/utils/TableGen/IntrinsicEmitter.cpp
index 714e73f22c..34bf768890 100644
--- a/utils/TableGen/IntrinsicEmitter.cpp
+++ b/utils/TableGen/IntrinsicEmitter.cpp
@@ -397,7 +397,10 @@ EmitAttributes(const std::vector<CodeGenIntrinsic> &Ints, std::ostream &OS) {
OS << " Attributes Attr = Attribute::NoUnwind;\n";
OS << " switch (id) {\n";
OS << " default: break;\n";
+ unsigned MaxArgAttrs = 0;
for (unsigned i = 0, e = Ints.size(); i != e; ++i) {
+ MaxArgAttrs =
+ std::max(MaxArgAttrs, unsigned(Ints[i].ArgumentAttributes.size()));
switch (Ints[i].ModRef) {
default: break;
case CodeGenIntrinsic::NoMem:
@@ -419,8 +422,34 @@ EmitAttributes(const std::vector<CodeGenIntrinsic> &Ints, std::ostream &OS) {
OS << " Attr |= Attribute::ReadOnly; // These do not write memory.\n";
OS << " break;\n";
OS << " }\n";
- OS << " AttributeWithIndex PAWI = AttributeWithIndex::get(~0, Attr);\n";
- OS << " return AttrListPtr::get(&PAWI, 1);\n";
+ OS << " AttributeWithIndex AWI[" << MaxArgAttrs+1 << "];\n";
+ OS << " AWI[0] = AttributeWithIndex::get(~0, Attr);\n";
+ OS << " unsigned NumAttrs = 1;\n";
+ OS << " switch (id) {\n";
+ OS << " default: break;\n";
+
+ // Add argument attributes for any intrinsics that have them.
+ for (unsigned i = 0, e = Ints.size(); i != e; ++i) {
+ if (Ints[i].ArgumentAttributes.empty()) continue;
+
+ OS << " case Intrinsic::" << Ints[i].EnumName << ":\n";
+
+ std::vector<std::pair<unsigned, CodeGenIntrinsic::ArgAttribute> > ArgAttrs =
+ Ints[i].ArgumentAttributes;
+ // Sort by argument index.
+ std::sort(ArgAttrs.begin(), ArgAttrs.end());
+
+ unsigned NumArgsWithAttrs = 0;
+
+ // FIXME: EMIT ATTRS
+
+
+ OS << " NumAttrs = " << NumArgsWithAttrs+1 << ";\n";
+ OS << " break;\n";
+ }
+
+ OS << " }\n";
+ OS << " return AttrListPtr::get(AWI, NumAttrs);\n";
OS << "}\n";
OS << "#endif\n\n";
}