我在一门课程中学习手臂汇编语言。入门时我没什么问题。我写了一个简单的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
我找不到错误,我做错了什么?
答案 0 :(得分:5)
您正尝试在用户模式下运行qemu。您还需要链接与arm相对应的库。
查看下面pkg中的脚本文件。
http://wiki.qemu.org/download/linux-user-test-0.3.tar.gz
您需要运行 qemu -L library_PATH_ARM ./a.out