csapp-linklab之第二阶段“输出学号”实验报告

本阶段主题是链接中的“重定位”。两次重定位,一次是绝对地址重定位,一次是PC相对地址重定位。

本题目标依旧是输出学号,反汇编phase2.o,看到学号“0000000000”已经存放在只读数据区了。现在任务就是改do_pheas的指令和重定位表(.rel.test)的内容。

step1 仿照phase1的代码,先写出指令的框架

00000030 <do_phase>:30:	55                   	push   %ebp31:	89 e5                	mov    %esp,%ebp33:	83 ec 08             	sub    $0x8,%esp36:	b8 xx xx xx xx       	mov    xxxxxxxx,%eax3b:	83 ec 0c             	sub    $0xc,%esp3e:	50                   	push   %eax3f:	e8 xx xx xx xx       	call   xxxxxxxx44:	83 c4 10             	add    $0x10,%esp47:	90                   	nop48:	c9                   	leave  49:	c3                   	ret    4a:	90                   	nop4b:	90                   	nop4c:	90                   	nop4d:	90                   	nop4e:	90                   	nop4f:	90                   	nop50:	90                   	nop51:	90                   	nop52:	90                   	nop53:	90                   	nop54:	5d                   	pop    %ebp55:	c3                   	ret    

两个都是x的地方就是接下来要改的地方。

step2 判断是绝对地址重定位还是PC相对地址重定位

有两种办法.

办法一:参考phase1链接后的可执行文件的机器代码

0804845d <do_phase>:804845d:	55                   	push   %ebp804845e:	89 e5                	mov    %esp,%ebp8048460:	83 ec 08             	sub    $0x8,%esp8048463:	b8 61 a0 04 08       	mov    $0x804a061,%eax8048468:	83 ec 0c             	sub    $0xc,%esp804846b:	50                   	push   %eax804846c:	e8 7f fe ff ff       	call   80482f0 <puts@plt>8048471:	83 c4 10             	add    $0x10,%esp8048474:	90                   	nop8048475:	c9                   	leave  8048476:	c3                   	ret    8048477:	66 90                	xchg   %ax,%ax8048479:	66 90                	xchg   %ax,%ax804847b:	66 90                	xchg   %ax,%ax804847d:	66 90                	xchg   %ax,%ax804847f:	90                   	nop

如上,ax那里是绝对地址,call那里用的e8,就是PC相对

办法二:看phase2.o的重定位节,命令为readelf -r phase2.o

类型那一列直接写明了。

step3 改重定位表

找出框架,eax那行需要重定位的地方的字节是37,call那是40,则用hexedit编辑phase2.o,改重定位表。

00000030 <do_phase>:30:	55                   	push   %ebp31:	89 e5                	mov    %esp,%ebp33:	83 ec 08             	sub    $0x8,%esp36:	b8 xx xx xx xx       	mov    xxxxxxxx,%eax3b:	83 ec 0c             	sub    $0xc,%esp3e:	50                   	push   %eax3f:	e8 xx xx xx xx       	call   xxxxxxxx44:	83 c4 10             	add    $0x10,%esp47:	90                   	nop48:	c9                   	leave  49:	c3                   	ret    4a:	90                   	nop4b:	90                   	nop4c:	90                   	nop4d:	90                   	nop4e:	90                   	nop4f:	90                   	nop50:	90                   	nop51:	90                   	nop52:	90                   	nop53:	90                   	nop54:	5d                   	pop    %ebp55:	c3                   	ret    

step4 代码填完整

这一步需要了解重定位的完整过程。

00000030 <do_phase>:30:	55                   	push   %ebp31:	89 e5                	mov    %esp,%ebp33:	83 ec 08             	sub    $0x8,%esp36:	b8 00 00 00 00       	mov    xxxxxxxx,%eax3b:	83 ec 0c             	sub    $0xc,%esp3e:	50                   	push   %eax3f:	e8 fc ff ff ff      	call   xxxxxxxx44:	83 c4 10             	add    $0x10,%esp47:	90                   	nop48:	c9                   	leave  49:	c3                   	ret    4a:	90                   	nop4b:	90                   	nop4c:	90                   	nop4d:	90                   	nop4e:	90                   	nop4f:	90                   	nop50:	90                   	nop51:	90                   	nop52:	90                   	nop53:	90                   	nop54:	5d                   	pop    %ebp55:	c3                   	ret    

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

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

