| // REQUIRES: x86-registered-target |
| // RUN: %clang_cc1 %s -triple x86_64-apple-darwin10 -fasm-blocks -Wno-microsoft -verify -fsyntax-only |
| |
| void t1(void) { |
| __asm __asm // expected-error {{__asm used with no assembly instructions}} |
| } |
| |
| void f() { |
| int foo; |
| __asm { |
| mov eax, eax |
| .unknowndirective // expected-error {{unknown directive}} |
| } |
| f(); |
| __asm { |
| mov eax, 1+=2 // expected-error {{unknown token in expression}} |
| } |
| f(); |
| __asm { |
| mov eax, 1+++ // expected-error {{unknown token in expression}} |
| } |
| f(); |
| __asm { |
| mov eax, LENGTH bar // expected-error {{unable to lookup expression}} |
| } |
| f(); |
| __asm { |
| mov eax, SIZE bar // expected-error {{unable to lookup expression}} |
| } |
| f(); |
| __asm { |
| 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. |
| |
| // expected-error@+2 {{expected identifier}} |
| __asm { |
| and ecx, ~15 |
| } |
| |
| int x = 0; |
| // expected-error@+3 {{expected identifier}} |
| __asm { |
| and ecx, x |
| and ecx, ~15 |
| } |
| } |