使用qemu运行二进制文件

时间:2012-08-09 11:34:54

标签: assembly arm qemu

我在一门课程中学习手臂汇编语言。入门时我没什么问题。我写了一个简单的c代码:

int main()
{
    int a = 10;
    int b = 20;
    int c = a+b;
}

然后我通过给出命令将其转换为使用gnu arm的汇编代码:

arm-elf-gcc -S first.c

这生成了一个包含汇编代码的文件first.s

    .file   "first.c"
    .text
    .align  2
    .global main
    .type   main, %function
main:
    @ args = 0, pretend = 0, frame = 12
    @ frame_needed = 1, uses_anonymous_args = 0
    mov ip, sp
    stmfd   sp!, {fp, ip, lr, pc}
    sub fp, ip, #4
    sub sp, sp, #12
    mov r3, #10
    str r3, [fp, #-16]
    mov r3, #20
    str r3, [fp, #-20]
    ldr r2, [fp, #-16]
    ldr r3, [fp, #-20]
    add r3, r2, r3
    str r3, [fp, #-24]
    mov r0, r3
    sub sp, fp, #12
    ldmfd   sp, {fp, sp, pc}
    .size   main, .-main
    .ident  "GCC: (GNU) 3.4.3"

然后我使用以下命令编译汇编代码:

arm-elf-gcc -g first.s

这生成了一个二进制文件。然后我尝试使用命令运行a.out和qemu:

qemu-arm a.out

但这会产生输出

Segmentation fault

我找不到错误,我做错了什么?

1 个答案:

答案 0 :(得分:5)

您正尝试在用户模式下运行qemu。您还需要链接与arm相对应的库。

查看下面pkg中的脚本文件。

http://wiki.qemu.org/download/linux-user-test-0.3.tar.gz

您需要运行 qemu -L library_PATH_ARM ./a.out