基于AT91RM9200的多路CAN总线接口及驱动程序设计

发布者:朱颜素韵最新更新时间:2016-05-31 来源: eefocus关键字:MCP2515  CAN总线接口  驱动程序 手机看文章 扫描二维码
随时随地手机看文章
引言

  在铁路系统中,为了保证列车的安全运行,需要对铁轨及周围状况进行实时检测。目前采用的方法是在铁路沿线安装多个检测设备,用于检测洪水、大风、泥石流等自然灾害及轨温等参数。这些设备一般采用的通信方式是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独占一条中断线,以满足不同通信速率下数据处理的需要。

按此在新窗口浏览图片
图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]。

按此在新窗口浏览图片
图3  AT91RM9200 SPI控制器主机模式流程

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

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

按此在新窗口浏览图片
图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报文帧是否为远程帧。

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的中断处理流程相同。

按此在新窗口浏览图片
图5  IRQ0中断处理流程

按此在新窗口浏览图片
图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执行一个命令操作的代码。

结语

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

关键字:MCP2515  CAN总线接口  驱动程序 引用地址:基于AT91RM9200的多路CAN总线接口及驱动程序设计

上一篇:STM32的开漏模式和外接上拉电阻问题
下一篇:剖析LPC2119USB-CAN连接器电路设计方案

推荐阅读最新更新时间:2024-03-16 14:55

pcf8563外部RTC驱动程序基于STM32F10x
#ifndef uchar #define uchar unsigned char #endif #define SEC 0x02 //秒寄存器 #define MIN 0x03 //分寄存器 #define HOUR 0x04 //时寄存器 #define DAY 0x05 //日寄存器 #define WEEK 0x06 //周寄存器 #define MONTH 0x07 //月寄存器 #define YEAR 0x08 //年寄存器 #define read_ADD 0xA3 //写器件地址 #define write_ADD 0xA2 //读器件地址 tm timer_8563; /
[单片机]
CC1100的功能特性与在TinyOS环境下的CC1100驱动程序介绍
1 概述 无线传感器网络(Wireless Sensor Network, WSN)是当前信息技术领域的热点研究方向之一,它综合了传感器技术、遥测技术、嵌入式计算技术、分布式信息处理技术和无线通信技术,是一种通过无线通信方式形成的多跳自组织网络系统。无线传感器网络由大量体积小、功耗低、具有无线通信、传感和数据处理功能的传感器节点组成。节点是无线传感器网络的基本单元,它一般由传感器模块(传感器、A/D转换器)、处理器模块(微处理器、存储器)、无线通信模块(无线收发器)和能量供应模块(电池)组成。 本文研发的无线传感器网络节点选用Chipcon公司低功耗低成本单片收发芯片CC1100作为无线通信模块,将其通过SPI串行总线技术与M
[单片机]
CC1100的功能特性与在TinyOS环境下的CC1100<font color='red'>驱动程序</font>介绍
基于μC/OS-II的CAN总线驱动程序设计
  引言   应用实时多任务操作系统(RTOS)作为嵌入式设计的基础和开发平台将成为嵌入式应用设计的主流。μC/OS-II是一种源码公开、可移植性、可固化、可裁剪、占先式的实时多任务操作系统,目前已经得到广泛的应用。   在为电力系统接地选线装置开发的数据采集监测系统的设计中,笔者设计了集散式的数据采集结构,灵活的组态适应了目前国内多数中低压输配电网的数据采集需求。在此硬件平台上,笔者将实时操作系统μC/OS-II移植到TMS320LF2407A型号的DSP上,实现了多任务的并行执行,系统的可靠性和实时性得到大幅提升;设计了CAN总线驱动程序,使得下位采集处理模块与上位的主控制器具备了可靠快速的通信功能和协调功能。  
[嵌入式]
VxWorks下ComPactPCI总线驱动程序设计
   引言   VxWorks是美国Wind River公司专门为嵌入式处理器设计的一种模块化、高性能的实时多任务操作系统。嵌入式软件多采用交叉开发的方式,即主机运行开发工具Tonado,通过某种连接方式连接目标机,硬件平台为PC/104+架构。这里提出一种VxWorks操作系统下ComPactPCI总线驱动程序的设计及实现。该设计使用德国Kontron DT-64,它是一款高性能嵌入式计算机。采用Dual PentiLim 3 CPU,工作频率高达866 MHz,具有128 KB一级高速缓存和128 KB二级高速缓存。KontronDT-64与PC/AT标准完全兼容,并遵从PC/104+标准。具有PC/104结构的优点,适用
