2014-09-03 74 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