lab 1实验报告
练习1:理解通过make生成执行文件的过程。
1.操作系统镜像文件ucore.img是如何一步一步生成的?
生成 bin/kern 部分
生成 init.o
生成 readline.o
生成 stdio.o
生成 kdebug.o
生成 kmonitor.o
生成 panic.o
生成 clock.o
生成 console.o
生成 intr.o
生成 picirq.o
生成 trap.o
生成 trapentry.o
生成 vectors.o
生成 pmm.o
生成 printfmt.o
生成 string.o
用上面 .o 文件连接生成 bin/kern
生成bin/bootblock部分
生成 bootasm.o
生成 bootmain.o
用上面两个.o文件生成 bin/bootblock
生成 bin/sign
生成 sign.o
用上面.o生成 bin/sign
生成 ucore.img
2.一个被系统认为是符合规范的硬盘主引导扇区的特征是什么?
主引导扇区大小为512字节,并且最后结尾为 0x55,0xAA
练习2:使用qemu执行并调试lab1中的软件
1. 从CPU加电后执行的第一条指令开始,单步跟踪BIOS的执行。
(1).首先启动一个终端,使用 qemu -S -s -hda bin/ucore.img -monitor stdio 的方式启动qemu,等待gdb连接
(2).在启动一个终端,启动gdb用远程连接的方式连接qemu
(3).在qemu终端输入 x /6i $pc 这条指令,观察qemu启动时候首先执行的指令
发现第一条指令是一个长跳转,在gdb终端输入 i r观察寄存器值
可以看到现在的CS:IP --> 0xffff0,这是指向内存的开始位置,也是加电后bios初始化后cs:ip的位置。
然后在gdb终端输入si执行一条汇编指令,然后在qemu终端观察下面的执行指令已经变为下面
也就是第一条指令后跳转后的位置
2.在初始化位置0x7c00设置实地址断点,测试断点正常。
打开qemu和gdb,建立远程连接,在gdb终端输入 p *0x7c00,然后输入c执行
执行完毕,可以正常运行到断点
3.从0x7c00开始跟踪代码运行,将单步跟踪反汇编得到的代码与bootasm.S和 bootblock.asm进行比较。
使用si单步执行观察下面10条指令,进行比较。
反汇编得到的代码是:
代码指令比较简洁,没有多余东西,bootasm代码是:
代码也比较简洁,不过里面带有注释,bootlock.asm代码是:
发现里面除了具有注释,还有代码所在的位置,位置与反编译得到的一致
4.自己找一个bootloader或内核中的代码位置,设置断点并进行测试。
在gdb终端载入file ./bin/kernel,然后设置暂停点memset,用c执行,得到下面结果,在string里面暂停了下来
习题3.分析bootloader进入保护模式的过程
为何开启A20,以及如何开启A20
开启A20可以使用32根地址总线,如果不开启只能使用20根地址总线,寻址能力只有1MB,开启后寻址能力可以达到4GB。
打开A20方法,不断查看0x64端口的值,如果是2表示不忙,如果不忙,把x0d1写入0x64端口,把0xdf写入0x60端口
如何初始化GDT表
在bootasm.s里面有这样一段代码来对GDT进行了初始化
# Bootstrap GDT
.p2align # force byte alignment
gdt:
SEG_NULLASM # null seg
SEG_ASM(STA_X|STA_R, 0x0, 0xffffffff) # code seg for bootloader and kernel
SEG_ASM(STA_W, 0x0, 0xffffffff) # data seg for bootloader and kernel gdtdesc:
.word 0x17 # sizeof(gdt) -
.long gdt # address gdt
如何使能和进入保护模式
movl %cr0, %eax
orl $CR0_PE_ON, %eax
movl %eax, %cr0 ljmp $PROT_MODE_CSEG, $protcseg
由上面代码可以看出进入保护模式是把cr0寄存器的最后一位编程1,然后跳转到保护模式段
lab 1实验报告的更多相关文章
- 20169219 SQL注入实验报告
实验介绍 SQL注入技术是利用web应用程序和数据库服务器之间的接口来篡改网站内容的攻击技术.通过把SQL命令插入到Web表单提交框.输入域名框或页面请求框中,最终欺骗服务器执行恶意的SQL命令. 在 ...
- ucoreOS_lab8 实验报告
所有的实验报告将会在 Github 同步更新,更多内容请移步至Github:https://github.com/AngelKitty/review_the_national_post-graduat ...
- ucoreOS_lab5 实验报告
所有的实验报告将会在 Github 同步更新,更多内容请移步至Github:https://github.com/AngelKitty/review_the_national_post-graduat ...
- 《ucore lab8》实验报告
资源 ucore在线实验指导书 我的ucore实验代码 练习1: 完成读文件操作的实现(需要编码) 题目 首先了解打开文件的处理流程,然后参考本实验后续的文件读写操作的过程分析,编写在sfs_inod ...
- 《ucore lab3》实验报告
资源 ucore在线实验指导书 我的ucore实验代码 练习1:给未被映射的地址映射上物理页 题目 完成do_pgfault(mm/vmm.c)函数,给未被映射的地址映射上物理页.设置访问权限的时候需 ...
- 《ucore lab1》实验报告
资源 ucore在线实验指导书 我的ucore实验代码 练习1:理解通过make生成执行文件的过程 详见<ucore lab1 exercise1>实验报告 练习2:使用qemu执行并调试 ...
- 《MIT 6.828 Lab1: Booting a PC》实验报告
<MIT 6.828 Lab1: Booting a PC>实验报告 本实验的网站链接见:Lab 1: Booting a PC. 实验内容 熟悉x86汇编语言.QEMU x86仿真器.P ...
- CSAPP_BombLab实验报告
Lab_2实验报告 目录 Lab_2实验报告 屏幕截图 考察内容 各题答案 bomb1 bomb2 bomb3 bomb4 bomb5 bomb6 secret_phase 解题思路 bomb1 bo ...
- 北京电子科技学院(BESTI)实验报告5
北京电子科技学院(BESTI)实验报告5 课程: 信息安全系统设计基础 班级:1452.1453 姓名:(按贡献大小排名) 郑凯杰.周恩德 学号:(按贡献大小排名) 20145314.20145217 ...
随机推荐
- iOS8上放大缩小的动画
CGAffineTransformMakeScale这个方法我们以前经常使用,但是在IOS8上出现问题了 [UIView animateWithDuration:0.3 animations:^{ b ...
- javascript随手记
编码规范 避免使用全局变量 写在所有函数外面的变量就是全局变量. 之所以要避免使用全局变量是因为:如果有多个类库的话,它们都定义了一个名字的变量.这时候后引入的类库中该变量的值就会覆盖前面引入的类库中 ...
- js构造函数传参
1.直接传参并用this关键字初始化属性 function Person(name,age,learn){ this.name = name; this.age = age; this.learn = ...
- Hadoop Datanode节点无法启动(All directories in dfs.data.dir are invalid)
Hadoop Datanode节点无法启动(All directories in dfs.data.dir are invalid) java.io.IOException: All director ...
- java.io.IOException: Cannot run program "bash": error=12, Cannot allocate memory
java.io.IOException: Cannot run program , Cannot allocate memory 云服务器运行nutch报出的异常: 解决方案: http://daim ...
- Portal技术综述
从上世纪八十年代起,随着个人计算机(PC)的发展,企事业单位逐步建立起计算机应用系统来处理传统事务.从简单的单机应用逐步发展到局域网系统,进而建立跨地区垮国家的广域网系统.从单纯的以科学计算和数据管理 ...
- 网上测试了很多关于PYTHON的WEBSOCKET样例,下面这个才成功了
这是最底层的, 嘿嘿,我 还是习惯搞个框架来实现急需要的功能... 这个东东玩得很有意思的.. 服务器端的代码: import simplejson import socket import sys ...
- java Class的Long id初始化 为0的问题android数据库操做出现的 android.database.sqlite.SQLiteConstraintException: error code 19: constraint failed
java的class中的Long类型变量调用默认的 构造函数new后会被初始化为0. 这句话大家可能感觉这么低级的事情还用你说? 我想说的是这个会产生的一个应用场景 和 避免方法 场景:db插入时候p ...
- SpringMVC与Struts2关于controller线程安全问题
SpringMVC的controller是单例的,因此springMVC的controller不是线程安全的,在使用的时候要谨慎添加成员变量,因为所有的请求都会共享这个变量. 与springMVC不同 ...
- Lua 笔记
lua命令: #enter shell lua #excute script file lua xxx.lua lua脚本: #!/usr/local/bin/lua 核心概念: As a exten ...