[嵌入式]
AURIX™嵌入式软件增加了符合ASIL D和SIL-2标准的驱动程序,以支持AUTOSARv4.4.0
英飞凌科技股份公司(FSE代码:IFX / OTCQX代码:IFNNY)通过在现有的AUTOSARv4.2.2 MCAL基础上增加对AUTOSARv4.4.0的支持,进一步扩展其AURIX™ TC3xx MCAL。这将加快OEM厂商的软件开发。针对ASIL D应用,MC-ISAR TC3xx路线图已更新,以提供符合ASIL D标准的驱动程序。通过即将推出的维护版2.25.0,该驱动程序将包含符合ASIL D标准的软件产品。2.30.0版本将提供对IEC 61508 SIL-2的支持。最新版本面向各个汽车领域的AUTOSAR应用,包括 发动机 、底盘、安全和车身,以及商业农用车、工业和船舶应用。 MC-ISAR AS440 EX
[汽车电子]
ST9+系列单片机I2C总线驱动程序实现
    摘要: 串行扩展总线技术是新一代单片机技术发展的一个显著特点,其中Philips公司推出的I2C总线最为著名。ST9+系列是意法半导体公司的单片机产品,能够很好地支持I2C总线协议。本文以ST9+单片机为例阐述I2C总线协议,并给出在ST9+单片机上实现I2C总线驱动程序的流程和方法。     关键词: I2C总线 串行扩展总线 ST9+ 总线驱动 串行扩展总线技术是新一代单片机技术发展的一个显著特点,其中Philips公司推出的 I2C总线最为著名。I2C总线最显著的特点是规范的完整性、结构的独立性和用户使用时的简单化。 I2C总线有严格的规范,如接口的电气特性、信号时序、信号传输的定
[工业控制]
基于CAN总线接口的红外检测系统的设计思路
    1 引言        一氧化碳(CO)是剧毒性气体,人体吸人后造成人体组织和细胞缺氧,导致引起中毒窒息。在煤矿井下,CO也是引起瓦斯爆炸的主要气体之一。CO无论是对工业生产还是人类都造成巨大的损害,因此,CO检测尤为重要,特别在煤矿井下,《煤矿安全规程》规定,井下作业场所的CO浓度应控制在0.002 4%以下。因此,实时、准确地测出井下CO气体浓度,对保障煤矿工业安全生产具有重要意义。 目前检测CO的方法主要有化学法、电化学法、气相色谱法等。这些方法普遍存在价格高、普适性差等问题,且测量精度较低。这里设计一种新的检测系统,选用红外CO传感器和 MSP430 单片机作为核心信号处理电路,结合数字滤波、温度补偿运算.
[嵌入式]
一种新型编码芯片及其驱动程序的设计方案
    摘 要: 介绍了C-Cube公司的处理器型芯片DVxper-II的内部结构、功能及其特点,提出了将DVxpert-II集成于一块PCI插卡上的设计方案,并论述了编码器虚拟驱动程序的实现方法。     关键词: DVxpert-II芯片 PCI总线 VxD     目前,电视节目的拍摄、制作、传输到播出正在实现数字化。MPEG视频音频编码标准的出现,解决了电视信号数字化后信息量过大而信道带宽有限的问题,加上数字视频硬件方面的产品不断进步,促进了各种数字视频产品的推出,这一切都预示着电视广播全面步入数字化的时代。数字电视产品的开发不仅能给观众带来高品质画面和音响效果的享受,而且MPEG-II视频音频压缩的ATM
[应用]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
  • 最近困扰在心中的一个小疑问终于解惑了~~
    最近在驱动方面一直在概念上不能很好的理解 有时候结合别人写的一点usb的例子能有点感觉,但是因为arm体系里面没有像单片机那样直接讲解引脚 ...
  • 学习ARM开发(1)
    做任何事情之前,一定要想好目标。没有目标的事情是做不好的,也做不成。我的目标就是学习ARM开发,当然是深入的学习。目标如下 :1、学习A ...
  • 学习ARM开发(2)
    天是星期天,刚好在家里休息。又是学习ARM的大好时机了。早上起得很早,因为都想着怎么样搞好这个ARM开发环境,总是心急的。搞得睡觉,也睡 ...
  • 学习ARM开发(4)
    已经把CPU大体架构学会了,当然我之前已经学习过80X86的结构,所以对于像RISC的计算机,也能想像到它是什么样的东西。如果没有学习过《微机 ...
  • 学习ARM开发(6)
    上一次,说到要学习ARM汇编,好,现在就开始。目前我的引导程序是在UBOOT1 1 2上修改过来的,大家可以下载UBOOT的源程序,也许你们会问在那 ...
  • 学习ARM开发(7)
  • 学习ARM开发(8)
  • 学习ARM开发(9)
  • 学习ARM开发(10)
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved