看TheShellcoderbook不明白之处,求解释

jimette 2013-06-26 11:20:15
0x8048430 <triangle>: push %ebp
0x8048431 <triangle + 1>: mov %esp, %ebp
0x8048433 <triangle + 3>: push %edi
0x8048434 <triangle + 4>: push %esi
0x8048435 <triangle + 5>: sub $0x30, %esp

0x8048438 <triangle + 8>: lea 0xffffffd8(%ebp), %edi //这一句
0x804843b <triangle + 11>: mov $0x8049508, %esi //这一句

0x8048440 <triangle + 16>: cld
0x8048441 <triangle + 17>: mov $0x30, %esp
0x8048446 <triangle + 22>: repz movsl %ds:(%esi), %es:(%edi)
0x8048448 <triangle + 24>: mov 0x8(%ebp), %eax
0x804844b <triangle + 27>: mov %eax, %edx
0x804844d <triangle + 29>: imul 0xc(%ebp), %edx
0x8048451 <triangle + 33>: mov %edx, %eax

0x8048453 <triangle + 35>: sar $0x1f, %eax//这一句
0x8048456 <triangle + 38>: shr $0x1f, %eax//这一句
0x8048459 <triangle + 41>: lea (%eax, %edx,1), %eax//这一句
0x804845c <triangle + 44>: sar %eax//这一句
0x804845e <triangle + 46>: mov %eax, oxffffffd4(%ebp)//这一句
0x8048461 <triangle + 49>: mov 0xffffffd4(%ebp), %eax//这一句
0x8048464 <triangle + 52>: mov %eax, %eax//这一句

0x8048466 <triangle + 54>: add $0x30, %esp
0x8048469 <triangle + 57>: pop %esi
0x804846a <triangle + 58>: pop %edi
0x804846b <triangle + 59>: pop %ebp
0x804846c <triangle + 60>: ret

在 vs2010反汇编没这么复杂

求i解释
...全文
498 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
jimette 2013-08-09
  • 打赏
  • 举报
回复
jimette 2013-07-17
  • 打赏
  • 举报
回复
www_adintr_com 2013-06-27
  • 打赏
  • 举报
回复
这是 at&t 风格的汇编,unix 下一般用这种 lea 0xffffffd8(%ebp), %edi 等价于 mov edi,[ebp-自己转补码算] 0x804843b <triangle + 11>: mov $0x8049508, %esi 这一句很简单呀 mov esi, 0x8049508 0x8048453 <triangle + 35>: sar $0x1f, %eax//这一句 0x8048456 <triangle + 38>: shr $0x1f, %eax//这一句 0x8048459 <triangle + 41>: lea (%eax, %edx,1), %eax//这一句 0x804845c <triangle + 44>: sar %eax//这一句 0x804845e <triangle + 46>: mov %eax, oxffffffd4(%ebp)//这一句 0x8048461 <triangle + 49>: mov 0xffffffd4(%ebp), %eax//这一句 0x8048464 <triangle + 52>: mov %eax, %eax//这一句 依次翻译为: sar eax, 1fh shr eax, 1fh lea eax, [eax + edx * 1] sar eax mov eax,[ebp - 自己算] mov [ebp - 自己算], eax mov eax,eax
www_adintr_com 2013-06-27
  • 打赏
  • 举报
回复
看不懂, 似乎没什么作用, 全是空操作, 它是不是想在代码段构造出特定的数据来哦, 看看这些代码对应的机器码有没有什么含义呢
jimette 2013-06-27
  • 打赏
  • 举报
回复
0x8048459 <triangle + 41>: lea (%eax, %edx,1), %eax//这一句 0x804845c <triangle + 44>: sar %eax//这一句 0x804845e <triangle + 46>: mov %eax, oxffffffd4(%ebp)//这一句 0x8048461 <triangle + 49>: mov 0xffffffd4(%ebp), %eax//这一句 0x8048464 <triangle + 52>: mov %eax, %eax//这一句 这几句是用来做什么的?
jimette 2013-06-27
  • 打赏
  • 举报
回复
sar $0x1f, %eax shr $0x1f, %eax 为什么右移两次31bit?
jimette 2013-06-27
  • 打赏
  • 举报
回复
引用 1 楼 adlay 的回复:
这是 at&t 风格的汇编,unix 下一般用这种 lea 0xffffffd8(%ebp), %edi 等价于 mov edi,[ebp-自己转补码算] 0x804843b <triangle + 11>: mov $0x8049508, %esi 这一句很简单呀 mov esi, 0x8049508 0x8048453 <triangle + 35>: sar $0x1f, %eax//这一句 0x8048456 <triangle + 38>: shr $0x1f, %eax//这一句 0x8048459 <triangle + 41>: lea (%eax, %edx,1), %eax//这一句 0x804845c <triangle + 44>: sar %eax//这一句 0x804845e <triangle + 46>: mov %eax, oxffffffd4(%ebp)//这一句 0x8048461 <triangle + 49>: mov 0xffffffd4(%ebp), %eax//这一句 0x8048464 <triangle + 52>: mov %eax, %eax//这一句 依次翻译为: sar eax, 1fh shr eax, 1fh lea eax, [eax + edx * 1] sar eax mov eax,[ebp - 自己算] mov [ebp - 自己算], eax mov eax,eax
大牛,字面意思我懂 只不过不知道那几句的作用
基于扩展(EKF)和无迹卡尔曼滤波(UKF)的电力系统动态状态估计(Matlab代码实现)内容概要:本文档围绕基于扩展卡尔曼滤波(EKF)和无迹卡尔曼滤波(UKF)的电力系统动态状态估计展开,提供了完整的Matlab代码实现方案。重点介绍如何利用EKF与UKF算法对电力系统中的动态状态进行高精度估计,尤其适用于存在非线性特性和测量噪声的实际场景。文中详细阐述了两种滤波方法的理论基础、适用条件及在电力系统中的具体应用流程,并通过仿真验证其有效性。此外,文档还整合了多个相关科研方向的技术资源,涵盖智能优化算法、机器学习、信号处理、路径规划、电力系统优化等多个领域,突出Matlab在科研仿真中的广泛应用。; 适合人群:具备一定电力系统基础知识和Matlab编程能力的研究生、科研人员及工程技术人员,尤其适合从事电力系统状态估计、动态建模与仿真研究的相关从业者;; 使用场景及目标:①掌握EKF与UKF在非线性系统状态估计中的实现原理与差异;②应用于含新能源接入的复杂电力系统动态状态估计;③为科研项目、论文复现或算法优化提供可运行的代码基础和技术参考;; 其他说明:文档内容高度聚焦科研实用价值,强调“借力”于成熟算法与工具提升研究效率,建议结合提供的网盘资源(含YALMIP等工具包)进行代码调试与扩展应用,同时按目录顺序系统学习以避免理解断层。

21,498

社区成员

发帖
与我相关
我的任务
社区描述
汇编语言(Assembly Language)是任何一种用于电子计算机、微处理器、微控制器或其他可编程器件的低级语言,亦称为符号语言。
社区管理员
  • 汇编语言
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