社区
汇编语言
帖子详情
如何区分JMP指令是一般的短跳转还是函数调用
star19678051
2011-05-04 05:01:40
如何编程实现区分出JMP指令是一般的短跳转还是函数的调用?
大致说明一下方法或者有什么特点即可,多谢高人们
...全文
317
14
打赏
收藏
如何区分JMP指令是一般的短跳转还是函数调用
如何编程实现区分出JMP指令是一般的短跳转还是函数的调用? 大致说明一下方法或者有什么特点即可,多谢高人们
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
14 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
GAOSHENGWEI
2011-05-12
打赏
举报
回复
若是函数调用一般都用call指令,jmp一般只用作跳转,否则,跳回来多麻烦。
xtdumpling
2011-05-12
打赏
举报
回复
纯靠软件反汇编不容易看出来,
迷惑的地方你可以单步试试看就知道了
mjznet
2011-05-08
打赏
举报
回复
哥们儿,我在一楼回复的你明白吗? 下面给你个例子,你看看吧,应该不需要再做更说明了:
1) call A
2) push 0
jmp A
3) push 0
push A
ret
A: pop eax
琢磨鸟
2011-05-06
打赏
举报
回复
那这就不能单纯的看JMP,而必须把眼光放宽,根据上下文来判断了。
star19678051
2011-05-06
打赏
举报
回复
我也知道函数调用前多数会有PUSH指令,但现在问题是我必须也能识别出那些通过间接跳转去调用的函数,因为如果不识别出来,会影响整个反编译的流程,因为流程是按程序顺序一条一条反汇编出来,所以如果不识别出会导致指令的地址错乱... ...说到自己都糊涂了,不知各位仁兄是否看明白
琢磨鸟
2011-05-05
打赏
举报
回复
你完全可以把所有的Call都自己用push jmp等等的指令自己模拟出来
琢磨鸟
2011-05-05
打赏
举报
回复
[Quote=引用 4 楼 star19678051 的回复:]
引用 3 楼 fuchen_1989 的回复:
函数调用要保护返回地址,而返回时要恢复堆栈(即pop返回地址)。
所以,是函数调用的话,在需要有push ip(段内调用) 或push ip;push cs(段间调用) 或者32位汇编中push eip这些个指令,用来保护返回地址。而返回时又需要相应的pop指令返回到调用程序处继续执行。
而jmp指令一般没有
那可不一定哦!就像调用一些……
[/Quote]
所以它的前两个JMP不是函数调用了嘛。
天外来客-007
2011-05-05
打赏
举报
回复
函数调用的特性就是调用前的原来寄存器数据的入栈和调用结束后数据的出栈,从这点出发,或许有解决思路!
琢磨鸟
2011-05-05
打赏
举报
回复
函数调用要保护返回地址,而返回时要恢复堆栈(即pop返回地址)。
所以,是函数调用的话,在需要有push ip(段内调用) 或push ip;push cs(段间调用) 或者32位汇编中push eip这些个指令,用来保护返回地址。而返回时又需要相应的pop指令返回到调用程序处继续执行。
而jmp指令一般没有
lr2131
2011-05-05
打赏
举报
回复
王爽<汇编语言>第二版 提到过,call指令是CPU专门提供的函数调用的指令,但用push和jmp指令的组合,自己操作堆栈也是可以实现call指令的效果的。一般来说jmp指令是做转移的,除非写这个代码的人想自己用jmp和push来替代call。不过有上面一条的话,还是看看在jmp之前是否有push的相关操作,实现了函数调用类似的功能。
Lactoferrin
2011-05-05
打赏
举报
回复
函数调用一般用call,那个JMP [XXXX]只是一个间接跳转,ida能够通过分析导入表确定JMP [XXXX]去的是不是导入函数
star19678051
2011-05-05
打赏
举报
回复
[Quote=引用 3 楼 fuchen_1989 的回复:]
函数调用要保护返回地址,而返回时要恢复堆栈(即pop返回地址)。
所以,是函数调用的话,在需要有push ip(段内调用) 或push ip;push cs(段间调用) 或者32位汇编中push eip这些个指令,用来保护返回地址。而返回时又需要相应的pop指令返回到调用程序处继续执行。
而jmp指令一般没有
[/Quote]
那可不一定哦!就像调用一些导入函数,先JMP XXXXXX ,然后XXXX中是是通过一句JMP [XXXX],去调用导入函数,IDA就是把XXXX也识别成一个函数... ...
mengtao1235
2011-05-04
打赏
举报
回复
一般在调用函数之前都 要用push传递参数吧。
mjznet
2011-05-04
打赏
举报
回复
无法区分,除非:
1. 有特定的语句序列;
2. 有 call 指令也调用了这个地址,不过,你能确定call过来,这就一定是函数吗?也很难
JMP
指令
也可能是
函数调用
,二进制实时
函数调用
检测
由于call
指令
是
函数调用
的其中一种表现形式,且容易检测,所以本文的主要工作其实识别哪些
JMP
指令
实际上是
函数调用
的问题。该工作仅面向编译器生成的代码,不考虑多入口、函数交错(手写汇编才会出现);要求返回...
【Android 逆向】x86 汇编 ( call 子
函数调用
指令
|
jmp
跳转
指令
| lea 加载
指令
| mov 数据传送
指令
)
一、call 子
函数调用
指令
、 二、
jmp
跳转
指令
、 三、lea 加载
指令
、 四、mov 数据传送
指令
、 总结、
逆向入门(5)汇编篇-函数相关学习与JCC
指令
此时就会出现一个问题,当通过
JMP
调用了
指令
后,无法再次回到使用
JMP
指令
的地方,解决的话可以在函数中再次使用
JMP
指令
跳转
回来。 但是这样做同样也会出现问题,回想函数的定义,重复使用的特定功能,那么下次再...
函数调用
时call
指令
和ret
指令
函数调用
一般是通过call
指令
和ret
指令
相互配合使用来实现的,当函数运行到call
指令
时,call
指令
会做两件事:1,将当前的ip压入栈中;2,
跳转
到call
指令
后被调用的函数。 当被调用函数运行完毕之后,通过ret
指令
返回...
第39部分-Linux x86 64位汇编
跳转
/调用/中断/循环
第39部分-Linux x86 64位汇编
跳转
/调用/中断/循环
跳转
JMP
指令
把
指令
指针的值改变为
JMP
指令
中指定的内存位置。 单一汇编
跳转
指令
被汇编为
跳转
操作码的3种不同类型之一。
短
跳转
近
跳转
远
跳转
由当前
指令
的...
汇编语言
21,459
社区成员
41,600
社区内容
发帖
与我相关
我的任务
汇编语言
汇编语言(Assembly Language)是任何一种用于电子计算机、微处理器、微控制器或其他可编程器件的低级语言,亦称为符号语言。
复制链接
扫一扫
分享
社区描述
汇编语言(Assembly Language)是任何一种用于电子计算机、微处理器、微控制器或其他可编程器件的低级语言,亦称为符号语言。
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章