summaryrefslogtreecommitdiff
path: root/test/Sema/ms-inline-asm.c
diff options
context:
space:
mode:
Diffstat (limited to 'test/Sema/ms-inline-asm.c')
-rw-r--r--test/Sema/ms-inline-asm.c69
1 files changed, 68 insertions, 1 deletions
diff --git a/test/Sema/ms-inline-asm.c b/test/Sema/ms-inline-asm.c
index 69f234e5e9ae..66504aa08417 100644
--- a/test/Sema/ms-inline-asm.c
+++ b/test/Sema/ms-inline-asm.c
@@ -1,4 +1,4 @@
-// REQUIRES: x86-64-registered-target
+// REQUIRES: x86-registered-target
// RUN: %clang_cc1 %s -triple x86_64-apple-darwin10 -fasm-blocks -Wno-microsoft -verify -fsyntax-only
void t1(void) {
@@ -32,3 +32,70 @@ void f() {
mov eax, TYPE bar // expected-error {{unable to lookup expression}}
}
}
+
+void rdar15318432(void) {
+ // We used to crash on this. When LLVM called back to Clang to parse a name
+ // and do name lookup, if parsing failed, we did not restore the lexer state
+ // properly.
+
+ __asm {
+ and ecx, ~15
+ }
+
+ int x = 0;
+ __asm {
+ and ecx, x
+ and ecx, ~15
+ }
+}
+
+static int global;
+
+int t2(int *arr, int i) {
+ __asm {
+ mov eax, arr;
+ mov eax, arr[0];
+ mov eax, arr[1 + 2];
+ mov eax, arr[1 + (2 * 5) - 3 + 1<<1];
+ }
+
+ // expected-error@+1 {{cannot use base register with variable reference}}
+ __asm mov eax, arr[ebp + 1 + (2 * 5) - 3 + 1<<1]
+ // expected-error@+1 {{cannot use index register with variable reference}}
+ __asm mov eax, arr[esi * 4]
+ // expected-error@+1 {{cannot use more than one symbol in memory operand}}
+ __asm mov eax, arr[i]
+ // expected-error@+1 {{cannot use more than one symbol in memory operand}}
+ __asm mov eax, global[i]
+
+ // FIXME: Why don't we diagnose this?
+ // expected-Xerror@+1 {{cannot reference multiple local variables in assembly operand}}
+ //__asm mov eax, [arr + i];
+ return 0;
+}
+
+typedef struct {
+ int a;
+ int b;
+} A;
+
+void t3() {
+ __asm mov eax, [eax] UndeclaredId // expected-error {{unknown token in expression}}
+
+ // FIXME: Only emit one diagnostic here.
+ // expected-error@+2 {{unexpected type name 'A': expected expression}}
+ // expected-error@+1 {{unknown token in expression}}
+ __asm mov eax, [eax] A
+}
+
+void t4() {
+ // The dot in the "intel dot operator" is optional in MSVC. MSVC also does
+ // global field lookup, but we don't.
+ __asm mov eax, [0] A.a
+ __asm mov eax, [0].A.a
+ __asm mov eax, [0].a // expected-error {{Unable to lookup field reference!}}
+ __asm mov eax, fs:[0] A.a
+ __asm mov eax, fs:[0].A.a
+ __asm mov eax, fs:[0].a // expected-error {{Unable to lookup field reference!}}
+ __asm mov eax, fs:[0]. A.a // expected-error {{Unexpected token type!}}
+}