相关文章

题目标题:乐乐摘苹果(杨鼎强)

一天乐乐去果园玩&#xff0c;发现一棵苹果树上结出10个苹果。乐乐跑去摘苹果。乐乐找到一个30厘米高的板凳&#xff0c;当她不能直接用手摘到苹果的时候&#xff0c;就会踩到板凳上再试试。 现在已知10个苹果到地面的高度&#xff0c;以及乐乐把手伸直的时候能够达到的最大高度…

Ubuntu系统Springboot项目Nginx安装(编译安装方式)

1.下载 nginx官网下载 Index of /download/ 2.解压 这里我下载的1.25.3版本&#xff0c;系统是ubuntu 解压 tar -zxvf nginx-1.25.3.tar.gz 3.编译安装 安装前需要执行安装一些系统依赖 3.1安装PCRE库 ubuntu&#xff1a;执行以下命令 sudo apt-get install libpcre…

uniapp2023年微信小程序头像+昵称分别获取

1、DOM <view class"m-user"><view class"user-info"><!--头像 GO--><button class"avatar avatar-wrapper" open-type"chooseAvatar" chooseavatar"onChooseAvatar"slot"right"><im…

c++实现程序单例运行的两种方式

第一种使用互斥体 // 使用互斥体保证单体运行 BOOL IsAlreadyRun() {HANDLE hMutex NULL;hMutex CreateMutex(NULL, FALSE, L"MYFLAG");if (hMutex ! NULL){if (ERROR_ALREADY_EXISTS GetLastError()){ReleaseMutex(hMutex);return TRUE;}}return FALSE; } int m…

国家高新技术企业认定,可以提前准备这些!

尽早获取核心自主知识产权 对于高新技术企业认定中有Ⅰ类和Ⅱ类知识产权之分。 其中&#xff0c;企业拥有的专利、植物新品种、国家新药、软件著作权等属于Ⅰ类核心知识产权&#xff0c;是高新技术企业认定的首要和必须条件&#xff0c;在高企认定中也会给申请人带来相应较高…

获取国内城市编码API

获取国内城市编码API接口 一、获取国内城市编码接口二、使用步骤1、接口2、请求参数 三、 案例和demo 一、获取国内城市编码接口 一款免费的帮助你获取取国内城市编码的接口 二、使用步骤 1、接口 重要提示:建议使用https协议,当https协议无法使用时再尝试使用http协议 请求…

【Lidar】基于Python的Open3D库可视化点云数据

1 Open3D库介绍 1.1 介绍 Open3D是一个开源的3D数据处理库&#xff0c;发布于2015年&#xff0c;目前已经更新到0.17.0版本。它基于MIT协议开源许可&#xff0c;使用C11实现&#xff0c;并经过高度优化&#xff0c;还通过Python Pybinding提供了前端Python API。 Open3D为开发…

C语言之atoi函数的使用和模拟实现

C语言之atoi函数的使用和模拟实现 1. atoi函数介绍 函数声明如下&#xff1a; int atoi (const char * str);atoi是用来将字符串中第一次出现的数字字符&#xff0c;转为一个整数 跳过空白字符&#xff0c;&#xff08;空白字符包括&#xff1a;空格 ’ ’ &#xff0c;换页…

我叫:基数排序【JAVA】

1.自我介绍 基数排序(radix sort)属于“分配式排序” (distribution sort)&#xff0c;又称“桶子法” (bucket sort)或bin sort,它是通过键值的各个位的值,将要排序的元素分配至某些“桶”中,是‘桶排序’的扩展 2.基本思想 将所有待比较数值统一为同样的数位长度,数位较短的数…

docker start一个容器之后,怎么进入这个容器界面

要进入已经启动的 docker 容器的交互式终端&#xff0c;可以使用 docker exec 命令。这个命令可用于在运行中的容器内部执行命令或脚本&#xff0c;并以交互模式与容器进行交互&#xff0c;具体格式如下&#xff1a; # docker exec -it [container_id or container_name] /bin/…

