5

我正在我的一门课程中学习 arm 汇编语言。我在开始时没有什么问题。我写了一个简单的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

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

qemu-arm a.out

但这会产生输出

Segmentation fault

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

4

1 回答 1

5

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

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

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

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

于 2012-08-10T04:39:33.567 回答