通过嵌入式汇编语言递增变量

阿拉尼

我试图了解如何在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
阿姆斯

您无需多说x两次;一次就足够了:

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

+r说的价值将被输入输出。

采用单独的输入和输出寄存器的方式要求您从中获取输入%1,将其添加一个并将其写入%0,但是您不能使用来做到这一点incl

它适用于一些编译器的原因是因为GCC是自由分配都%0%1同一个寄存器,并出现在那些情况下已经这样做了,但它并没有。顺便说一句,如果要防止GCC将输入和输出分配给同一寄存器(例如,如果要在使用输入计算最终输出之前初始化输出),则需要使用&修饰符。

修饰符的文档在这里

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章