操作系统lab1实验报告

实验一:系统软件启动过程


实验目的:

操作系统是一个软件,也需要通过某种机制加载并运行它。在这里我们将通过另外一个更加简单的软件-bootloader来完成这些工作。为此,我们需要完成一个能够切换到x86的保护模式并显示字符的bootloader,为启动操作系统ucore做准备。lab1提供了一个非常小的bootloader和ucore OS,整个bootloader执行代码小于512个字节,这样才能放到硬盘的主引导扇区中。通过分析和实现这个bootloader和ucore OS,读者可以了解到:

  • 计算机原理

    CPU的编址与寻址: 基于分段机制的内存管理
    CPU的中断机制
    外设:串口/并口/CGA,时钟,硬盘

  • Bootloader软件

    编译运行bootloader的过程
    调试bootloader的方法
    PC启动bootloader的过程
    ELF执行文件的格式和加载
    外设访问:读硬盘,在CGA上显示字符串

  • ucore OS软件

    编译运行ucore OS的过程
    ucore OS的启动过程
    调试ucore OS的方法
    函数调用关系:在汇编级了解函数调用栈的结构和处理过程
    中断管理:与软件相关的中断处理
    外设管理:时钟

实验内容:


练习1:理解通过make生成执行文件的过程

1.操作系统镜像文件ucore.img是如何一步一步生成的?(需要比较详细地解释Makefile中每一条相关命令和命令参数的含义,以及说明命令导致的结果)

首先利用make V=指令查看执行了哪些命令

执行less Makefile指令,查看Makefile文件的内容,生成ucore.img的代码截图如下:
在这里插入图片描述
查看输出结果如下图:

在这里插入图片描述由以上代码可以看出,生成ucore.img需要kernel和bootblock,于是我们再回到makefile中查看生成kernel和bootblock的代码:
在这里插入图片描述在这里插入图片描述以上就是生成kernel以及bootblock的代码,有了kernel和bootblock以后,就可以生成ucore.img了

根据生成ucore的代码可知

首先要生成一个有10000个块的文件,每个块默认512字节,用0填充
dd if=/dev/zero of=bin/ucore.img count=10000

接着把bootblock中的内容写到第一个块
dd if=bin/bootblock of=bin/ucore.img conv=notrunc

于是从第二个块开始写kernel中的内容
dd if=bin/ke

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值