《Linux内核分析》第一周学习笔记
《Linux内核分析》第一周学习笔记 计算机是如何工作的
郭垚 原创作品转载请注明出处 《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000
1. 存储程序计算机工作模型
1.1 冯诺依曼体系结构
冯诺依曼体系结构,即具有存储程序的计算机的体系结构。超级计算机都可以用这种体系描述。
1.2 存储程序计算机工作模型
- 从硬件上看:CPU与内存之间由总线连接,CPU中一个关键寄存器IP(在16位CPU中叫IP,在32位CPU中叫EIP,在64位CPU中叫RIP)总是指向内存中某块区域,IP指向内存中的代码段CS。CPU执行IP指向的指令,执行完后IP自加1继续执行下一条指令。
 - 从软件上看:内存保留指令和数据,CPU解释、执行这些指令。
 
1.3.1 API与ABI
- API:程序员与计算机的接口界面。
 - ABI:程序与CPU接口界面,多数指令可直接访问内存。
 
1.3.2 EIP
在32位X86计算机中指向内存的某条指令,EIP可自加到下一条指令(指令长度不同),也可被其他指令(CALL、RET、JMP、condition JMP)修改。
2. X86汇编基础
2.1 X86 CPU的寄存器
2.1.1 通用寄存器
32位的寄存器中,低16位作为16位的寄存器:AX、BX、CX、DX。一般开头增加了E的寄存器是32位。如:累加器EAX、基地址寄存器EBX、计数寄存器ECX、数据寄存器EDX、堆栈基指针EBP、变址寄存器ESI和EDI、堆栈顶指针ESP
2.1.2 段寄存器
- 指令都存储于代码段,CPU实际取指令的时候通过cs:eip来描述。
 - 每个指令都有一个堆栈
 

2.1.3 标志寄存器
标志寄存器用于标识当前状态。
2.2 常见汇编指令
2.2.1 mov指令及几种内存寻址方式
后缀b,w,l,q分别代表8,16,32,64位
- 寄存器寻址movl %eax,%edx(操作的都是寄存器,与内存无关)
 - 立即寻址movl $0x123,%edx($表示立即数,立即寻址与内存无关)
 - 直接寻址movl 0x123,%edx(没有$则表示地址,将内存地址0x123指向的内存数据放入edx寄存器)
 - 间接寻址movl (%ebx),%edx(将寄存器ebx存的值作为内存地址,将内存地址存储的数据放入edx)
 - 变址寻址movl 4(%ebx),%edx(在间接寻址前改变寄存器的值,本句是+4)
 
注:Linux使用的A&T汇编格式与Intel汇编略有不同。
2.2.2 几个重要的汇编指令

- movl %eax,(%esp) 将eax放到esp所在的内存位置。()可表示该寄存器指向的值
 - call 0x1234 调用0x1234这个地址(eip存储着cpu要读取指令的地址,此句表示CPU下条指令从0x1234开始执行)
 - ret是把之前保存的eip弹出,ret后会继续执行函数调用完的下一条指令
 - *表示是伪指令,不能被程序员直接使用。因为eip寄存器不能被直接修改,只能间接修改。
 
2.3 堆栈练习
例1:

例2:

例3:

堆栈过程分析:


3. 汇编一个简单的C程序
3.1 将C代码编译成汇编代码
gcc -S -o main.s main.c -m32
实验环境为64位,-m32将代码编译为32位的汇编代码main.s
3.2 enter与leave指令

- enter将在栈上新建一个空栈
 - leave撤销函数调用堆栈
 
注:
- 函数调用堆栈是由逻辑上多个堆栈叠加起来的。
 - 函数的返回值默认用%eax存储返回给上一级函数。
 - pop %ebp 意思是ebp指回上一次的位置
 
3.3 实验
实验过程截图:

C程序源代码:

汇编代码:


堆栈过程分析:




4.总结
根据本门课程中老师对冯诺依曼原理体系的讲解,我了解到计算机的基本原理是存储程序和程序控制。计算机由CPU、I/O总线、输入输出系统、存储器以及I/O设备组成。其中CPU与内存之间由总线连接,内存保留指令和数据,CPU解释、执行这些指令。每一条指令中明确规定了计算机从哪个地址取数,进行什么操作,然后送到什么地址去等步骤。CPU中一个关键寄存器IP总是指向内存中某块区域。计算机在工作时会先从内存中取出一条IP指向的指令给CPU执行,按指令的要求从存储器中取出数据进行指定的运算和逻辑操作,然后再把结果送到内存中去。执行完后IP自加1继续执行下一条指令,则再取出第二条指令依此进行下去。直至遇到停止指令。由此可以看出,计算机能完成很多复杂的计算实质上都是依赖于简单的一步一步地取出指令,自动地完成指令规定的操作。
《Linux内核分析》第一周学习笔记的更多相关文章
- linux内核分析第一周学习笔记
		
