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

一种基于I2C的逻辑器件的固件升级方法及系统与流程

2021-12-03 23:10:00 来源:中国专利 TAG:

一种基于i2c的逻辑器件的固件升级方法及系统
技术领域
1.本发明涉及固件升级技术领域,尤其涉及一种基于i2c的逻辑器件的固件升级方法及系统。


背景技术:

2.服务器、交换机以及存储器等产品领域,cpld(complex programmable logic device,复杂可编程逻辑器件)和fpga(field programmable gate array现场可编程阵列)是必不可少的逻辑器件。对于cpld&fpga的固件升级,现有的行业做法是,在cpld&fpga固件下载到器件内部的非易失存储介质后,必须完成一次掉电重启动作,新的cpld&fpga固件才会在不影响正常业务的情况下生效。这样带来的问题是,跑在服务器、交换机以及存储器的正常业务不得不被迫停止一段时间,以完成硬件机器的掉电重启操作。通常cpld&fpga固件升级通道有两种,一种是jtag(joint test action group,联合测试工作组),jtag是一种国际标准测试协议,主要用于芯片内部测试;一种是i2c(inter

integrated circuit),i2c是一种串行通讯总线。采用jtag升级的优点是传输速度快,适合较大固件传输,缺点是需要单独拉一条硬件jtag通道,硬件资源利用率低。采用i2c升级的优点是,cpld&fpga可以和其他i2c器件共用一条i2c通道,不占用额外的硬件资源,并且,cpld&fpga内部的业务寄存器也是以i2c逻辑实现的,这样一来,不管是正常的业务寄存器访问,还是升级需求,就都设计在了同一条i2c链路上。缺点是i2c传输速率较jtag低,但一般cpld&fpga的固件只有几十、几百k大小,升级时间完全可以接受。因此本发明提出一种基于i2c进行固件升级的方案,解决cpld&fpga固件升级后需进行额外的掉电重启操作的问题。


技术实现要素:

