实现SSD固件升级立即生效的方法及相关设备与流程

文档序号:32166784发布日期:2022-11-12 05:03阅读:72来源:国知局
实现SSD固件升级立即生效的方法及相关设备与流程
实现ssd固件升级立即生效的方法及相关设备
技术领域
1.本发明涉及ssd固件升级技术领域,尤其是指一种实现ssd固件升级立即生效的方法及相关设备。


背景技术:

2.nvme协议中固件升级feature由fw download和fw commit两个命令共同完成。fw download命令负责将固件下载到ssd的内存中。fw commit命令通过commit action参数指示ssd的新固件是在重置后生效,还是立即生效。关于新固件立即生效的请求,nvme协议没有规定具体的实现方案。现有固件升级方案,需要通过device reset(power cycle)才可以使新固件生效,无法满足nvme中对于固件升级立即生效的要求。


技术实现要素:

3.本发明所要解决的技术问题是:提供一种实现ssd固件升级立即生效的方法及相关设备。
4.为了解决上述技术问题,本发明采用的技术方案为:一种实现ssd固件升级立即生效的方法,包括,
5.将ssd准备升级的fw固件下载到ssd的dram中;
6.将准备升级的fw固件从ssd的dram中写到ssd的nand中;
7.将nvme与host之间的上下文保存到ssd的nand中;
8.ssd中正在运行的fw固件触发ssd的pmu进入off模式;
9.ssd的pmu重启ssd的cpu,加载准备升级的fw固件,完成ssd的fw固件升级。
10.进一步的,将ssd准备升级的fw固件下载到ssd的dram中具体为,
11.通过fw download命令将ssd准备升级的fw固件下载到ssd的dram中。
12.进一步的,将准备升级的fw固件从ssd的dram中写到ssd的nand中具体为,
13.根据fw commit中ca参数的指示,将准备升级的fw固件从ssd的dram中写到ssd的nand中。
14.进一步的,ssd的pmu重启ssd的cpu,加载准备升级的fw固件,完成ssd的fw固件升级具体包括,
15.ssd的pmu重启ssd的cpu,ssd的cpu停止运行;
16.ssd的pmu使能ssd的cpu,从ssd的rom开始运行引导程序;
17.引导程序从ssd的nand中加载运行升级的fw固件;
18.在升级的fw固件运行后,从ssd的nand中恢复nvme与host之间的上下文,继而恢复ssd与host之间的通信,完成ssd的fw固件升级。
19.本发明还一种实现ssd固件升级立即生效的装置,包括,
20.固件下载模块,用于将ssd准备升级的fw固件下载到ssd的dram中;
21.固件写入模块,用于将准备升级的fw固件从ssd的dram中写到ssd的nand中;
22.协议写入模块,用于将nvme与host之间的上下文保存到ssd的nand中;
23.模式切换模块,用于ssd中正在运行的fw固件触发ssd的pmu进入off模式;
24.固件重加载模块,用于ssd的pmu重启ssd的cpu,加载准备升级的fw固件,完成ssd的fw固件升级。
25.进一步的,固件下载模块具体用于,
26.通过fw download命令将ssd准备升级的fw固件下载到ssd的dram中。
27.进一步的,固件写入模块具体用于,
28.根据fw commit中ca参数的指示,将准备升级的fw固件从ssd的dram中写到ssd的nand中。
29.进一步的,固件重加载模块具体用于,
30.ssd的pmu重启ssd的cpu,ssd的cpu停止运行;
31.ssd的pmu使能ssd的cpu,从ssd的rom开始运行引导程序;
32.引导程序从ssd的nand中加载运行升级的fw固件;
33.在升级的fw固件运行后,从ssd的nand中恢复nvme与host之间的上下文,继而恢复ssd与host之间的通信,完成ssd的fw固件升级。
34.本发明还提供了一种计算机设备,所述计算机设备包括存储器及处理器,所述存储器上存储有计算机程序,所述处理器执行所述计算机程序时实现如上所述的实现ssd固件升级立即生效的方法。
35.本发明还提供了一种存储介质,所述存储介质存储有计算机程序,所述计算机程序被处理器执行时可实现如上所述的实现ssd固件升级立即生效的方法。
36.本发明的有益效果在于:能够保持nvme/pcie硬件单元不掉电,同时保存固件中的nvme与host之间的上下文到nand上;ssd的mpu只对ssd的cpu进行reset,然后从ssd的nand上加载新固件,再从ssd的nand上恢复nvme与host之间的上下文;在host无感的情况下,实现新固件的立即生效。
附图说明
37.下面结合附图详述本发明的具体结构。
38.图1为本发明实施例的实现ssd固件升级立即生效的方法流程图;
39.图2为本发明实施例的实现ssd固件升级立即生效的固件重加载流程图;
40.图3为本发明实施例的实现ssd固件升级立即生效的装置框图;
41.图4为本发明实施例的实现ssd固件升级立即生效的方法的具体流程图;
42.图5为本发明实施例的计算机设备的示意性框图。
具体实施方式
43.下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
44.应当理解,当在本说明书和所附权利要求书中使用时,术语“包括”和“包含”指示
所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
45.还应当理解,在此本发明说明书中所使用的术语仅仅是出于描述特定实施例的目的而并不意在限制本发明。如在本发明说明书和所附权利要求书中所使用的那样,除非上下文清楚地指明其它情况,否则单数形式的“一”、“一个”及“该”意在包括复数形式。
46.还应当进一步理解,在本发明说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
47.如图1所示,本发明第一实施例为:一种实现ssd固件升级立即生效的方法,包括步骤,
48.s10、将ssd准备升级的fw固件下载到ssd的dram中;
49.s20、将准备升级的fw固件从ssd的dram中写到ssd的nand中;
50.s30、将nvme与host之间的上下文保存到ssd的nand中;
51.s40、ssd中正在运行的fw固件触发ssd的pmu进入off模式;
52.s50、ssd的pmu重启ssd的cpu,加载准备升级的fw固件,完成ssd的fw固件升级。
53.其中,步骤s10中,将ssd准备升级的fw固件下载到ssd的dram中具体为,
54.通过fw download命令将ssd准备升级的fw固件下载到ssd的dram中。
55.其中,mpu(power manage unit)为电源管理单元。
56.其中,步骤s20中,将准备升级的fw固件从ssd的dram中写到ssd的nand中具体为,
57.根据fw commit中ca参数的指示,将准备升级的fw固件从ssd的dram中写到ssd的nand中。
58.如图2所示,步骤s50中,ssd的pmu重启ssd的cpu,加载准备升级的fw固件,完成ssd的fw固件升级具体包括步骤,
59.s51、ssd的pmu重启ssd的cpu,ssd的cpu停止运行;
60.s52、ssd的pmu使能ssd的cpu,从ssd的rom开始运行引导程序;
61.s53、引导程序从ssd的nand中加载运行升级的fw固件;
62.s54、在升级的fw固件运行后,从ssd的nand中恢复nvme与host之间的上下文,继而恢复ssd与host之间的通信,完成ssd的fw固件升级。
63.本发明实施例的有益效果在于:如图4所示为实现ssd固件升级立即生效的方法具体流程图,通过本技术的实现ssd固件升级立即生效的方法能够保持nvme/pcie硬件单元不掉电,同时保存固件中的nvme与host之间的上下文到nand上;ssd的mpu只对ssd的cpu进行reset,然后从ssd的nand上加载新固件,再从ssd的nand上恢复nvme与host之间的上下文;在host无感的情况下,实现新固件的立即生效。其中,host为主机,相当于计算机的主板,上面装有操作系统。
64.如图3所示,本发明的另一实施例为一种实现ssd固件升级立即生效的装置,包括,
65.固件下载模块10,用于将ssd准备升级的fw固件下载到ssd的dram中;
66.固件写入模块20,用于将准备升级的fw固件从ssd的dram中写到ssd的nand中;
67.协议写入模块30,用于将nvme与host之间的上下文保存到ssd的nand中;
68.模式切换模块40,用于ssd中正在运行的fw固件触发ssd的pmu进入off模式;
69.固件重加载模块50,用于ssd的pmu重启ssd的cpu,加载准备升级的fw固件,完成
ssd的fw固件升级。
70.其中,固件下载模块10具体用于,
71.通过fw download命令将ssd准备升级的fw固件下载到ssd的dram中。
72.其中,固件写入模块20具体用于,
73.根据fw commit中ca参数的指示,将准备升级的fw固件从ssd的dram中写到ssd的nand中。
74.其中,固件重加载模块50具体用于,
75.ssd的pmu重启ssd的cpu,ssd的cpu停止运行;
76.ssd的pmu使能ssd的cpu,从ssd的rom开始运行引导程序;
77.引导程序从ssd的nand中加载运行升级的fw固件;
78.在升级的fw固件运行后,从ssd的nand中恢复nvme与host之间的上下文,继而恢复ssd与host之间的通信,完成ssd的fw固件升级。
79.需要说明的是,所属领域的技术人员可以清楚地了解到,上述实现ssd固件升级立即生效的装置的具体实现过程,可以参考前述方法实施例中的相应描述,为了描述的方便和简洁,在此不再赘述。
80.上述实现ssd固件升级立即生效的装置可以实现为一种计算机程序的形式,该计算机程序可以在如图5所示的计算机设备上运行。
81.请参阅图5,图5是本技术实施例提供的一种计算机设备的示意性框图。该计算机设备500可以是终端,也可以是服务器,其中,终端可以是智能手机、平板电脑、笔记本电脑、台式电脑、个人数字助理和穿戴式设备等具有通信功能的电子设备。服务器可以是独立的服务器,也可以是多个服务器组成的服务器集群。
82.参阅图5,该计算机设备500包括通过系统总线501连接的处理器502、存储器和网络接口505,其中,存储器可以包括非易失性存储介质503和内存储器504。
83.该非易失性存储介质503可存储操作系统5031和计算机程序5032。该计算机程序5032包括程序指令,该程序指令被执行时,可使得处理器502执行一种实现ssd固件升级立即生效的方法。
84.该处理器502用于提供计算和控制能力,以支撑整个计算机设备500的运行。
85.该内存储器504为非易失性存储介质503中的计算机程序5032的运行提供环境,该计算机程序5032被处理器502执行时,可使得处理器502执行一种实现ssd固件升级立即生效的方法。
86.该网络接口505用于与其它设备进行网络通信。本领域技术人员可以理解,图5中示出的结构,仅仅是与本技术方案相关的部分结构的框图,并不构成对本技术方案所应用于其上的计算机设备500的限定,具体的计算机设备500可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。
87.其中,所述处理器502用于运行存储在存储器中的计算机程序5032,以实现如上所述的实现ssd固件升级立即生效的方法。
88.应当理解,在本技术实施例中,处理器502可以是中央处理单元(central processing unit,cpu),该处理器502还可以是其他通用处理器、数字信号处理器(digital signal processor,dsp)、专用集成电路(application specific integrated circuit,
asic)、现成可编程门阵列(field-programmable gate array,fpga)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。其中,通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
89.本领域普通技术人员可以理解的是实现上述实施例的方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成。该计算机程序包括程序指令,计算机程序可存储于一存储介质中,该存储介质为计算机可读存储介质。该程序指令被该计算机系统中的至少一个处理器执行,以实现上述方法的实施例的流程步骤。
90.因此,本发明还提供一种存储介质。该存储介质可以为计算机可读存储介质。该存储介质存储有计算机程序,其中计算机程序包括程序指令。该程序指令被处理器执行时使处理器执行上所述的实现ssd固件升级立即生效的方法。
91.所述存储介质可以是u盘、移动硬盘、只读存储器(read-only memory,rom)、磁碟或者光盘等各种可以存储程序代码的计算机可读存储介质。
92.本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
93.在本发明所提供的几个实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的。例如,各个单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式。例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。
94.本发明实施例方法中的步骤可以根据实际需要进行顺序调整、合并和删减。本发明实施例装置中的单元可以根据实际需要进行合并、划分和删减。另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以是两个或两个以上单元集成在一个单元中。
95.该集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分,或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,终端,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。
96.以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到各种等效的修改或替换,这些修改或替换都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应以权利要求的保护范围为准。
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1