当前位置:首页 > 嵌入式 > 嵌入式硬件
[导读]引言在铁路系统中,为了保证列车的安全运行,需要对铁轨及周围状况进行实时检测。目前采用的方法是在铁路沿线安装多个检测设备,用于检测洪水、大风、泥石流等自然灾害及轨

引言

在铁路系统中,为了保证列车的安全运行,需要对铁轨及周围状况进行实时检测。目前采用的方法是在铁路沿线安装多个检测设备,用于检测洪水、大风、泥石流等自然灾害及轨温等参数。这些设备一般采用的通信方式是RS232、RS485或CAN,并通过专线连接至监控中心的各个监控设备。这种方式极大浪费了线路资源,也不易于设备的统一管理。因此,需要一种安装在铁路沿线的设备,它将附近的检测设备发送的信息统一收集并通过一条专线直接送往监控中心。为了与多个检测设备通信,必须同时具有多个RS232、RS485和CAN接口。基于这种应用需要,本文提出了扩展多个CAN总线接口的方法。

1 系统结构

1.1 芯片介绍系统

采用Atmel公司的AT91RM9200(以下简称“9200”)作为MCU。该处理器基于ARM920T内核,主频为180 MHz时,性能可达到200MIPS;最高主频为209 MHz。该处理器还具有丰富的外设资源,非常适合工业控制领域的应用[1];采用的操作系统是ARMLinux,内核版本为2.4.19。

目前主流的CAN协议控制器一般采用I/O总线(SJA1000等)或SPI接口(MCP2515等)与MCU进行通信。由于本设计采用PC /104总线扩展卡的方式来扩展多个RS232和RS485接口,没有多余的I/O片选线可用,因此最终选用9200的SPI接口与MCP2515进行多路CAN总线接口的扩展。

MCP2515是Microchip公司推出的具有SPI接口的独立CAN控制器。它完全支持CAN V2.0B技术规范,通信速率最高可达1 Mbps,内含3个发送缓冲器、2个接收缓冲器、6个29位验收滤波寄存器和2个29位验收屏蔽寄存器[2];它的SPI接口时钟频率最高可达10 MHz,可满足一个SPI主机接口扩展多路CAN总线接口的需要。

1.2 系统硬件接口

图1是9200与MCP2515的接口原理框图,通过9200的SPI接口,连接了5个MCP2515。由于9200的SPI从设备片选线数量有限,故采用片选译码方式,NPCS0可作为普通的外部中断线使用(NPCS0与IRQ5复用引脚)。由于9200的外部中断线资源有限,故采用中断线共享的方式,即分别有两个MCP2515共享同一中断线,最后一个MCP2515独占一条中断线,以满足不同通信速率下数据处理的需要。

 


500)this.width=500" border=0>

图1 AT91RM9200与MCP2515接口原理框图

 


图2 MCP2515 CAN总线接口电路

图2是MCP2515的外围CAN总线接口框图,图中省略了MCP2515和9200的接口部分。由于设备需要安装在铁路沿线,必须具有防雷击的能力。因此MCP2515与CAN总线收发器(TJA1050)之间采用高速光耦进行完全的电气隔离,并且光耦两端电路的电源也必须用电源隔离模块隔离开,这样才能真正起到隔离的作用。在TJA1050的CANH和CANL引脚与地之间连接2个30 pF的电容,可以过滤CAN总线上的高频干扰;2个二极管可以在总线电压发生瞬变干扰时起保护作用。光耦正常工作时输入电流为10 mA左右,内部发光二极管的正向电压降为1.7 V左右,因此要特别注意输入端串联电阻的阻值选择。

2 SPI主机的工作方式

9200通过SPI接口与5个MCP2515进行通信,9200的SPI控制器工作在主机模式,MCP2515工作在从机模式。MCP2515 支持多个指令(如复位指令、读指令、写指令等),以便于9200通过SPI接口对MCP2515的内部寄存器进行读/写操作。9200 SPI控制器作为主机时工作模式流程如图3所示[1]。

 


500)this.width=500" border=0>

图3 AT91RM9200 SPI控制器主机模式流程

需要注意的是,SPI使能后,只有在SPI_TDR(发送数据寄存器)中有数据时,才会根据片选配置(固定外设或可变外设)使能相应片选;而 SPI_TDR中无数据时,则片选自动禁用。因此,9200向MCP2515连续发送多个字节时,要保证在前一个字节传输完毕前,后一个字节就被写入到 SPI_TDR中,以避免片选被自动禁用;同时,在传输完每一个字节后,还要读取SPI_RDR(接收数据寄存器)。

