OS lab1 实验报告

OSlab1实验报告

实验步骤

1:填充helloworld.c。已经被助教填了,这一步直接搞定- -
2:编译出带elf的helloworld,使用命令
gcc helloworld.c -T boot.lds -nostdlib uart.o -m16 -o helloworld.
3: objcopy -O binary helloworld bin得到去掉elf头的可执行代码段
dd if=bin of=out count=1 bs=512 conv=sync扩充到512个字节
然后在511,512字节处加入magic number 55 aa
具体使用vim -b out ,通过:%!xxd 可将其变成可修改的二进制文件形式来修改
4: qemu-system-i386 -m 1024 -hda out -nographic

思考题

1:qemu-system-i386 -m 1024 -hda out -nographic -s -S可以使qemu驻留并且等待一个gdb来调试
另外开启一个终端,进入gdb
通过命令target remote localhost:1234来使得gdb与qemu相连,之后正常使用gdb就行了
2:在helloworld.c的main()函数的最开始加入
asm volatile(“mov $0x7f00,%bp”);
这样就能给bp赋上一个初始值,找一块内存去读写,也就是初始化了一个栈。
3:我们给定的代码默认就会触发这一个问题,经过一系列处理得到最后去执行的文件out,
将其反汇编可以发现port_out()的代码段出现在了main()的代码段前面
在没有了elf文件以后,qemu去运行out只会从代码段的初始开始一个指令一个指令执行
这样就导致了问题。
解决思路有两个:
1>让port_out()不出现在main前面,我们将port_out()从uart.h放到helloworld.c就行了
2>让有函数出现在main前面也不影响,在整个程序的最开始加入一个函数call_main()就行了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值