《Linux内核分析》第一周笔记 计算机是如何工作的
一、计算机是如何工作的?
1、存储程序计算机工作模型
1)冯诺依曼体系结构
学习研究计算机的基本概念。就是指存储程序计算机。所有的有计算功能的电子设备小到计算器,大到超级计算机核心部分都可以用这种体系结构来描述。
2)存储程序计算机工作模型
从硬件(计算机的主板):逻辑上抽象为,CPU与内存之间通过总线连接,CPU内部有一个关键寄存器IP(Instruction Pointer)(在16位CPU中叫IP,在32位CPU中叫EIP,在64位CPU中叫RIP),总是指向内存的某块区域,指向内存中的代码段CS(Code Segment)。CPU从IP指向的内存地址取一条指令执行,完成后IP自+1,执行下一条指令,之后重复取指令执行。
从程序员:内存保存指令和数据,CPU负责解释和执行这些指令。
3)CPU识别什么样的指令?如何定义?
API:程序员与计算机的接口界面。
ABI:程序与CPU接口界面
- 汇编指令
- 约定使用什么样的寄存器
- 对X86来讲,多数指令可直接访问内存
EIP:在X86计算机中EIP指向内存的一条指令,EIP自动加到下一条指令,每条指令的长度不同,也可被CALL、RET、JMP、condition JMP指令修改。
2、X86汇编基础
1) X86 CPU的寄存器
1.通用寄存器:
32位的寄存器中,低16位作为16位的寄存器:AX、BX、CX、DX。
开头为E的寄存器是32位。累加器EAX、基地址寄存器EBX、计数寄存器ECX、数据寄存器EDX、堆栈基指针EBP(重要)、变址寄存器ESI和EDI、堆栈顶指针ESP(重要)。堆栈是计算机中基础性的东 西。
开头为R的寄存器是64位。机制上与32位差别不大。
2.段寄存器:
CS——代码段寄存器(Code Segment Register),其值为代码段的段值;
DS——数据段寄存器(Data Segment Register),其值为数据段的段值;
ES——附加段寄存器(Extra Segment Register),其值为附加数据段的段值;
SS——堆栈段寄存器(Stack Segment Register),其值为堆栈段的段值;
FS——附加段寄存器(Extra Segment Register),其值为附加数据段的段值;
GS——附加段寄存器(Extra Segment Register),其值为附加数据段的段值。
其中代码段和堆栈段使用最多。CPU在实际取指令时根据cs:eip来准确定位一个指令的内存地址。
3.标志寄存器:
用于标识当前状态。
2)常见汇编指令
1.mov指令及几种内存寻址方式
b,w,l,q分别代表8位,16位,32位和64位

- 寄存器寻址,以%开头的寄存器标示符,操作寄存器,与内存无关。
- 立即寻址,立即数是以$开头的数值,与内存无关。
- 直接寻址,直接访问一个指定的内存地址的数据。没有$则表示地址,将内存地址0x123指向的内存数据放入edx寄存器。
- 间接寻址,将寄存器的值作为一个内存地址来访问内存,寄存器ebx存的值作为内存地址,将内存地址存储的数据放入edx。
- 变址寻址,在间接寻址之时改变寄存器的数值。
- Linux使用的A&T汇编格式与Intel汇编略有不同。
2.几个重要汇编指令push pop call ret

- 压栈:把eax这个寄存器压栈到堆栈的栈底,ebp指向栈底,将eax放到esp所在的内存位置。栈的位置在增长。
- 出栈:栈的位置在收缩。
- 函数调用:把地址0x12345地址放到eip里,eip存储着当前cpu要读取指令的地址(指令指针),表示CPU下条指令从0x1234开始执行。
- return:ret是把之前保存的eip还原,ret后会继续执行函数调用完的下一条指令。
*表示是伪指令,不能被程序员直接使用。因为eip寄存器不能被直接修改,只能通过指令间接修改。
3)练习
例1


例2


例3


3、汇编一个简单的C程序
实验过程

实验代码

汇编代码


分析汇编代码
函数的返回值默认使用eax存储返回给上一级函数



