我在一门课程中正在学习手臂汇编语言。我入门没有什么问题。我写了一个简单的C代码:
int main()
{
int a = 10;
int b = 20;
int c = a+b;
}
Run Code Online (Sandbox Code Playgroud)
然后通过使用以下命令,使用gnu arm将其转换为汇编代码:
arm-elf-gcc -S first.c
Run Code Online (Sandbox Code Playgroud)
这首先生成一个包含汇编代码的文件:
.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"
Run Code Online (Sandbox Code Playgroud)
然后,我使用以下命令编译了汇编代码:
arm-elf-gcc -g first.s
Run Code Online (Sandbox Code Playgroud)
这将生成一个.out二进制文件。然后我尝试使用命令使用qemu运行a.out:
qemu-arm a.out
Run Code Online (Sandbox Code Playgroud)
但这会产生输出
Segmentation fault
Run Code Online (Sandbox Code Playgroud)
我找不到错误,我在做什么错?
您正在尝试在用户模式下运行qemu。您还需要链接与arm对应的库。
看看pkg下面的脚本文件。
http://wiki.qemu.org/download/linux-user-test-0.3.tar.gz
您将需要运行qemu -L library_PATH_ARM ./a.out