新闻中心

EEPW首页>嵌入式系统>设计应用> 一个典型的嵌入式系统设计和实现

一个典型的嵌入式系统设计和实现

作者: 时间:2012-11-01 来源:网络 收藏

  二、步骤2:设计系统的体系结构,协同分配硬件/软件方面的要求

包含硬件和软件两部分:硬件架构上以嵌入式处理器为中心,配置存储器、i/o设备、通信模块等必要的外设;软件部分以软件开发平台为核心,向上提供应用编程接口(api),向下屏蔽具体硬件特性的板级支持包bsp。中,软件和硬件紧密配合,协调工作,共同完成系统预定的功能。根据osi的七层模型可以确定链路层和物理层由硬件实现,其他各层由软件实现,如图1。

图1:mvb的osi模型和软硬件划分。

  1、嵌入式操作系统选择:

  *通常而言,为一个选择操作系统要考虑如下几个因素:

  *操作系统支持的微处理器

  *操作系统的性能

  *操作系统的软件组件和设备驱动程序

  *操作系统的调试工具,开发环境、在线仿真器(ice)、编译器、汇编器、连接器、调试器以及模拟器等等

  *操作系统的标准兼容性

  *操作系统的技术支持程度

  *操作系统是提供源代码还是目标代码

  *操作系统的许可使用情况

  *操作系统的开发者声誉状况

  根据系统的需求和以上的原则,在中采用了vxworks实时操作系统,vxworks是风河公司(windriver)开发的实时操作系统之一,以其优秀的可靠性、实时性及内核的可裁减性,被广泛应用于通信、军事、航天、航空、工业控制等关键行业领域,其开发环境为tornado。

  2、处理器的选择:在为嵌入式系统选择处理器时需要考虑以下几个方面:

  *性能:处理器必须有足够的性能执行任务和支持产品生命周期。

  *工具支持:支持软件创建、调试、系统集成、代码调整和优化工具对整体项目成功与否非常关键。

  *操作系统支持:嵌入式系统应用需要使用有帮助的抽象来减少其复杂性。

  *开发人员过去的处理器经验:拥有处理器或处理器系列产品的开发经验可以减少可观的学习新处理器、工具和技术的时间。

  *成本,功耗,产品上市时间,技术支持等等

  在本系统的设计中,综合以上各方面的因素,考虑到处理器性能,操作系统支持以及列车上严酷的工业环境等等,在中选用了atmel用于工业控制领域的工业级的at91系列arm处理器at91m40800,它是基于arm7tdmi内核,内含高性能的32位risc处理器、16位高集成度指令集、8kb片上sram、可编程外部总线接口(ebi)、3通道16位计数器/定时器、32个可编程i/o口、中断控制器、2个usart、可编程看门狗定时器、主时钟电路和dram时序控制电路,并配有高级节能电路;同时,可支持jtag调试,主频可达到40mhz。

  3、相关外部设备的选择:

  在确定操作系统和处理器之后,就可以确定相关的外部设备,如flash,ram,串口等等。在mvb系统中,mvb控制器mvbc(multifunction vehicle bus controller)是一个mvb电路和实际的物理设备之间的接口控制器,它的主要功能是实现mvb总线信号与数据帧的编解码,纠错等功能,是本系统中要实现的关键的硬件模块。由于系统规模,上市时间等方面的要求,系统暂时不考虑asic实现,因此在mvb系统中用fpga来实现这个关键模块,fpga是asic最灵活和最合算的替代方案。考虑到系统需求与fpga资源,成本,供货情况等因素,最终选择了altera公司的cyclone系列fpga,其开发工具是quartus ii。

  4、mvb系统架构

  由以上的需求分析和选型,完整的系统硬件架构和软件架构如图2图3所示。

  其中,处理器和 mvbc通过traffic memory(tm)进行通讯数据交换,所有软件和mvbc要交换的控制信息和数据都可以在tm地址空间中找到,这个地址空间对处理器和mvbc都是可访问的。其示意图4如下

图4:traffic memory。

  三、步骤3:详细的软硬件设计和rtl代码、软件代码开发

  在系统架构确定的基础上,详细的软硬件设计就可以开始了。

  1、硬件设计

  硬件设计设计包括了mvb控制器的fpga设计和mvb总线系统的板级设计,其中关键的mvb控制器的设计如图5

图5:mvb控制器的框图。

  如图所示,mvb控制器包含以下功能模块:

  *编码器:产生曼彻斯特编码,传送数据帧

  *发送缓冲区:作为要发送的数据和crc检测值的缓冲区

  *译码器:接收、曼彻斯特译码,数据提取、数据错误检测

  *接收缓冲区:作为接收端数据和crc结果的缓冲区

  *报文分析单元:检测主帧和从帧超时,帧误检测、错误状态报告

  *状态控制寄存器:mvbc配置

  *主控单元:支持mvbc作为主设备或者从设备工作,支持队列消息传送

  *设备地址读取和储存单元:硬件定义的设备地址可以被不同的值覆盖

  *地址逻辑:把cpu对mvbc内部寄存器进行访问的输入地址进行解析;产生mvbc访问tm的输出地址

  *总线复用、转换单元:处理mvbc内部的数据传送

  *中断逻辑:支持16种中断源;

  *通用定时器:两个定时输出信号,可提供给系统同步使用

  *时钟产生电路:产生所有mvbc工作的时钟和计数器

  2、软件设计

  由于在mvb系统中,过程数据,消息数据,监视数据是三种不同的通讯机制,因此,mvb系统软件的模块设计如图6。

图6:mvb系统软件模块。



评论


相关推荐

技术专区

关闭