3.有鉴于此,本发明提出了一种基于i2c的逻辑器件的固件升级方法及系统,解决了cpld&fpga固件升级后需进行额外的掉电重启操作的问题,保证了业务场景的连贯性,节省了硬件资源。
4.基于上述目的,本发明实施例的一方面提供了一种基于i2c的逻辑器件的固件升级方法,具体包括如下步骤:
5.将待升级的逻辑器件的固件拷贝到与逻辑器件连接的闪存;
6.由系统侧向所述逻辑器件发起第一次握手,使所述逻辑器件进行逻辑准备并备份逻辑器件中寄存器的寄存器数据;
7.响应于所述寄存器数据备份完成并且接收到对逻辑器件的更新命令,由系统侧将拷贝到所述闪存的固件发送到逻辑器件的静态随机存储器以对所述逻辑器件更新,并在所述逻辑器件的更新完成后,恢复所述寄存器数据;
8.响应于所述寄存器数据恢复完成,由所述逻辑器件向系统侧发起第二次握手进行所述逻辑器件的逻辑修复,并在所述逻辑修复完成后结束升级。
9.在一些实施方式中,方法还包括:
10.在内核加载hwmon驱动,并基于所述hwmon驱动获取升级逻辑器件的固件需要的所述逻辑器件中的寄存器;
11.将所述寄存器的寄存器数据写入sysfs节点。
12.在一些实施方式中,向所述逻辑器件发起第一次握手,使所述逻辑器件进行逻辑准备,包括:
13.以协议形式向所述逻辑器件发送命令,使逻辑器件与系统侧进行交互,以进行所述逻辑器件的逻辑准备。
14.在一些实施方式中,备份逻辑器件中寄存器的寄存器数据,包括:
15.读取所述sysfs节点中的寄存器数据,并将所述寄存器数据写入本地缓冲寄存器。
16.在一些实施方式中,恢复寄存器数据,包括:
17.读取本地缓冲寄存器中的寄存器数据,并将所述寄存器数据写入所述sysfs节点中对应的寄存器数据。
18.在一些实施方式中,所述逻辑器件包括复杂可编程逻辑器件和现场可编程阵列中的任意一个或全部。
19.在一些实施方式中,备份逻辑器件中寄存器的寄存器数据以及恢复寄存器数据,包括:
20.基于逻辑器件的固件升级主线程构建子线程,并基于所述子线程备份寄存器数据以及恢复寄存器数据。
21.在一些实施方式中,方法还包括:在主线程定义变量;
22.基于所述子线程备份寄存器数据以及恢复寄存器数据,包括:响应于接收到主线程发送的变量,基于所述变量确定执行备份寄存器数据或执行恢复寄存器数据。
23.在一些实施方式中,基于所述变量确定执行备份寄存器数据或执行恢复寄存器数据,还包括:
24.响应于执行备份寄存器数据或执行恢复寄存器数据完成,基于所述变量继续执行逻辑器件的固件升级主线程。
25.本发明实施例的另一方面,还提供了一种逻辑器件的固件升级系统,包括:
26.拷贝模块,所述拷贝模块配置为将待升级的逻辑器件的固件拷贝到与逻辑器件连接的闪存;
27.第一握手模块,所述第一握手模块配置为由系统侧向所述逻辑器件发起第一次握手,使所述逻辑器件进行逻辑准备并备份逻辑器件中寄存器的寄存器数据;
28.更新模块,所述更新模块配置为响应于所述寄存器数据备份完成并且接收到对逻辑器件的更新命令,由系统侧将拷贝到所述闪存的固件发送到逻辑器件的静态随机存储器以对所述逻辑器件更新,并在所述逻辑器件的更新完成后,恢复所述寄存器数据;
29.第二握手模块,所述第二握手模块配置为响应于所述寄存器数据恢复完成,由所述逻辑器件向系统侧发起第二次握手以进行所述逻辑器件的逻辑修复,并在所述逻辑修复完成后结束升级。
30.在一些实施方式中,系统还包括获取模块,所述获取模块配置为在内核加载hwmon驱动,并基于所述hwmon驱动获取升级逻辑器件的固件需要的所述逻辑器件中的寄存器;
31.将所述寄存器的寄存器数据写入sysfs节点。
32.在一些实施方式中,向所述逻辑器件发起第一次握手,使所述逻辑器件进行逻辑准备,包括:
33.以协议形式向所述逻辑器件发送命令,使逻辑器件与系统侧进行交互,以进行所述逻辑器件的逻辑准备。
34.在一些实施方式中,备份逻辑器件中寄存器的寄存器数据,包括:
35.读取所述sysfs节点中的寄存器数据,并将所述寄存器数据写入本地缓冲寄存器。
36.在一些实施方式中,恢复寄存器数据,包括:
37.读取本地缓冲寄存器中的寄存器数据,并将所述寄存器数据写入所述sysfs节点中对应的寄存器数据。
38.在一些实施方式中,所述逻辑器件包括复杂可编程逻辑器件和现场可编程阵列中的任意一个或全部。
39.在一些实施方式中,备份逻辑器件中寄存器的寄存器数据以及恢复寄存器数据,包括:
40.基于逻辑器件的固件升级主线程构建子线程,并基于所述子线程备份寄存器数据以及恢复寄存器数据。
41.在一些实施方式中,系统还定义模块,所述定义模块配置为在主线程定义变量;
42.基于所述子线程备份寄存器数据以及恢复寄存器数据,包括:响应于接收到主线程发送的变量,基于所述变量确定执行备份寄存器数据或执行恢复寄存器数据。
43.在一些实施方式中,基于所述变量确定执行备份寄存器数据或执行恢复寄存器数据,还包括:
44.响应于执行备份寄存器数据或执行恢复寄存器数据完成,基于所述变量继续执行逻辑器件的固件升级主线程。
45.本发明实施例的又一方面,还提供了一种计算机设备,包括:至少一个处理器;以及存储器,所述存储器存储有可在所述处理器上运行的计算机程序,所述计算机程序由所述处理器执行时实现如上方法的步骤。
46.本发明实施例的再一方面,还提供了一种计算机可读存储介质,计算机可读存储介质存储有被处理器执行时实现如上方法步骤的计算机程序。
47.本发明具有以下有益技术效果:通过本发明的方案,解决了cpld&fpga固件升级后需进行额外的掉电重启操作的问题,保证了业务场景的连贯性,节省了硬件资源。
附图说明
48.为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的实施例。
49.图1为本发明提供的逻辑器件的固件升级方法的一实施例的框图;
50.图2为本发明提供的逻辑器件的固件升级系统的一实施例的示意图。
具体实施方式
51.为使本发明的目的、技术方案和优点更加清楚明白,以下结合具体实施例,并参照附图,对本发明实施例进一步详细说明。
52.需要说明的是,本发明实施例中所有使用“第一”和“第二”的表述均是为了区分两个相同名称非相同的实体或者非相同的参量,可见“第一”“第二”仅为了表述的方便,不应理解为对本发明实施例的限定,后续实施例对此不再一一说明。
53.基于上述目的,本发明实施例的第一个方面,提出了一种基于i2c的逻辑器件的固件升级方法的实施例。如图1所示,其包括如下步骤:
54.步骤s101、将待升级的逻辑器件的固件拷贝到与逻辑器件连接的闪存;
55.步骤s103、由系统侧向所述逻辑器件发起第一次握手,使所述逻辑器件进行逻辑准备并备份逻辑器件中寄存器的寄存器数据;
56.步骤s105、响应于所述寄存器数据备份完成并且接收到对逻辑器件的更新命令,由系统侧将拷贝到所述闪存的固件发送到逻辑器件的静态随机存储器以对所述逻辑器件更新,并在所述逻辑器件的更新完成后,恢复所述寄存器数据;
57.步骤s107、响应于所述寄存器数据恢复完成,由所述逻辑器件向系统侧发起第二次握手以进行所述逻辑器件的逻辑修复,并在所述逻辑修复完成后结束升级。
58.具体的,将待升级的逻辑器件的固件拷贝到与逻辑器件连接的闪存(flash),即把固件下载到逻辑器件外挂的flash,新的固件只是烧写到了非易失存储介质,并没有实时生效到当前逻辑器件的逻辑处理中,只有重新上电逻辑器件后(通过掉电重启整个机器),逻辑器件内部初始化逻辑才会把flash中的新固件刷到其自身内部的静态随机存储器(static random

access memory,简称sram)中生效。其中,逻辑器件,例如可以为cpld、fpga等逻辑器件。
59.由系统侧,例如soc,以私有协议形式,发起第一次握手,通知逻辑器件接下来需要进行实时刷新sram等逻辑动作,在soc与逻辑器件经过若干交互之后,cpld&fpag完成自身的逻辑准备工作,向soc发送ack信息,表示其已准备就绪,可以做接下来的动作。
60.接下来备份业务寄存器,并在业务寄存器备份完成并且接收到对逻辑器件的更新命令后由soc将拷贝到flash的固件发送到逻辑器件的sram以完成对逻辑器件的实时更新,但逻辑器件的实时更新,会导致之前缓存在sram中的寄存器数据会被一并冲掉,也因此,需要在发送refresh命令前后,做额外的寄存器备份和恢复动作,因此在逻辑器件的更新完成后,进行恢复所述寄存器数据的动作;
61.第二次握手,由逻辑器件侧发起,当寄存器完成恢复后,逻辑器件还需要做一些额外的逻辑修复动作,等到这些全部完成就绪后,逻辑器件向soc发送最终的升级成功信息,soc接收到信息后,结束整个升级流程,升级工作结束。
62.通过本发明的方案,解决了cpld&fpga固件升级后需进行额外的掉电重启操作的问题,保证了业务场景的连贯性,节省了硬件资源。
63.在一些实施方式中,方法还包括:
64.在内核加载hwmon驱动,并基于所述hwmon驱动获取升级逻辑器件的固件需要的所述逻辑器件中的寄存器;
65.将所述寄存器的寄存器数据写入sysfs节点。
66.在内核加载逻辑器件的hwmon驱动,将在固件升级过程中会被破坏的业务寄存器导出到sysfs节点,为系统侧升级工具提供编程接口。
67.在一些实施方式中,向所述逻辑器件发起第一次握手,使所述逻辑器件进行逻辑准备,包括:
68.以协议形式向所述逻辑器件发送命令,使逻辑器件与系统侧进行交互,以进行所述逻辑器件的逻辑准备。
69.在一些实施方式中,备份逻辑器件中寄存器的寄存器数据,包括:
70.读取所述sysfs节点中的寄存器数据,并将所述寄存器数据写入本地缓冲寄存器。
71.在一些实施方式中,恢复寄存器数据,包括:
72.读取本地缓冲寄存器中的寄存器数据,并将所述寄存器数据写入所述sysfs节点中对应的寄存器数据。
73.在一些实施方式中,所述逻辑器件包括复杂可编程逻辑器件和现场可编程阵列中的任意一个或全部。
74.在一些实施方式中,备份逻辑器件中寄存器的寄存器数据以及恢复寄存器数据,包括:
75.基于逻辑器件的固件升级主线程构建子线程,并基于所述子线程备份寄存器数据以及恢复寄存器数据。
76.在一些实施方式中,方法还包括:在主线程定义变量;
77.基于所述子线程备份寄存器数据以及恢复寄存器数据,包括:响应于接收到主线程发送的变量,基于所述变量确定执行备份寄存器数据或执行恢复寄存器数据。
78.在一些实施方式中,基于所述变量确定执行备份寄存器数据或执行恢复寄存器数据,还包括:
79.响应于执行备份寄存器数据或执行恢复寄存器数据完成,基于所述变量继续执行逻辑器件的固件升级主线程。
80.具体的,根据本发明的多个实施方式,为提高原有代码的执行效率和代码清晰度,对于备份寄存器数据和恢复寄存器数据,可以在固件升级主线程创建一个子线程加以处理,子线程中,通过主线程传入的一个标识变量,判断是做备份动作还是恢复动作。如果是备份,则通过读取逻辑器件hwmon驱动抛出的sysfs节点,将寄存器数据缓存到本地buffer;如果是恢复,则把之前已保存到本地buffer的寄存器数据逐一再写入逻辑器件hwmon驱动抛出的sysfs节点,固件升级主线程等待子线程完成寄存器备份或恢复后,将条件变量置位,随后,主线程再继续往下跑。
81.下面,通过一个具体的实施例对本发明的逻辑器件的固件升级方法进行说明。
82.以ast2500 bmc(arm平台)为例,具体实施方案如下:
83.加载cpld&fpga hwmon驱动
84.#modprobe boardid_cpld_productid
85.#echo boardid_cpld_productid i2caddr>/sys/bus/devices/i2c

