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

发动机控制系统和控制软件启动方法与流程

2022-02-25 18:04:46 来源:中国专利 TAG:


1.本发明主要涉及发动机控制系统和软件开发领域,尤其涉及一种发动机控制系统和基于多核处理器的发动机控制软件启动方法。


背景技术:

2.随着半导体技术的日益发展,越来越多的单核处理器逐渐面临停产,多核处理器(multicore processor)的市场占有率逐渐提升。而在发动机控制领域,fadec(full authority digital engine control,全权限数字发动机控制系统)已经越来越多的采用多核处理器作为其计算平台,多核处理器由于其集成化程度的提升,不仅带来了性能上的优化,也能使得控制器的体积、重量、功耗等进一步降低。但与此同时,多核处理器的发展和广泛应用也带来了软件开发难度的提升,并造成了适航难度高等问题。传统的多核软件架构主要有smp(symmetric multi processing,对称多处理)和amp(asymmetric multi processing,非对称多处理)两种,这两种架构在软件开发复杂度和适航难度之间各存优劣。
3.smp是多核同步的架构,一个操作系统管理多个处理器核,使得软件开发人员可以将该多核处理器在整体上看成一个单核处理器来进行应用软件的开发,开发复杂度较低。但是,smp的特点是由一个操作系统管理多核处理器的核,软件耦合度高,因此,smp架构下处理器核之间的资源竞争、同步等各种复杂的行为都给操作系统的适航带来不小的难度。
4.相比之下,amp是多核异步的架构,每个核运行独立的操作系统,因此在操作系统层面,多核之间的资源竞争、同步等情况较为简单。但是,由于amp的每个核都等于是一个独立的软件,软件开发人员需要对每一个核进行单独的开发,因此,amp架构下的应用程序开发复杂度相对较高。
5.有鉴于此,上述两种架构对于软件开发均存在一定程度的缺点,分别增加了操作系统的适航难度和应用软件的开发成本。


技术实现要素:

