CN108255538A - 一种分布异构系统机上原位加载二级控制器软件的方法 - Google Patents
一种分布异构系统机上原位加载二级控制器软件的方法 Download PDFInfo
- Publication number
- CN108255538A CN108255538A CN201711293635.5A CN201711293635A CN108255538A CN 108255538 A CN108255538 A CN 108255538A CN 201711293635 A CN201711293635 A CN 201711293635A CN 108255538 A CN108255538 A CN 108255538A
- Authority
- CN
- China
- Prior art keywords
- loading
- level controller
- application project
- object code
- engineering
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/445—Program loading or initiating
- G06F9/44521—Dynamic linking or loading; Link editing at or after load time, e.g. Java class loading
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
Abstract
本发明涉及一种分布异构系统机上原位加载二级控制器软件的方法。通过JTAG接口将二级控制器与装有CCS开发环境的普通PC机连接。通过CCS开发环境将含有加载功能的加载工程目标码加载到二级控制器的FLASH的第0个扇区中。在飞机上,将二级控制器通过1394总线与一级控制器连接。在飞机上电复位后,二级控制器的程序指针跳转到加载工程执行,当满足在线加载条件时,进行目标码加载;当不满足在线加载条件时,跳转到应用工程执行功能任务。应用工程执行功能任务的过程中,通过复位将CPU的控制权转给加载工程。在加载过程中若出现掉电,可以重新上电继续执行加载功能,直到应用工程目标码加载完成。
Description
技术领域
本发明属于飞行器数字控制技术领域,涉及一种分布异构系统机上原位加载二级控制器软件的方法。
背景技术
新一代飞机提出了高技术指标与效能最优的需求,分立、集中式机载系统构架难以满足新一代飞机系统综合设计要求,机载系统需采用分布式、综合化机载系统架构是技术发展的趋势和必然选择。
在分布异构系统架构下,二级控制器机载设备种类繁多,随着航空机载设备的数字化进程快速发展,航空机载嵌入式软件在机载设备研制中实现的功能越来越多,软件起到的作用越来越大,软件的升级和加载任务非常繁重,很多二级控制器加载软件时需要从飞机上将控制器拆下,在加载环境中进行加载,有些还需要返厂,加载周期较长。
对于有高安全性高实时性要求的二级控制器机载设备来说,一方面,机载嵌入式软件加载的周期较长;另一方面,新一代飞机的快速形成战斗力又要求加载机载嵌入式软件的周期越短越好。如何实现软件加载的快速性,是摆在设计人员面前的一个突出问题。
发明内容
本发明的目的是:提供一种分布异构系统机上原位加载二级控制器软件的方法,在飞机上不拆卸二级控制器的情况下,设备上电后,二级控制器软件接收一级控制器发来的新版软件目标码,当接收到完整的新版二级控制器软件目标码后,将新版软件目标码烧写到二级控制器的片外FLASH中,重新上下电后,即可实现新版二级控制器软件的正常工作。
本发明的技术方案是:一种分布异构系统机上原位加载二级控制器软件的方法,所述方法以DSP6701为平台,存储器为片外FLASH,执行器件为片内RAM和外挂SRAM,所述方法包括以下步骤:
步骤一:通过JTAG接口将二级控制器与装有CCS开发环境的普通PC机连接。
步骤二:在CCS开发环境下设计两个工程,一个加载工程、一个应用工程。
通过CCS开发环境将含有加载功能的加载工程目标码加载到二级控制器的FLASH的第0个扇区中,加载工程目标码仅加载这一次,在飞机上使用二级控制器的过程中不再更改,加载完成后,二级控制器进行封装并装机。
步骤三:在飞机上,将二级控制器通过1394总线与一级控制器连接。
步骤四:在飞机上电复位后,二级控制器的程序指针跳转到加载工程执行,当满足在线加载条件时,即在线加载NVM(即非易失存储器Nonvolatile Memory)标志字为加载,按照与一级控制器的通讯协议,接收一级控制器发来的二级控制器应用工程目标码,并将目标码存放在二级控制器片外SRAM中,软件目标码接收完成后,从FLASH的第1个扇区开始加载应用工程目标码,直到应用工程目标码加载完成,然后对目标码进行校验并将结果上传给一级控制器,清除在线加载NVM标志字,加载完成,等待下电;当不满足在线加载条件时,跳转到应用工程执行功能任务。
步骤五:应用工程执行功能任务的过程中,根据接收到的一级控制器的指令和连锁条件实时判断是否执行在线加载,满足在线加载条件后,应用工程设置在线加载NVM标志字为加载,然后通过复位将CPU的控制权转给加载工程。
步骤六:在加载过程中,在线加载NVM标志字为正在加载,若出现掉电情况导致应用工程目标码加载失败后,因为加载工程目标码在整个加载过程中保持不变所以不受掉电的影响,可以重新上电,二级控制器的程序指针跳转到加载工程执行,根据在线加载NVM标志字继续执行加载功能,直到应用工程目标码加载完成。
本发明的有益效果是:本发明实现了分布异构系统下,在机上原位加载二级控制器软件目标码的要求,解决了二级控制器软件加载周期长的问题,为分布异构系统二级控制器软件的快速加载提供了一个有效的实现途径。
附图说明
图1为本发明中分布异构系统一、二级控制器连接示意图。
图2为本发明中FLASH扇区分布示意图。
图3为本发明中加载工程、应用工程执行流程示意图。
具体实施方式
下面结合附图对本发明的具体实施方式做进一步说明。
参见图1,二级控制器通过1394总线与一级控制器连接。二级控制器的存储芯片包括FLASH,SRAM,处理器为DSP6701,具有与TI(美国德州仪器)公司CCS开发环境通讯的JTAG接口。在试验室环境下,二级控制器能与装有CCS开发环境的普通PC机通过仿真器连接,在飞机上二级控制器与装有CCS开发环境的普通PC机之间的连接是断开的。
图2为FLASH扇区分布示意图。扇区0存放加载工程目标码,扇区1~扇区31存放应用工程目标码。
图3为加载工程、应用工程执行流程示意图。
下面以在DSP6701开发平台下的二级控制器机上原位加载目标码为例对本发明做进一步详细描述。
在CCS开发环境下建立一个应用工程OFP.PRG。应用工程文件主要是根据系统需求实现相关控制功能,在应用工程软件设计过程中,设计软件在线加载模块,根据接收到的一级控制器的指令和连锁条件判断是否执行在线加载功能,满足在线加载条件后,应用工程设置一个在线加载NVM标志字,然后将CPU的控制权转给加载工程。
在CCS开发环境下建立一个加载工程LOADER.PRG。此工程主要功能是:当满足在线加载条件时,即在线加载NVM标志字为加载,接收一级控制器发来的二级控制器应用工程目标码,并将目标码存放在二级控制器片外SRAM中,软件目标码接收完成后,从FLASH的第1个扇区开始加载应用工程目标码,直到应用工程目标码加载完成,然后对目标码进行校验并将结果上传给一级控制器,清除在线加载NVM标志字;当不满足在线加载条件时,跳转到应用工程执行功能任务。加载工程的存储地址设计在二级控制器的FLASH第0个扇区,执行地址设计在二级控制器的RAM中。
在试验室中,将装有CCS开发环境的PC机与二级控制器通过仿真器(仿真器型号为TDS560PLUS)连接起来,仿真器一端链在PC机的USB口,另一端链在二级控制器的JTAG接口。在CCS开发环境中将加载工程目标码通过仿真器加载到二级控制器FLASH的第0个扇区。对加载工程目标码进行加载时,只对第0个扇区进行擦除,编程操作。加载完成后,二级控制器进行封装并装机。
在飞机上,二级控制器通过1394总线与一级控制器连接。飞机上电时,二级控制器的加载工程目标码要从FLASH中搬运到RAM中,然后在RAM中运行,执行对应用工程目标码的加载。
应用工程的升级加载,只需要将应用工程目标码交给一级控制器,即可实现机上原位加载应用工程目标码。
通过这种方式,能有效缩短软件的加载周期。
Claims (1)
1.一种分布异构系统机上原位加载二级控制器软件的方法,其特征为:所述方法以DSP6701为平台,存储器为片外FLASH,执行器件为片内RAM和外挂SRAM,所述方法包括以下步骤:
步骤一:通过JTAG接口将二级控制器与装有CCS开发环境的普通PC机连接;
步骤二:在CCS开发环境下设计两个工程,一个加载工程、一个应用工程;
通过CCS开发环境将含有加载功能的加载工程目标码加载到二级控制器的FLASH的第0个扇区中,加载工程目标码仅加载这一次,在飞机上使用二级控制器的过程中不再更改,加载完成后,二级控制器进行封装并装机;
步骤三:在飞机上,将二级控制器通过1394总线与一级控制器连接;
步骤四:在飞机上电复位后,二级控制器的程序指针跳转到加载工程执行,当满足在线加载条件时,即在线加载NVM标志字为加载,按照与一级控制器的通讯协议,接收一级控制器发来的二级控制器应用工程目标码,并将目标码存放在二级控制器片外SRAM中,软件目标码接收完成后,从FLASH的第1个扇区开始加载应用工程目标码,直到应用工程目标码加载完成,然后对目标码进行校验并将结果上传给一级控制器,清除在线加载NVM标志字,加载完成,等待下电;当不满足在线加载条件时,跳转到应用工程执行功能任务;
步骤五:应用工程执行功能任务的过程中,根据接收到的一级控制器的指令和连锁条件实时判断是否执行在线加载,满足在线加载条件后,应用工程设置在线加载NVM标志字为加载,然后通过复位将CPU的控制权转给加载工程;
步骤六:在加载过程中,在线加载NVM标志字为正在加载,若出现掉电情况导致应用工程目标码加载失败后,则重新上电,二级控制器的程序指针跳转到加载工程执行,根据在线加载NVM标志字继续执行加载功能,直到应用工程目标码加载完成。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201711293635.5A CN108255538B (zh) | 2017-12-08 | 2017-12-08 | 一种分布异构系统机上原位加载二级控制器软件的方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201711293635.5A CN108255538B (zh) | 2017-12-08 | 2017-12-08 | 一种分布异构系统机上原位加载二级控制器软件的方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN108255538A true CN108255538A (zh) | 2018-07-06 |
CN108255538B CN108255538B (zh) | 2021-02-09 |
Family
ID=62721152
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201711293635.5A Active CN108255538B (zh) | 2017-12-08 | 2017-12-08 | 一种分布异构系统机上原位加载二级控制器软件的方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN108255538B (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111026420A (zh) * | 2019-11-14 | 2020-04-17 | 天津航空机电有限公司 | 一种基于tms320c6000系列处理器的在线加载方法 |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH09305409A (ja) * | 1996-05-21 | 1997-11-28 | Hitachi Ltd | 遠隔プログラムダウンロード制御システム |
CN103019786A (zh) * | 2012-12-12 | 2013-04-03 | 上海派芬自动控制技术有限公司 | 一种控制器升级方法及系统 |
CN103902305A (zh) * | 2012-12-26 | 2014-07-02 | 中国航空工业集团公司第六三一研究所 | 基于ti dsp的软件远程加载与固化方法 |
CN105259806A (zh) * | 2015-10-16 | 2016-01-20 | 珠海格力电器股份有限公司 | 控制器升级方法和系统及主控制器和从控制器 |
US20160019044A1 (en) * | 2014-07-21 | 2016-01-21 | Big Switch Networks, Inc. | Systems and methods for performing uninterrupted network upgrades with controllers |
CN103631591B (zh) * | 2013-11-29 | 2016-08-17 | 中国航空无线电电子研究所 | 符合民用飞机不同软件等级要求的软件运行控制系统与方法 |
CN106951289A (zh) * | 2017-03-23 | 2017-07-14 | 苏州英威腾电力电子有限公司 | 一种在线升级方法、dsp控制器及升级系统 |
-
2017
- 2017-12-08 CN CN201711293635.5A patent/CN108255538B/zh active Active
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH09305409A (ja) * | 1996-05-21 | 1997-11-28 | Hitachi Ltd | 遠隔プログラムダウンロード制御システム |
CN103019786A (zh) * | 2012-12-12 | 2013-04-03 | 上海派芬自动控制技术有限公司 | 一种控制器升级方法及系统 |
CN103902305A (zh) * | 2012-12-26 | 2014-07-02 | 中国航空工业集团公司第六三一研究所 | 基于ti dsp的软件远程加载与固化方法 |
CN103631591B (zh) * | 2013-11-29 | 2016-08-17 | 中国航空无线电电子研究所 | 符合民用飞机不同软件等级要求的软件运行控制系统与方法 |
US20160019044A1 (en) * | 2014-07-21 | 2016-01-21 | Big Switch Networks, Inc. | Systems and methods for performing uninterrupted network upgrades with controllers |
CN105259806A (zh) * | 2015-10-16 | 2016-01-20 | 珠海格力电器股份有限公司 | 控制器升级方法和系统及主控制器和从控制器 |
CN106951289A (zh) * | 2017-03-23 | 2017-07-14 | 苏州英威腾电力电子有限公司 | 一种在线升级方法、dsp控制器及升级系统 |
Non-Patent Citations (1)
Title |
---|
张路 张开锋 胡昆明 肖山竹: "《单片机与嵌入式系统应用》", 1 December 2010 * |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111026420A (zh) * | 2019-11-14 | 2020-04-17 | 天津航空机电有限公司 | 一种基于tms320c6000系列处理器的在线加载方法 |
Also Published As
Publication number | Publication date |
---|---|
CN108255538B (zh) | 2021-02-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN105373407A (zh) | 嵌入式系统dsp和fpga在线升级方法 | |
CN102346235A (zh) | 一种面向硬件设备功能的自动测试系统及方法 | |
CN105930186B (zh) | 多cpu的软件加载方法及基于多cpu的软件加载装置 | |
CN101859244A (zh) | 多工具链工程构建方法及系统 | |
CN105740139B (zh) | 一种基于虚拟环境的嵌入式软件调试方法 | |
CN104216746B (zh) | 一种星上设备dsp程序地面在线烧写的实时监控和校验方法 | |
CN103927187A (zh) | 嵌入式系统程序执行方法 | |
US11403202B2 (en) | Power monitoring system for virtual platform simulation | |
CN108182078B (zh) | 一种优化的弹载设备不拆弹软件在线升级方法 | |
CN102117449A (zh) | 一种用于电网模型投在线的动态验证和软切换方法 | |
CN103294599A (zh) | 一种基于云的嵌入式软件交叉测试方法 | |
CN103513966A (zh) | 基于组件的php开发框架 | |
CN107577223A (zh) | 一种核电厂模拟控制系统数字化改进的验证系统 | |
CN108255538A (zh) | 一种分布异构系统机上原位加载二级控制器软件的方法 | |
CN108614516A (zh) | 一种虚拟plc仿真系统及方法 | |
CN110134598B (zh) | 一种批量处理方法、装置及系统 | |
CN110955605A (zh) | 一种cpu验证单步动态执行的方法 | |
US20110060582A1 (en) | Diversity and Defense-In-Depth Simulation Apparatus | |
CN103729202A (zh) | 一种基于gel脚本的dsp可靠在线flash烧写方法 | |
CN111367579A (zh) | 一种v-rep插件及基于v-rep插件的处理器在环仿真方法 | |
CN105868042B (zh) | 一种看门狗电路 | |
CN104850015A (zh) | 一种软件封装方法及一种汽车电子控制器 | |
CN209570925U (zh) | 用于tee测试的板卡设备 | |
CN105516158A (zh) | 一种可配置协议转换状态机电路结构及协议配置方法 | |
CN104965742A (zh) | 一种处理前端任务的自动化脚本及装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |