- 1、本文档共17页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
附录E 过程调用语句的翻译和数据空间的安排 ——以C语言为例 C 的函数调用语句CALL_S - id ( realParams ) ; 小结(一) 1、IA32的栈是用来存放临时数据。栈的增长方向是从高地址向低地址增长,按字节为单位编址。 2、EBP是栈基址的指针,永远指向栈底(高地址),ESP是栈指针,永远指向栈顶(低地址)。 3、CALL指令用来调用一个函数或过程,相当于以下两条指令: pushl %eip jmp _func 4、RET指令用来从一个函数或过程返回,与CALL相反。 5、ENTER是建立当前函数的栈框架,即相当于以下两条指令: pushl %ebp movl %esp,%ebp 6、LEAVE是释放当前函数或者过程的栈框架,与ENTER相反。 7、栈框架的建立由主调过程与被调过程合作完成,撤销则主要由被调完成,跟调用方式(_cdecl,_stdcall...)有关。 小结(二) 8、局部变量的分配,可以通过esp减去所需字节数 subl $8,%esp 局部变量的释放,通过leave指令完成; 局部变量的访问,可以通过ebp减去偏移量实现: movl -8(%ebp),%eax 9、对形式单元的访问可以通过ebp加上偏移量实现。 10、IA32系列CPU的一些指令分别在4、8、16字节对齐时会有更快的运行速度,因此gcc编译器为提高生成代码在IA32上的运行速度,默认对产生的代码进行16字节对齐;如果查一下gcc的手册,就会发现关于栈对齐的参数设置: -mpreferred-stack-boundary=n 希望栈按照2的n次的字节边界对齐, n的取值范围是2~12;默认情况下,n是等于4的,也就是说,默认情况下,gcc是16字节对齐,以适应IA32大多数指令的要求。 * * 控制流 调用 返回 数据流 参数 返回值 调用add 调用printf push的用途 %eax用途 局部变量 如何寻址 形式参数 如何寻址 接下来再通过一个例子,来详细看看栈的布局: 8f538 123 8f534 424 8f530 8f52c 8f528 8f524 124 8f520 1692 8f51c 8f538 8f518 300 8f514 8f510 8f538 123 8f534 424 8f530 8f52c 8f528 8f524 124 8f520 1692 8f51c 8f538 8f518 300 8f514 8f510 i j y x ? 8f538 123 8f534 424 8f530 0 8f52c 0 8f528 0 8f524 124 8f520 1692 8f51c 8f538 8f518 300 8f514 8f514 8f510 older_ebp i j empty empty empty y rtn_addr old_ebp x p func g() func f() ? 8f538 123 8f534 424 8f530 0 8f52c 0 8f528 0 8f524 124 8f520 1692 8f51c 8f538 8f518 300 8f514 8f514 8f510 older_ebp i j empty empty empty y rtn_addr old_ebp x p func g() _g: pushl %ebp movl %esp, %ebp subl $8, %esp movl $123, -4(%ebp) subl $12, %esp movl -4(%ebp), %eax incl %eax pushl %eax call _f ? 8f538 123 8f534 424 8f530 0 8f52c 0 8f528 0 8f524 124 8f520 1692 8f51c 8f538 8f518 300 8f514 8f514 8f510 older_ebp i j empty empty empty y rtn_addr old_ebp x p _f: pushl %ebp movl %esp, %ebp subl $8, %esp movl $300, -4(%ebp) leal -4(%ebp), %eax movl %eax, -8(%ebp) ... movl -8(%ebp), %eax addl $12, %eax pushl %eax movl -8(%ebp), %eax addl $8, %eax pushl %eax movl -8(
您可能关注的文档
- 腹腔镜下胆囊切除术(LC).ppt
- 分子的性质-(第二课时上课用)).ppt
- 分子的性质(第一课时).pptx
- 分子的性质周周清20160326带答案.doc
- 腹腔镜下阑尾切除术的护理配合.ppt
- 分子地层学汇报.pptx
- 腹腔镜相关知识和管理.ppt
- 腹腔镜与开腹子宫肌瘤剔除术的比较-徐蕴芸.ppt
- 腹腔镜直肠癌TME手术的研究现状及分析--杨烈.pptx
- 腹外疝本科讲课.ppt
- 剧本杀行业报告:内容创作规范与剧本市场拓展策略.docx
- 剧本杀行业区域市场区域文化特色与市场潜力分析报告.docx
- 剧本杀行业区域市场拓展实战案例研究.docx
- 剧本杀行业区域市场拓展路径与模式探索报告.docx
- 剧本杀行业区域市场竞争态势与品牌差异化策略研究报告.docx
- 剧本杀行业2025年西北区域市场市场细分领域竞争态势与品牌竞争策略分析研究报告.docx
- 剧本杀行业2025年西北市场拓展前景预测报告.docx
- 剧本杀行业2025年长沙市场发展潜力分析报告.docx
- 剧本杀行业2025年长三角市场竞争策略与布局分析.docx
- 医疗行业数据合规:2025年数据安全法实施后的合规监管挑战与应对.docx
最近下载
- 《第一单元 生活中的音乐学习项目二 音乐开启心灵之窗》教案(表格式)七年级音乐人教版(2024新版).pdf VIP
- 成功标书大餐——15份浙江省自然科学基金申请书.pdf VIP
- (辽宁富士电梯)系统故障代码及说明.doc VIP
- 2025版高考政治全程一轮复习必修2第一单元生产资料所有制与经济体制第一课我国的生产资料所有制课件.pptx VIP
- 陕西省专业技术人员继续教育2025公需课《党的二十届三中全会精神解读与高质量发展》20学时题库及答案.docx VIP
- 伤口换药护理操作.pptx VIP
- 贵州01-贵州省居住建筑节能设计标准DBJ52-49-20082.pptx VIP
- 《2023年度中国展览数据统计报告》.docx
- 城市名居商住楼房地产估价报告.doc VIP
- [说明]富士变频器维修与故障处理.doc VIP
文档评论(0)