当前位置:首页 > 嵌入式 > 嵌入式软件

  引 言

  在嵌入式产品中,一般使用Flash作为应用程序代码及各种数据和参数的存储介质。尤其是NOR Flash具有操作接口简单、传输效率高、芯片内执行(eXecute In Place,XIP)的特点,在电力、铁路等工业控制领域得到了广泛应用。

  为了便于用户的使用,VxWorks操作系统提供了基于Flash的文件系统,即TrueFFS。TrueFFS与DosFS文件系统基本兼容,通过VxWorks提供的操作接口以文件的方式实现对Flash的操作。而对于用户来说,如何在自己的硬件系统上根据Flash的具体型号和使用要求实现TrueFFS系统,并在此基础上完成应用程序代码的灵活启动、更新,同时兼顾仿真调试的需求,则非常重要。

  1 系统基本功能

  本系统应用于铁路牵引自动化系统中,实现在电气化铁路供电系统中对相关电力设备的保护、测量和控制功能。系统基本功能框图如图1所示。核心CPU选用Freescale公司的ColdFire系列32位微控制器MCF5234。该处理器内部集成了UART、SPI、I2C、ETPU、CAN、以太网等丰富的功能模块,系统主频可达150 MHz,主要用于工业控制、智能家电等方面(尤其是电力自动化控制领域)。系统通过2路以太网接口实现与当地或远方设备的通信,维护串口用来实现对本设备的维护,采用2片16位接口的NOR Flash实现应用程序和有关参数及数据的存储。系统提供模拟量输入、数字量输入、数字量输出等接口。有关的模拟量及开关量状态信息经过对应接口采集到系统内部,经过保护算法软件的处理后,再通过数字量输出接口完成对有关设备的控制操作。

  在传统嵌入式系统中,编译好的运行态应用程序一般通过硬件调试工具(如BDM调试器)直接固化到程序Flash的指定位置,装置上电或复位后,CPU直接跳转到Flash的起始位置,从Flash中取指并开始执行。但是在VxWorks中,采用该方式不方便软件的仿真调试,需要重新固化bootrom才行。另外,由于系统要求保存较多的参数和数据,需要在2片Flash中都实现TrueFFS系统;并且为了满足动态更新程序的要求,还需要实现FTP的功能。因此,需要实现如下功能:在2片Flash上实现True-FFS;在bootrom和应用VxWorks程序上实现TrueFFS和FTP的加载;对bootrom进行改造,以实现应用VxWorks程序和调试VxWorks程序分别通过TrueFFS和TFTP的方式启动。

  2 TrueFFS的实现及加载

  2.1 TrueFFS的层次结构

  如图2所示,VxWorks中TrueFFS的层次结构包括内核层、翻译层、socket层、MTD层。由于VxWorks对TrueFFS进行了优秀的层次划分和封装,用户一般不需要对上述基本层次代码进行修改。MTD层实现了对常用几种类型Flash的读、写、擦除等基本控制。如果用户选用了支持的类型,则基本不需要编写代码;而如果用户选用了特殊类型的Flash,则可以参考用例代码完成对应MTD层代码的编写。

  2.2 MTD层代码实现

  由于本系统中选用的2片Flash为Spansion公司的S29AL032D,因此需要编写对应的驱动代码。对于MTD层,一般向上提供MTD识别、Flash连续扇区擦除、Flash连续数据写等主要接口函数,可以不提供单独的镜像函数,系统会使用内部缺省的镜像函数。需要在2片Flash上实现TrueFFS,即每片Flash相当于一个分区,这一点在编写驱动程序时需要重点考虑。在MTD层驱动程序中,Flash的单个字节(或字)写入接口函数为重点,不同Flash类型以及不同的端口宽度都会导致该函数的实现不同。其写操作流程如图3所示。

  为了在两片Flash上实现2个文件分区,可以采用以下方式:在sysTffs.c中定义新的MTD类型,并根据实际需要定义2片Flash(即两个分区)的起始地址和长度,并根据上述定义完成TrueFFS设备基址和窗口尺寸的设置;在sysTffsInit()函数中进行2次rfaRegister()操作以完成2个分区的注册;在rfaRegister()中根据注册的TrueFFS设备个数设置本TrueFFS设备的设备号。在MTD层接口函数中一般都有一个Flash驱动设备的参数,可以根据该参数来获取2个TrueFFS设备的设备号,然后分别指向对应的Flash地址范围进行相应的操作。

  MTD驱动设计完成后,可以根据VxWorks提供的方式完成TrueFFS的加载。在应用程序中可以通过组件配置界面进行加载配置,而在bootrom中则需要手动修改相应的配置文件。

  由于系统的启动需要从boottom开始,其编译的结果文件必须以二进制方式固化到程序Flash的起始位置,因此每片Flash起始的256 KB空间都预留出来,不参与TrueFFS系统的管理。这样,Flash上文件的操作与bootrom启动代码的保存不存在冲突。

  3 bootrom的改进

  在VxWorks中,修改好的bootrom一般通过硬件调试工具固化到代码Flash中,bootrom启动后通过TFTP方式实现编译好的调试用VxWorks映像文件的下载过程,并完成该映像文件的启动。这样就可以实现基于串口或网络的应用程序调试,使用更加方便灵活。

  为了满足系统的要求,bootrom还需要增加如下功能:支持2个Flash分区的TrueFFS加载;支持FTP功能;支持从TrueFFS加载及启动应用程序,以及从TFTP网络方式加载及启动调试态VxWorks映像文件两种方式,以保证系统即使在现场运行过程中,一旦发现问题,也能够方便地进行仿真调试;支持Flash的格式化及True-FFS的初始化功能,一旦文件系统异常后,可以通过该功能进行TrueFFS的彻底重构。由于boottom的主要工作在bootconfig.c文件中实现,因此上述改进工作也主要在该文件中进行。

  还需要完成以下工作:在对应配置文件中加入IN-CLUDE_TFFS和INCLUDE_FTP_SERVER的定义,从而实现系统对TrueFFS和FTP功能的加载;对bootloader函数进行修改,使其不支持基于TrueFFS的应用程序启动,当需要调试时通过网络方式加载和启动;增加一个类似于bootloader的功能函数,可以以此函数为模版进行修改,完成TrueFFS功能的初始化和加载过程,以及基本网络功能和FTP功能的加载,同时在程序Flash文件分区中存在应用程序文件的前提下,实现该应用程序的加载和启动功能;增加2片Flash的格式化和TrueFFS的初始化功能函数。

  对bootCmdLoop任务执行流程进行调整,改进后的流程如图4所示。

  在bootCmdLoop进入超级终端界面循环操作过程后,可以通过相关命令完成基于网络方式的调试态VxWorks映像文件的加载和启动,也可以根据实际需要增加Flash格式化、自动进入超级终端界面标志命令设置、软件复位等功能。经过上述改进,可以实现bootrom上运行态应用程序及调试态VxWorks映像文件的灵活加载和启动,不仅避免了现场运行系统为进行调试而重新写入bootrom的问题,而且方便应用程序的动态更新。

  4 应用程序的动态更新

  为了便于产品的维护和升级,本系统需要支持基于FTP的应用程序动态更新,而VxWorks提供了各种类型应用程序的加载启动方式。由于应用程序最终在动态RAM中执行,因此在TrueFFS和FTP功能具备的前提下,实现应用程序的动态更新非常方便。

  经过改造后,bootrom和最终应用程序中都实现了TrueFFS和FTP功能,因此在bootrom和最终应用程序执行时都可以完成应用程序加载。另外,由于具备了bootrom中更新应用程序的功能,即使由于应用程序异常导致无法运行,复位后重新进入bootrom仍然可以进行新程序的更新,从而增强了系统的健壮性。

  需要注意的是,通过TrueFFS方式加载启动的最终应用程序也是default类型的,而不是rom类型的。如果下载到文件系统中的应用程序是rom类型,则会导致bootrom无法成功加载该文件,因为其实现方式与仿真调试过程基本类似。

  结 语

  经过测试,采用上述实现方案后,系统运行稳定。通过FTP工具,可以灵活地对2片Flash上文件分区中的文件进行读写操作,2 MB左右的应用程序文件可在30 s内下载到Flash中。整个系统的启动过程稳定可靠,对于2 MB左右的应用程序,从装置上电到bootrom启动,再到应用程序正常开始运行,基本可在十几秒内完成。本方案对于基于VxWorks系统的嵌入式产品有一定的借鉴意义。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

