Until now curly braces could only be used in MS inline assembly to mark block start/end.
All curly braces were removed completely at a very early stage.
This approach caused bugs like:
"m{o}v eax, ebx" turned into "mov eax, ebx" without any error.
In addition, AVX-512 added special operands (e.g., k registers), which are also surrounded by curly braces that mark them as such.
Now, we need to keep the curly braces and identify at a later stage if they are marking block start/end (if so, ignore them), or surrounding special AVX-512 operands (if so, parse them as such).
This patch fixes the bug described above and enables the use of AVX-512 special operands.
This commit is the the clang part of the patch.
The clang part of the review is: http://reviews.llvm.org/D17766
The llvm part of the review is: http://reviews.llvm.org/D17767
Differential Revision: http://reviews.llvm.org/D17766
llvm-svn: 262842
63 lines
1.3 KiB
C
63 lines
1.3 KiB
C
// REQUIRES: x86-registered-target
|
|
// RUN: %clang_cc1 %s -triple i386-apple-darwin10 -verify -fasm-blocks
|
|
// Disabling gnu inline assembly should have no effect on this testcase
|
|
// RUN: %clang_cc1 %s -triple i386-apple-darwin10 -verify -fasm-blocks -fno-gnu-inline-asm
|
|
|
|
#define M __asm int 0x2c
|
|
#define M2 int
|
|
|
|
void t1(void) { M }
|
|
void t2(void) { __asm int 0x2c }
|
|
void t3(void) { __asm M2 0x2c }
|
|
void t4(void) { __asm mov eax, fs:[0x10] }
|
|
void t5() {
|
|
__asm {
|
|
int 0x2c ; } asm comments are fun! }{
|
|
}
|
|
__asm {}
|
|
}
|
|
int t6() {
|
|
__asm int 3 ; } comments for single-line asm
|
|
__asm {}
|
|
|
|
__asm int 4
|
|
return 10;
|
|
}
|
|
void t7() {
|
|
__asm {
|
|
push ebx
|
|
mov ebx, 0x07
|
|
pop ebx
|
|
}
|
|
}
|
|
void t8() {
|
|
__asm nop __asm nop __asm nop
|
|
}
|
|
void t9() {
|
|
__asm nop __asm nop ; __asm nop
|
|
}
|
|
void t10() {
|
|
__asm {
|
|
mov eax, 0
|
|
__asm {
|
|
mov eax, 1
|
|
{
|
|
mov eax, 2
|
|
}
|
|
}
|
|
}
|
|
}
|
|
void t11() {
|
|
do { __asm mov eax, 0 __asm { __asm mov edx, 1 } } while(0);
|
|
}
|
|
void t12() {
|
|
__asm jmp label // expected-error {{use of undeclared label 'label'}}
|
|
}
|
|
void t13() {
|
|
__asm m{o}v eax, ebx // expected-error {{expected identifier}} expected-error {{use of undeclared label '{o}v eax, ebx'}}
|
|
}
|
|
|
|
int t_fail() { // expected-note {{to match this}}
|
|
__asm
|
|
__asm { // expected-error 3 {{expected}} expected-note {{to match this}}
|