2015-01-06 12:26:34 +08:00
|
|
|
// RUN: %clang_cc1 -triple i686 -fsyntax-only -verify %s
|
|
|
|
// RUN: %clang_cc1 -triple x86_64 -fsyntax-only -verify %s
|
|
|
|
|
|
|
|
void I(int i, int j) {
|
|
|
|
static const int BelowMin = -1;
|
|
|
|
static const int AboveMax = 32;
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
2015-01-23 05:01:00 +08:00
|
|
|
: "0"(i), "I"(j)); // expected-error{{constraint 'I' expects an integer constant expression}}
|
2015-01-06 12:26:34 +08:00
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "I"(BelowMin)); // expected-error{{value '-1' out of range for constraint 'I'}}
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "I"(AboveMax)); // expected-error{{value '32' out of range for constraint 'I'}}
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "I"(16)); // expected-no-error
|
|
|
|
}
|
|
|
|
|
|
|
|
void J(int i, int j) {
|
|
|
|
static const int BelowMin = -1;
|
|
|
|
static const int AboveMax = 64;
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
2015-01-23 05:01:00 +08:00
|
|
|
: "0"(i), "J"(j)); // expected-error{{constraint 'J' expects an integer constant expression}}
|
2015-01-06 12:26:34 +08:00
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "J"(BelowMin)); // expected-error{{value '-1' out of range for constraint 'J'}}
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "J"(AboveMax)); // expected-error{{value '64' out of range for constraint 'J'}}
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "J"(32)); // expected-no-error
|
|
|
|
}
|
|
|
|
|
|
|
|
void K(int i, int j) {
|
|
|
|
static const int BelowMin = -129;
|
|
|
|
static const int AboveMax = 128;
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
2015-01-23 05:01:00 +08:00
|
|
|
: "0"(i), "K"(j)); // expected-error{{constraint 'K' expects an integer constant expression}}
|
2015-01-06 12:26:34 +08:00
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "K"(BelowMin)); // expected-error{{value '-129' out of range for constraint 'K'}}
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "K"(AboveMax)); // expected-error{{value '128' out of range for constraint 'K'}}
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "K"(96)); // expected-no-error
|
|
|
|
}
|
|
|
|
|
[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
llvm-svn: 242665
2015-07-20 20:08:00 +08:00
|
|
|
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
|
|
|
|
}
|
|
|
|
|
2015-01-06 12:26:34 +08:00
|
|
|
void M(int i, int j) {
|
|
|
|
static const int BelowMin = -1;
|
|
|
|
static const int AboveMax = 4;
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
2015-01-23 05:01:00 +08:00
|
|
|
: "0"(i), "M"(j)); // expected-error{{constraint 'M' expects an integer constant expression}}
|
2015-01-06 12:26:34 +08:00
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "M"(BelowMin)); // expected-error{{value '-1' out of range for constraint 'M'}}
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "M"(AboveMax)); // expected-error{{value '4' out of range for constraint 'M'}}
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "M"(2)); // expected-no-error
|
|
|
|
}
|
|
|
|
|
|
|
|
void N(int i, int j) {
|
|
|
|
static const int BelowMin = -1;
|
|
|
|
static const int AboveMax = 256;
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
2015-01-23 05:01:00 +08:00
|
|
|
: "0"(i), "N"(j)); // expected-error{{constraint 'N' expects an integer constant expression}}
|
2015-01-06 12:26:34 +08:00
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "N"(BelowMin)); // expected-error{{value '-1' out of range for constraint 'N'}}
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "N"(AboveMax)); // expected-error{{value '256' out of range for constraint 'N'}}
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "N"(128)); // expected-no-error
|
|
|
|
}
|
|
|
|
|
|
|
|
void O(int i, int j) {
|
|
|
|
static const int BelowMin = -1;
|
|
|
|
static const int AboveMax = 128;
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
2015-01-23 05:01:00 +08:00
|
|
|
: "0"(i), "O"(j)); // expected-error{{constraint 'O' expects an integer constant expression}}
|
2015-01-06 12:26:34 +08:00
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "O"(BelowMin)); // expected-error{{value '-1' out of range for constraint 'O'}}
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "O"(AboveMax)); // expected-error{{value '128' out of range for constraint 'O'}}
|
|
|
|
__asm__("xorl %0,%2"
|
|
|
|
: "=r"(i)
|
|
|
|
: "0"(i), "O"(64)); // expected-no-error
|
|
|
|
}
|
|
|
|
|