[发明专利]一种栈解析方法和装置有效
申请号: | 201611145387.5 | 申请日: | 2016-12-13 |
公开(公告)号: | CN106802785B | 公开(公告)日: | 2019-07-09 |
发明(设计)人: | 殷罗英;李祥云;王超 | 申请(专利权)人: | 北京华为数字技术有限公司 |
主分类号: | G06F9/30 | 分类号: | G06F9/30 |
代理公司: | 深圳市深佳知识产权代理事务所(普通合伙) 44285 | 代理人: | 王仲凯 |
地址: | 100085 *** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | 本发明实施例公开了一种栈解析的方法和装置,可以在栈解析过程中,通过获取一个栈帧例如第一栈帧的最低位地址,可以从这个栈帧中得到第二函数调用这个栈帧所对应的第一函数的调用关系,并可以根据固定偏移从第一栈帧中得到第一栈帧的长度信息,从而可以依据第一栈帧的长度信息和第一栈帧的最低位地址确定出第二栈帧的最低位地址,以此往复可以得到各函数的调用关系,在获取调用栈时不需要使用BP寄存器,也不需要在栈帧中保存寄存器值,而所使用的SP寄存器在各个应用场景中基本都属于专用于栈帧的寄存器,SP寄存器不会被优化作为其他用处,能正确获取,从而在获取调用栈的过程中节约了寄存器资源,不会影响系统性能。 | ||
搜索关键词: | 一种 解析 方法 装置 | ||
【主权项】:
1.一种栈解析方法,其特征在于,应用于一个线程所对应的栈,所述栈中具有多个栈帧,所述方法包括:获取第一栈帧的最低位地址,所述第一栈帧为所述多个栈帧中的一个栈帧,所述第一栈帧为用于保存第一函数私有资源的栈帧,所述第一函数为所述线程使用到的一个函数;根据所述第一栈帧的最低位地址,从第一栈帧中获取第二函数的指令地址,所述第二函数用于在所述线程中调用第一函数,所述第二函数的指令地址用于指示第二函数调用第一函数的调用关系;根据固定偏移以及所述第一栈帧的最低位地址所指示的位置,从所述第一栈帧中获取第一栈帧的长度信息;根据所述第一栈帧的最低位地址以及所述第一栈帧的长度信息确定出第二栈帧的最低位地址,所述第二栈帧为用于保存第二函数私有资源的栈帧。
下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京华为数字技术有限公司,未经北京华为数字技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/patent/201611145387.5/,转载请声明来源钻瓜专利网。