linux内核分析第一周学习笔记 标签(空格分隔): 20135328陈都 陈都 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.co ...
 - 20135320赵瀚青LINUX内核分析第一周学习笔记
		
赵瀚青原创作品转载请注明出处<Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 一.概述 第一周的学习内容主 ...
 - Linux内核分析——第一周学习笔记20135308
		
第一周 计算机是如何工作的 第一节 存储程序计算机工作模型 1.冯·诺依曼结构模型:冯·诺依曼结构也称普林斯顿结构,是一种将程序指令存储器和数据存储器合并在一起的存储器结构.程序指令存储地址和数据存储 ...
 - Linux内核分析——第一周学习笔记
		
20135313吴子怡.北京电子科技学院 chapter 1 知识点梳理 第一节 存储程序计算机工作模型 1.冯诺依曼体系结构:即具有存储程序的计算机体系结构.目前大多数拥有计算和存储功能的设备(智能 ...
 - LINUX内核分析第一周学习总结——计算机是如何工作的
		
LINUX内核分析第一周学习总结——计算机是如何工作的 张忻(原创作品转载请注明出处) <Linux内核分析>MOOC课程http://mooc.study.163.com/course/ ...
 - Linux内核分析第二周学习笔记
		
linux内核分析第二周学习笔记 标签(空格分隔): 20135328陈都 陈都 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.co ...
 - Linux内核分析第一周学习博客     ---     通过反汇编方式学习计算机工作过程
		
Linux内核分析第一周学习博客 通过反汇编方式学习计算机工作过程 总结: 通过这次对一个简单C程序的反汇编学习,我了解到计算机在实际工作工程中要涉及大量的跳转指针操作.计算机通常是顺序执行一条一条的 ...
 - 三20135320赵瀚青LINUX内核分析第二周学习笔记
		
赵瀚青原创作品转载请注明出处<Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 一.计算机的三个法宝 存储程 ...
 - Linux内核分析第一周学习总结:计算机是如何工作的?
		
韩玉琪 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 一.冯诺依曼体系 ...
 - Linux内核分析——第二周学习笔记
		
20135313吴子怡.北京电子科技学院 chapter 1 知识点梳理 (一)计算机是如何工作的?(总结)——三个法宝 ①存储程序计算机工作模型,计算机系统最最基础性的逻辑结构: ②函数调用堆栈,高 ...
 
随机推荐
- DevExpress07、DataNavigator、 ControlNavigator
			
https://documentation.devexpress.com/WindowsForms/DevExpress.XtraEditors.DataNavigator.class 1.DataN ...
 - N皇后问题 各种优化
			
0.问题引入 N皇后问题是一个经典的问题,在一个N*N的棋盘上放置N个皇后,每行一个并使其不能互相攻击(同一行.同一列.同一斜线上的皇后都会自动攻击),问有多少种摆法. 题目链接:https://ww ...
 - jenkins发版脚本更新
			
jenkins 项目名中明确了 是jar tar.gz war包研发需要提供 项目名-地点-环境(研发.测试.生产)-应用项目名称(admin)-包格式(jar\war\gz) deployment ...
 - 关于Spring IOC (DI-依赖注入)需要知道的一切
			
关联文章: 关于Spring IOC (DI-依赖注入)你需要知道的一切 关于 Spring AOP (AspectJ) 你该知晓的一切 <Spring入门经典>这本书无论对于初学者或者有 ...
 - [转]System.DllNotFoundException: 无法加载 DLL“*.dll”: 内存位置访问无效。 (异常来自 HRESULT:0x800703E6)
			
我在使用地税发票控件进行开票的测试的时候,在xp上测试时正常的,在别人的win7系统测试也是正常,但我在我本机确不正常.我本机装的是msdn版本win7系统,这个系统比较原装. 错误信息如下: -- ...
 - 客户端本地存储的比较及使用window.name数据传输
			
一:cookie: 1. 什么是cookie? Cookie是在客户端用于存储会话信息的,用户请求页面在web服务器与浏览器之间传递.每当同一台计算机通过浏览器请求某个页面时,就会发送这个 cooki ...
 - Android百度地图2.0运行定位到当前位置时“服务没有启动”
			
现象:运行mapView.requestLocation(),返回值为1即“服务没有启动”. 解决方案:看一下主配置文件中服务是否配置了,具体如下: <service android:name= ...
 - mysql删除关联表数据
			
DELETE og,oiFROM order_goods og, order_info oiWHERE oi.order_id = og.order_id and oi.user_id = 6
 - DD-WRT
			
定时任务: 每日凌晨1點關, 星期1-, 上午7點半開, 8點半關, 晚上9點開 星期6/日, 上午開10點開 administration -> management -> enable ...
 - AbelSu教你搭建go语言开发环境
			
go语言官网:https://golang.org/ windows:官网下载go1.6.windows-amd64.msi安装文件,安装位置选择默认C:\Go\安装结束后配置环境变量Path: C: ...