调试分析Linux 0.00引导程序
Bochs虚拟机的配置文件
简介 Bochs
虚拟机的配置文件
描述待启动的虚拟机的配置,例如内存大小、启动镜像、网络功能、存储配置。
Bochs
运行后,会先查找配置文件,解析模拟器要虚拟的系统相关信息后启动系统。
如何设置从软驱启动
floppya: 1_44="Image", status=inserted
boot: a
如何设置从硬盘启动
ata0-master: type=disk, path="30M.sample", cylinders=615, heads=6, spt=17
boot: disk
如何设置调试选项
log: bochsout.txt
:设置日志生成文件。config_interface
:配置界面,一系列菜单和对话框。根据平台的不同,有3种配置界面可供选择。display_library
:这一行指定了Bochs如何渲染模拟机的显示输出。
# windows
config_interface: win32config
display_library: win32, options="gui_debug"
# Linux
# display_library: x, options="gui_debug"
# MacOS
# display_library: sdl2
win32
表示它将使用Windows原生的GUI库。options="gui_debug"
表示在GUI中启用调试功能。
Bochs虚拟机的调试技巧
如何单步跟踪?
命令s
,或点击Step(s)
。
如何设置断点进行调试?
vb / vbreak seg:0ffset
在虚拟地址上设置指令断点。lb / lbreak addr
在线性地址上设置断点。b / break / pb / pbreak addr
在物理地址上设置断点。info break
显示当前所有断点的信息。d / del / delete n
删除断点 n。(断点是从1开始编号的)
如何查看通用寄存器的值?
registers / reg / r
如何查看系统寄存器的值?
sreg
查看段寄存器info flags
查看标志寄存器cr
查看控制寄存器
如何查看内存指定位置的值?
x /nuf addr
检查位于线性地址addr处的内存内容xp /nuf addr
检查位于物理地址addr处的内存内容- 参数
n
:显示内存单元的计数值,默认为1 - 参数
u
:单元大小,默认为w
b
:bytes 1字节h
:halfwords 2字节w
:words 4字节g
:giantwords 8字节
- 参数
f
:显示格式,默认为x
x
:hex 十六进制数d
:decimal 十进制数u
:unsigned 无符号十进制o
:octal 八进制t
:binary 二进制数c
:char 对应的字符
如何查看各种表,如 gdt
,idt
,ldt
等?
info gdt
info gdt [num]
显示第num
项
info idt
info ldt
如何查看 TSS
?
info tss
如何查看栈中的内容?
print-stack
如何在内存指定地方进行反汇编?
u/disasm/disassemble start end
u /10
:反汇编从当前地址开始的10条指令
计算机引导程序
如何查看 0x7c00
处被装载了什么?
查看数据: View -> Linear Dump
输入 0x7c00
。
反汇编:u/disasm/disassemble 0x7c00 end
如何把真正的内核程序从硬盘或软驱装载到自己想要放的地方;
调用BIOS中断int 0x13
功能2从启动盘读取代码。
如何查看实模式的中断程序?
实模式的中断向量表处于内存0开始的地方。中断向量表中中断向量保存着中断程序的入口地址。
如何静态创建 gdt
与 idt
?
在程序中定义数据,静态输入对应的gdt
与idt
的值。
如何从实模式切换到保护模式?
控制寄存器CR0
位0,为标志PE
。置位时为保护模式,复位时为实模式。
利用lmsw
指令,Load Machine State Word
,将PE
置为1,切换到保护模式。
调试跟踪 jmpi 0,8
,解释如何寻址?
此时不是实模式下的段基址与偏移地址的寻址方式了。段值已经是段选择子。
0为偏移量,8为段选择子,对应GDT
中的段描述符2。
即从GDT
中找到段选择子为 8的段描述符,然后从段描述符中,取出基地址(base address),与偏移量合成线性地址。
该指令执行后,CS:IP
即变为0x8:0x0
。
实验报告
请简述 head.s
的工作原理
- 初始化GDT和IDT,设置GDHR和IDTR。
- 设置8253定时芯片。
- 设置定时中断门描述符和系统调用陷阱门描述符,分别在IDT表的第8项和第128项。
- 利用
iret
命令,跳转到程序 任务0。
记录head.s
的内存分布状况
简述head.s
57
至62
行在做什么
57
至62
行:
<57> pushl $0x17 # 堆栈段选择符(SS)入栈
<58> pushl $init_stack # 堆栈段偏移(SP)入栈
<59> pushfl # 标志寄存器入栈
<60> pushl $0x0f # 代码段选择符(CS)入栈
<61> pushl $task0 # 代码段偏移(IP)入栈
<62> iret
因为当前head.s
程序是内核程序,特权级别为 0。
由于处于特权级0的代码不能直接把控制权转移到特权级3的代码中执行,但中断返回操作可以。因此,可以利用中断返回指令 iret
来启动任务0。
具体操作是,在初始堆栈init_stack
中人工设置一个返回环境(初始堆栈也是任务0的用户栈):
- 任务0的 TSS段选择符加载到任务寄存器
LTR
。 - 任务0的 LDT段选择符加载到
LDTR
。 - 任务0的用户栈指针(
SS:SP
),代码指针(CS:IP
)以及标志寄存器压入栈中。 - 执行返回中断指令
iret
。弹出栈中内容,对应到任务0的堆栈指针、代码指针、标志寄存器。
简述iret
执行后,pc
如何找到下一条指令?
由于在iret
前,栈中压入了代码指针,即代码段的段选择符和偏移量(CS:IP
),所以iret
后,弹出代码指针,pc
根据当前代码指针执行下一条指令。
记录 iret
执行前后,栈是如何变化的?
执行前:可以看到,栈顶自下的5个内容(双字)分别为 IP、CS、EFLAGS、SP、SS
。对应压栈的顺序。
执行后:可见,弹出5个双字,
当任务进行系统调用时,即 int 0x80
时,记录栈的变化情况。
任务0进行系统调用int 0x80
前:
SS:0x17 ESP:0x0bd8
CS:0x0F EIP:0x10E9
栈空间为任务0的用户栈,即init_stack
。
系统调用后:
SS:0x10 ESP:0x0e4c
CS:0x08 EIP:0x166
栈空间为任务0的内核栈。ESP不为0x0e60
,可知栈中压入了内容。
观察图,发现栈中压入了5个双字,由栈顶自下分别为 调用前的EIP、调用前的CS、调用前的EFLAGS、调用前的ESP、调用前的SS
。
可知,在调用中断时,指令int 0x80
,会将当前任务的该 5个寄存器内容压入调用后的栈空间中。也就是被调用者保存。
调试分析Linux 0.00引导程序的更多相关文章
- 通过gdb调试分析Linux内核的启动过程
作者:吴乐 山东师范大学 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 一.实验流程 1.打开环境 执 ...
- Linux调试分析诊断利器——strace
strace是个功能强大的Linux调试分析诊断工具,可用于跟踪程序执行时进程系统调用(system call)和所接收的信号,尤其是针对源码不可读或源码无法再编译的程序. 在Linux系统中,用户程 ...
- 跟踪分析Linux内核的启动过程小解
跟踪分析Linux内核的启动过程 “20135224陈实 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029 ...
- 20135239 益西拉姆 linux内核分析 跟踪分析Linux内核的启动过程
回顾 1.中断上下文的切换——保存现场&恢复现场 本节主要课程内容 Linux内核源代码简介 1.打开内核源代码页面 arch/目录:支持不同CPU的源代码:其中的X86是重点 init/目录 ...
- 分析Linux内核创建一个新进程的过程【转】
转自:http://www.cnblogs.com/MarkWoo/p/4420588.html 前言说明 本篇为网易云课堂Linux内核分析课程的第六周作业,本次作业我们将具体来分析fork系统调用 ...
- 通过从代码层面分析Linux内核启动来探知操作系统的启动过程
通过从代码层面分析Linux内核启动来探知操作系统的启动过程 前言说明 本篇为网易云课堂Linux内核分析课程的第三周作业,我将围绕Linux 3.18的内核中的start_kernel到init进程 ...
- 跟踪分析Linux内核的启动过程--实验报告 分析 及知识重点
跟踪分析Linux内核的启动过程 攥写人:杨光 学号:20135233 ( *原创作品转载请注明出处*) ( 学习课程:<Linux内核分析>MOOC课程http://mooc.stud ...
- 用 CPI 火焰图分析 Linux 性能问题
https://yq.aliyun.com/articles/465499 用 CPI 火焰图分析 Linux 性能问题 yangoliver 2018-02-11 16:05:53 浏览1076 ...
- 实验 六:分析linux内核创建一个新进程的过程
实验六:分析Linux内核创建一个新进程的过程 作者:王朝宪 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029 ...
- 20135202闫佳歆--week3 跟踪分析Linux内核的启动过程--实验及总结
实验三:跟踪分析Linux内核的启动过程 一.调试步骤如下: 使用gdb跟踪调试内核 qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd r ...
随机推荐
- 10.0 探索API调试事件原理
本章笔者将通过Windows平台下自带的调试API接口实现对特定进程的动态转存功能,首先简单介绍一下关于调试事件的相关信息,调试事件的建立需要依赖于DEBUG_EVENT这个特有的数据结构,该结构用于 ...
- VScode+X11支持连接服务器时支持open3d、openCV、matplotlib等可视化
背景 连接服务器以后,想用open3d可视化点云.matplotlib画点图,但是一直不能用,原因也很简单,就是没有配置GUI传输显示,那肯定是要配置X11相关的东西. 过程 服务器 确保服务器下载了 ...
- 2023-10-07:用go语言,给定n个二维坐标,表示在二维平面的n个点, 坐标为double类型,精度最多小数点后两位, 希望在二维平面上画一个圆,圈住其中的k个点,其他的n-k个点都要在圆外。
2023-10-07:用go语言,给定n个二维坐标,表示在二维平面的n个点, 坐标为double类型,精度最多小数点后两位, 希望在二维平面上画一个圆,圈住其中的k个点,其他的n-k个点都要在圆外. ...
- ElasticSearch系列——介绍、安装、插件介绍、安装ElasticSearch插件、安装Kibana、安装中文分词器、倒排索引、索引操作、映射管理
文章目录 ElasticSearch之介绍 一 Elasticsearch产生背景 1.1 大规模数据如何检索 1.2 传统数据库的应对解决方案 1.3 非关系型数据库解决方案 1.4 内存数据库解决 ...
- Django框架项目——redis操作、Celery
1-redis操作 redis介绍 redis安装 """ 1.官网下载:安装包或是绿色面安装 2.安装并配置环境变量 """ redis ...
- frida动态插桩初探
前言 近期碰到了分析app的需求,就学习了一下 frida的动态插桩技术.frida是一款轻量级HOOK框架,可用于多平台上,例如android.windows.ios等.frida分为两部分,服务端 ...
- android的listview控件,加了行内按钮事件导致行点击失效的问题
近日,修改一个app,原来的listview中只有行点击事件 ListView.setOnItemClickListener(new AdapterView.OnItemClickListener() ...
- OTOCI 题解
OTOCI 题目大意 给定 \(n\) 个带权的点,需要进行四种操作:查询两点连通性:加边:修改点权:查询两点路径的权值和. 思路分析 首先观察题目,我们会发现,在所有的操作结束后,所有的点构成一个森 ...
- NFT(数字藏品)热度没了?这玩意是机会还是泡沫?
感谢你阅读本文! 大家好,今天分享一下NFT(数字藏品)这个领域,虽然今天的NFT已经没有之前那么火热,不过市场上依旧还是有很多平台存在,有人离开,也有人不断进来,所以很有必要再分析一番. 需要注意的 ...
- 企业FTP搭建教程
安装Vsftpd 提前关闭selinux 和firewalld防火墙 安装vsftp软件包: yum install -y vsftpd* 启动vsftp服务器: systemctl start vs ...