首页
社区
课程
招聘
[求助]请问这是哪种传参方式?非寄存器非push
发表于: 2022-10-29 22:44 6862

[求助]请问这是哪种传参方式?非寄存器非push

2022-10-29 22:44
6862

逆向时发现一种非常另类的传参方式,用C++测试了所有函数调用约定都无法实现图中的结果,通常来说传参都是压栈或特定寄存器,而这个是直接修改esp再对栈进行修改,求解答疑惑。
图片描述


[招生]科锐逆向工程师培训(2024年11月15日实地,远程教学同时开班, 第51期)

收藏
免费 0
支持
分享
最新回复 (5)
雪    币: 5734
活跃值: (1737)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
2
stdcall 大概看了一下 栈上11个参数
2022-10-30 03:47
0
雪    币: 2341
活跃值: (722)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
3
参数特别多的时候不会一个个push吧
2022-10-30 09:20
0
雪    币: 3545
活跃值: (4679)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
4
就是stdcall 但是GCC会编译成这样 甚至寄存器传参 微软32位系统内核也会这样优化
2022-10-30 11:51
0
雪    币: 1541
活跃值: (1613)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
5
有可能这个函数的参数有一个比较大的结构体
2022-10-30 16:48
0
雪    币: 6106
活跃值: (2573)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
6
好像是thiscall 3个参数+ecx
2022-10-31 08:10
0
游客
登录 | 注册 方可回帖
返回
//