6.本发明要解决的技术问题是提供一种发动机控制系统及一种基于多核处理器的发动机控制软件的启动方法,可以降低操作系统的适航难度,降低应用软件的开发成本,从而提高软件的开发效率。
7.为解决上述技术问题,本发明提供了一种发动机控制系统,包括:多核处理器,包括第一处理器核与第二处理器核;易失性存储器;操作系统,适于加载到所述易失性存储器中并由所述第一处理器核与第二处理器核运行;应用程序,适于加载到所述易失性存储器中并由所述第一处理器核和/或第二处理器核运行,所述应用程序包括集成模块和多个功能模块,所述集成模块包括与业务相关的模块和驱动程序,所述多个功能模块配置为部署所述多个功能模块的运行时间和空间;以及引导程序,配置为启动所述第一处理器核、第二处理器核、操作系统和应用程序。
8.在本发明的一实施例中,所述第一处理器核与第二处理器核对应同一操作系统,所述集成模块中具有所述第一处理器核与第二处理器核的内核配置。
9.在本发明的一实施例中,所述多个功能模块的运行时间包括运行周期和时间预算。
10.在本发明的一实施例中,所述多个功能模块的运行空间包括分配运行空间、任务间交互空间和/或运行的处理器核。
11.在本发明的一实施例中,所述操作系统配置为解析所述应用程序的集成模块,并部署多个所述功能模块运行的处理器核。
12.在本发明的一实施例中,所述易失性存储器具有不同的第一存储区和第二存储区,其中当所述操作系统运行时,分别在所述第一存储区和第二存储区运行。
13.在本发明的一实施例中,所述多个功能模块的一部分被部署在所述第一处理器核,另一部分被部署在所述第二处理器核。
14.在本发明的一实施例中,所述引导程序配置为先启动所述第一处理器核,将所述操作系统加载到所述第一存储区中后,再启动所述操作系统,将所述操作系统复制到所述第二存储区中。
15.在本发明的一实施例中,所述引导程序配置为在将所述操作系统加载到所述第一存储区中后且启动所述操作系统前,启动所述第二处理器核,并阻塞所述第二处理器核。
16.本发明的另一方面提供一种基于多核处理器的发动机控制软件启动方法,包括以下步骤:启动多核处理器的第一处理器核,并初步初始化所述第一处理器核;将操作系统及应用程序加载到易失性存储器中,其中所述操作系统加载到第一存储区中,所述应用程序包括集成模块和多个功能模块,所述多个功能模块包括与业务相关的模块和驱动程序,所述集成模块配置为部署所述功能模块的运行时间和空间;启动所述多核处理器的第二处理器核,并阻塞所述第二处理器核;启动所述操作系统;使用所述操作系统完整初始化所述第一处理器核与第二处理器核;将所述操作系统复制到所述易失性存储器的第二存储区中;所述操作系统解析所述应用程序的集成模块,并部署多个所述功能模块运行的处理器核;以及释放所述第二处理器核。
17.在本发明的一实施例中,根据上述基于多核处理器的发动机控制软件启动方法,所述多个功能模块的运行空间包括分配运行空间、任务间交互空间和/或运行的处理器核。
18.在本发明的一实施例中,根据上述基于多核处理器的发动机控制软件启动方法,所述操作系统将所述多个功能模块的一部分部署在所述第一处理器核,另一部分部署在所述第二处理器核。
19.在本发明的一实施例中,根据上述基于多核处理器的发动机控制软件启动方法,在释放所述第二处理器核后还包括:所述第一处理器核与第二处理器核分别调转到对应的操作系统存储地址,进行周期任务调度。
20.本发明的另一方面还提供一种基于多核处理器的发动机控制系统,包括:
21.存储器,用于存储可由处理器执行的指令;以及
22.处理器,用于执行所述指令以实现上述基于多核处理器的发动机控制软件启动方法。
23.本发明的另一方面还提供一种存储有计算机程序代码的计算机可读介质,所述计
算机程序代码在由处理器执行时实现上述基于多核处理器的发动机控制软件启动方法。
24.与现有技术相比,本发明具有以下优点:本发明虽然是基于amp架构的多核使用方案,但是通过在操作系统层面进行架构优化,使得应用软件的开发仍可以像smp架构一样灵活,从而降低了软件开发的难度,减少了软件的开发成本,并同时避免了smp架构操作系统适航难度高的问题,在整体上提高了软件开发的效率。
附图说明
25.包括附图是为提供对本技术进一步的理解,它们被收录并构成本技术的一部分,附图示出了本技术的实施例,并与本说明书一起起到解释本发明原理的作用。附图中:
26.图1是本发明一实施例的发动机控制系统结构示意图;
27.图2是本发明一实施例的发动机控制系统的应用程序的开发原理示意图;
28.图3是本发明一实施例的基于多核处理器的发动机控制软件启动方法的原理示意图。
具体实施方式
29.为了更清楚地说明本技术的实施例的技术方案,下面将对实施例描述中所需要使用的附图作简单的介绍。显而易见地,下面描述中的附图仅仅是本技术的一些示例或实施例,对于本领域的普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图将本技术应用于其他类似情景。除非从语言环境中显而易见或另做说明,图中相同标号代表相同结构或操作。
30.如本技术和权利要求书中所示,除非上下文明确提示例外情形,“一”、“一个”、“一种”和/或“该”等词并非特指单数,也可包括复数。一般说来,术语“包括”与“包含”仅提示包括已明确标识的步骤和元素,而这些步骤和元素不构成一个排它性的罗列,方法或者设备也可能包含其他的步骤或元素。
31.除非另外具体说明,否则在这些实施例中阐述的部件和步骤的相对布置、数字表达式和数值不限制本技术的范围。同时,应当明白,为了便于描述,附图中所示出的各个部分的尺寸并不是按照实际的比例关系绘制的。对于相关领域普通技术人员已知的技术、方法和设备可能不作详细讨论,但在适当情况下,所述技术、方法和设备应当被视为授权说明书的一部分。在这里示出和讨论的所有示例中,任何具体值应被解释为仅仅是示例性的,而不是作为限制。因此,示例性实施例的其它示例可以具有不同的值。应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步讨论。
32.本发明的一实施例提出一种发动机控制系统,可以降低操作系统的适航难度,降低应用软件的开发成本,从而提高软件的开发效率。
33.图1是本发明一实施例的发动机控制系统结构示意图。如图1所示,该发动机控制系统10包括一多核处理器11,该多核处理器11进一步包括一第一处理器核111和一第二处理器核112。发动机控制系统10还包括一易失性存储器12,一操作系统13,一应用程序14和一引导程序15。
34.图2是本发明一实施例的发动机控制系统的应用程序的开发原理示意图。图2使用
了流程图示例性的展示了根据本技术的实施例的发动机控制系统的应用程序在开发时所需要所执行的操作。应当理解的是,前面或后面的操作不一定按照顺序来精确地执行。相反,可以按照倒序或同时处理各种步骤。同时,或将其他操作添加到这些过程中,或从这些过程移除某一步或数步操作。
35.图2所示的应用程序的开发原理可以适用于图1所示的本发明一实施例的发动机控制系统中的应用程序14的开发,但本发明不以此为限。下面结合图1和图2,对本发明在该实施例中的一种发动机控制系统做出说明,并对该发动机控制系统中应用程序的开发原理进行详细说明。
36.在发动机领域,发动机控制系统的软件开发程序主要包括应用程序(as)、平台程序(ps)以及启动程序(boot)三部分,且三者一般独立开发。其中,平台程序ps主要负责最小系统的集成、软件程序的整体调度以及功能与功能间的交互,而与业务相关的应用功能,主要在应用程序as中开发,平台程序ps可能承担部分的与外部接口相关的应用功能。
37.而在本发明如图1所示的实施例中,该发动机控制系统与现有技术中的软件开发方法关键的区别在于将平台程序ps从业务功能中独立,将与业务相关的输入、处理、输出等全部应用功能划归在应用程序as中处理。并且,与现有技术不同的是,驱动的程序在本发明中也是集成在应用程序as中。因此,在本发明的amp多核异步架构中,也可以做到每个核采用相同的操作系统内核,从而实现如图1所示的操作系统13和应用程序之间14只有一个映像,而非传统的针对amp架构中的每个核均有独立对应的映像。从而降低了开发的复杂程度,节约了开发成本。
38.如图1所示,以一双核处理器为例,在本发明的该实施例中,多核处理器11的第一处理器核111与第二处理器核112对应同一操作系统13,采用同一个操作系统内核,但是第一处理器核111与第二处理器核112各具有不同的操作系统内核配置,并体现在应用程序需14中,用来实现不同的与业务相关的应用功能。
39.在本发明的该实施例中,如图1所示的操作系统13可以加载到易失性存储器12中并由第一处理器核111与第二处理器核112运行。
40.在本发明的一实施例中,该易失性存储器12还具有不同的第一存储区和第二存储区,操作系统13可以分别在第一存储区和第二存储区中运行,从而为第一处理器核111和第二处理器核112分别提供独立的操作系统。
41.如图2所示,本发明的发动机控制系统中的应用程序的开发方法20分为多个功能模块设计21和集成模块设计22两个独立的流程。功能模块设计的流程21主要用于开发多个功能模块,包括与业务相关的输入、处理、输出等全部应用功能以及驱动程序。集成模块设计的流程22主要用于部署多个功能模块的运行空间和运行时间的相关参数,并且该集成模块在设计时具有上述第一处理器核111和第二处理器核112的操作系统内核配置。
42.示例性的,在本发明的一实施例中,该集成模块设计的流程22在部署多个功能模块的运行空间时,主要分配运行空间、任务间交互空间和/或运行的处理器核;而在部署多个功能模块的运行时间时,主要分配多个功能模块的运行周期和时间运算等参数。在此基础上,上述多个功能模块中的一部分被部署分配给第一处理器核111,而另一部分则被部署分配给第二处理器核112。
43.在本发明的一实施例中,如图1所示的操作系统13还配置为解析应用程序的集成
模块,并部署多个功能模块运行的处理器核,即通过上述示例性的描述中所提到运行时间和运行空间的参数,决定各核所需要实现的功能和运行的程序及方式。
44.应当理解的是,本发明不以上述的部署方案以及运行空间和运行时间的具体选定为限,任何为了实现本发明的应用程序的开发而对于功能模块的运行空间和运行时间的限定参数的选取以及部署方案的调整均属于本发明的精神和范围。
45.更具体的,如图2所示,本发明中发动机控制系统的应用程序在开发时,步骤211和步骤221分别为输入多个功能模块a1,a2

