[发明专利]一种面向RISC-V汇编指令级的关键路径自动检测方法有效

专利信息
申请号: 202210974046.8 申请日: 2022-08-15
公开(公告)号: CN115390915B 公开(公告)日: 2023-03-31
发明(设计)人: 许瑾晨;李飞;周蓓;宋广辉;张作言 申请(专利权)人: 中国人民解放军战略支援部队信息工程大学
主分类号: G06F8/75 分类号: G06F8/75;G06F8/73;G06F9/30
代理公司: 郑州大通专利商标代理有限公司 41111 代理人: 刘莹莹
地址: 450000 河*** 国省代码: 河南;41
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 一种 面向 risc 汇编 指令 关键 路径 自动检测 方法
【权利要求书】:

1.一种面向RISC-V汇编指令级的关键路径自动检测方法,其特征在于,包括:

步骤1:对待检测汇编程序中的所有分支进行编码;

步骤2:遍历待检测汇编程序所涉及的所有浮点寄存器,从而判断待检测汇编程序中是否有至少两个全局无依赖的浮点寄存器,若是,则执行步骤3,若否,则执行步骤4;

步骤3:基于两个全局无依赖的浮点寄存器和分支编码,设计全局无依赖式插桩探针;

步骤4:调用非全局无依赖的其他浮点寄存器作为辅助寄存器,基于辅助寄存器和分支编码,设计辅助寄存器式插桩探针;

步骤5:识别分支标识以定位到各个分支的首行位置,将全局无依赖式插桩探针和/或辅助寄存器式插桩探针自动插桩至各个分支的首行位置;

步骤6:使用测试集对插桩后的待检测汇编程序进行测试,将测试集生成的编码结果输出到结果文件,对结果文件中相同的编码结果进行统计,对数量最多的编码结果进行解码以得到关键路径;所述测试集是指由若干个用于检测关键路径的测试样本组成的集合。

2.根据权利要求1所述的一种面向RISC-V汇编指令级的关键路径自动检测方法,其特征在于,步骤1具体包括:

按照分支顺序,分别对每个分支进行二进制编码、十进制编码和十六进制编码;其中,针对第i个分支,其二进制编码由首位为1末尾为i-1个0组成;其十进制编码即为二进制编码对应的十进制数,其十六进制编码即为二进制编码对应的十六进制数;i=1,2,3…,n。

3.根据权利要求1所述的一种面向RISC-V汇编指令级的关键路径自动检测方法,其特征在于,步骤3具体包括:

利用其中一个全局无依赖的浮点寄存器存储插桩探针所在分支的分支编码,利用另一个全局无依赖的浮点寄存器存储编码和;所述编码和是通过对测试样本经过的所有分支的编码进行累加运算后得到的。

4.根据权利要求1所述的一种面向RISC-V汇编指令级的关键路径自动检测方法,其特征在于,步骤4具体包括:

利用一个全局无依赖的浮点寄存器存储插桩探针所在分支的分支编码,利用辅助寄存器存储编码和;所述编码和是通过对测试样本经过的所有分支的进行累加运算后得到的;

其中,针对任意一个探针,在调用辅助寄存器之前,先将辅助寄存器的原值进行压栈;然后再将编码和进行压栈;在完成调用之后,将辅助寄存器的原值从栈中取出。

5.根据权利要求1所述的一种面向RISC-V汇编指令级的关键路径自动检测方法,其特征在于,步骤5中,识别分支标识具体包括:遍历RISC-V汇编代码行的字符,若识别到的字符不是助记符,则认为该字符是分支标识。

6.根据权利要求3或4所述的一种面向RISC-V汇编指令级的关键路径自动检测方法,其特征在于,步骤6中,对数量最多的编码结果进行解码以得到关键路径具体包括:

对数量最多的十六进制编码结果解码为二进制字符串,统计所述二进制字符串中“1”所在的顺序号i,所有顺序号i对应的分支所组成的路径即为关键路径。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国人民解放军战略支援部队信息工程大学,未经中国人民解放军战略支援部队信息工程大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/202210974046.8/1.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top