LLVM/GCC中如何使用Intel格式的汇编

在GCC以及LLVM编译器中,默认情况下,如果使用汇编或在C/C++,Objective C/C++中内嵌汇编的话都是AT&T格式。

尽管本人接触GCC已经很久了,但对于AT&T汇编还是不忒习惯,尤其是写SSE的时候很别扭,呵呵。因此如果能写Intel格式汇编的话就会非常舒服。下面提供此方法——(注:此方法已经在Apple LLVM1.6编译器下成功通过)

int main(int argc, const char * argv[]) { __asm__ volatile(".intel_syntax /n/t" "mov r8, qword ptr [r8] /n/t" "mov r9, r9"); __asm__ volatile(".att_syntax /n/t" "mov %r8, %r8 /n/t" "mov %r9, %r9"); }  

上述代码中,第一行使用了Intel格式的内联汇编;第二行则是AT&T的。

 

上述代码对应的反汇编将是:

Ltmp5: ## InlineAsm Start .intel_syntax mov r8, qword ptr [r8] mov r9, r9 ## InlineAsm End Ltmp6: ## InlineAsm Start .att_syntax mov %r8, %r8 mov %r9, %r9 ## InlineAsm End 

 

这里要注意的是,当你用完Intel内联汇编后,务必再切换回AT&T格式,否则编译器可能会发生故障,呵呵⋯⋯

比如:

int main(int argc, const char * argv[]) { NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init]; // insert code here... __asm__ volatile(".intel_syntax /n/t" "mov r8, qword ptr [r8] /n/t" "mov r9, r9 /n/t" ".att_syntax /n/t"); [pool drain]; return 0; }  

如果上述代码中,最后没有切换AT&T语法格式,那么编译器会有莫名其妙的错误。上述代码内联汇编部分所对应的反汇编是:

## InlineAsm Start .intel_syntax mov r8, qword ptr [r8] mov r9, r9 .att_syntax  

 

这里要注意的是,从LLVM2.0开始,其自带的汇编器就不再支持Intel汇编语法了。如果要使用Intel汇编语法的话可以选择使用LLVM GCC。

你可能感兴趣的:(apple,汇编,gcc,insert,编译器)