diff options
| author | Bill Wendling <isanbard@gmail.com> | 2012-10-25 00:05:55 +0000 |
|---|---|---|
| committer | Bill Wendling <isanbard@gmail.com> | 2012-10-25 00:05:55 +0000 |
| commit | 753c8782dfeb96609634adb5950929e3b12da3ae (patch) | |
| tree | 3b4dc72c9b96d17ceb94355e7b5a691a2a51a29a /clang/lib/Basic/Targets.cpp | |
| parent | 9004798da8e158c5b6f3c4110c81e1b27825a4de (diff) | |
| download | bcm5719-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.cpp | 23 |
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 ""; |