专业的调查问卷平台推荐:提升数据收集与分析效率

无论是学生还是职场人士&#xff0c;想做好一份调查问卷&#xff0c;关键先要确定调查的主题&#xff0c;然后确定调查人群&#xff0c;编辑问题&#xff0c;最后能够尽可能的美化问卷调查的主题。 想要做到这几点&#xff0c;就要要求问卷调查平台: 1、能够帮助你快速制作出一…

【开题报告】基于模糊控制的花卉光照时间控制系统

题 目 基于模糊控制的花卉光照时间控制系统 一、研究目的和意义 用光电传感器检测自然光&#xff0c;根据花卉开花时长&#xff0c;用MATLAB软件&#xff0c;使用模糊控制算法&#xff0c;对测得数据进行分析&#xff0c;得出结论&#xff0c;并传回下位机控制电机运动…

软件测试测试文档的编写和阅读

在软件测试中的流程中&#xff0c;测试文档也是一个重要的流程&#xff0c;所以测试人员也需要学习测试文档的编写和阅读。 一、定义&#xff1a; 测试文档&#xff08;Testing Documentation&#xff09;记录和描述了整个测试流程&#xff0c;它是整个测试活动中非常重要的文…

QT应用示例

一个简单的QT应用示例&#xff1a;创建一个窗口程序。 首先&#xff0c;确保已经安装了Qt开发环境。接下来&#xff0c;按照以下步骤创建一个简单的窗口程序&#xff1a; 1. 打开Qt Creator&#xff0c;点击“新建文件或项目”。 2. 选择“应用程序”&#xff0c;然后点击“下…

年终好价节有什么必买的数码好物?值得入手的数码好物推荐

大家是不是都没听说过好价节&#xff1f;直白点说就是原来的双十二购物狂欢节&#xff0c;只不过换一个说法&#xff0c;不过今年毕竟是第一年换个说法&#xff0c;所以淘宝年终好价节优惠还是值得我们期待的&#xff01;作为年前的最后一波大促&#xff0c;一起来看看有哪些好…

QML通用属性 pyside6

在 QML 中&#xff0c;几乎所有组件都继承自 Item 类型&#xff0c;因此它们共享一些通用的属性。 QML 组件通用属性 位置和尺寸 x 和 y: 组件在其父元素中的位置坐标 Item {x: 100y: 100 }width 和 height: 组件的宽度和高度 Item {width: 200height: 100 }z: 组件在 Z 轴…

SQL server界面操作链接服务器

1.打开链接服务器&#xff0c;右击连接服务器“新建链接服务器” 2.输入链接服务器名称和数据源 3.安全性中输入密码建立远程连接&#xff0c;点击确定&#xff1a; 4.打开新建的连接服务器&#xff0c;测试连接&#xff1a; 注意:链接服务器必须在局域网执行&#xff0c;不是同…

【Openstack Train安装】十、Neutron安装

Neutron&#xff0c;是Openstack中的一大核心组件&#xff0c;设计目标是实现“网络即服务&#xff08;Networking as a Service&#xff09;”。为了达到这一目标&#xff0c;在设计上遵循了基于 SDN 实现网络虚拟化的原则&#xff0c;在实现上充分利用了 Linux 系统上的各种网…

Python简单线性回归算法实现及应用示例

简单线性回归&#xff0c;是一种使用单个特征预测响应的方法。 它是机器学习爱好者了解的最基本的机器学习模型之一。 在线性回归中&#xff0c;我们假设两个变量&#xff0c;即因变量和自变量是线性相关的。 因此&#xff0c;我们尝试找到一个线性函数&#xff0c;作为特征或自…

4.5-容器之间的link

我们在实际项目中可能会有种需求&#xff0c;假如我们有个后台项目&#xff0c;它要访问数据库&#xff0c;比如MySQL&#xff0c;它想要访问数据库&#xff0c;就需要数据库的ip和端口。如果有两个容器&#xff0c;一个容器启动的是数据库的MySQL服务&#xff0c;另一个容器启…