一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

TF卡固件升级的方法、装置、计算机设备及存储介质与流程

2022-04-02 05:16:28 来源:中国专利 TAG:

tf卡固件升级的方法、装置、计算机设备及存储介质
技术领域
1.本发明涉及tf卡固件升级技术领域,尤其是指tf卡固件升级的方法、装置、计算机设备及存储介质。


背景技术:

2.现有tf卡固件在线升级的方法中,升级过程中host(主机)设备需要发送一个tf卡厂商自定义的vendor command(厂商特殊协议命令,例如:cmd56),而这个命令需要host设备自己设计一个符合该厂商特殊协议命令的时序,然后发送给tf卡;tf卡收到该命令后,会将原来对nandflash操作的读写函数改为对norflash的读写函数,当host对tf卡做读写操作时,就是对norflash操作,利用这样的原理,host设备将新固件写到norflash中旧固件的区域,直接覆盖掉旧固件,当tf卡系统再次启动时,运行的就是烧录的新固件。由此可见,上述方法需host设备自己设计一个发送命令的时序,若设计的时序无法准确的满足要求,则host发下来后会导致tf卡内部状态异常,直接影响后续的升级过程,导致其升级失败。


技术实现要素:

3.本发明的目的在于克服现有技术的不足,提供tf卡固件升级的方法、装置、计算机设备及存储介质。
4.为了解决上述技术问题,本发明采用如下技术方案:
5.tf卡固件升级的方法,包括以下步骤:
6.获取主机下发的命令序列;
7.判断命令序列与预设值是否相同;
8.若是,则将tf卡内部对nandflash的读写函数切换成对norflash的读写函数;
9.获取主机下发的新固件,并将新固件写入norflash中,以完成固件升级。
10.其进一步技术方案为:所述获取主机下发的命令序列步骤之前,还包括:对tf卡进行sd接口的初始化。
11.其进一步技术方案为:所述命令序列为若干个读命令组合,所述预设值包括若干个读命令的顺序及其参数。
12.其进一步技术方案为:所述获取主机下发的新固件,并将新固件写入norflash中,以完成固件升级步骤中,新固件写入norflash的区域为norflash中旧固件所在的区域,新固件对旧固件进行覆盖。
13.tf卡固件升级的装置,包括:获取单元,判断单元,切换单元及获取写入单元;
14.所述获取单元,用于获取主机下发的命令序列;
15.所述判断单元,用于判断命令序列与预设值是否相同;
16.所述切换单元,用于将tf卡内部对nandflash的读写函数切换成对norflash的读写函数;
17.所述获取写入单元,用于获取主机下发的新固件,并将新固件写入norflash中,以
完成固件升级。
18.其进一步技术方案为:还包括:初始化单元,用于对tf卡进行sd接口的初始化。
19.其进一步技术方案为:所述命令序列为若干个读命令组合,所述预设值包括若干个读命令的顺序及其参数。
20.其进一步技术方案为:所述获取写入单元中,新固件写入norflash的区域为norflash中旧固件所在的区域,新固件对旧固件进行覆盖。
21.一种计算机设备,所述计算机设备包括存储器及处理器,所述存储器上存储有计算机程序,所述处理器执行所述计算机程序时实现如上述所述的tf卡固件升级的方法。
22.一种存储介质,所述存储介质存储有计算机程序,所述计算机程序包括程序指令,所述程序指令当被处理器执行时可实现如上述所述的tf卡固件升级的方法。
23.本发明与现有技术相比的有益效果是:通过tf卡的普通读写命令序列代替原来tf厂商定义的特殊协议命令对卡进行升级,避免了主机对于tf厂商协议命令严苛的时序要求,这样扩展了tf卡升级功能的兼容性,使其可以兼容更多的主机设备,提高了普适性。
24.下面结合附图和具体实施例对本发明作进一步描述。
附图说明
25.为了更清楚地说明本发明实施例中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
26.图1为tf卡芯片启动过程的示意图;
27.图2为本发明实施例提供的tf卡固件升级的方法的流程示意图;
28.图3为本发明实施例提供的tf卡固件升级的方法的应用场景示意图;
29.图4为本发明实施例提供的tf卡固件升级的装置的示意性框图;
30.图5为本发明实施例提供的计算机设备的示意性框图。
具体实施方式
31.下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
32.应当理解,当在本说明书和所附权利要求书中使用时,术语“包括”和“包含”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
33.还应当理解,在此本发明说明书中所使用的术语仅仅是出于描述特定实施例的目的而并不意在限制本发明。如在本发明说明书和所附权利要求书中所使用的那样,除非上下文清楚地指明其它情况,否则单数形式的“一”、“一个”及“该”意在包括复数形式。
34.还应当进一步理解,在本发明说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
35.其中,本发明需要涉及到的英文解释如下:
36.host:主机;
37.vendor command:厂商特殊协议命令;
38.nandflash:一种存储器;
39.norflash:一种非易失闪存;
40.bootrom:芯片上电启动程序;
41.bootloader:引导程序;
42.fw:固件;
43.rom:只读存储器。
44.其中,如图1所示,tf卡芯片启动包括过程bootrom阶段,bootloader阶段和运行fw固件阶段;初始状态下,芯片的rom中存放bootrom代码,在norflash中存放有bootloader和fw代码,芯片上电启动后,rom中的bootrom运行,将bootloader代码加载到运行空间中;然后bootloader代码运行,将fw的代码再加载到运行空间;最后运行fw代码,芯片启动完毕。其中,该在线升级方法中,需host设备自己设计一个发送vendor command命令的时序,正确发送后,接着就可以用普通的cmd25(多块写)命令将新固件写到tf卡中;但若host设计的vendor command命令时序无法满足要求,则其发给tf卡后很有可能会导致卡内状态异常,进而导致后续的普通读写命令也会出现问题,很有可能导致在线升级过程失败。
45.请参阅图2到图5所示的具体实施例,其中,请参阅图2至图3所示,本发明公开了一种tf卡固件升级的方法,包括以下步骤:
46.s1,获取主机下发的命令序列;
47.其中,在本实施例中,在s1步骤之前,还包括:对tf卡进行sd接口的初始化,以便接收主机下发的命令序列。
48.s2,判断命令序列与预设值是否相同;若否,则返回执行步骤s1;
49.其中,所述命令序列为若干个读命令组合,所述预设值包括若干个读命令的顺序及其参数。
50.其中,在本实施例中,读命令的个数为5个,顺序及其参数分别为cmd17 0xa0000001,cmd17 0xa0000003,cmd17 0xa0000005,cmd17 0xa0000007及cmd17 0xa0000002;tf卡依次接收这5个读命令,只有在这5个命令的顺序及其参数完全符合预设时,tf卡才会将内部对nandflash的读写函数切换成对norflash的读写函数。
51.s3,若是,则将tf卡内部对nandflash的读写函数切换成对norflash的读写函数;
52.s4,获取主机下发的新固件,并将新固件写入norflash中,以完成固件升级。
53.其中,在s4步骤中,新固件写入norflash的区域为norflash中旧固件所在的区域,新固件对旧固件进行覆盖。
54.其中,在本实施例中,主机将新固件切成4kb对齐后,用一个open-ended(无限制)的cmd25写命令,将新固件写入tf卡中,此时tf卡内部会将接收到新固件数据写到norflash上,写入的位置就是cmd25的参数(事先是知道固件fw在norflash的分布位置,可以用此参数指定将要写入数据在norflash中的位置),在将旧固件覆盖掉后,当tf卡系统运行时,bootloader加载的就是升级后的新固件了。
55.其中,如图3所示的具体应用场景:tf卡在线升级过程中卡内芯片全部代码存储态
的变化过程,旧固件存储在norflash中,在线升级时,直接用新固件覆盖norflash中旧固件的区域,这样再次上电tf卡运行后,bootloader加载的就是新固件了。
56.其中,本发明中,host只需发送普通的读命令序列(具体为“cmd17 参数”,其中命令顺序和命令参数符合预期),将对tf卡nandflash的读写函数切换成对norflash的读写函数,接着就可以用普通的cmd25(多块写)命令将新固件写到tf卡中以完成升级。
57.本发明通过tf卡的普通读写命令序列(host设备都支持)代替原来tf厂商定义的特殊协议命令对卡进行升级,避免了主机对于tf厂商协议命令严苛的时序要求,这样扩展了tf卡升级功能的兼容性,使其可以兼容更多的主机设备,提高了普适性。
58.请参阅图4所示,本发明还公开了一种tf卡固件升级的装置,包括:获取单元10,判断单元20,切换单元30及获取写入单元40;
59.所述获取单元10,用于获取主机下发的命令序列;
60.所述判断单元20,用于判断命令序列与预设值是否相同;
61.所述切换单元30,用于将tf卡内部对nandflash的读写函数切换成对norflash的读写函数;
62.所述获取写入单元40,用于获取主机下发的新固件,并将新固件写入norflash中,以完成固件升级。
63.其中,该装置还包括:初始化单元,用于对tf卡进行sd接口的初始化。
64.其中,所述命令序列为若干个读命令组合,所述预设值包括若干个读命令的顺序及其参数。
65.其中,所述获取写入单元40中,新固件写入norflash的区域为norflash中旧固件所在的区域,新固件对旧固件进行覆盖。
66.需要说明的是,所属领域的技术人员可以清楚地了解到,上述tf卡固件升级的装置和各单元的具体实现过程,可以参考前述方法实施例中的相应描述,为了描述的方便和简洁,在此不再赘述。
67.上述tf卡固件升级的装置可以实现为一种计算机程序的形式,该计算机程序可以在如图5所示的计算机设备上运行。
68.请参阅图5,图5是本技术实施例提供的一种计算机设备的示意性框图;该计算机设备500可以是终端,也可以是服务器,其中,终端可以是智能手机、平板电脑、笔记本电脑、台式电脑、个人数字助理和穿戴式设备等具有通信功能的电子设备。服务器可以是独立的服务器,也可以是多个服务器组成的服务器集群。
69.参阅图5,该计算机设备500包括通过系统总线501连接的处理器502、存储器和网络接口505,其中,存储器可以包括非易失性存储介质503和内存储器504。
70.该非易失性存储介质503可存储操作系统5031和计算机程序5032。该计算机程序5032包括程序指令,该程序指令被执行时,可使得处理器502执行一种tf卡固件升级的方法。
71.该处理器502用于提供计算和控制能力,以支撑整个计算机设备500的运行。
72.该内存储器504为非易失性存储介质503中的计算机程序5032的运行提供环境,该计算机程序5032被处理器502执行时,可使得处理器502执行一种tf卡固件升级的方法。
73.该网络接口505用于与其它设备进行网络通信。本领域技术人员可以理解,图5中
示出的结构,仅仅是与本技术方案相关的部分结构的框图,并不构成对本技术方案所应用于其上的计算机设备500的限定,具体的计算机设备500可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。
74.应当理解,在本技术实施例中,处理器502可以是中央处理单元(central processing unit,cpu),该处理器502还可以是其他通用处理器、数字信号处理器(digital signal processor,dsp)、专用集成电路(application specific integrated circuit,asic)、现成可编程门阵列(field-programmable gate array,fpga)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。其中,通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
75.本领域普通技术人员可以理解的是实现上述实施例的方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成。该计算机程序包括程序指令,计算机程序可存储于一存储介质中,该存储介质为计算机可读存储介质。该程序指令被该计算机系统中的至少一个处理器执行,以实现上述方法的实施例的流程步骤。
76.因此,本发明还提供一种存储介质。该存储介质可以为计算机可读存储介质。该存储介质存储有计算机程序,其中计算机程序包括程序指令,所述程序指令当被处理器执行时可实现上述的tf卡固件升级的方法。
77.所述存储介质可以是u盘、移动硬盘、只读存储器(read-only memory,rom)、磁碟或者光盘等各种可以存储程序代码的计算机可读存储介质。
78.本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
79.在本发明所提供的几个实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的。例如,各个单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式。例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。
80.本发明实施例方法中的步骤可以根据实际需要进行顺序调整、合并和删减。本发明实施例装置中的单元可以根据实际需要进行合并、划分和删减。另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以是两个或两个以上单元集成在一个单元中。
81.该集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分,或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,终端,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。
82.上述实施例为本发明较佳的实现方案,除此之外,本发明还可以其它方式实现,在不脱离本技术方案构思的前提下任何显而易见的替换均在本发明的保护范围之内。
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献