PC逆向之代码还原技术,第三讲汇编中加法的代码还原
PC逆向之代码还原技术,第三讲汇编中加法的代码还原
一丶汇编简介
在讲解加法的代码还原之前.我们首先要知道. 加法在汇编中对应的指令是什么.
Add 汇编指令. Add x,y 将x的值 加上y 并且重新赋值给x
二丶高级代码对应汇编观看.
观看如下代码
int main(int argc, char* argv[])
{
1 + 2;
int nValue = 10 + 2; //常量 + 常量
int nVar = nValue + 10; //变量 + 常量
int nVar3 = nValue + nVar; //变量 + 变量
return 0;
}
有四种方式
第一种 直接 空语句 1 + 2 ;
第二种 常量 + 常量
第三种 变量 + 常量
第四种 变量 + 变量
1.代码还原解析:
代码还原解析需要了解的知识:
reg: 代表任意通用寄存器
imm: 立即数,可以看做常量
? : 代表任意数值.可以 [ebp -?]可以确定那个变量,变量是在栈中存放的.
第一种方式
此语句并不会产生作用.所以不会产生对应的汇编代码.第二种方式
常量 + 常量 会在编译的时候直接进行优化. 如上面代码 10 + 2 产生的对应汇编代码为
mov [ebp - ?],0xC
- 第三种方式:
第三种方式是变量+ 常量. 在汇编中.变量 + 常量并不能直接操作.需要交给寄存器进行中转
所以会产生如下表达式
mov reg,[ebp - ?]
add reg,imm
mov [ebp - ?],reg
上面代码对应:
.text:0040126F mov eax, [ebp+ - 4]
.text:00401272 add eax, 0Ah
.text:00401275 mov [ebp - 4], eax
- 第四种方式
第四种方式 变量+变量
变量 + 变量 不用想,肯定是交给寄存器中转.
产生代码定式:
mov reg,[ebp - ?]
add reg,[ebp - ?]
mov [ebp - ?],reg
上面代码产生的汇编代码.IDA中查看.
.text:00401278 mov ecx, [ebp+var_4]
.text:0040127B add ecx, [ebp+var_8]
.text:0040127E mov [ebp+var_C], ecx
三丶根据上图完整汇编代码进行还原总结
text:00401250 _main_0 proc near ; CODE XREF: _main↑j
.text:00401250
.text:00401250 var_4C = byte ptr -4Ch
.text:00401250 var_C = dword ptr -0Ch
.text:00401250 var_8 = dword ptr -8
.text:00401250 var_4 = dword ptr -4
.text:00401268 mov [ebp+var_4], 0Ch 常量赋值给变量
.text:0040126F mov eax, [ebp+var_4] 三句代码可以看成一句
.text:00401272 add eax, 0Ah 变量 + 常量
.text:00401275 mov [ebp+var_8], eax
.text:00401278 mov ecx, [ebp+var_4] 三句代码可以看成一句
.text:0040127B add ecx, [ebp+var_8] 变量 + 变量 结果给变量
.text:0040127E mov [ebp+var_C], ecx
.text:00401289 _main_0 endp
.text:00401289
总结
根据上面加法的代码以及汇编对应的代码.我们可以产生代码定式
常量 + 常量 常量直接进行优化.不会产生汇编代码.如果赋值给变量则产生汇编代码
mov [ebp - ?],imm
常量 + 变量 赋值给变量 会产生汇编代码.此时我们心中要知道.如果操作变量相加.则肯定需要寄存器
中转.所以会产生汇编代码
mov reg,[ebp - ?]
add reg,imm
mov [ebp - ?] reg
变量 + 变量 赋值给变量 操作了变量.那么心中自然知道.会操作寄存器. 而汇编允许寄存器+栈中的值
所以可以产生代码定式
mov reg,[ebp - 4] 变量1
add reg,[ebp - 8] 变量2
mov [ebp - c],reg 变量3
三个代码可以看成 变量 + 变量 赋值给了变量
注意:上面为Debug版本下产生的代码定式. 在Releas下会进行优化.
在Releas下我们上面的代码会直接优化,没有产生任何汇编代码.
原因是: 常量传播 窥孔优化 常量折叠. 因为上面代码我们并没有用. 无意义的代码.所以不断进行优化就会优化没有.
可以参考本人编写的详细博客: 博客链接
PC逆向之代码还原技术,第三讲汇编中加法的代码还原的更多相关文章
- PC逆向之代码还原技术,第五讲汇编中乘法的代码还原
目录 PC逆向之代码还原技术,第五讲汇编中乘法的代码还原 一丶简介乘法指令 1.乘法指令 2.代码还原注意问题 二丶乘法的汇编代码产生的格式 1.高级代码观看 2.乘法的汇编代码还原. 三丶乘法总结 ...
- 好代码是管出来的——.Net中的代码规范工具及使用
上一篇文章介绍了编码标准中一些常用的工具,本篇就具体来介绍如何使用它们来完成代码管理. 本文主要内容有: Roslyn简介 开发基于Roslyn的代码分析器 常用的基于Roslyn的代码分析器 在.N ...
- PC逆向之代码还原技术,第六讲汇编中除法代码还原以及原理第二讲,被除数是正数 除数非2的幂
目录 一丶简介 二丶代码还原讲解 1.被除数无符号 除数非2的幂 2.被除数无符号 除数为特例7 三丶代码还原总结 一丶简介 上一篇博客说的除2的幂. 如果被除数是有符号的,那么会进行调整,并使用位操 ...
- 【图片+代码】:GCC 链接过程中的【重定位】过程分析
作 者:道哥,10+年嵌入式开发老兵,专注于:C/C++.嵌入式.Linux. 关注下方公众号,回复[书籍],获取 Linux.嵌入式领域经典书籍:回复[PDF],获取所有原创文章( PDF 格式). ...
- git 一般的开发流程中的代码管理
一般的开发流程中的代码管理 1. 从版本库中下载代码 git clone ssh://wenbin@192.168.1.3:29418/mustang-web 2. 针对某个feature(比如ins ...
- Net中的代码规范工具及使用
Net中的代码规范工具及使用 https://www.cnblogs.com/selimsong/p/9209254.html 上一篇文章介绍了编码标准中一些常用的工具,本篇就具体来介绍如何使用它们来 ...
- PC逆向之代码还原技术,第四讲汇编中减法的代码还原
目录 PC逆向之代码还原技术,第四讲汇编中减法的代码还原 一丶汇编简介 二丶高级代码对应汇编观看. 1.代码还原解析: 三丶根据高级代码IDA反汇编的完整代码 四丶知识总结 PC逆向之代码还原技术,第 ...
- PC逆向之代码还原技术,第二讲寻找程序入口点
PC逆向之代码还原技术,第二讲寻找程序入口点 一丶简介 程序逆向的时候.我们需要知道程序入口点.动态分析的时候以便于看是什么程序编写的. 比如VC++6.0 我们可以写一个程序测试一下 我们写一段代码 ...
- PC逆向之代码还原技术,第一讲基本数据类型在内存中的表现形式.浮点,指针寻址公式
目录 代码还原技术 一丶简介代码还原 二丶代码还原中的数据类型表现形式 1.整数类型 2.无符号整数 3.有符号整数 4.浮点数数据类型 5.浮点编码 4.Double类型解析. 三丶浮点汇编 1.浮 ...
随机推荐
- Bphero-UWB 基站0 和 电脑串口数据格式定义
基站0 通过串口将系统中测得的距离信息发送到电脑,电脑定位软件通过三边定位算法计算出TAG的坐标,基站0 和 定位软件之间的数据格式定义如下(对官方数据结构进行了简化) 更多UWB定位信息请参阅论坛b ...
- 20181117-python第二章学习小结-part1
什么是二进制,十进制如何转化成二进制. 在python上可使用简单的函数进行转化,bin() 数据量的基本关系: 1bit 就是0/1的一个单位 1bytes = 8bit #1个字节,就是一 ...
- 理解JavaScript【转】
第一题 if (!("a" in window)) { var a = 1; } alert(a); 第二题 var a = 1, b = function a(x ...
- win10 音频设备图形隔离 占用CPU
这几天工作很烦!每次上班开机我的电脑就超级卡,自我感觉i7处理器加上8g内存应该杠杠的,打开任务管理器发现就不对了, 有“windows 音频设备图形隔离 ”这个进程吃了我20%的cpu,电脑的风扇也 ...
- 快速幂 ,快速幂优化,矩形快速幂(java)
快速幂形式 public static int f(int a,int b,int c){ int ans =1; int base=a; while(b!=0){ if((b&1)!=0) ...
- IOS开发中将定时器添加到runLoop中
runLoop主要就是为线程而生的.他能够让线程在有任务的时候保持工作状态,没有任务的时候让线程处于休眠待备状态. 主线程的runloop默认是开启的.主线程上创建的定时器已经默认添加到runLoop ...
- webpack2入门概念
webpack是一种JavaScript应用模块化打包工具,它配置起来简单易上手,因此很多企业工程化代码都使用它来打包.在具体介绍如何使用webpack之前,先来介绍下webpack的四个核心概念. ...
- [LeetCode] Lemonade Change 买柠檬找零
At a lemonade stand, each lemonade costs $5. Customers are standing in a queue to buy from you, and ...
- 文件访问时间简记(Modify time 和 Change time)
[root@77-29-68-bx-core]# stat hql.out File: 'hql.out' Size: 13750 Blocks: 32 IO Block: 4096 regular ...
- C语言常用的编程规范
1排版 1-1相对独立的程序块之间.变量说明之后必须加空行. 示例:如下例子不符合规范. if (!valid_ni(ni)) { ... // program code } repssn_ind = ...