[发明专利]具有掩蔽功能的编译器设备在审
申请号: | 201980057790.8 | 申请日: | 2019-07-05 |
公开(公告)号: | CN112639774A | 公开(公告)日: | 2021-04-09 |
发明(设计)人: | W·C·马龙;A·佩斯特林;O·加西亚莫尔琼 | 申请(专利权)人: | 皇家飞利浦有限公司 |
主分类号: | G06F21/14 | 分类号: | G06F21/14 |
代理公司: | 永新专利商标代理有限公司 72002 | 代理人: | 刘兆君 |
地址: | 荷兰艾*** | 国省代码: | 暂无信息 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 具有 掩蔽 功能 编译器 设备 | ||
1.一种被布置用于混淆计算机程序的编译器设备(400),所述编译器设备包括:
通信接口(431),其被布置为接收计算机程序表示;
处理器,其被配置为:
对所述计算机程序表示执行存活变量分析,所述存活变量分析获得与在所述计算机程序表示中分配的变量集合(442)相关联的存活性区域(444)、指示变量被写入的位置的定义信息,以及指示变量被读取的位置的使用信息,
从所述变量集合中选择第一变量和第二变量,其中,根据与所述第二变量相关联的所述定义信息,未在与所述第一变量相关联的所述存活性区域中定义所述第二变量,
利用编码代码在由与所述第一变量相关联的所述定义信息和所述使用信息所定义的位置处修改所述计算机程序表示,所述编码代码被配置为使用至少所述第二变量作为编码参数来对所述第一变量进行编码。
2.根据权利要求1所述的编译器设备,其中,所述计算机程序表示包括控制流图(CFG)、所述存活性区域、包括所述控制流图中的节点的定义信息和使用信息。
3.根据前述权利要求中的任一项所述的编译器设备,其中,所述处理器被配置为:
从所述变量集合中随机选择第一变量,或者
从所述变量集合中依次选择第一变量。
4.根据前述权利要求中的任一项所述的编译器设备,其中,所述处理器被配置为:
根据所述计算机程序表示中的编译器指令来选择第一变量,
确定是否存在第二变量,并且如果不存在所述第二变量,则生成警告信号。
5.根据前述权利要求中的任一项所述的编译器设备,其中,所述处理器被配置为确定针对给定的第一变量的多个第二变量,并且
从所确定的第二变量中随机选择第二变量,或者
选择其使用更接近所述第一变量的所述存活性区域的第二变量。
6.根据前述权利要求中的任一项所述的编译器设备,其中,所述编码代码被配置为:
利用所述第二变量来掩蔽所述第一变量,或者
将编码表应用于所述第一变量,所述表接收所述第二变量作为输入而充当密钥。
7.根据前述权利要求中的任一项所述的编译器设备,其中,所述编码代码被配置为在余数系统中对所述第一变量进行编码,其中,所述余数系统的模数是至少部分地根据所述第二变量导出的。
8.根据前述权利要求中的任一项所述的编译器设备,其中,修改所述计算机程序表示包括:利用编码操作来替换对已编码的第一变量的操作。
9.根据权利要求8所述的编译器设备,其中,所述编码操作不修改所述第二变量。
10.根据前述权利要求中的任一项所述的编译器设备,其中,所述处理器被配置为编译经修改的计算机程序。
11.根据前述权利要求中的任一项所述的编译器设备,其中,所述处理器被配置为执行以下各项中的一项或多项:解析、中间代码生成、代码优化、分配、目标代码生成。
12.一种被布置用于混淆计算机程序的编译器方法(500),所述编译器方法包括:
接收(510)计算机程序表示;
对所述计算机程序表示执行(520)存活变量分析,所述存活变量分析获得与在所述计算机程序表示中分配的变量集合(442)相关联的存活性区域(444)、指示变量被写入的位置的定义信息,以及指示变量被读取的位置的使用信息;
从所述变量集合中选择(530)第一变量和第二变量,其中,根据与所述第二变量相关联的所述定义信息,未在与所述第一变量相关联的所述存活性区域中定义所述第二变量;
利用编码代码在由与所述第一变量相关联的所述定义信息和所述使用信息所定义的位置处修改(540)所述计算机程序表示,所述编码代码被配置为使用至少所述第二变量作为编码参数来对所述第一变量进行编码。
13.一种计算机可读介质(1000),其包括表示指令的瞬态或非瞬态数据(1020),所述指令使处理器系统执行根据权利要求12所述的方法。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于皇家飞利浦有限公司,未经皇家飞利浦有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201980057790.8/1.html,转载请声明来源钻瓜专利网。
- 上一篇:使用与多个发动机相关联的一个或多个参数控制多个发动机
- 下一篇:膜和包装容器