an,以及输入集成模块,分别作为功能模块设计21和集成模块设计22两个独立开发流程的起点。
46.在进行功能模块设计21的流程时,步骤212为对于步骤211输入的多个功能模块a1,a2

an通过编译器编译为多个目标码m1,m2,

mn。步骤212生成的多个目标码m1,m2,

mn代表了本发明的一发动机控制系统中与业务相关的不同应用功能和驱动程序。步骤213为整合多个目标码m1,m2,

mn以生成一最终的目标码m,该目标码m包含了与应用功能相关的功能信息和驱动程序的信息。
47.在进行集成模块设计22的流程时,对于步骤221输入的集成模块首先生成该集成模块的源代码y1,y2,

yn。在此步骤中,也可以选取来自步骤212的对于多个功能模块编译形成的多个目标码m1,m2,

mn为输入代码;或者选取来自步骤211的多个功能模块所涉及的信息作为输入代码,如任务交互信息的代码等,源代码y1,y2,

yn因此代表了部署多个功能模块的运行时间和运行空间的信息。步骤223为通过编译集成模块的源代码以生成集成模块的目标码m,该目标码m包含了本发明的一发动机控制系统中对于多个功能模块a1,a2

an的运行空间和运行时间的部署,并包含了任务交互信息、多核配置信息等其他与双核系统运行相关的信息。
48.最后,步骤23为链接最终生成的多个功能模块的目标码m和集成模块的目标码m以生成完整的应用程序映像,即将各功能模块所包含的各功能与其运行空间和运行时间、以及任务交互信息、多核配置信息等其他与双核系统运行相关的信息以映像的方式一一对应,可以在后续启动双核系统后进行任务调度,使各核分别以设定好的运行方式实现其相对应的功能。
49.示例性的,步骤23中链接的具体方案可以是,提前为每个功能模块a1,a2

