您的位置:首页 > 其它

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

2011-05-16 00:19 483 查看
在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。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: