易语言教程_易语言源码_易语言视频教程_易语言论坛

 找回密码
 点击注册

Vip新手入门区
新手学习指南  学员作品展示 Vip课程总纲  Vip绝密课程系列

Vip相关下载区
Vip模块下载   Vip模块绑定   Vip模块例子 魔鬼插件下载  魔鬼插件例子  教程工具下载

Vip论坛服务区
教程问题提问区   模块问题提问区 技术交流区   魔鬼插件建议   忘记密码找回

VIP会员办理QQ: 8643245   
【请先加好友,然后到好友列表双击联系客服,办理VIP会员。】
【基础篇】易语言辅助入门基础教程
VIP模块办理QQ: 7189694 办理正版魔鬼作坊VIP模块 【基础篇】OD与CE入门基础教程
办理【终身VIP会员】“秒杀价” 仅需 RMB278.00元… 【基础篇】零基础绝密汇编语言入门课程 (共26课已完成)…
办理VIP详情…猛击这里查看详情 【基础篇】VIP辅助入门基础教程-新手必学 已发布10课 ……
VIP教程免费试看章节…猛击下载 【第1款】制作“辅助挂”教程目录查看(共107+16_x64下更新课已完成)…
亲爱的VIP学员,请到此写下你学习的感受与发布作品截图… 【第2款】制作“任务挂”教程目录查看(共77+1_x64下更新课已完成)…
卍解吧!不用bp send类封包断点找CALL的各种通杀思路 【第3款】驱动过保护技术课程(共38课已完成)…
【绝密教程】VIP绝密教程系列---注意:随时会更新! 【第4款】VIP邪恶二叉树辅助课程 (共31+17_x64下更新课已完成)…
【精品第13款】3D射击游戏与页游透视 智辅课程 已完成17课… 【第5款】零基础易语言按键辅助教程 (30课已完成)…
【精品第14款】变态功能辅助是如何炼成的 已完成36课… 【第6款】从零开始学习封包辅助技术教程(20课已完成) …
【精品第15款】DNF商业变态辅助的修炼之路 已完成27课… 【第7款】大杀特杀分析来源与CALL吸血鬼课程 (56课已完成)
【精品第16款】中控台多线程多开自动化商业辅助课程 已完成66课… 【第8款】完全零基础网页辅助课程(40课已完成)
【全新精品第17款】检测原理与过游戏内存检测技术课程 已发布9课… 【第9款】自动登录与操控LUA技术课程 (共46+8_x64下更新课已完成)…
【全新精品第18款】手游全自动化任务脚本辅助课程 已发布25课…… 【第10款】网页辅助封包脱机进阶课程 已完成30课…
【全新精品第19款】D3D方框骨骼透视与自瞄辅助课程进阶篇 已发布34课…… 【第11款】VC++ Lua脚本辅助课程 已完成112课…
【全新精品第20款】 X64模拟器吃鸡游戏方框透视自瞄辅助课程 发布中... 【第12款】网游脱机封包智辅课程 已完成35课…
查看: 2276|回复: 0

对call堆栈平衡的一点心得,希望对新手有所帮助。

[复制链接]

16

主题

3

回帖

26

积分

编程入门

Rank: 1

魔鬼币
577
发表于 2017-5-30 07:52:57 | 显示全部楼层 |阅读模式
当你对游戏某项功能实现的时候需要调用call  ,call 前面往往有一些入栈操作

例如    push  a
            push b
            push c
            push d
            call  游戏功能子程序

游戏功能子程序:
          push esi
          push ebx
            .........
          add  esp ,4 /sub esp ,8
            .........
          pop  ebx
          pop  esi
          ret   

简单解释:  
子程序中 不管对堆栈如何操作(像上例中的add esp ,4 或者sub esp ,8) 不管游戏子程序开始对应的push /pop 乱起八糟的有多少,只要找到子程序末尾的 ret  ,那此时堆栈一定退回到 call 刚入栈的状态,esp的值 = eip的值(即call调用子程序结束后,需要执行的下个语句的地址)

简单分类:
  1 .  “游戏子程序”末尾是  ret  
      
这个需要call调用返回后,用户自己对堆栈进行平衡,像上面的例子 ,调用前压入了4个参数 ,返回后,4个参数还在栈中,占用了堆栈的十六进制的4*4=10
的栈空间 ,那自己注入写的代码 需要 在call 后面加add esp ,10  
      
如果您的程序接下来的执行,需要压入的参数,那您可以不用 平衡,平衡交给后面执行的程序。
      
但我们见的99%的需要马上平衡,后面程序不需要上面压入的参数,那自己注入代码 需要 在call 后面加add esp ,10 ,来进行堆栈的平衡操作。
   
2.”游戏子程序”末尾是  ret  N
      
这个是您调用的call 子程序 ,自己对堆栈平衡做了操作,这样的一般来说就不用我们对注入的代码进行 add esp 参数个数*4 的操作了
     
ret N    就是程序运行到这句时  ,先执行 ret  ,同时让 add  esp ,n 操作。 ret是返回调用程序 ,add esp ,n 是对被调用程序压入的参数操作,以使堆栈平衡  


ps:    当自己嵌入汇编代码到其他高级语言的时候 ,注意您自己的参数是否正确,否则程序要么提示**内存不可读,要么直接挂掉退出。

比如  上面例子 push a  a 是一个地址  ,您却把此地址的值压入了栈,当执行call程序的时候,访问虚拟内存这个地址的时候,是不会找到的,因为您传入的是一个值,而非地址。
      
俺以前经常犯这样的错误,总认为很对,结果。。。

以上是个人拙解,不对的地方请指正,偶马上改正。
您需要登录后才可以回帖 登录 | 点击注册

本版积分规则

魔鬼作坊|易语言教程|易语言源码|易语言论坛|易语言视频教程| 论坛导航|免责申明|手机版||网站地图
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表魔鬼作坊立场!
任何人不得以任何方式翻录、盗版或出售本站视频,一经发现我们将追究其相关责任!
我们一直在努力成为最好的编程论坛!
Copyright© 2010-2019 All Right Reserved.
快速回复 返回顶部 返回列表