an的链接赋予唯一的标识符,查询如图1所示的第一处理器和111和第二处理器核112与各功能模块a1,a2

an的映射关系,如下表1所示。通过如表1中映射关系的查找,得到各功能模块a1,a2

an需要在哪一个处理器核运行的信息,根据这些信息,生成第一处理器核111和第二处理器核112的静态调度表并编译在目标码m中,同时与编译在目标码m中的其他任务交互信息、运行空间和时间信息等其他多核配置信息结合,以实现后续发动机控制系统后对于功能任务的完整调度。
50.功能运行位置功能模块a1第一处理器核111功能模块a2第二处理器核112
……
功能模块an第一处理器核111
51.表1处理器核与功能模块的映射关系表
52.进一步的,如图1所示,本发明的一发动机控制系统还包括一引导程序15,配置为启动第一处理器核111、第二处理器核112、操作系统13和应用程序14。
53.示例性的,在本发明的一实施例中,该引导程序15配置为先启动第一处理器核111,将操作系统13加载到易失性存储器12的一第一存储区中后,启动操作系统13,并将该操作系统13复制到易失性存储器12的一第二存储区中。在此基础上,该引导程序15还配置为在将操作系统13加载到易失性存储器12的第一存储区中之后,以及在启动操作系统13前,启动第二处理器核112,并阻塞第二处理器核112。
54.关于该引导程序15的具体实现方法将在下文做详细阐述。
55.以上是本发明一实施例的一种发动机控制系统的实现原理,可以理解的是,图1、图2以及上述的说明仅仅示例性的展示了本发明的一发动机控制系统的基本架构及其应用程序的一种开发方法。目的是为了说明本发明相较于现有技术,如何将与业务相关的输入、处理、输出等全部应用功能以及驱动程序划归在应用程序as中处理,从而实现基于amp的多核异步架构也可以做到每个核采用相同的操作系统,且操作系统和应用程序之间只有一个映像,降低了开发的复杂程度,节约了开发成本。
56.本发明的另一方面提供了一种发动机控制软件的启动方法,可以用来实现如图1所示的本发明的发动机控制系统中的引导程序。该启动方法配合本发明的发动机控制系统使用,可以降低操作系统的适航难度,降低应用软件的开发成本,从而提高软件的开发效率。
57.图3是本发明一实施例的基于多核处理器的发动机控制软件启动方法的原理示意图。图3使用了流程图用来说明根据本技术的实施例的基于多核处理器的发动机控制软件在启动时所需要所执行的操作。应当理解的是,前面或后面的操作不一定按照顺序来精确地执行。相反,可以按照倒序或同时处理各种步骤。同时,或将其他操作添加到这些过程中,或从这些过程移除某一步或数步操作。
58.下面结合图3,仍然以一双核处理器为例,对本发明的一基于多核处理器的发动机控制软件启动方法30做出说明。
59.首先,在开始上电后,步骤31为启动并初步初始化第一处理器核,以满足第一处理器核的基本运行需求。
60.步骤32为加载操作系统到易失性存储器的一第一存储区中,该第一存储区为第一处理器核的特定地址,以供第一处理器核使用。步骤32同时加载应用程序到易失性存储器的一特定位置中,该应用程序包括集成模块和多个功能模块。其中,该集成模块配置为部署功能模块的运行时间和运行空间,包括分配运行空间、任务间交互和/或运行的处理器核;多个功能模块包括与业务相关的模块和驱动程序。关于应用程序的具体实现方式,可以参照图2及上述实施例中的说明,在此不再赘述。
61.步骤33为启动并阻塞第二处理器核,由于此时第二处理器核上尚未有部署的应用程序,因此需要通过阻塞第二处理器核的方式保障系统的正常运行。
62.步骤34为跳转至第一处理器核的操作系统启动地址,启动操作系统。由于此时的系统尚未知晓在应用程序中的各功能模块中具体哪些需要在第一处理器核上运行,因此,通过启动操作系统而将cpu控制权交由操作系统负责。
63.步骤35为使用该操作系统完整初始化第一处理器核与第二处理器核,以满足基本
的处理器核运行的需求。
64.步骤36为将操作系统复制到易失性存储器的第二存储区中,该第二存储区为第二处理器核的特定地址,以供第二处理器核使用,从而与步骤32中将操作系统加载到易失性存储器中的第一存储区中形成区分,实现第一处理器核和第二处理器核的相互独立运行。
65.步骤37为操作系统解析应用程序的集成模块并部署相应处理器核,即分别部署第一处理器核和第二处理器核所需要运行的代码。更具体的,参照图2和以上的实施例说明,该集成模块配置为部署功能模块的运行时间和运行空间,因此,操作系统通过解析应用程序的集成模块,可以将相对应的一部分功能模块部署在第一处理器核,而将相对应的另一部分功能模块部署在第二处理器核,以实现双核所需要运行的代码的分配。
66.最后,步骤38为释放第二处理器核,从而成功启动基于同一操作系统而具有不同应用功能的双核异构处理器。
67.在实际生产中,在执行完一次步骤31-38对于双核的任务调度分配后,将第一处理器核和第二处理器核分别调转到对应的操作系统的存储地址,以实现双核的周期任务调度。
68.在本发明的一实施例中,如图3所示的步骤31-34可以按照现有技术中传统的启动程序boot来开发,以保持其通用性。
69.以上是本发明一实施例的一种基于多核处理器的发动机控制软件启动方法,该启动方法适用于启动本发明的一种具有相同操作系统的多核异构处理器的发动机控制系统,在效果上降低了操作系统的适航难度,也降低了应用软件的开发成本,从而提高软件的开发效率。
70.本发明的另一方面提出一种基于多核处理器的发动机控制系统,该控制系统包括一存储器,用于存储可由处理器执行的指令;该控制系统还包括一处理器,用于执行指令以实现如上述实施例的参考图3所示的步骤31-38的基于多核处理器的发动机控制软件启动方法。
71.本发明的另一方面还提出一种存储有计算机程序代码的计算机可读介质,该计算机程序代码在由处理器执行时可以实现如上述实施例的参考图3所示的步骤31-38的基于多核处理器的发动机控制软件启动方法。
72.可以理解的是,本发明不以图1和图3所示以及上述说明中的双核处理器为限,领域内的技术人员可以根据实际生产的需要选取更多核的处理器,并在图1和图3以及上述说明的基础上做出适应性的变形,则各种变形均属于本发明的精神和范围。
73.上文已对基本概念做了描述,显然,对于本领域技术人员来说,上述发明披露仅仅作为示例,而并不构成对本技术的限定。虽然此处并没有明确说明,本领域技术人员可能会对本技术进行各种修改、改进和修正。该类修改、改进和修正在本技术中被建议,所以该类修改、改进、修正仍属于本技术示范实施例的精神和范围。
74.同时,本技术使用了特定词语来描述本技术的实施例。如“一个实施例”、“一实施例”、和/或“一些实施例”意指与本技术至少一个实施例相关的某一特征、结构或特点。因此,应强调并注意的是,本说明书中在不同位置两次或多次提及的“一实施例”或“一个实施例”或“一替代性实施例”并不一定是指同一实施例。此外,本技术的一个或多个实施例中的某些特征、结构或特点可以进行适当的组合。
75.本技术的一些方面可以完全由硬件执行、可以完全由软件(包括固件、常驻软件、微码等)执行、也可以由硬件和软件组合执行。以上硬件或软件均可被称为“数据块”、“模块”、“引擎”、“单元”、“组件”或“系统”。处理器可以是一个或多个专用集成电路(asic)、数字信号处理器(dsp)、数字信号处理器件(dapd)、可编程逻辑器件(pld)、现场可编程门阵列(fpga)、处理器、控制器、微控制器、微处理器或者其组合。此外,本技术的各方面可能表现为位于一个或多个计算机可读介质中的计算机产品,该产品包括计算机可读程序编码。例如,计算机可读介质可包括,但不限于,磁性存储设备(例如,硬盘、软盘、磁带
……
)、光盘(例如,压缩盘cd、数字多功能盘dvd
……
)、智能卡以及闪存设备(例如,卡、棒、键驱动器
……
)。
76.计算机可读介质可能包含一个内含有计算机程序编码的传播数据信号,例如在基带上或作为载波的一部分。该传播信号可能有多种表现形式,包括电磁形式、光形式等等、或合适的组合形式。计算机可读介质可以是除计算机可读存储介质之外的任何计算机可读介质,该介质可以通过连接至一个指令执行系统、装置或设备以实现通讯、传播或传输供使用的程序。位于计算机可读介质上的程序编码可以通过任何合适的介质进行传播,包括无线电、电缆、光纤电缆、射频信号、或类似介质、或任何上述介质的组合。
77.同理,应当注意的是,为了简化本技术披露的表述,从而帮助对一个或多个发明实施例的理解,前文对本技术实施例的描述中,有时会将多种特征归并至一个实施例、附图或对其的描述中。但是,这种披露方法并不意味着本技术对象所需要的特征比权利要求中提及的特征多。实际上,实施例的特征要少于上述披露的单个实施例的全部特征。
78.一些实施例中使用了描述成分、属性数量的数字,应当理解的是,此类用于实施例描述的数字,在一些示例中使用了修饰词“大约”、“近似”或“大体上”来修饰。除非另外说明,“大约”、“近似”或“大体上”表明所述数字允许有
±
20%的变化。相应地,在一些实施例中,说明书和权利要求中使用的数值参数均为近似值,该近似值根据个别实施例所需特点可以发生改变。在一些实施例中,数值参数应考虑规定的有效数位并采用一般位数保留的方法。尽管本技术一些实施例中用于确认其范围广度的数值域和参数为近似值,在具体实施例中,此类数值的设定在可行范围内尽可能精确。
79.虽然本技术已参照当前的具体实施例来描述,但是本技术领域中的普通技术人员应当认识到,以上的实施例仅是用来说明本技术,在没有脱离本技术精神的情况下还可作出各种等效的变化或替换,因此,只要在本技术的实质精神范围内对上述实施例的变化、变型都将落在本技术的权利要求书的范围内。
再多了解一些

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

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

相关文献