下面以MCP2515的读指令为例,说明图4所示的驱动程序完成一次读指令操作(只读一个字节数据)的过程,并假设9200 SPI采用固定外设的片选配置方式。其他指令的软件实现流程与读指令类似。

 


500)this.width=500" border=0>

图4 SPI读指令操作软件流程

3 驱动程序设计

驱动程序是应用程序与硬件之间的中间软件层,它完全隐蔽了设备工作的细节。Linux操作系统根据设备中信息传送方式的不同,将设备分成3种类型:字符设备、块设备和网络设备[3]。9200与MCP2515的通信都是通过SPI接口以字节为单位进行的,因此MCP2515属于字符设备。由于5 个MCP2515共享9200的一个SPI接口,因此采用一个驱动程序来管理所有的MCP2515,这样做有利于对所有设备进行统一管理。

3.1 驱动程序中定义的主要数据结构

CAN总线通信是基于报文帧的,在驱动程序中,无论发送数据还是接收数据都是基于报文帧的操作[4],因此需要设计合适的数据结构以满足数据操作的需要。

3.1.1接收与发送CAN报文帧结构体

typedef struct {

unsigned char node_num;

unsigned intid;

unsigned char dlc;

unsigned char data[8];

int ext_flag;

int rtr_flag;

} CanFrame;

其中,node_num为MCP2515的节点号(0~4),id为CAN报文帧的标识符,dlc为数据长度(0~8),data为CAN报文帧的数据缓冲区,ext_flag用于标识CAN报文帧是否为扩展帧,rtr_flag用于标识CAN报文帧是否为远程帧。[!--empirenews.page--]

3.1.2 设备配置结构体

(1) 波特率和报文滤波配置结构体

typedef struct{

unsigned charnode_num;

CanBaudRatebaudrate;

CanFilter filter;

int br_flag;

int fi_flag;

} CanDevConfig;

其中,node_num为MCP2515的节点号(0~4),baudrate为CAN总线通信速率,filter为报文滤波配置结构,br_flag用于标识波特率配置是否有效,fi_flag用于标识报文滤波配置是否有效。 baudrate和filter的数据结构类型定义如下:

typedef enum {

_125kbps,

_250kbps,

_500kbps,

_1Mbps

} CanBaudRate;

typedef struct{

unsigned int mask_0;

unsigned int mask_1;

unsigned int filter_0;

unsigned int filter_1;

unsigned int filter_2;

unsigned int filter_3;

unsigned int filter_4;

unsigned int filter_5;

}CanFilter;

(2) 工作模式配置结构体

typedef struct{

unsigned char node_num;

unsigned char oper_mode;

} CanDevMode;

其中,node_num意义同上,oper_mode表示该节点的工作模式。MCP2515共有5种工作模式,分别是配置模式、休眠模式、仅监听模式、回环模式和正常模式。一般设备都工作在正常模式。

3.1.3 环形数据接收缓冲区结构体

typedef struct {

CanFrame can_recv_buf[RECV_BUF_SIZE];

int recv_pos;

int read_pos;

wait_queue_head_twq;

} CanDev;

其中,can_recv_buf为接收CAN报文帧环形数据缓冲区,recv_pos和read_pos分别表示数据存入和读出缓冲区的位置;wq定义的是一个等待队列,用于实现阻塞型read操作。

3.2 驱动程序接口

驱动程序的接口主要分为3个部分:初始化与退出函数接口,完成设备安装和卸载等操作;文件系统接口,由file_operations数据结构来完成;与设备的接口,完成对设备的读/写等操作。

3.2.1 初始化与退出函数

在安装驱动程序时,操作系统会调用初始化函数进行设备注册、设备初始化以及安装中断处理例程等操作。参考文献[3]详细论述了设备注册的方法,而这里主要讨论设备初始化时的配置方法。在本驱动程序中,设备初始化分两步:一是对9200的SPI控制器初始化,二是对5个MCP2515初始化。

在卸载设备驱动程序时会调用退出函数,退出函数主要完成设备的注销和中断释放。

参考文献[3]详细论述了中断处理例程的安装、设备注销和中断释放的方法,此处不再详述。

3.2.2 中断接收服务例程