4、总结
通过第一次学习《Linux内核分析》这门课程,我收获了许多知识。首先复习了冯诺依曼体系结构的知识,对存储程序计算机工作模型从两个方面进行了了解。之后有了解了CPU可以识别的口令。第二部分学习了X86的汇编基础知识,了解了CPU的三种寄存器,以及几种重要的寻址方式寄存器寻址,以%开头的寄存器标示符,操作寄存器,与内存无关。立即寻址,立即数是以$开头的数值,与内存无关。直接寻址,直接访问一个指定的内存地址的数据。间接寻址,将寄存器的值作为一个内存地址来访问内存,寄存器ebx存的值作为内存地址,将内存地址存储的数据放入edx。变址寻址,在间接寻址之时改变寄存器的数值。之后学习并应用了几个重要汇编指令push pop call ret,通过习题更加了解这些指令的具体含义。
《Linux内核分析》第一周笔记 计算机是如何工作的的更多相关文章
- linux内核分析第一周学习笔记
linux内核分析第一周学习笔记 标签(空格分隔): 20135328陈都 陈都 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.co ...
- LINUX内核分析第一周学习总结——计算机是如何工作的
LINUX内核分析第一周学习总结——计算机是如何工作的 张忻(原创作品转载请注明出处) <Linux内核分析>MOOC课程http://mooc.study.163.com/course/ ...
- Linux内核分析第一周学习博客 --- 通过反汇编方式学习计算机工作过程
Linux内核分析第一周学习博客 通过反汇编方式学习计算机工作过程 总结: 通过这次对一个简单C程序的反汇编学习,我了解到计算机在实际工作工程中要涉及大量的跳转指针操作.计算机通常是顺序执行一条一条的 ...
- Linux内核分析——第一周学习笔记20135308
第一周 计算机是如何工作的 第一节 存储程序计算机工作模型 1.冯·诺依曼结构模型:冯·诺依曼结构也称普林斯顿结构,是一种将程序指令存储器和数据存储器合并在一起的存储器结构.程序指令存储地址和数据存储 ...
- 20135320赵瀚青LINUX内核分析第一周学习笔记
赵瀚青原创作品转载请注明出处<Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 一.概述 第一周的学习内容主 ...
- Linux内核分析——第一周学习笔记
20135313吴子怡.北京电子科技学院 chapter 1 知识点梳理 第一节 存储程序计算机工作模型 1.冯诺依曼体系结构:即具有存储程序的计算机体系结构.目前大多数拥有计算和存储功能的设备(智能 ...
- Linux内核分析第一周学习总结:计算机是如何工作的?
韩玉琪 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 一.冯诺依曼体系 ...
- Linux内核分析第一周——计算机是如何工作的
冯诺依曼体系结构 核心思想 1.冯诺依曼是:数字计算机的数制采用二进制:计算机应该按照程序顺序执行. 2.采用二进制作为计算机数值计算的基础,以0.1代表数值.不采用人类常用的十进制计数方法,二进制使 ...
- linux内核分析 第一周
计算机是如何工作的 冯·诺依曼理论的要点是: 数字计算机的数制采用二进制:计算机应该按照程序顺序执行. 冯·诺依曼体系结构 根据冯·诺依曼体系结构构成的计算机,必须具有如下功能:把需要的程序和数据送至 ...
随机推荐
- 在Word2007,2010,2016中分栏但不换页的方法
解决方法: word2007:界面左上角的按钮->选择word选项->依次点击“高级”->“版式选项”->点开加号,“按word6.x/95/97的方式排放脚注”. Word2 ...
- 用python实现MRO算法
引子: 如图反映了python3中,几个类的继承关系和查找顺序.对于类A,其查找顺序为:A,B,E,C,F,D,G,(Object),这并不是一个简单的深度优先或广度优先的规律.那么这个顺序到底是如何 ...
- pstools工具使用
该工具的目的:批量远程操作windows服务器, 个人实验的方法步骤: 1.在被远程的电脑上开通139,445端口 2.建立ipc$链接, 格式:Net use \\目标ip\ipc$ 密码 /use ...
- ES6标准入门之字符串的拓展讲解
在开始讲解ES6中字符串拓展之前,我们先来看一下ES5中字符串的一些方法. 获取字符串长度 str.length 分割字符串 str.split() 拼接字符串 str1+str2 或 str1.co ...
- android 解决小米手机上选择照片路径为null情况
昨天测试帅哥说他手机选择图库崩溃了,这是一个上传头像的功能,相信很多应用都有这个功能,于是我就把手机拿过来打log看了下返回的路径 为null,在网上搜索了下解决方案,现在把解决方案记录下: 这是在o ...
- HDU1754
https://vjudge.net/contest/66989#problem/B 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少. 这让很多学生很反感. 不管你喜 ...
- 我的$OI$
我只是懒得写日记啦\(\color{pink}{qwq}\) //11月8日 啊--终于要\(NOIp\)了,为此期盼了好久.紧张了好久的我,不知道会迎来怎样的结果. 我只知道这段回忆是值得保留封存的 ...
- Python3入门(九)——面向对象OOP高级编程
一.使用__slots__限制属性绑定 动态绑定实例的方法: class Person(object): def run(self): print("奔跑吧!") p1 = Per ...
- 2017-2018-2 《网络对抗技术》20155322 Exp8 web基础
[-= 博客目录 =-] 1-实践目标 1.1-实践介绍 1.2-实践内容 1.3-实践要求 2-实践过程 2.1-Web前端HTML 2.2-Web前端javascipt 2.3-Web后端 2.4 ...
- 原创zynq文章整理(MiZ702教程+例程)
MiZ702教程+例程 网盘链接: http://pan.baidu.com/s/1sj23yxv 不时会跟新版本,增加勘误之类的,请关注--