LLVM/GCC中如何使用Intel格式的汇编
发布网友
发布时间:2022-05-25 11:58
我来回答
共1个回答
热心网友
时间:2023-10-24 23:48
尽管本人接触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 EndLtmp6:## InlineAsm Start
.att_syntax
mov %r8, %r8
mov %r9, %r9
## InlineAsm End
这里要注意的是,当你用完Intel内联汇编后,务必再切换回AT&T格式,否则编译器可能会发生故障,呵呵�6�8�6�8比如:int main(int argc, const char * argv[]){NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
__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
这里要注意的是,从LLVM2.0开始,其自带的汇编器就不再支持Intel汇编语法了。