summaryrefslogtreecommitdiffstats
path: root/clang/lib/Basic/Targets.cpp
diff options
context:
space:
mode:
authorBill Wendling <isanbard@gmail.com>2012-10-25 00:05:55 +0000
committerBill Wendling <isanbard@gmail.com>2012-10-25 00:05:55 +0000
commit753c8782dfeb96609634adb5950929e3b12da3ae (patch)
tree3b4dc72c9b96d17ceb94355e7b5a691a2a51a29a /clang/lib/Basic/Targets.cpp
parent9004798da8e158c5b6f3c4110c81e1b27825a4de (diff)
downloadbcm5719-llvm-753c8782dfeb96609634adb5950929e3b12da3ae.tar.gz
bcm5719-llvm-753c8782dfeb96609634adb5950929e3b12da3ae.zip
Add some support for diagnosing possibly mismatched constraint, type size and
modifiers. (From an idea by Eric...) <rdar://problem/12284092> llvm-svn: 166647
Diffstat (limited to 'clang/lib/Basic/Targets.cpp')
-rw-r--r--clang/lib/Basic/Targets.cpp23
1 files changed, 23 insertions, 0 deletions
diff --git a/clang/lib/Basic/Targets.cpp b/clang/lib/Basic/Targets.cpp
index ba96185f72d..960a2858e41 100644
--- a/clang/lib/Basic/Targets.cpp
+++ b/clang/lib/Basic/Targets.cpp
@@ -3315,6 +3315,29 @@ public:
}
return R;
}
+ virtual bool validateConstraintModifier(StringRef Constraint,
+ const char Modifier,
+ unsigned Size) const {
+ // Strip off constraint modifiers.
+ while (Constraint[0] == '=' ||
+ Constraint[0] == '+' ||
+ Constraint[0] == '&')
+ Constraint = Constraint.substr(1);
+
+ switch (Constraint[0]) {
+ default: break;
+ case 'r': {
+ switch (Modifier) {
+ default: return Size == 32;
+ case 'q':
+ // A register of size 32 cannot fit a vector type.
+ return false;
+ }
+ }
+ }
+
+ return true;
+ }
virtual const char *getClobbers() const {
// FIXME: Is this really right?
return "";
OpenPOWER on IntegriCloud