| | 网站首页 | 资讯 | 培训中心 | 技术文章 | 软件下载 | 产品展示 | 留言板 | 电子商城 | 供求信息 | 求职招聘 | |
| 您现在的位置: 华信单片机 > 技术文章 > 设计应用 > 嵌入式系统 > 文章正文 |
|
||||||||||||||||
| 一个典型的嵌入式系统设计和实现 | ||||||||||||||||
作者:周缵 文章来源:芯原微电子(上海)有限公司 点击数: 更新时间:2005-6-17 ![]() |
||||||||||||||||
|
在计算机、互联网和通信技术高速发展的同时,嵌入式系统开发技术也取得迅速发展,嵌入式技术应用范围的急剧扩大。本文介绍了一种基于 ARM 和 FPGA ,从软件到硬件完全自主开发多功能车辆总线 (Multifunction Vehicle Bus)MVB 嵌入式系统的设计和实现。 系统设计和实现 通常来说,一个嵌入式系统的开发过程如下: • 确定嵌入式系统的需求; • 设计系统的体系结构:选择处理器和相关外部设备,操作系统,开发平台以及软硬件的分割和总体系统集成; • 详细的软硬件设计和 RTL 代码、软件代码开发; • 软硬件的联调和集成; • 系统的测试。 一、步骤 1 :确定系统的需求 : 嵌入式系统的典型特征是面向用户、面向产品、面向应用的,市场应用是嵌入式系统开发的导向和前提。一个嵌入式系统的设计取决于系统的需求。 1 、 MVB 总线简介 列车通信网( Train Communication Network, 简称 TCN )是一个集整列列车内部测控任务和信息处理任务于一体的列车数据通讯的 IEC 国际标准( IEC - 61375-1 ) , 它包括两种总线类型绞线式列车总线 (WTB) 和多功能车厢总线 (MVB) 。 TCN 在列车控制系统中的地位相当与 CAN 总线在汽车电子中的地位。多功能车辆总线 MVB 是用于在列车上设备之间传送和交换数据的标准通信介质。附加在总线上的设备可能在功能、大小、性能上互不相同,但是它们都和 MVB 总线相连,通过 MVB 总线来交换信息,形成一个完整的通信网络。在 MVB 系统中,根据 IEC - 61375 - 1 列车通信网标准, MVB 总线有如下的一些特点: 拓扑结构: MVB 总线的结构遵循 OSI 模式,吸取了 ISO 的标准。支持最多 4095 个设备,由一个中心总线管理器控制。简单的传感器和智能站共存于同一总线上。 数据类型: MVB 总线支持三种数据类型: a. 过程数据:过程变量表示列车的状态,如速度、电机电流、操作员的命令。过程变量的值叫过程数据。它们的传输时间是确定的和有界的。为保证这一延迟时间,这些数据被周期性地传送。 b. 消息数据:消息被分成小的包,这些包分别被编号并由目的站确认。消息包及与之相关的控制数据形成消息数据。消息数据以命令方式传输。功能消息被应用层所使用;服务消息用于列车通信系统自身的管理等。 c. 监视数据:是短的帧,主设备用它作同一总线内设备的状态校验、联机设备的检测、主权传输、列车初运行和其它管理功能。 介质访问形式: MVB 总线支持 RS485 铜介质和光纤。其物理层的数据格式为 1.5Mbps 串行曼彻斯特编码数据。 MVB 的介质访问是由总线管理器 BA 进行管理的,总线管理器 BA 是唯一的总线主设备,所有其它设备都是从设备。主设备按照某种预定的顺序对端口进行周期性轮询,在周期的间隔中,主设备转而处理偶发性请求。 可靠性措施: MVB 容错措施包括 发送的完整性:链路层有扩充的检错机制,该机制提供的汉明码距为 8 ,可检测位、帧和同步错误。 2 、 MVB 系统的基本需求如下 : a. 完全与 IEC-61375-1(TCN) 国际标准兼容,支持 MVB 总线定义的三种数据类型过程数据,消息数据,监视数据。 b. 系统可配置成为: c. 采用 ARM7TDMI 的处理器 d. 采用实时操作系统 e. 供 TCN 的实时协议栈协议( RTP ) f. 支持 4096 逻辑端口的过程数据 g. 支持与上位 PC104 主机的双口 RAM 接口 h. 输入电压 5V i. 工作环境温度:- 40 ℃~ 75 ℃ 3 、其他需求 多功能车辆总线 MVB 系统与用户的列车控制系统同步设计,有着严格的时间限制。 二、步骤 2 :设计系统的体系结构,协同分配硬件 / 软件方面的要求 嵌入式系统包含硬件和软件两部分:硬件架构上以嵌入式处理器为中心,配置存储器、 I/O 设备、通信模块等必要的外设;软件部分以软件开发平台为核心,向上提供应用编程接口( API ),向下屏蔽具体硬件特性的板级支持包 BSP 。嵌入式系统中,软件和硬件紧密配合,协调工作,共同完成系统预定的功能。根据 OSI 的七层模型可以确定链路层和物理层由硬件实现,其他各层由软件实现,如图 1 。
1 、嵌入式操作系统选择 :
根据系统的需求和以上的原则,在 MVB 系统中采用了 Vxworks 实时操作系统, VxWorks 是风河公司( Windriver )开发的实时操作系统之一,以其优秀的可靠性、实时性及内核的可裁减性,被广泛应用于通信、军事、航天、航空、工业控制等关键行业领域,其开发环境为 Tornado 。 2 、处理器的选择 :在为嵌入式系统选择处理器时需要考虑以下几个方面:
在本系统的设计中,综合以上各方面的因素,考虑到处理器性能,操作系统支持以及列车上严酷的工业环境等等,在 MVB 系统中选用了 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 如下
三、步骤 3 :详细的软硬件设计和 RTL 代码、软件代码开发 在系统架构确定的基础上,详细的软硬件设计就可以开始了。 硬件设计设计包括了 MVB 控制器的 FPGA 设计和 MVB 总线系统的板级设计,其中关键的 MVB 控制器的设计如图 5
如图所示, MVB 控制器包含以下功能模块:
2 、软件设计 于在 MVB 系统中,过程数据,消息数据,监视数据是三种不同的通讯机制,因此, MVB 系统软件的模块设计如图 6 。
四、软硬件的联调和集成 下面,以一个简单的例子来说明 MVB 系统的软硬件的集成和验证。 过程数据在 MVB 系统中是周期性发送的数据,其在本系统中的通讯机制如下:对于发送方,用户应用模块将一个端口的过程变量发送给过程数据处理模块,过程数据处理模块按照逻辑端口的设置定时通过链路层接口模块更新 Traffic Memory 当中的相应逻辑端口的数据,此时发送方软件的任务完成。发送方的 MVBC 硬件接收总线管理器 BA 定时发出的主帧,通过译码器解码得到相应的逻辑端口的值,通过查询 Traffic Memory 相关的逻辑端口发送设置后将 MVBC 自动设置为发送状态,将逻辑端口的数据作为过程数据从帧通过编码器发出,如图 7 所示:
对于接收方,其接收过程与发送方相逆,接收方的 MVBC 硬件接收总线管理器 BA 定时发出的主帧,通过译码器解码得到相应的逻辑端口的值,通过查询 Traffic Memory 相关的逻辑端口接收设置后将 MVBC 自动设置为接收状态将,在收到发送方发出的从帧后更新相应逻辑端口在 Traffic Memory 的数据并发出中断信号从而完成硬件的接收过程。接收方的软件可以用中断或定时查询的方式通过过程数据处理模块得到更新后的逻辑端口的过程数据 五、系统的测试 在本系统中,系统的测试即包括了软件的测试,也包括了硬件, FGPA 的测试,在本文中不再赘述。 |
||||||||||||||||
| 文章录入:admin 责任编辑:admin | ||||||||||||||||
| 【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口】 | ||||||||||||||||
| 最新热点 | 最新推荐 | 相关文章 | ||
| 嵌入式系统 |
网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!) |
| | 设为首页 | 加入收藏 | 联系站长 | 友情链接 | 版权申明 | 企业招聘 | 管理登录 | | |
![]() |
Copyright © 2004-2008 hx51.com hx51.cn All Rights Reserved |