2018-2019-1 20189221《Linux内核原理与分析》第二周作业
读书报告
《庖丁解牛Linux内核分析》
第 1 章 计算工作原理
1.1 存储程序计算机工作模型
1.2 x86-32汇编基础
1.3汇编一个简单的C语言程序并分析其汇编指令执行过程
因为本科时期学过《微机原理与接口技术》课程,学习过8086/8088的汇编语言,所以基本上算是复习。
- 通用寄存器
EAX:累加器,是算术运算的主要寄存器,I/O指令使用该寄存器与外设传送信息
EBX:通用寄存器,常用作基址寄存器
ECX:通用寄存器,在循环时作为隐含的计数器
EDX:通用寄存器,可以和AX一起存储双字,DX存放高位
ESP:用来指示栈顶的偏移地址
EBP:常用作堆栈区中的基地址指针
ESI:源变址寄存器,具有自动增/减功能
EDI:目的变址寄存器,具有自动增/减功能- 段寄存器
CS:代码段寄存器,存放代码段的段基址或段选择字
DS:数据段寄存器,存放数据段的段基址或段选择字
ES:附加段寄存器,存放附加数据段的段基址或段选择字。
SS:堆栈段寄存器,存放堆栈段的段基址或段选择字
FS:附加段寄存器,存放附加数据段的段基址或段选择字
GS:附加段寄存器,存放附加数据段的段基址或段选择字
《Linux内核原理与实现(第3版)》第1、2、18章
第 1 章 Linux内核简介
- Linux与Unix的渊源及历史
- 操作系统和内核
- Linux内核的特点
第 2 章 从内核出发
- 内核源码的获取
- 内核和编译内核
第 18 章 调试
- 调试准备
- 内核bug的分类
- 调试方法
- printk( )
- oops
- 配置选项
- BUG( )和BUG_ON( )
- 系统请求键
- gdb和kgdb
- 探测系统
- 二分搜索
本科时学习过操作系统课程,对于内核态有一定了解,但未自己进行内核开发,第 2 章进行学习准备,第 18 章先学习怎样处理之后内核开发可能会遇到的问题,十分合理。
- Linux内核获取
$ git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git
$ git pull
- 结合上次所学,对gdb的使用更加了解,但gdb无法修改内核数据。
- 近期俗事缠身,未能真正完全按照老师教导的方式深入学习第 18 章,没能对内核调试函数进行一个个详细的分析学习。
读书收获
- mov指令中,movl中的l是指32位,movb中b指8位,movq中q指64位;
- 对Linux内核有了一个初步的浅显的了解,获取了内核源码,学习了几种调试方法,为之后的内核编程做准备;
- 两年以后再次学习汇编语言,很有意思,有不少新的感悟,希望能用于以后的编程实现中;
- 之前学过的操作系统知识终于要用于编程实现,希望在之后的Linux内核开发中获得更多乐趣。
实验报告
实验过程
- 使用vim按照要求编辑main.c
可通过实验楼支持的复制/粘贴数据传递- 使用gcc编译main.c,产生汇编代码文件main.s
$ gcc -S -o main.s main.c -m32
过程如图:
- 打开main.s,删除辅助信息,查看汇编代码
使用g/.s*/d删除所有以“.”打头的字符
结果如图:
实验分析
汇编代码工作过程
从main程序开始执行
- ebp入栈
- 把ebp值赋予给esp
- 将esp值减4,指向下一存储空间(栈单位存储空间)
- 将数值20181018(日期)存在esp所指的存储空间中
调用f函数
- ebp入栈
- 把ebp值赋予给esp
- 将esp减4,指向下一地址空间
- 将ebp加8所指向的存储空间内的内容赋予给累加寄存器eax
- 将eax的内容赋予给esp
调用g函数
- 对ebp进行压栈
- 把ebp值赋予给esp
- 将ebp加8所指向的存储空间内的内容赋予给累加寄存器eax
- 将eax储存的数值加20189221(学号)
- 出栈
返回main函数
- 返回到f函数的leave命令
- 撤销函数堆栈
- 返回到主函数的leave命令
- 将eax储存的数加9527
- 撤销函数堆栈
- 返回程序运行值
实验收获
汇编语言:
- eave指令包含着两个步骤
- 将esp指向ebp的位置;
- 将当前ebp所指向的内存单元里的内容弹出,并存入eip及存取
- 再次熟悉了汇编语言,对于mov指令有了更为深入的了解;
- 真正将汇编语言与C语言结合起来,真正了解很多时候的代码优化原理;
入栈出栈:
- 复习了堆栈中入栈出栈的步骤
- 学习栈在程序执行过程的作用,特别是编译之后用汇编语言的执行过程
2018-2019-1 20189221《Linux内核原理与分析》第二周作业的更多相关文章
- 2019-2020-1 20199303<Linux内核原理与分析>第二周作业
2019-2020-1 20199303第二周作业 1.汇编与寄存器的学习 寄存器是中央处理器内的组成部份.寄存器是有限存贮容量的高速存贮部件,它们可用来暂存指令.数据和位址.在中央处理器的控制部件中 ...
- 20169219 linux内核原理与分析第二周作业
"linux内核分析"的第一讲主要讲了计算机的体系结构,和各寄存器之间对数据的处理过程. 通用寄存器 AX:累加器 BX:基地址寄存器 CX:计数寄存器 DX:数据寄存器 BP:堆 ...
- 2019-2020-1 20199314 <Linux内核原理与分析>第二周作业
1.基础学习内容 1.1 冯诺依曼体系结构 计算机由控制器.运算器.存储器.输入设备.输出设备五部分组成. 1.1.1 冯诺依曼计算机特点 (1)采用存储程序方式,指令和数据不加区别混合存储在同一个存 ...
- Linux内核原理与分析-第二周作业
写之前回看了一遍秒速五厘米:如果
- Linux内核原理与分析-第一周作业
本科期间,学校开设过linux相关的课程,当时的学习方式主要以课堂听授为主.虽然老师也提供了相关的学习教材跟参考材料,但是整体学下来感觉收获并不是太大,现在回想起来,主要还是由于自己课下没有及时动手实 ...
- 2019-2020-1 20199314 <Linux内核原理与分析>第一周作业
前言 本周对实验楼的Linux基础入门进行了学习,目前学习到实验九完成到挑战二. 学习和实验内容 快速学习了Linux系统的发展历程及其简介,学习了下的变量.用户权限管理.文件打包及压缩.常用命令的和 ...
- 2018-2019-1 20189221《Linux内核原理与分析》第一周作业
Linux内核原理与分析 - 第一周作业 实验1 Linux系统简介 Linux历史 1991 年 10 月,Linus Torvalds想在自己的电脑上运行UNIX,可是 UNIX 的商业版本非常昂 ...
- 2020-2021-1 20209307 《Linux内核原理与分析》第九周作业
这个作业属于哪个课程 <2020-2021-1Linux内核原理与分析)> 这个作业要求在哪里 <2020-2021-1Linux内核原理与分析第九周作业> 这个作业的目标 & ...
- 2018-2019-1 20189221 《Linux内核原理与分析》第九周作业
2018-2019-1 20189221 <Linux内核原理与分析>第九周作业 实验八 理理解进程调度时机跟踪分析进程调度与进程切换的过程 进程调度 进度调度时机: 1.中断处理过程(包 ...
- 2018-2019-1 20189221 《Linux内核原理与分析》第八周作业
2018-2019-1 20189221 <Linux内核原理与分析>第八周作业 实验七 编译链接过程 gcc –e –o hello.cpp hello.c / gcc -x cpp-o ...
随机推荐
- Python 读取目录、文件
在读文件的时候往往需要遍历文件夹,python的os.path包含了很多文件.文件夹操作的方法.下面列出: os.path.abspath(path) #返回绝对路径 os.path.basename ...
- hadoop程序实例
安装了Eclipse及hadoop-eclipse-plugin后学着<hadoop权威指南>中的气温例子写了一个输出气温的程序,数据是我自己简单写的,但是输出却不是我预想的,这中间还有很 ...
- vs2017默认以管理员运行
1. 打开VS的安装目录,找到devenv.exe,右键,选择“兼容性疑难解答”. 2. 选择“疑难解答程序” 3. 选择“该程序需要附加权限” 4. 确认用户帐户控制后,点击测试程序,不然这个对话框 ...
- ifnull与nvl
mysql 用 ifnull ,oracle没有ifnull 但是有相应的替换函数 nvl NVL(eExpression1, eExpression2)
- Tif文件合并类
using System; using System.Collections; using System.Collections.Generic; using System.Drawing; usin ...
- 2018ACM-ICPC南京区域赛M---Mediocre String Problem【exKMP】【Manacher】
这题就单独写个题解吧.想了两天了,刚刚问了一个大佬思路基本上有了. 题意: 一个串$S$,一个串$T$,在$S$中选一段子串$S[i,j]$,在$T$中选一段前缀$T[1,k]$使得$S[i,j]T[ ...
- 初试 Entity Framework Core 的多对多映射
今天在博问中看到一个关于 EF Core 的提问 ef core 2.0 多对多查询的问题,由于还没使用过 EF Core 的多对多映射,于是参考 EF Core 帮助文档快速写了个 .net cor ...
- H. GSS and Simple Math Problem 高精度乘法模板
链接:https://www.nowcoder.com/acm/contest/104/G来源:牛客网 题目描述 Given n positive integers , your task is to ...
- MSSQL数据库优化经验
数据库优化的目标无非是避免磁盘I/O瓶颈.减少CPU利用率和减少资源竞争.1. 在业务密集的SQL当中尽量不采用IN操作符2. 不使用not in 因为它不能应用表的索引.用not exists 或 ...
- Shell实现判断进程是否存在并重新启动脚本
Shell实现判断进程是否存在并重新启动脚本 - superbfly的专栏 - CSDN博客 https://blog.csdn.net/superbfly/article/details/52513 ...