PowerPC栈帧分析.doc

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
PowerPC栈帧分析

PowerPC栈帧分析 1 .PowerPC寄存器的使用规则 通用寄存器的用途: r0   在函数开始(function prologs)时使用。 r1   堆栈指针,相当于ia32架构中的esp寄存器,idapro把这个寄存器反汇编标识为sp。 r2   内容表(toc)指针,idapro把这个寄存器反汇编标识为rtoc。系统调用时,它包含系统调用号(这个好像跟系统有关吧)。 r3   作为第一个参数和返回值。 r4-r10 函数或系统调用开始的参数。 r11   用在指针的调用和当作一些语言的环境指针。 r12   它用在异常处理和glink(动态连接器)代码。 r13   保留作为系统线程ID。 r14-r31 作为本地变量,非易失性。 专用寄存器的用途: lr   链接寄存器,它用来存放函数调用结束处的返回地址。 ctr   计数寄存器,它用来当作循环计数器,会随特定转移操作而递减。 xer   定点异常寄存器,存放整数运算操作的进位以及溢出信息。 msr   机器状态寄存器,用来配置微处理器的设定。 cr   条件寄存器,它分成8个4位字段,cr0-cr7,它反映了某个算法操作的结果并且提供条件分支的机制。 2.栈帧的使用规则 PowerPC寄存器没有专用的Pop,Push指令来执行堆栈操作,所以PowerPC构架使用存储器访问指令stwu,lwzu来代替Push和Pop指令。PowerPC处理器使用GPR1来将这个堆栈段构成一个单向链表,这个单链表的每一个数据成员,我们称之为堆栈帧(Stack Frame),每一个函数负责维护自己的堆栈帧。 PowerPC体系结构中栈的增长方向是从高地址到低地址,堆的增长方式是从低地址到搞地址,当两者相遇时就会产生溢出。 堆栈帧的格式如下: 各部分名词解释: 函数参数域(Function Parameter Area):这个区域的大小是可选的,即如果如果调用函数传递给被调用函数的参数少于六个时,用GPR4至GPR10这个六个寄存器就可以了,被调用函数的栈帧中就不需要这个区域;但如果传递的参数多于六个时就需要这个区域。 局部变量域(Local Variables Area):通上所示,如果临时寄存器的数量不足以提供给被调用函数的临时变量使用时,就会使用这个域。 CR寄存器:即使修改了CR寄存器的某一个段CRx(x=0至7),都有保存这个CR寄存器的内容。 通用寄存器GPR:当需要保存GPR寄存器中的一个寄存器器GPRn时,就需要把从GPRn到GPR31的值都保存到堆栈帧中。 浮点寄存器FPR:使用规则共GPR寄存器。 3.?PowerPC的汇编指令和栈操作 ??? PowerPC寄存器没有专用的push和pop指令来执行堆栈操作,所以PowerPC构架使用存储器访问指令stwu、lwzu来代替push和pop指令。 4.函数执行时栈帧的建立与消亡过程 函数栈的建立与消亡过程如下图所示: 4.1函数栈的建立与消亡过程说明 如前所属,PowerPC体系结构中栈的增长方向是从高地址到低地址,故形成过程可以概括为如下几点: 调用函数r1指向栈顶(SP),用间接寻址方式分配一定大小栈空间; r31指向栈顶,以r31为基值将参数压入栈内; 进入被调函数,跳转到被调函数的SP处; 被调函数同样进行栈分配及参数压栈操作; 被调函数执行完毕之后,跳转LR,返回到被调用处的下一条指令,继续后续操作(此时的SP即为调用函数的SP) 4.2举例说明栈操作过程 以下以一个简单的函数调用,说明PowerPC栈的操作过程。 函数例子如下: int calltest2( int a) { int t1=5; int t2 = 6; int result =0; char * p =0; *p =a; } int calltest1( int a) { int t1=3; int t2 = 4; int result =0; result = calltest2( t2); t1 =3; } void calltest( ) { int t1=7; int t2 = 9; int result =0; result = calltest1( t1); t1 =3; } 利用反汇编工具,生成汇编代码及分析如下: int calltest2( int a) { Calltest2栈帧建立分析: stwu r1,-48(r1):分配48字节的栈帧,r1指向栈顶;(powerpc省略了EBP,所以一上

文档评论(0)

kaiss + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档