[发明专利]一种基于LLVM的程序代码保护方法及装置有效
| 申请号: | 201910004367.3 | 申请日: | 2019-01-03 |
| 公开(公告)号: | CN109858204B | 公开(公告)日: | 2021-01-15 |
| 发明(设计)人: | 许伟;陈国庆 | 申请(专利权)人: | 武汉极意网络科技有限公司 |
| 主分类号: | G06F21/14 | 分类号: | G06F21/14 |
| 代理公司: | 北京路浩知识产权代理有限公司 11002 | 代理人: | 王莹;吴欢燕 |
| 地址: | 430000 湖北省武汉市东湖开发区大学*** | 国省代码: | 湖北;42 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 一种 基于 llvm 程序代码 保护 方法 装置 | ||
1.一种基于LLVM的程序代码保护方法,其特征在于,包括:
判定遍历到的LLVM编译生成的中间代码文件中的函数是否需进行复杂化处理,当判定结果为需进行复杂化处理时,将所述函数的所有指令保存为调用位CallSite对象;
将所有CallSite对象组成第一集合,并根据所述第一集合中每一CallSite对象所指向的函数是否为空指针或依赖上下文的非直接调用指令,对所述第一集合进行清洗以生成第二集合;
将所述第二集合中每一CallSite对象所指向的函数进行复杂化处理以生成新函数,并将所述新函数替换所述CallSite对象所指向的函数;
判定遍历到的LLVM编译生成的中间代码文件中的函数是否需进行复杂化处理,包括:
若第一判定条件的输出结果为逻辑真,则判定遍历到的LLVM编译生成的中间代码文件中的函数需进行复杂化处理;否则,判定所述函数无需进行复杂化处理;
第一判定条件为:生成随机数,并将该随机数作为预设的随机函数的参数,并获取该随机函数的函数值,将该随机数与该函数值进行大小比较,若前者大于后者,则第一判定条件输出逻辑真,否则,输出逻辑假;将所述第二集合中每一CallSite对象所指向的函数进行复杂化处理以生成新函数,包括:
对于所述第二集合中每一CallSite对象所指向的函数,根据预设复杂化处理次数,对所述函数进行所述预设复杂化处理次数次封装,将封装后得到的函数作为新函数;
若预设复杂化处理次数为1,则对于所述第二集合中每一CallSite对象所指向的函数,根据所述函数的类型、操作符信息,创建一个中间函数,并对所述中间函数补充参数属性、返回值属性和额外属性信息,以完成一次封装,并将封装得到的函数作为新函数;
若预设复杂化处理次数为n,其中,n大于1且为正整数,则对于所述第二集合中每一CallSite对象所指向的函数,根据第n-1次封装得到的函数的类型、操作符信息,创建一个中间函数,并对所述中间函数补充参数属性、返回值属性和额外属性信息,以完成第n次封装,并将封装得到的函数作为新函数;
根据所述第一集合中每一CallSite对象所指向的函数是否为空指针或依赖上下文的非直接调用指令,对所述第一集合进行清洗以生成第二集合,包括:
对于所述第一集合中的每一CallSite对象,判定所述CallSite对象所指向的函数是否为空指针或依赖上下文的非直接调用指令;
将为空指针或依赖上下文的非直接调用指令的函数所对应的CallSite对象从所述第一集合中剔除后,将剩余的CallSite对象组成第二集合。
2.根据权利要求1所述的方法,其特征在于,判定遍历到的LLVM编译生成的中间代码文件中的函数是否需进行复杂化处理,之前还包括:
基于LLVM,将源代码文件编译为中间代码文件,并遍历所述中间代码文件中的每一函数。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于武汉极意网络科技有限公司,未经武汉极意网络科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201910004367.3/1.html,转载请声明来源钻瓜专利网。