x/new_device
86.驱动加载后,/sys/bus/devices/i2c

x/下会生成新的hwmon,末端路径下,就是全部寄存器的编程节点。
87.将待升级的cpld&fpga固件拷贝到bmc的指定目录下;
88.执行cpldupdate

i2c,启动固件升级流程,即第一次握手

备份寄存器数据

固件更新

恢复寄存器数据

第二次握手,具体用法如下:
89.cpldupdate

i2c<bus><address><img_path><boardnumber><cpldnumber><hitless>
90.其中,<bus>为cpld&fpga的i2c链路上游的i2c bus number,<address>为cpld&fpga的i2c address,<img_path>为待升级cpld&fpga固件的存放路径,<boardnumber>和<cpldnumber>用于标识具体板卡上的具体cpld&fpgaic,<hitless>用来标识第一二次握手的开始和结束,实现上可以用一个gpio,也可以读写母板上cpld&fpga的指定寄存器。
91.需要注意的是,母板上的cpld&fpga的固件升级还是不得不使用一个gpio作为hitless信号,其他cpld&fpga的固件升级可以借助来自母板的cpld&fpga寄存器作为hitless信号。
92.基于同一发明构思,根据本发明的另一个方面,如图2所示,本发明的实施例还提供了一种逻辑器件的固件升级系统,包括:
93.拷贝模块110,所述拷贝模块110配置为将待升级的逻辑器件的固件拷贝到与逻辑器件连接的闪存;
94.第一握手模块120,所述第一握手模块120配置为由系统侧向所述逻辑器件发起第一次握手,使所述逻辑器件进行逻辑准备并备份逻辑器件中寄存器的寄存器数据;
95.更新模块130,所述更新模块130配置为响应于所述寄存器数据备份完成并且接收到对逻辑器件的更新命令,由系统侧将拷贝到所述闪存的固件发送到逻辑器件的静态随机存储器以对所述逻辑器件更新,并在所述逻辑器件的更新完成后,恢复所述寄存器数据;
96.第二握手模块140,所述第二握手模块140配置为响应于所述寄存器数据恢复完成,由所述逻辑器件向系统侧发起第二次握手以进行所述逻辑器件的逻辑修复,并在所述逻辑修复完成后结束升级。
97.在一些实施方式中,系统还包括获取模块,所述获取模块配置为在内核加载hwmon驱动,并基于所述hwmon驱动获取升级逻辑器件的固件需要的所述逻辑器件中的寄存器;
98.将所述寄存器的寄存器数据写入sysfs节点。
99.在一些实施方式中,向所述逻辑器件发起第一次握手,使所述逻辑器件进行逻辑准备,包括:
100.以协议形式向所述逻辑器件发送命令,使逻辑器件与系统侧进行交互,以进行所述逻辑器件的逻辑准备。
101.在一些实施方式中,备份逻辑器件中寄存器的寄存器数据,包括:
102.读取所述sysfs节点中的寄存器数据,并将所述寄存器数据写入本地缓冲寄存器。
103.在一些实施方式中,恢复寄存器数据,包括:
104.读取本地缓冲寄存器中的寄存器数据,并将所述寄存器数据写入所述sysfs节点中对应的寄存器数据。
105.在一些实施方式中,所述逻辑器件包括复杂可编程逻辑器件和现场可编程阵列中的任意一个或全部。
106.在一些实施方式中,备份逻辑器件中寄存器的寄存器数据以及恢复寄存器数据,
包括:
107.基于逻辑器件的固件升级主线程构建子线程,并基于所述子线程备份寄存器数据以及恢复寄存器数据。
108.在一些实施方式中,系统还定义模块,所述定义模块配置为在主线程定义变量;
109.基于所述子线程备份寄存器数据以及恢复寄存器数据,包括:响应于接收到主线程发送的变量,基于所述变量确定执行备份寄存器数据或执行恢复寄存器数据。
110.在一些实施方式中,基于所述变量确定执行备份寄存器数据或执行恢复寄存器数据,还包括:
111.响应于执行备份寄存器数据或执行恢复寄存器数据完成,基于所述变量继续执行逻辑器件的固件升级主线程。
112.基于同一发明构思,根据本发明的另一个方面,本发明的实施例还提供了一种计算机设备,在该计算机设备中包括处理器以及存储器,存储器存储有可在处理器上运行的计算机程序,处理器执行程序时执行如下的方法的步骤:
113.将待升级的逻辑器件的固件拷贝到与逻辑器件连接的闪存;
114.由系统侧向所述逻辑器件发起第一次握手,使所述逻辑器件进行逻辑准备并备份逻辑器件中寄存器的寄存器数据;
115.响应于所述寄存器数据备份完成并且接收到对逻辑器件的更新命令,由系统侧将拷贝到所述闪存的固件发送到逻辑器件的静态随机存储器以对所述逻辑器件更新,并在所述逻辑器件的更新完成后,恢复所述寄存器数据;
116.响应于所述寄存器数据恢复完成,由所述逻辑器件向系统侧发起第二次握手以进行所述逻辑器件的逻辑修复,并在所述逻辑修复完成后结束升级。
117.在一些实施方式中,方法还包括:
118.在内核加载hwmon驱动,并基于所述hwmon驱动获取升级逻辑器件的固件需要的所述逻辑器件中的寄存器;
119.将所述寄存器的寄存器数据写入sysfs节点。
120.在一些实施方式中,向所述逻辑器件发起第一次握手,使所述逻辑器件进行逻辑准备,包括:
121.以协议形式向所述逻辑器件发送命令,使逻辑器件与系统侧进行交互,以进行所述逻辑器件的逻辑准备。
122.在一些实施方式中,备份逻辑器件中寄存器的寄存器数据,包括:
123.读取所述sysfs节点中的寄存器数据,并将所述寄存器数据写入本地缓冲寄存器。
124.在一些实施方式中,恢复寄存器数据,包括:
125.读取本地缓冲寄存器中的寄存器数据,并将所述寄存器数据写入所述sysfs节点中对应的寄存器数据。
126.在一些实施方式中,所述逻辑器件包括复杂可编程逻辑器件和现场可编程阵列中的任意一个或全部。
127.在一些实施方式中,备份逻辑器件中寄存器的寄存器数据以及恢复寄存器数据,包括:
128.基于逻辑器件的固件升级主线程构建子线程,并基于所述子线程备份寄存器数据
以及恢复寄存器数据。
129.在一些实施方式中,方法还包括:在主线程定义变量;
130.基于所述子线程备份寄存器数据以及恢复寄存器数据,包括:响应于接收到主线程发送的变量,基于所述变量确定执行备份寄存器数据或执行恢复寄存器数据。
131.在一些实施方式中,基于所述变量确定执行备份寄存器数据或执行恢复寄存器数据,还包括:
132.响应于执行备份寄存器数据或执行恢复寄存器数据完成,基于所述变量继续执行逻辑器件的固件升级主线程。
133.基于同一发明构思,根据本发明的另一个方面,本发明的实施例还提供了一种计算机可读存储介质,计算机可读存储介质存储有被处理器执行时执行如下方法的计算机程序:
134.将待升级的逻辑器件的固件拷贝到与逻辑器件连接的闪存;
135.由系统侧向所述逻辑器件发起第一次握手,使所述逻辑器件进行逻辑准备并备份逻辑器件中寄存器的寄存器数据;
136.响应于所述寄存器数据备份完成并且接收到对逻辑器件的更新命令,由系统侧将拷贝到所述闪存的固件发送到逻辑器件的静态随机存储器以对所述逻辑器件更新,并在所述逻辑器件的更新完成后,恢复所述寄存器数据;
137.响应于所述寄存器数据恢复完成,由所述逻辑器件向系统侧发起第二次握手以进行所述逻辑器件的逻辑修复,并在所述逻辑修复完成后结束升级。
138.在一些实施方式中,方法还包括:
139.在内核加载hwmon驱动,并基于所述hwmon驱动获取升级逻辑器件的固件需要的所述逻辑器件中的寄存器;
140.将所述寄存器的寄存器数据写入sysfs节点。
141.在一些实施方式中,向所述逻辑器件发起第一次握手,使所述逻辑器件进行逻辑准备,包括:
142.以协议形式向所述逻辑器件发送命令,使逻辑器件与系统侧进行交互,以进行所述逻辑器件的逻辑准备。
143.在一些实施方式中,备份逻辑器件中寄存器的寄存器数据,包括:
144.读取所述sysfs节点中的寄存器数据,并将所述寄存器数据写入本地缓冲寄存器。
145.在一些实施方式中,恢复寄存器数据,包括:
146.读取本地缓冲寄存器中的寄存器数据,并将所述寄存器数据写入所述sysfs节点中对应的寄存器数据。
147.在一些实施方式中,所述逻辑器件包括复杂可编程逻辑器件和现场可编程阵列中的任意一个或全部。
148.在一些实施方式中,备份逻辑器件中寄存器的寄存器数据以及恢复寄存器数据,包括:
149.基于逻辑器件的固件升级主线程构建子线程,并基于所述子线程备份寄存器数据以及恢复寄存器数据。
150.在一些实施方式中,方法还包括:在主线程定义变量;
151.基于所述子线程备份寄存器数据以及恢复寄存器数据,包括:响应于接收到主线程发送的变量,基于所述变量确定执行备份寄存器数据或执行恢复寄存器数据。
152.在一些实施方式中,基于所述变量确定执行备份寄存器数据或执行恢复寄存器数据,还包括:
153.响应于执行备份寄存器数据或执行恢复寄存器数据完成,基于所述变量继续执行逻辑器件的固件升级主线程。
154.最后需要说明的是,本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,可以通过计算机程序来指令相关硬件来完成,程序可存储于一计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,程序的存储介质可为磁碟、光盘、只读存储记忆体(rom)或随机存储记忆体(ram)等。上述计算机程序的实施例,可以达到与之对应的前述任意方法实施例相同或者相类似的效果。
155.以上是本发明公开的示例性实施例,但是应当注意,在不背离权利要求限定的本发明实施例公开的范围的前提下,可以进行多种改变和修改。根据这里描述的公开实施例的方法权利要求的功能、步骤和/或动作不需以任何特定顺序执行。此外,尽管本发明实施例公开的元素可以以个体形式描述或要求,但除非明确限制为单数,也可以理解为多个。
156.应当理解的是,在本文中使用的,除非上下文清楚地支持例外情况,单数形式“一个”旨在也包括复数形式。还应当理解的是,在本文中使用的“和/或”是指包括一个或者一个以上相关联地列出的项目的任意和所有可能组合。
157.上述本发明实施例公开实施例序号仅仅为了描述,不代表实施例的优劣。
158.本领域普通技术人员可以理解实现上述实施例的全部或部分步骤可以通过硬件来完成,也可以通过程序来指令相关的硬件完成,程序可以存储于一种计算机可读存储介质中,上述提到的存储介质可以是只读存储器,磁盘或光盘等。
159.所属领域的普通技术人员应当理解:以上任何实施例的讨论仅为示例性的,并非旨在暗示本发明实施例公开的范围(包括权利要求)被限于这些例子;在本发明实施例的思路下,以上实施例或者不同实施例中的技术特征之间也可以进行组合,并存在如上的本发明实施例的不同方面的许多其它变化,为了简明它们没有在细节中提供。因此,凡在本发明实施例的精神和原则之内,所做的任何省略、修改、等同替换、改进等,均应包含在本发明实施例的保护范围之内。
再多了解一些

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

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

相关文献