diff options
author | Alexey Bataev <a.bataev@hotmail.com> | 2015-07-20 12:08:00 +0000 |
---|---|---|
committer | Alexey Bataev <a.bataev@hotmail.com> | 2015-07-20 12:08:00 +0000 |
commit | f19106baada3c5ad40d749f1ff0b0e9c0a1a536e (patch) | |
tree | 56e28a9da7f1bb727b8db80de4539a2d53ccbc1f /test/Sema | |
parent | 9de19363153ac84da1f7b619fb3a02b7adf2727f (diff) | |
download | clang-f19106baada3c5ad40d749f1ff0b0e9c0a1a536e.tar.gz |
[X86, inlineasm] Improve analysis of x,Y0,Yi,Ym,Yt,L,e,Z,s asm constraints (patch by Alexey Frolov)
Improve Sema checking of 9 existing inline asm constraints (‘x’, ‘Y*’, ‘L’, ‘e’, ‘Z’, ‘s’).
Differential Revision: http://reviews.llvm.org/D10536
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@242665 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Sema')
-rw-r--r-- | test/Sema/inline-asm-validate-x86.c | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/test/Sema/inline-asm-validate-x86.c b/test/Sema/inline-asm-validate-x86.c index 658b714056..f21ef6940a 100644 --- a/test/Sema/inline-asm-validate-x86.c +++ b/test/Sema/inline-asm-validate-x86.c @@ -52,6 +52,32 @@ void K(int i, int j) { : "0"(i), "K"(96)); // expected-no-error } +void L(int i, int j) { + static const int Invalid1 = 1; + static const int Invalid2 = 42; + static const int Valid1 = 0xff; + static const int Valid2 = 0xffff; + static const int Valid3 = 0xffffffff; + __asm__("xorl %0,%2" + : "=r"(i) + : "0"(i), "L"(j)); // expected-error{{constraint 'L' expects an integer constant expression}} + __asm__("xorl %0,%2" + : "=r"(i) + : "0"(i), "L"(Invalid1)); // expected-error{{value '1' out of range for constraint 'L'}} + __asm__("xorl %0,%2" + : "=r"(i) + : "0"(i), "L"(Invalid2)); // expected-error{{value '42' out of range for constraint 'L'}} + __asm__("xorl %0,%2" + : "=r"(i) + : "0"(i), "L"(Valid1)); // expected-no-error + __asm__("xorl %0,%2" + : "=r"(i) + : "0"(i), "L"(Valid2)); // expected-no-error + __asm__("xorl %0,%2" + : "=r"(i) + : "0"(i), "L"(Valid3)); // expected-no-error +} + void M(int i, int j) { static const int BelowMin = -1; static const int AboveMax = 4; |