​开关电源作为典型的反馈控制系统,其核心目标是实现稳定、精准的直流输出。但实际设计中,环路并非仅针对直流成分进行调控,反而必须涵盖一定范围的交流频率成分。这一设计选择并非妥协,而是由开关电源的工作机制、稳定性需求及动态性...

关键字: 反馈控制 交流频率 动态

北京2025年12月15日 /美通社/ -- 亚马逊云科技在2025 re:Invent全球大会上宣布推出两项全新的Amazon Lambda功能——Amazon Lambda持久化函数(Amazon Lambda Du...

关键字: 亚马逊 函数 应用程序 SERVER

多数受访粉丝认为,AI驱动的功能会对他们观看体育赛事的方式产生重大影响 超过半数的受访者希望通过AI技术获得对过去、现在和未来体育赛事的评论和分析 移动体育应用...

关键字: IBM AI 应用程序 移动

青岛 2025年5月23日 /美通社/ -- 全球领先的消费电子和家电品牌海信今天宣布将谷歌全新Home API集成至其ConnectLife应用程序。今年秋季前,用户可通过该应用程序将第三方智能家居设备接入Conne...

关键字: API NEC 海信 应用程序

-Arya.ai推出MCP应用程序,将通用LLM转化为特定领域专家 印度孟买和纽约 2025年5月13日 /美通社/ -- Arya.ai今天宣布推出APEX MCP(模...

关键字: MCP 应用程序 AI 人工智能

北京2025年1月15日 /美通社/ -- 2025年1月8日,STIF第五届国际科创节暨新质生产力领航者峰会在北京举行。作为科技创新与数字化服务领域最具影响力的年度盛会之一,本届大会汇聚全球科创品牌,旨在通过构建多元、...

关键字: 数字化 APP 互联网 应用程序

推动技术创新与业务增长 北京2024年12月19日 /美通社/ -- 在亚马逊云科技2024 re:Invent全球大会上,亚马逊云科技与东南亚领先的超级应用程序Grab共同宣布,Grab已选择亚马逊云科技为首选云服务...

关键字: 亚马逊 应用程序 云服务 AI技术

Amazon Aurora DSQL是一款性能卓越的分布式SQL数据库,具备99.999%的多区域可用性、几乎无限的可扩展性、强一致性,且完全消除了基础设施管理的负担。 北京2024年12月13日 /美通社/ -- 亚...

关键字: 亚马逊 分布式 SQL数据库 应用程序

为数据、分析和AI提供统一平台 北京2024年12月10日 /美通社/ -- 亚马逊云科技在2024 re:Invent全球大会上,宣布推出新一代Amazon SageMaker,将客户所需的快速SQL分析、PB级大数...

关键字: 亚马逊 MAKER GE 应用程序

随着嵌入式系统的发展,从裸机应用程序迁移到实时操作系统(RTOS)已成为提升系统性能、可靠性和可维护性的重要趋势。RTOS为多任务处理、资源管理和实时响应提供了强大的支持,使得开发者能够构建更复杂、更高效的系统。本文将深...

关键字: RTOS 应用程序
关闭