社区
汇编语言
帖子详情
如何区分JMP指令是一般的短跳转还是函数调用
star19678051
2011-05-04 05:01:40
如何编程实现区分出JMP指令是一般的短跳转还是函数的调用?
大致说明一下方法或者有什么特点即可,多谢高人们
...全文
329
14
打赏
收藏
如何区分JMP指令是一般的短跳转还是函数调用
如何编程实现区分出JMP指令是一般的短跳转还是函数的调用? 大致说明一下方法或者有什么特点即可,多谢高人们
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用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
指令
也可能是
函数调用
,二进制实时
函数调用
检测
Now You See Me: Real-time Dynamic Function Call Detection Remarks Conference: ACSAC 2018 Full Paper: https://syssec.mistakenot.net/papers/acsac18.pdf Artifact: https://github.com/Frky/iCi Summary 作者...
【Android 逆向】x86 汇编 ( call 子
函数调用
指令
|
jmp
跳转
指令
| lea 加载
指令
| mov 数据传送
指令
)
一、call 子
函数调用
指令
、 二、
jmp
跳转
指令
、 三、lea 加载
指令
、 四、mov 数据传送
指令
、 总结、
JMP
跳转
指令
的
指令
长度、直接转移与间接转移、段内
跳转
与段间
跳转
原文链接:https://blog.csdn.net/liuchuo/article/details/51990669
指令
长度=操作码的长度+操作数地址的长度1.段内
跳转
JMP
指令
占1个字节。操作数的地址长度 = (目标地址-
指令
当前地址)//若能用1个字节表示,则占用1个字节,那么整体
指令
长度为2个字节;若需2个字节表示,则占用2个字节,此时整体
指令
为3个字节。比...
逆向入门(5)汇编篇-函数相关学习与JCC
指令
0x01 函数 汇编眼中的函数,函数就是一系列
指令
的集合,为了完成某个会重复使用的特定功能。 可以使用
JMP
指令
或者CALL
指令
来进行调用函数,先看
JMP
指令
。
JMP
指令
调用函数 假设定义一个函数功能为将eax,ecx的值赋值为0,假设使用
JMP
来进行调用 此时就会出现一个问题,当通过
JMP
调用了
指令
后,无法再次回到使用
JMP
指令
的地方,解决的话可以在函数中再次使用
JMP
指令
跳转
回来。 但是这样做同样也会出现问题,回想函数的定义,重复使用的特定功能,那么下次再进行函数时,仍然会回到首次定义的
JMP
地方
第39部分-Linux x86 64位汇编
跳转
/调用/中断/循环
第39部分-Linux x86 64位汇编
跳转
/调用/中断/循环
跳转
JMP
指令
把
指令
指针的值改变为
JMP
指令
中指定的内存位置。 单一汇编
跳转
指令
被汇编为
跳转
操作码的3种不同类型之一。
短
跳转
近
跳转
远
跳转
由当前
指令
的内存位置和目的点的内存位置之间的距离决定的。 依据跳过的字节数目决定使用哪种
跳转
类型。 当偏移量小于128字节时候,用
短
跳转
。 在分段内存模式下,当
跳转
到另一个段中的
指令
时使用元
跳转
。 近
跳转
用于所有其他
跳转
。 使用汇编语言助记符
指令
时,不需要担心
跳转
的长度,单
汇编语言
21,497
社区成员
41,618
社区内容
发帖
与我相关
我的任务
汇编语言
汇编语言(Assembly Language)是任何一种用于电子计算机、微处理器、微控制器或其他可编程器件的低级语言,亦称为符号语言。
复制链接
扫一扫
分享
社区描述
汇编语言(Assembly Language)是任何一种用于电子计算机、微处理器、微控制器或其他可编程器件的低级语言,亦称为符号语言。
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章