MCP2515收到CAN报文帧后,产生中断并将INT引脚置低。9200响应外部中断,并调用和外部中断相对应的中断处理例程。中断处理例程共有 3个: at91_mcp2515_irq_handler_0响应IRQ0的中断,at91_mcp2515_irq_handler_1_2响应IRQ1的中断,at91_mcp2515_irq_handler_3_4响应IRQ2的中断。其中IRQ0只和一个MCP2515相连,而IRQ1和IRQ2分别被两个MCP2515所共享。IRQ0和IRQ1的中断处理流程分别如图5和图6所示,IRQ2与IRQ1的中断处理流程相同。

 


500)this.width=500" border=0>

图5 IRQ0中断处理流程

 


500)this.width=500" border=0>

图6 IRQ1中断处理流程

需要注意的是,在图5的处理流程中并没有清中断操作。这是因为采用了RX读缓冲区指令读取MCP2515 RX缓冲区中的数据。该指令操作结束后,MCP2515会自动清除相应的接收中断标志位。

3.2.3 文件系统接口定义

文件系统接口struct file_operations的成员全部是函数指针,这些指针指出了设备驱动程序所提供的入口点位置。本驱动程序所定义的file_operations为:

static struct file_operations at91_mcp2515_fops = {

owner: THIS_MODULE,

write: at91_mcp2515_write,

read:at91_mcp2515_read,

ioctl: at91_mcp2515_ioctl,

open: at91_mcp2515_open,

release:at91_mcp2515_release,

};

3.2.4 ioctl函数

ioctl函数用于对设备进行配置。我们在ioctl函数中实现了两个命令: IOCTRL_CONFIG_CAN_DEV用于配置节点的CAN总线波特率和报文滤波,IOCTRL_SET_OPER_MODE用于配置节点的工作模式。这两种配置命令所对应的配置参数都是指向应用层相应数据结构的指针,两个配置结构在3.1.2小节已经介绍过了。

用IOCTRL_CONFIG_CAN_DEV命令配置波特率和报文滤波时,在配置完成后,如果节点处于INACTIVE状态,则需要使能节点内部的接收中断,使能节点所对应的外部中断,并将节点状态设置为ACTIVE。在通常情况下,通过ioctl函数对需要配置的节点执行完 IOCTRL_CONFIG_CAN_DEV命令后,还要再对配置过的节点执行IOCTRL_SET_OPER_MODE命令,使节点处于正常的工作模式。

3.2.5 关于竞争问题

本系统是单CPU系统,采用Linux 2.4.19内核,且是非抢占式的;同时,此设计的驱动程序也只允许一个进程打开并操作该设备。在这种情况下,驱动程序中所涉及的竞争问题主要就是中断处理程序内核代码和其他设备操作的内核代码之间的资源竞争。在上文中所提到的所有设备操作中,都要通过9200的SPI接口与MCP2515进行通信。 9200与MCP2515进行通信都是以命令字节开始的,并且在一个命令操作过程中(一般会连续传输多个字节),片选和时钟是不能被禁用的,否则操作就会失败。因此,MCP2515的一个完整的命令操作就是一个临界区域,在对MCP2515进行一个命令操作的过程中必须禁用所有的中断,以保证命令操作的正常执行。在驱动程序中,采用local_irq_save和local_irq_restore函数对中断禁用和恢复,在这两个函数调用之间,就是对 MCP2515执行一个命令操作的代码。[!--empirenews.page--]

结语

本文针对特有的应用需求提出的多路CAN总线接口和驱动程序设计,经过测试,可以稳定正常地运行。关于驱动程序的编译和运行方法,参考文献 [3]有很好的说明。上层的测试程序编写也比较简单,但要注意数据结构的定义和底层驱动程序的一致性。本文侧重介绍设计的基本方法和实现基本的功能。 MCP2515本身提供了许多的功能,在实现基本功能的基础上,也可以根据自己的应用需要再进行功能扩展。

参考文献

[1] Atmel corporation. AT91RM9200 data sheet, 2006.

[2] Microchip Technology Inc. MCP2515 data sheet,2005.

[3] 魏永明,骆刚,姜君. LINUX设备驱动程序[M]. 第2版.北京:中国电力出版社,2004.

[4] 杜尚丰,曹晓钟,徐津.CAN总线测控技术及其应用[M].北京:电子工业出版社,2007.

徐晓东(硕士研究生),主要研究方向为嵌入式系统及其应用;

路红英(高级工程师),主要研究方向为计算机应用和多媒体技术;

张宁(教授),主要研究方向为计算机测控、视频技术以及嵌入式系统。

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

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