动态可配置多输出RO PUF设计研究

摘 要: 针对已提出的环形振荡器物理不可克隆函数(ring oscillator physical unclonable functions)输出位数少和鲁棒性不足的缺点,提出了由多输出环振荡器和动态配置处理模块组成的动态可配置多输出ro puf。多路输出环振荡器用于提高芯片资源利用率和增加输出位数。动态配置处理模块根据工作环境的变化动态调整振荡器结构,从而增强系统的鲁棒性和可靠性。实验结果表明,相比传统ro puf和可配置ro puf, 动态可配置多输出ro puf展现出更高的片间汉明距离和更低的片内汉明距离,可进一步提取芯片id的精度。
0 引言 随着计算机技术和集成电路的飞速发展和广泛应用,芯片信息安全越来越受重视。而环形振荡器物理不可克隆函数(ro puf)在信息安全领域作为一项非常有潜力的技术,在芯片信息安全领域备受关注[1]。传统ro puf通过比较放置在同一芯片不同位置的一对环形振荡器的频率来生成输出0或1。由于随机的工艺偏差,输出位将因芯片的不同而变得无法预测[2]。因此,基于传统ro puf的可配置的ro puf被提出来。在可配置ro puf中, 输出位通过最大频率差的配置向量生成[3],从而可以降低工艺偏差带来的影响。
然而,不论是传统ro puf还是可配置ro puf都存在一个相同的不足:通过比较两个环形振荡器频率的不同只能产生一位输出。为了产生更多的输出位,只能不断增加振荡器数量。虽然频率比较的方法可以提高输出位数,但是有限的芯片资源限制了可配置ro puf的实际运用[4]。
根据以上不足,本文提出了动态可配置多路输出ro puf。不仅从根本上增加了输出位数,而且可以根据实际需求确定输出位的数量。同时,振荡器的结构随工作条件的变化而相应的改变,因此可以提高芯片的鲁棒性和安全性。
1 多输出环形振荡器 多输出环形振荡器由反相器、开关单元和路径分配器组成,路径分配器是动态可配置多路输出ro puf的基础。多输出结构的环形振荡器如图1所示。
图1中所有开关单元都与仲裁器puf[5]中的开关单元一致。如果在开关s[0..2]配置位是‘1’,信号将在对应的开关交叉,否则信号将平行通过。图1中由3个开关单元组成的振荡器共有8(23=8)种信号传输模式。路径分配器用以确保信号不会在振荡器上下路径之间交叉传播,以保证每条路径的稳定振荡。信号从路径分配器的输出端开始传输,通过反相器和开关单元,最后回到路径分配器的输入引脚。路径分配器根据每个信号的配置向量决定信号的流向,确保信号重新开始流动时,会沿着之前的路径流动。不同的配置向量将导致不同的信号传输模式。不同的传输模式导致不同传输延迟的线路和门电路,从而产生不同的振荡频率。
相比传统ro puf中和可配置ro puf振荡器只能产生一位输出,该振荡器只占一个lab却可以产生2个输出位。除此之外,通过调整开关单元的通断和路径分配器的信号分配路径,该振荡器还可以产生更多的输出位。
图2表示一对多输出环形振荡器和4个输出位(ro1-1、ro1-2、ro2-1、ro2-2)。ro1和ro2的配置向量相同。通过逻辑锁存器,ro1-和 ro2-1具有相同的路径。所以ro1-和ro2-1(或ro1-2and ro2-2)唯一的区别就是物理工艺偏差。因此,ro1-1和 ro2-1(或ro1-2and ro2-2)频率比较结果可以作为一个输出位。
在xilinx fpga中进行实验,如图3所示,实验结果表明ro1-1和ro1-2在不同配置向量下的输出频率。
实验结果表明,ro1-1和ro1-2的输出频率确实存在差异。此外,随着配置向量的不同,它们的输出频率也存在差异。因此,验证了多输出振荡器结构确实能有效产生多个输出位。
ro1-1和ro2-1的频率差和ro1-2和ro2-2的频率差在不同配置向量下的实验结果如图4所示。可以看出,ro1-1和ro2-1的频率差和ro1-2和ro2-2的频率差是不相关的。因此,它们的输出不相互影响,可以看作两个独立输出位。
表1列出了不同输出位数多输出ro和传统ro的芯片资源占用情况。第二列表示不同输出位数下,一对多输出ros用以产生不同的输出位的lab占用数量。第三列表示传统ro产生相对应的输出位数所占用的lab数量。可以看出,多输出ro占用的芯片资源更少。例如,128位输出需要65个两位输出ros,占65个lab,也可以由33个四位输出ros产生,占99个lab, 但如果使用传统的ro结构,则需要129年ros,占129个lab,所占的lab数量是最多的。可以看出,多输出ro在芯片资源利用率上具有很大的优势。
2 动态配置过程模块 动态可配置多路输出ro puf的总体结构如图5所示。n个两位输出的一对环形振荡器(ros)通过比较相邻ros的频率生成2(n-1)个输出位。传感器由五级环形振荡器构成,振荡频率与环境温度和电源电压成线性关系[6]。传感器主要用于检测芯片工作情况。为了可以根据环境情况动态调整相邻振荡器的结构,从而确保相邻的ros保持一个相对较大的频率差,当环境温度和工作电压超过预先设定的阈值时,fsm控制器[7]启动动态配置过程从而计算出在当前环境下的“最优配置向量”。因此,环境对输出位的影响将降低,从而动态可配置多输出ro puf鲁棒性得到提高。
“最优配置向量”不是简单的产生最大的频率差的向量。相反,它是由ros的频率差的分布来决定。对不同配置向量下所有的ros的正频率差进行求和。如果上一个ros的正频率差大于下一个ros的正频率差,表明上下两对ros的频率差为正,选择可使正频率差最大的配置向量作为“最优配置向量”。相反,如果上一个ros的正频率差小于下一个ros的正频率差,选择一个对应的负频率差最大的配置向量作为“最优配置向量”,从而可以扩大上下频率差的绝对值,进而提高比较精度。
3 实验结果 对10个xilinx spartan xc3s1000 fpga进行数据提取,数据通过快速单一链接(fast simple link)接口传输到microblaze中进行处理。每个fpga通过65个ros产生128位的输出。每个输出测量50次。分别对传统ro puf、可配置ro puf和动态可配置多输出ro puf进行数据分析。
ro puf的平均片间汉明距离比例[8]可以表征同一类型puf电路与其他个体的区分度。其计算方式如式(1)。
其中hij表示第i和第j个puf电路产生的位输出相应,k是fpga的个数。提取数据后计算可得不同ro puf的平均片间汉明距离比例如表2所示。
对比以上3种ro puf对总的位数输出相应的平均片间汉明距离比例结果可以看出,3种ro puf的平均片间汉明距离比例都接近理想的50%,动态可配置多输出ro puf片间汉明距离比例最高。但3种ro puf都表现出良好的唯一性。因此,3种ro puf的输出都可以作为每个芯片id。
片内汉明距离可以描述puf系统的鲁棒性和可靠性,其计算如式(2)所示。
其中,m为不同工作环境的个数,hri表示在理想工作条件(25 ℃,1.2 v)下和第i种工作情况对比条件下的n位输出响应。由于鲁棒性和可靠性主要受环境温度和电源电压的影响。让所使用的xilinx fpga分别工作在固定工作环境下和变化的工作环境下进行参数提取,分别对其片内汉明距离进行检测。
(1)固定环境温度和电源电压情况下
在30 ℃,1.2 v接近理想工作环境下进行参数提取,不同ro puf结构的平均片内汉明距离如表3所示。
在接近fpga标准工作条件下,测试误差和片内噪声是影响其鲁棒性的主要因素[9]。由表可以看出,可配置ro puf可以将该ro puf对误差和噪声影响降至几乎0。
(2)变化的环境温度和电源电压情况下
现实条件下,芯片的工作环境温度和电源电压总是在不断的变化之中。因此,降低环境温度和电源电压对芯片id提取的影响意义重大。表4列出环境温度从-30 ℃变化到+70 ℃,电压1.15 v变化到1.25 v时,3种ro puf的平均片内汉明距离比例变化情况。虽然在温度变化时,动态可配置ro puf在id提取上没有很大优势,但是电源电压改变时,可配置多输出ro puf在位翻转率最低,可更加精确地提取芯片id。
4 结论 本文结合针对传统ro puf和可配置ro puf输出位数不足,占用芯片资源过多的现实情况,在可配置ro puf的基础上改进,提出了动态可配置多输出ro puf,在提高输出位数和节约芯片资源的同时,还提高了系统的唯一性和鲁棒性,进而可提高提取芯片id的精度。对应用ro puf进行芯片知识产权(ip核)保护意义重大。

集博科技推出连网型数据汇集终端机的方案
学技术 | 带您认识Microchip MPU之第一篇 Microchip MPU产品
电源防雷器接线方式及使用注意事项
京东又开源一款新框架,用起来真优雅!
11月份动力电池产业链销售旺季依旧强势
动态可配置多输出RO PUF设计研究
采用CPLD(MAX7128)为核心实现压电生物传感器检测电路的设计
在Matlab环境下实现DSP的实时调试和代码生成方法研究
恩智浦推出全新i.MX 8X处理器,为工业应用带来更高的安全性、可靠性和可扩展性
凝胶放电灵感来源于电鳗的柔性电池
阿里将成立名为“平头哥”的半导体公司!为什么是“平头哥”?
PCB差分信号设计中常见的误区详解
PLC网关助力传统非标设备实现物联网升级
甲烷气体预校准模块FSM-T-01在焦化厂煤气泄漏检测中的应用
小米官方在微博正式宣布,旗下无线快充技术取得了新进展
继电器线圈端反向并接二极管的原因
我国首颗手机传感芯片推出 打破国外垄断
WINCC组态软件实现远程监控的应用方案
雷军连续5条爆料为黑鲨造势,发布会看点十足
Pinterest提出的带有AR滤镜用于眼影测试的示例