吾爱破解 - LCG - LSG |安卓破解|病毒分析|www.52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 926|回复: 4
收起左侧

[讨论] x64汇编调用call 堆栈问题

[复制链接]
lushihao 发表于 2023-1-5 23:36
25吾爱币
如果程序是.net是不是不能用x64汇编调用call  不管怎么写一调用就崩溃
之前也尝试调用过go写的程序发现也是一调用call 就崩溃 但c写的项目调用call 就啥事没有不会崩溃
我怀疑是不是这些语言的垃圾回收机制问题
CE的汇编

ce汇编

ce汇编

x64dbg
2E2C3PQL%]2C_(]F16C%M3B.png
断点我也下过 RCX,RDX,R8 这三个参数的的值不会变
但是我去call x64的MessageBoxW api就啥事没有
代码很简单就一个按钮点击一下弹出信息框
WWB7$%TQ@IA`D}BFK{BODST.png
9QBHM]EPKL4U1GP_9B8}KYK.png
测试例子
链接:https://pan.baidu.com/s/1xMJqq2XTSKC8QPObGxk1tA?pwd=m6cq
提取码:m6cq

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

kenxy 发表于 2023-1-6 10:29
学过x86的汇编,x64不太懂
 楼主| lushihao 发表于 2023-1-6 10:34
kenxy 发表于 2023-1-6 10:29
学过x86的汇编,x64不太懂


x86也一样崩溃 push两个参数 也一样会崩溃 如果你需要我可以给你生成x86的
PETiger 发表于 2023-1-6 11:07
确保call内函数过程为 __stdcall 的风格,否则在堆栈恢复现场时候会内存错误
 楼主| lushihao 发表于 2023-1-6 11:16
本帖最后由 lushihao 于 2023-1-6 11:34 编辑
PETiger 发表于 2023-1-6 11:07
确保call内函数过程为 __stdcall 的风格,否则在堆栈恢复现场时候会内存错误

x64 似乎默认是 fastcall  我看入参rdx,和rcx、上面那几条代码似乎是垃圾回收的附加入参
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则 警告:本版块禁止回复与主题无关非技术内容,违者重罚!

快速回复 收藏帖子 返回列表 搜索

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-5-10 09:13

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表