2014-09-03 39 views
3

我想了解如何在C语言中嵌入汇编语言(在x86_64架构上使用gcc)。我编写了这个程序来增加单个变量的值。但我得到垃圾价值作为输出。和想法为什么?通过嵌入式汇编语言递增变量

#include <stdio.h> 

int main(void) { 
    int x; 
    x = 4; 

    asm("incl %0": "=r"(x): "r0"(x)); 

    printf("%d", x); 
    return 0; 
} 

感谢

更新该计划是给在GCC 4.8.3预期的结果,但不是在GCC 4.6.3。我粘贴的非工作代码的程序集输出:

.file "abc.c" 
.section .rodata 
.LC0: 
.string "%d" 
.text 
.globl main 
.type main, @function 
main: 
.LFB0: 
.cfi_startproc 
pushq %rbp 
.cfi_def_cfa_offset 16 
.cfi_offset 6, -16 
movq %rsp, %rbp 
.cfi_def_cfa_register 6 
pushq %rbx 
subq $24, %rsp 
movl $4, -20(%rbp) 
movl -20(%rbp), %eax 

incl %edx 

movl %edx, %ebx 
.cfi_offset 3, -24 
movl %ebx, -20(%rbp) 
movl $.LC0, %eax 
movl -20(%rbp), %edx 
movl %edx, %esi 
movq %rax, %rdi 
movl $0, %eax 
call printf 
movl $0, %eax 
addq $24, %rsp 
popq %rbx 
popq %rbp 
.cfi_def_cfa 7, 8 
ret 
.cfi_endproc 
.LFE0: 
.size main, .-main 
.ident "GCC: (Ubuntu/Linaro 4.6.3-1ubuntu5) 4.6.3" 
.section .note.GNU-stack,"",@progbits 
+0

没关系在我的x86_64 linux – 2014-09-03 05:37:25

+0

@rakib你使用gcc吗?为了以防万一,我使用gcc 4.6.3。 – Arani 2014-09-03 06:06:26

+1

检查gcc正在生成的汇编代码。 'gcc -S test.c'将会在程序集列表中产生'test.s'。 – afenster 2014-09-03 06:19:18

回答

4

你不需要说x两次;一旦足够的:

asm("incl %0": "+r"(x)); 

+r说,该值将被输入输出。

你的方式,有独立的输入和输出寄存器,要求你把输入从%1,添加一个,输出写入%0,但你不能做到这一点与incl

它在一些编译器上工作的原因是因为GCC可以自由地将%0%1分配到同一个寄存器,并且在这些情况下似乎已经这样做了,但它并不是必须的。顺便说一句,如果你想阻止 GCC分配一个输入和输出到同一个寄存器(例如,如果你想在使用输入来计算最终输出之前初始化输出),你需要使用&修饰符。

修饰符的文档是here