2017-2018-1 20179215《Linux内核原理与分析》第二周作业

20179215《Linux内核原理与分析》第二周作业

这一周主要了解了计算机是如何工作的,包括现在存储程序计算机的工作模型、X86汇编指令包括几种内存地址的寻址方式和push、pop、call、re等几个重要的汇编指令。主要分为两部分进行这周的学习总结。第一部分对学习内容进行总结,第二部分对实验进行分析(反汇编一个C程序)。


一、学习内容

1、现在计算机绝大多数采用冯诺依曼体系结构,逻辑上可以抽象成:

neiyKF3.png

以程序员的角度看:

PuKRvoO.png

2、几种寻址方式

• movl %eax,%edx edx=eax 寄存器寻址

• movl \(0x123,%edx edx=0x123 立即寻址 ###• movl 0x123,%edx edx=*(int32_t)0x123 直接寻址 ###• movl (%ebx),%edx edx=(int32_t)ebx 间接寻址 ###• movl 4(%ebx),%edx edx=(int32_t)(ebx+4) 变址寻址 ####其中%..代表寄存器,\)..代表取出数据,(%..)代表取出寄存器中所存储的数据,b、w、l、q分别代表8位、16位、32位和64位。

3、push、pop、call等几个重要的汇编指令。

eg (1) pushl %eax 意思是把eax寄存器压栈。分解来看相当于第一步:subl $4 esp,第二步:movl %eax (%esp),来解释一下:首先我们要知道esp是指堆栈栈顶,那么由于栈的一般生长方向为自上向下增长,进行push压栈指令时栈顶指针向下移动4个字节(因为是32位机),之后把eax放入当前内存位置。

(2) popl %eax意思是把eax寄存器出栈。分解来看相当于第一步: movl(%esp), %eax第二步:add \(4 %esp,道理同(1)逆。 ###(3) call 0X12345 意思是函数调用,过程是首先将当前CPU获取内存的指令压栈保存,赋予新值,CPU下次就从新地址来取指令了,即实现了函数调用。 #二、实验分析 ##首先创建main.c文件,即:touch main.c,之后用如下命令输入一段C语言代码: ###\)vi main.c,之后用gedit main.c 查看编写好的C程序,如下图所示:

S2fd1KH.png

然后用如下命令反汇编:$gcc -S -o main.s main.c -m32,之后用gedit main.c 查看结果,如下图所示:

uMz7mKd.png
1xeYtnI.png
TBsy0Cc.png
vsBWpLR.png

由于“.”开头的大都是用于链接辅助信息,实际并不会执行,所以可以直接忽略。删除所有点开头的内容,留下来的是纯汇编代码。那么此段程序简化后就变成如下形式:

g:

pushl   %ebp
movl    %esp, %ebp
movl    8(%ebp), %eax
addl    $20, %eax
popl    %ebp
ret 

f:

pushl   %ebp
movl    %esp, %ebp
subl    $4, %esp
movl    8(%ebp), %eax
movl    %eax, (%esp)
call    g   
leave
ret 

main:

pushl   %ebp           
movl    %esp, %ebp
subl    $4, %esp
movl    $10, (%esp)
call    f   
addl    $30, %eax

分析如下图:

JYisZfi.jpg
rl8sDuI.png

Eip寄存器 从这条指令执行完自动执行下有一条指令

Ebp寄存器 总是指向堆栈的栈底 概念的是相对的,跳出该函数进入其他函数堆栈有其相应的栈底

Esp寄存器 总是指向堆栈的栈顶

Eax寄存器 函数的返回值默认使用该寄存器存储返回给上一级函数

分析如下:

程序从main函数开始运行,因为之前还有别的代码运行,所以把当前ebp进行压栈,之后指针向下一个字节,相当于在下个字节内填充数据,之后调用f函数,而当前eip指向call f的下一条指令(eip在进行call f指令后压栈,下回跳转到eip继续执行)。那么对于即将要执行的f函数来说首先要将当前ebp压栈,那么和main函数类似,指针下移一个字节,把10放进寄存器eax中,再把寄存器eax给esp,当前eip指向call g的下一条指令(当前eip在进行call g指令后压栈),之后调用g函数,同样先将ebp压栈,之后esp,ebp指向同一个位置,之后ebp指针向上移动两个字节把当前字节内内容放到eax寄存器中,将eax储存的数加20后出栈,返回到f函数的leave命令,撤销函数堆栈后返回到main函数的leave命令,将eax的当前值30加30,之后撤销函数堆栈,返回程序运行值。

转载于:https://www.cnblogs.com/yl-930/p/7638587.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/391180.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python:单例模式--使用__new__(cls)实现

单例模式:即一个类有且仅有一个实例。 那么通过python怎么实现一个类只能有一个实例呢。 class Earth:"""假如你是神,你可以创造地球"""print 欢迎来到地球# 生成一个地球 a Earth() print id(a)# 再生成一个地球 b Ear…

重学TCP协议(5) 自连接

1.自连接是什么 在发起连接时,TCP/IP的协议栈会先选择source IP和source port,在没有显示调用bind()的情况下,source IP由路由表确定,source port由TCP/IP协议栈从local port range中选取尚未使用的port。 如果destination IP正…

Gradle复制文件/目录方法

2019独角兽企业重金招聘Python工程师标准>>> gradle复制文件/文件夹方法 复制文件 //复制IDE生成的classes.jar文件到build/libs中,并改名为FileUtils.jar. task copyFile(type:Copy) {delete build/libs/FileUtils.jarfrom(build/intermediates/bundles…

用户参与度与活跃度的区别_用户参与度突然下降

用户参与度与活跃度的区别disclaimer: I don’t work for Yammer, this is a public data case study, I’ve written it in a narrative format to make this case study more engaging to read.免责声明:我不为Yammer工作,这是一个公共数据案例研究&am…

python:__new__()与__init__()

参考:https://blog.csdn.net/qq_41020281/article/details/79638370 转载于:https://www.cnblogs.com/gcgc/p/11585599.html

重学TCP协议(6) 四次挥手

1. 四次挥手 客户端进程发出连接释放报文,并且停止发送数据。释放数据报文首部,FIN1,其序列号为sequ(等于前面已经传送过来的数据的最后一个字节的序号加1),此时,客户端进入FIN-WAIT-1&#xff…

mysql数据库部分操作指令

用cmd开启服务时拒绝访问. 原因:不是管理员用户,没有权限 将服务中的 MySQL设置为手动启动, 否则 开机自动启动. 启动mysql服务,用管理员权限打开dos界面 windowsX A 打开开始界面 点击管理员开启cmd 启动服务:net start …

推箱子2-向右推!_保持冷静并砍箱子-哔

推箱子2-向右推!Hack The Box (HTB) is an online platform allowing you to test your penetration testing skills. It contains several challenges that are constantly updated. Some of them simulating real world scenarios and some of them leaning more towards a C…

UML建模图实战笔记

一、前言 UML:Unified Modeling Language(统一建模语言),使用UML进行建模的作用有哪些: 可以更好的理解问题可以及早的发现错误或者被遗漏的点可以更加方便的进行组员之间的沟通支持面向对象软件开发建模,可…

数据草拟:使您的团队热爱数据的研讨会

Learn the rules to Data Draw Up; a fun way to get your teams invested in data.了解数据收集的规则; 一种让您的团队投入数据的有趣方式。 Let’s keep things short. Metrics are one of the most important things in Product Management. They help us to u…

python:列表推导式

python中有种独特的语法:推导式,可以将代码压缩到1行,但是不使用也不影响。 有三种:列表、字典、集合(注意没有元组推导式) 列表推导式 # 1、一行代码实现1—100之和(知识点:列表推导式) print(…

WPF中删除打开过的图片

WPF中删除打开过的图片 原文:WPF中删除打开过的图片在WPF中,当我们删除打开过的图片时,往往会遇到"...无法删除,文件正在被另一个进程使用"的异常。即使当前文件是打开后关闭过的也不行。 这个问题的原因很简单,是因为W…

深入理解InnoDB(5)-文件系统

1. 数据库和文件系统的关系 像 InnoDB 、 MyISAM 这样的存储引擎都是把表存储在文件系统上的。当我们想读取数据的时候,这些存储引擎会从文件系统中把数据读出来返回给我们,当我们想写入数据的时候,这些存储引擎会把这些数据又写回文件系统。…

vim捐赠_#PayItBackwards-一位freeCodeCamp毕业生如何向事业捐赠10,000美元

vim捐赠On Monday my phone suddenly started buzzing. Shawn Wang, AKA Swyx, had just tweeted about a donation hed made to freeCodeCamp.org.星期一,我的电话突然开始嗡嗡作响。 Awn Swyx的Shawn Wang刚刚在推特上发布了他对freeCodeCamp.org的捐款。 I glan…

Digital River拉来Netconcepts站台 亚太营销服务升级

它是大洋彼岸的一家网络软件下载、分销商,很多重量级的软件行业领军企业都是其客户,它一直低调摸索亚太营销的路子,在今年九月份,它一改常态,高调宣布入华,三个月后,它带来了最新消息&#xff1…

按下按钮_按下

按下按钮Updated with the latest data: 23/8/2020更新最新数据:23/8/2020 As restrictions are lifted for Laois and Offaly, difficult times are set to continue for the people of Kildare, at least for another couple of weeks, as they continue to fight…

windows中怎么添加定时任务

linux中有crontab定时任务,很方便 其实windows也有类似的 需求:定时执行python脚本 1、Windows键R,调出此窗口,输入compmgmt.msc 2、 转载于:https://www.cnblogs.com/gcgc/p/11594467.html

css设置黑体宋体等(转)

代码如下: .selector{ font-family:"Microsoft YaHei",微软雅黑,"MicrosoftJhengHei",华文细黑,STHeiti,MingLiu } 说明: 加上中文名“微软雅黑”是为了兼容opera。 MicrosoftJhengHei为微软正黑体,STHeiti为华文黑体,Mi…

重学TCP协议(7) Timestamps 选项

1.Timestamps 选项的组成部分 时间戳选项占10个字节 kind(1字节) + length(1字节) info (8字节),其中kind8,length10,info由timestamp(TS value)和timestamp echo(TS Echo Reply)两…

sudoku代码_首席执行官可以编码吗? 在星期六晚上坐在酒吧时,从头开始观看Netlify首席执行官的Sudoku应用程序代码

sudoku代码Netlify CEO Matt Biilmann live-codes a Sudoku app using Netlify in this tutorial video. Matt shows how simple and quick it can be to create a working app using the JAMstack.在本教程视频中,Netlify CEO Matt Biilmann使用Netlify对Sudoku应用…