[发明专利]启动方法及装置、程序存储方法及装置有效
申请号: | 201811341020.X | 申请日: | 2018-11-12 |
公开(公告)号: | CN109491716B | 公开(公告)日: | 2021-11-16 |
发明(设计)人: | 张磊 | 申请(专利权)人: | 北京行易道科技有限公司 |
主分类号: | G06F9/4401 | 分类号: | G06F9/4401;G06F8/61 |
代理公司: | 北京超凡志成知识产权代理事务所(普通合伙) 11371 | 代理人: | 何明伦 |
地址: | 100192 北京*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 启动 方法 装置 程序 存储 | ||
本申请提供了一种启动方法及装置、程序存储方法及装置、电子设备、计算机可读存储介质,在启动的过程中,对中级启动代码和系统应用程序进行数字指纹的验证,从而保证了中级启动代码或系统应用程序是可靠并且完整的,基于可靠、完整的中级启动代码和系统应用程序提高了系统启动的安全性和成功率。
技术领域
本申请涉及计算机技术领域,尤其是涉及一种启动方法及装置、程序存储方法及装置。
背景技术
将双核处理器(CPU)和现场可编程门阵列(FPGA)集成在一起能够提高处理效率和集成性能,双核CPU中的每个CPU可以单独运行,FPGA需要由CPU初始化启动,启动后可与CPU独立运行或者协作运行。当前,一般将CPU和FPGA集成在一个芯片上,此集成芯片具有更好的灵活性和更高的效率。例如,zynq是一款集成了双CPU和FPGA的芯片。
上述集成芯片的启动过程一般是主CPU首先运行,然后引导从CPU和FPGA运行。上述启动过程中由于被加载的启动代码或系统应用程序没有校验和认证,因此存在加载的启动代码或系统应用程序不可靠或损坏的缺陷,将不可靠或被损坏的启动代码或系统应用程序烧写到芯片,会导致集成芯片不能被正常启动。
发明内容
有鉴于此,本申请的目的在于提供启动方法及装置、程序存储方法及装置,以提高集成了双核处理器和现场可编程门阵列的芯片或设备的启动的成功率和安全性。
第一方面,本申请实施例提供了一种启动方法,包括:
初级启动代码启动主CPU,加载中级启动代码,并控制所述中级启动代码开始执行;
所述中级启动代码获取并校验自身的数字指纹,并在所述中级启动代码的数字指纹通过校验的情况下,所述中级启动代码启动现场可编程门阵列、启动从CPU、加载系统应用程序、校验所述系统应用程序的数字指纹,并在所述系统应用程序的数字指纹通过校验的情况下,所述中级启动代码控制所述系统应用程序开始执行。
在一种可能的实施方式中,所述中级启动代码包括第一启动代码和第二启动代码;
所述方法还包括:
所述第一启动代码获取并校验自身的数字指纹,并在所述第一启动代码的数字指纹通过校验的情况下,所述第一启动代码初始化最小系统,并启动所述现场可编程门阵列;
所述第一启动代码加载所述第二启动代码,获取并校验所述第二启动代码的数字指纹;在所述第二启动代码的数字指纹通过校验的情况下,所述第一启动代码控制所述第二启动代码开始执行;
所述第二启动代码启动从CPU、加载所述系统应用程序、获取并校验所述系统应用程序的数字指纹,并在所述系统应用程序的数字指纹通过校验的情况下,所述第二启动代码控制所述系统应用程序开始执行。
在一种可能的实施方式中,所述系统应用程序为加密后的程序;
所述方法还包括:
所述第二启动代码解密所述系统应用程序,并控制解密后的系统应用程序开始执行。
在一种可能的实施方式中,所述第一启动代码、所述第二启动代码以及所述系统应用程序均为两份;
所述方法首先执行所述第一启动代码、所述第二启动代码以及所述系统应用程序中的一份,在所述第一启动代码、所述第二启动代码或所述系统应用程序出现异常时,执行另外的一份所述第一启动代码、所述第二启动代码或所述系统应用程序。
在一种可能的实施方式中,所述启动方法还包括:
在所有的所述第一启动代码不能通过校验的情况下,加载并运行备份的第一启动代码;
在所有的所述第二启动代码不能通过校验的情况下,加载并运行备份的第二启动代码;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京行易道科技有限公司,未经北京行易道科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201811341020.X/2.html,转载请声明来源钻瓜专利网。