《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键将含有小数点的代码行删除:
![](http://images2017.cnblogs.com/blog/1249685/201710/1249685-20171008152330215-667869273.png) 汇编并整理后的代码如图: ![](http://images2017.cnblogs.com/blog/1249685/201710/1249685-20171008153640824-325779027.png) ###下面开始代码的操作叙述:
![](http://images2017.cnblogs.com/blog/1249685/201710/1249685-20171008162731153-217978842.png) 首先将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内核原理与设计》第二周作业的更多相关文章

  1. 2019-2020-1 20199303<Linux内核原理与分析>第二周作业

    2019-2020-1 20199303第二周作业 1.汇编与寄存器的学习 寄存器是中央处理器内的组成部份.寄存器是有限存贮容量的高速存贮部件,它们可用来暂存指令.数据和位址.在中央处理器的控制部件中 ...

  2. 20169219 linux内核原理与分析第二周作业

    "linux内核分析"的第一讲主要讲了计算机的体系结构,和各寄存器之间对数据的处理过程. 通用寄存器 AX:累加器 BX:基地址寄存器 CX:计数寄存器 DX:数据寄存器 BP:堆 ...

  3. 2019-2020-1 20199314 <Linux内核原理与分析>第二周作业

    1.基础学习内容 1.1 冯诺依曼体系结构 计算机由控制器.运算器.存储器.输入设备.输出设备五部分组成. 1.1.1 冯诺依曼计算机特点 (1)采用存储程序方式,指令和数据不加区别混合存储在同一个存 ...

  4. Linux内核原理与分析-第二周作业

    写之前回看了一遍秒速五厘米:如果

  5. 2019-2020-1 20199303 《Linux内核原理分析》 第一周作业

    2019-2020-1 20199303 <Linux内核原理分析> 第一周作业 1. 环境准备 在众多的Linux发行版中,Ubuntu,小红帽还有类Unix系统的BSD系统,我选择了目 ...

  6. Linux内核原理与分析-第一周作业

    本科期间,学校开设过linux相关的课程,当时的学习方式主要以课堂听授为主.虽然老师也提供了相关的学习教材跟参考材料,但是整体学下来感觉收获并不是太大,现在回想起来,主要还是由于自己课下没有及时动手实 ...

  7. 2019-2020-1 20199314 <Linux内核原理与分析>第一周作业

    前言 本周对实验楼的Linux基础入门进行了学习,目前学习到实验九完成到挑战二. 学习和实验内容 快速学习了Linux系统的发展历程及其简介,学习了下的变量.用户权限管理.文件打包及压缩.常用命令的和 ...

  8. 2017-2018-1 20179205《Linux内核原理与设计》第十周作业

    <Linux内核原理与设计>第十周作业 教材17.19.20章学习及收获 1.在Linux以及所有unix系统中,设备被分为以下三种:块设备(blkdev)以块为单位寻址,通过块设备节点来 ...

  9. 2017-2018-1 20179205《Linux内核原理与设计》第九周作业

    <Linux内核原理与设计>第九周作业 视频学习及代码分析 一.进程调度时机与进程的切换 不同类型的进程有不同的调度需求,第一种分类:I/O-bound 会频繁的进程I/O,通常会花费很多 ...

  10. 2017-2018-1 20179205《Linux内核原理与设计》第八周作业

    <Linux内核原理与设计>第八周作业 视频学习及操作分析 预处理.编译.链接和目标文件的格式 可执行程序是怎么来的? 以C语言为例,经过编译器预处理.编译成汇编代码.汇编器编译成目标代码 ...

随机推荐

  1. VisualVM使用方法

    VisualVM 简介 VisualVM 是一个工具,它提供了一个可视界面,用于查看 Java 虚拟机 (Java Virtual Machine, JVM) 上运行的基于 Java 技术的应用程序( ...

  2. context.getResourceAsStream获取的是部署在服务器上面的文件位置 而不是我们本地的工程位置 意思是说获取的都是web下面的文件位置

    context.getResourceAsStream获取的是部署在服务器上面的文件位置 而不是我们本地的工程位置 意思是说获取的都是web下面的文件位置

  3. HTML5 不再支持哪些元素

    HTML5中已经不支持以下的元素,不建议在进行开发时再使用以下的元素. 1.acronym(建议abbr):定义首字母缩写 2.applet(建议object):定义applet 3.basefont ...

  4. hdu 1054 Strategic Game (二分匹配)

    Strategic Game Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  5. 【刷题】洛谷 P4329 [COCI2006-2007#1] Bond

    题意翻译 有 \(n\) 个人去执行 \(n\) 个任务,每个人执行每个任务有不同的成功率,每个人只能执行一个任务,求所有任务都执行的总的成功率. 输入第一行,一个整数 \(n\) ( \(1\leq ...

  6. 【BZOJ4892】DNA(后缀数组)

    [BZOJ4892]DNA(后缀数组) 题面 BZOJ 洛谷 题解 看到这道题目,我第一反应是\(FFT\)??? 然后大力码出了一个\(FFT\) 就像这样 #include<iostream ...

  7. 删边(cip)

    删边(cip) 给出一个没有重边和自环的无向图,现在要求删除其中两条边,使得图仍然保持连通. 你的任务是计算有多少组不合法的选边方案.注意方案是无序二元组. Sol 神题,无从下手啊. 考虑点dfs建 ...

  8. 【简单算法】18.实现strStr()

    题目: 实现 strStr() 函数. 给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始).如果不存 ...

  9. HDU 5586 (dp 思想)

    Sum Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Total Submis ...

  10. HDU4612:Warm up(缩点+树的直径)

    Warm up Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Total Su ...