2017-2018-1 20179205《Linux内核原理与设计》第二周作业
《Linux内核原理与分析》第二周作业
本周视频学习情况:
通过孟老师的视频教程,大致对风诺依曼体系结构有了一个初步的认识,视频从硬件角度和程序员角度对CPU和Main Memory(内存)的关系进行的解释,其中内存保存指令和数据,CPU解释指令。
一些基本的汇编指令:
通用寄存器:
EAX:累加器
EBX:基地址寄存器
ECX:计数寄存器
EDX:数据寄存器
ESI:源变址寄存器
EDI:目的变址寄存器
EIP:指令指针寄存器
其中EIP寄存器不能被直接修改,只能通过特殊指令间接修改。
mov指令及几种内存寻址方式:
b、w、l、q分别代表8位,16位,32位及64位
操作方法:
register mode(寄存器寻址):movl %eax,%edx edx=eax
immediate(立即寻址):movl $0x123,%edx edx=0x123
即把16进制数放到edx中
direct(直接寻址):movl 0x123,%edx edx=*(int32_t*)0x123
这里的(*)表示程序员不能直接使用
不加括号,表示把16进制数的地址放到edx中
indirect(间接寻址):movl (%ebx),%edx edx=*(int32_t*)ebx
加括号,表示把内存地址存储数据放到edx中
displaced(变址寻址):movl 4(%ebx),%edx edx=*(int32_t*)(ebx+4)
在间接寻址时改变寄存器的数值
实验操作
反汇编一个简单的C程序,为方便代码下载下来,在code下写代码,并通过vim打开main.c:
问题与分析:
通过vim打开main.c文件后,如何返回之间的界面?
通过查找答案,得知Esc键退出插入模式,输入:wq返回界面。
下面是简单的c程序:
问题与分析:
在反编译汇编代码时,不明白反汇编代码
gcc -S -o main.s main.c -m32
``` 中-S -o怎么来的?
通过查找答案,知道了在gcc命令中 -S是将源代码翻译成汇编指令,-o是指将生成的汇编代码保存到main.s中,了解了代码含义更有利于记忆。
再次退出插入模式,通过双击d键将含有小数点的代码行删除:

汇编并整理后的代码如图:

###下面开始代码的操作叙述:

首先将ebp压栈,并将ebp新的内存地址指向esp,然后将ebp增加8即向上移动两个单位格的内容存入eax寄存器,将eax存储的数增加10个立即数,popl指令进行出栈,ret指令相当于popl eip,就是把esp里所指向的栈顶的内容取出来放到eip中,从而改变程序执行流程。
其中enter指令等价于以下两条指令:
push %ebp
movl %esp,%ebp
leave指令等价于以下两条指令:
movl %ebp,%esp
popl %ebp
所以enter和leave指令其实都包含着两个步骤,分别是:
1、将ebp压入栈底;
2、将ebp指向esp的位置
1、将esp指向ebp的位置;
2、将当前ebp所指向的内存单元里的内容弹出,并存入eip及存取
##总结:
由于本科阶段没有学习过数据结构(自学过一些),所以开始看孟老师的视频理解的比较慢,反复多看了几遍,现在对栈以及栈针的变化有了一定的认识,对冯诺依曼体系结构中CPU和内存的关系明白了很多。有时间会多看看实验,多操作,以及别人的问题及解答,变为自己的知识,继续努力!
2017-2018-1 20179205《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内核原理与分析-第二周作业
写之前回看了一遍秒速五厘米:如果
- 2019-2020-1 20199303 《Linux内核原理分析》 第一周作业
2019-2020-1 20199303 <Linux内核原理分析> 第一周作业 1. 环境准备 在众多的Linux发行版中,Ubuntu,小红帽还有类Unix系统的BSD系统,我选择了目 ...
- Linux内核原理与分析-第一周作业
本科期间,学校开设过linux相关的课程,当时的学习方式主要以课堂听授为主.虽然老师也提供了相关的学习教材跟参考材料,但是整体学下来感觉收获并不是太大,现在回想起来,主要还是由于自己课下没有及时动手实 ...
- 2019-2020-1 20199314 <Linux内核原理与分析>第一周作业
前言 本周对实验楼的Linux基础入门进行了学习,目前学习到实验九完成到挑战二. 学习和实验内容 快速学习了Linux系统的发展历程及其简介,学习了下的变量.用户权限管理.文件打包及压缩.常用命令的和 ...
- 2017-2018-1 20179205《Linux内核原理与设计》第十周作业
<Linux内核原理与设计>第十周作业 教材17.19.20章学习及收获 1.在Linux以及所有unix系统中,设备被分为以下三种:块设备(blkdev)以块为单位寻址,通过块设备节点来 ...
- 2017-2018-1 20179205《Linux内核原理与设计》第九周作业
<Linux内核原理与设计>第九周作业 视频学习及代码分析 一.进程调度时机与进程的切换 不同类型的进程有不同的调度需求,第一种分类:I/O-bound 会频繁的进程I/O,通常会花费很多 ...
- 2017-2018-1 20179205《Linux内核原理与设计》第八周作业
<Linux内核原理与设计>第八周作业 视频学习及操作分析 预处理.编译.链接和目标文件的格式 可执行程序是怎么来的? 以C语言为例,经过编译器预处理.编译成汇编代码.汇编器编译成目标代码 ...
随机推荐
- VisualVM使用方法
VisualVM 简介 VisualVM 是一个工具,它提供了一个可视界面,用于查看 Java 虚拟机 (Java Virtual Machine, JVM) 上运行的基于 Java 技术的应用程序( ...
- context.getResourceAsStream获取的是部署在服务器上面的文件位置 而不是我们本地的工程位置 意思是说获取的都是web下面的文件位置
context.getResourceAsStream获取的是部署在服务器上面的文件位置 而不是我们本地的工程位置 意思是说获取的都是web下面的文件位置
- HTML5 不再支持哪些元素
HTML5中已经不支持以下的元素,不建议在进行开发时再使用以下的元素. 1.acronym(建议abbr):定义首字母缩写 2.applet(建议object):定义applet 3.basefont ...
- hdu 1054 Strategic Game (二分匹配)
Strategic Game Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- 【刷题】洛谷 P4329 [COCI2006-2007#1] Bond
题意翻译 有 \(n\) 个人去执行 \(n\) 个任务,每个人执行每个任务有不同的成功率,每个人只能执行一个任务,求所有任务都执行的总的成功率. 输入第一行,一个整数 \(n\) ( \(1\leq ...
- 【BZOJ4892】DNA(后缀数组)
[BZOJ4892]DNA(后缀数组) 题面 BZOJ 洛谷 题解 看到这道题目,我第一反应是\(FFT\)??? 然后大力码出了一个\(FFT\) 就像这样 #include<iostream ...
- 删边(cip)
删边(cip) 给出一个没有重边和自环的无向图,现在要求删除其中两条边,使得图仍然保持连通. 你的任务是计算有多少组不合法的选边方案.注意方案是无序二元组. Sol 神题,无从下手啊. 考虑点dfs建 ...
- 【简单算法】18.实现strStr()
题目: 实现 strStr() 函数. 给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始).如果不存 ...
- HDU 5586 (dp 思想)
Sum Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Total Submis ...
- HDU4612:Warm up(缩点+树的直径)
Warm up Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others)Total Su ...