新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > 从技术层级分析典型的嵌入式系统设计是什么样的?

从技术层级分析典型的嵌入式系统设计是什么样的?

作者: 时间:2018-08-07 来源:网络 收藏

本文引用地址:https://www.eepw.com.cn/article/201808/385691.htm

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所示


图2:MVB系统的硬件架构。


图3:MVB系统的软件架构。

其中,处理器和 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。


四、软硬件的联调和集成

下面,以一个简单的例子来说明MVB系统的软硬件的集成和验证。

过程数据在MVB系统中是周期性发送的数据,其在本系统中的通讯机制如下:对于发送方,用户应用模块将一个端口的过程变量发送给过程数据处理模块,过程数据处理模块按照逻辑端口的设置定时通过链路层接口模块更新Traffic Memory当中的相应逻辑端口的数据,此时发送方软件的任务完成。发送方的MVBC硬件接收总线管理器BA定时发出的主帧,通过译码器解码得到相应的逻辑端口的值,通过查询Traffic Memory相关的逻辑端口发送设置后将MVBC自动设置为发送状态,将逻辑端口的数据作为过程数据从帧通过编码器发出,如图7所示:


图7:过程数据通讯示例。

对于接收方,其接收过程与发送方相逆,接收方的MVBC硬件接收总线管理器BA定时发出的主帧,通过译码器解码得到相应的逻辑端口的值,通过查询 Traffic Memory相关的逻辑端口接收设置后将MVBC自动设置为接收状态将,在收到发送方发出的从帧后更新相应逻辑端口在Traffic Memory的数据并发出中断信号从而完成硬件的接收过程。接收方的软件可以用中断或定时查询的方式通过过程数据处理模块得到更新后的逻辑端口的过程数据

五、系统的测试

在本系统中,系统的测试即包括了软件的测试,也包括了硬件,FGPA的测试,在本文中不再赘述。

结束语

上述的MVB系统现已运行在列车控制系统中,成功实现对列车的运行控制、机车控制、车辆控制、状态监测、故障诊断。当然,如有需要,本文中的MVB系统可以转化成为ASIC设计,从而成为一个SOC的系统。


上一页 1 2 下一页

评论


相关推荐

技术专区

关闭