基于LPC2294的CAN总线主节点设计方案

发布者:中和子最新更新时间:2014-02-21 来源: ofweek关键字:LPC2294  CAN总线  主节点 手机看文章 扫描二维码
随时随地手机看文章

    1 总体设计

  主节点采用ARM7内核的LPC2294微控制器,使用RTL8019AS作为以太网控制器,软件上采用具有网络功能强、性能稳定、移植性好的μCLi nux作为操作系统。基于CAN总线的运动控制系统,主要由1个主节点(主控制器节点)、若干个从节点(电机控制节点)以及1台计算机构成,主节点与从节点之间通过CAN总线进行通信,主节点与计算机之间则通过以太网进行通信,如图1所示。

图1 运动系统控制结构

  主节点主要功能包括:1)通过CAN总线发送电机控制信息给从节点,并接收各从节点的反馈信息:2)通过以太网与计算机监控端进行通信,以实现远程监控。

  1.1 整体硬件设计

  主节点整体硬件结构如图2所示。

图2 硬件结构

  主节点采用的LPC2294基于ARM7TDMI内核的32位处理器,带有256kB高速FLASH、16kB静态RAM,内部集成4路CAN控制器,支持SRAM、FALSH扩展。由于LPC2294内部集成CAN,因此外部只需CAN收发器与之连接。CAN收发器选用周立功的CTMl050T.CTM1050T是一款带隔离的高速CAN收发器,主要功能是将CAN控制器的逻辑电平转换为CAN总线的差分电平,并具有隔离功能(DC2500 V)、ESD保护功能及TVS管防总线过压功能。 LPC2294具有外部存储器控制器(EMC),通过该部件可以扩展更多的FLASH和SRAM以及以太网、USB等外设。主节点采用RTL8019AS作为以太网控制器,分别使用MT45W4MW16、SST39VF1601、K9F2G08UOA进行SRAM、NORFLASH、NANDFLASH的扩展。

  1.2 软件结构

  主节点软件结构如图3所示,U-Boot作为BootLoader(启动引导程序),负责初始化目标板硬件与引导操作系统。这里采用μCLinux作为嵌入式操作系统。μCLinux(microcontrol linux)即“微控制器领域中的Linux系统”,主要是针对目标处理器没有存储管理单元(MMU)的嵌入式系统而设计的。它保留了Linux的大多数优点:稳定、良好的移植性、优秀的网络功能、对各种文件系统完备的支持和标准丰富的API.同时μCLinux包含大量的设备驱动程序,以及提供良好的驱动程序开发框架。驱动程序开发或配置主要包括CAN、以太网以及NANDFLASH3大部分。上层应用程序通过使用CAN接口函数、Socket接口以及库函数进行各种应用开发。整个系统的启动过程是:U-Boot把μCLinux内核从NORFLASH中加载到SRAM中,然后启动μCLinux,μCLinux初始化硬件及建立运行环境后,自动运行预设的应用程序。

图3 软件结构

  2 硬件设计

  2.1 LPC2294最小系统

  LPC2294采用LQFP144封装,最小系统需要模拟和数字3.3 V电源以及核心电源1.8 V.为了便于串口波特率的设置,外部接11.0 592 MHz晶振。P2.26(BOOT0)通过10 kΩ电阻上拉,P2.27(BOOT1)接一跳线座,通过跳线让P2.27可选择接高电平或低电平以选择从内部FLASH或外部NORFLASH启动。由CAT1025构成手动复位监控电路,提高了系统的可靠性。当SW按键按下时,CAT1025的2引脚输出持续为大于150 ms的低电平,LPC2294复位。在CAT1025的2引脚通过10 kΩ电阻上拉,防止产生错误的引脚输出状态,复位电路如图4所示。

图4 复位电路图

2.2 SRAM和NORFLASH电路

  为了运行μCLinux操作系统,必须扩展系统RAM与FLASH.LPC2294具有外部存储器控制器(EMC),该部件可同时支持多达4个单独配置的存储器组。每个存储器组都支持SRAM、ROM、Flash EPROM、Burst ROM以及外部I/O设备。主节点外部存储器地址分配情况如表1.[page]

表1 主节点外部存储器地址分配情况

  主节点采用的SRAM和NORFLASH分别是MT45W4MW16、SST39VF1601.MT45W4MW16是一个16位、8 MB容量的PSRAM.SST39VF1601是一个16位的CMOS多功能Flash MPF器件,储存容量为2 MB.其电路连接如图5、图6所示。

图5 SRAM电路连接图

图6 NORFLASH电路连接图

  2.3 NANDFLASH电路

  NANDFLASH用作存放μCLinux的根文件系统和应用程序,使用Jff2文件系统格式。NANDFLASH采用三星公司的K9F2G08UOA,存储容量为256 M.NANDFLASH的数据接口为8位串行接口,使用nCS2作为片选线,地址区间使用0x8200 0000-0x82FF FFFF,CLE(指令使能)和ALE(地址使能)分别连接到地址总线A2和A3,因此NANDFLASH的数据写入地址为0x82000000,命令写入地址为0x82000004,地址写入地址为0x82000008.R/B(准备/忙等待)连接到P1.18,用于读取当前状态,此引脚须上拉。其电路连接如图7所示。

图7 NANDFLASH电路连接图

2.4 CAN接口电路

  LPC2294内部集成了4路CAN控制器。每个总线上的数据传输速率高达1 Mb/s,兼容CAN2.0B.LPC2294没有集成CAN收发器,无法将TTL电平转换为CAN总线的差分电平信号。因此主节点采用了带有隔离功能的CTM1050T作为CAN收发器。在CAN总线两端须连接120Ω的电阻,以匹配总线阻抗,提高数据通信的抗干扰性及可靠性。以下是1路CAN收发器的电路图,其余3路连接方式与此一样。[page]

图8 CAN收发器电路图

  2.5 以太网电路

  主节点采用RTL8019AS作为以太网控制器。RTL8019AS是一种全双工即插即用的以太网控制器,已集成了RTL8019内核和一个16 kB的SDR AM存储器。它兼容RTL8019控制软件和NE2000 8 bit或16 bit的传输。网络接口采用带网络变压器的HR901170A.RTL8019AS使用的片选线为nCS3,地址范围为0x8300 0000-0x83FF FFFF,由于只有256 B的寄存器,因此可操作地址范围为0x8300 0000-0x8300 00FF.RTL8019AS使用20M晶振。

  3 软件设计

  3.1 U-Boot移植

  U-Boot(Universal Boot Loader)是遵循GPL条款的开放源码项目。从FADSROM、8xxROM、PPCBOOT逐步发展演化而来,支持多种嵌入式操作系统内核与微处理器系列。U-Boot的启动过程:初始化目标板硬件。给嵌入式操作系统提供板上硬件资源信息,加载、引导嵌入式操作系统。主节点使用U-Boot-2009-01,它不仅支持ARM-720T内核,而且间接提供了对LPC2294的板级支持。U-Boot的移植过程:首先通过修改star t.s文件设定系统主频:然后针对U-Boot所支持的LPC2292硬件资源配置信息作必要的修改,如外部存储器控制器(EMC)、以太网控制器等的硬件连接信息;接下来修改串口驱动代码使之与系统主频匹配;最后通过配置菜单配置U-Boot,主要配置所需要的命令和所要支持的硬件。

  3.2 μCLinux移植

  LPC2294没有MMU单元,不能运行定制的Linux,只能使用μCLinux.主节点移植的μCLinux版本号为2.6.25.从该版本开始,μCLinux支持CAN总线驱动。移植过程如下:

  1)打Philips公司针对该芯片提供的官方补丁;

  2)修改NANDFLASH部分的驱动程序;

  3)配置μCLinux内核;

  4)交叉编译内核。

  所需源码及补丁文件如表2所示。

表2 所需源码及补丁文件

  移植需要修改的部分驱动代码:

  1)修改arch/arm/math-lpc22xx/head.s因为μCLinux假设运行前已由BootLoader完成基本硬件初始化工作,因此不再进行系统时钟频率、串口初始化等基本硬件的初始化。在head.s文件中包括初始化存储器控制器、系统分频器PLL等部分代码,需要更改这部分代码,使之与U-Boot中Lowlevel_init.s文件的描述一致。另外μCLinux运行前必须由BootLoader将其内核装入内存偏移量为0x80000000的地方,因此要保证在μCLinux源码中的对应设置与启动引导程序的初始化设置相同。

  2)修改NANDFLASH驱动代码

  μCLinux内核从2.6.14开始更改了NANDFLASH的驱动代码,使驱动更加智能化,不再需要写读写函数,只需要实现读写时序函数。时序函数只关心如何来发送指令到NANDFLASH,例如写指令周期需要对ALE线使能,那么μCLinux下的读写函数会给这个时序函数发送一段指令中包含使能ALE线的指令,然后将数据写到数据总线上,CLE的实现与之相类似。

  3.3 CAN控制器驱动设计

  对于微处理器来说,CAN控制器完全是基于事件触发的,即CAN控制器会在本身状态发生改变时,会将状态变化的结果告诉微处理器。所以微处理器处理CAN控制器时,可以采用中断的方式,也可以采用轮询查看CAN控制器状态的方式来对CAN控制器做出相应的处理。在μCLinux下CAN驱动程序设计包括初始化函数、读函数、写函数、中断服务函数等设计,使用文件指针注册设备,用户程序则通过对设备文件的操作来收发CAN总线数据。CAN驱动程序主要功能包括:

  1)CAN控制器的初始化CAN控制器的初始化工作包括硬件使能CAN、设置管脚连接、软件复位、设置CAN报警界限、设置总线波特率、设置中断工作方式、设置CAN验收过滤器的工作方式以及启动等。

  2)CAN总线数据发送先将数据送到发送缓冲区,然后对发送寄存器赋值以启动发送。CAN控制器只负责发送,并不保证发送成功。因此要知道是否发送成功,须查询TCS状态位,或配合发送成功中断来判断。

  3)CAN总线数据接收CAN总线数据接收通过读取状态寄存器查询当前缓冲区中是否有数据,当有数据时将数据读出并放到CAN接收环形数据存储区中,当用户程序需要数据时则从该缓存区中读出。

  4)CAN中断处理 通过中断获知CAN控制器的当前状态,然后做出相应的处理,包括接收中断处理、发送中断处理以及异常中断处理。中断处理由中断服务函数实现。

  4 结论

  本文提出一种基于LPC2294微控制器,使用μCLinux作为操作系统的CAN主节点软硬件设计方案。主节点通过扩展SRAM、FLASH提高了系统的性能,采用带隔离功能的CAN收发器增强了CAN总线节点的抗干扰能力,外接以太网控制器实现了计算机远程监控。基于μCLinux的软件系统既提高了系统的稳定性、应用软件的开发效率,又使得众多的Linux平台软件可容易地移植到主节点,增强系统的功能。通过制作了样机并进行实验,验证了这一方案的有效性。

关键字:LPC2294  CAN总线  主节点 引用地址:基于LPC2294的CAN总线主节点设计方案

上一篇:一种基于EFSL的嵌入式MP3播放器设计方法
下一篇:一种非接触式单相费控智能电表的设计

推荐阅读最新更新时间:2024-03-16 13:36

CAN总线混合动力骄车电控系统的设计与实现
  混合动力汽车是一种由内燃机和电动机混合驱动的汽车,其主要特点是节能、环保。这种汽车在起步时用电动机驱动,消除了内燃机起步时由于燃烧不充分而排黑烟的现象。在汽车减速或刹车时,利用发电机把动能转化成电能,贮存到蓄电池中,实现能量回收达到节能的目的。由于这种汽车是内燃机和电动机两种动力并存,仅用传统的针对内燃机的电控系统无法实现两种动力的最佳配合,因此开发混合动力车的全新电控系统是十分必要的.本文以一种电机并联式混合动力汽车成功实现为背景,从系统角度介绍了混合动力汽车电控系统结构、功能及效果。 并联式混合动力驱动结构简介   并联式混合动力汽车的驱动系统结构见图1。发动机通过机械传动装置与驱动桥连接,电动机通过动力复合装置也与驱
[汽车电子]
<font color='red'>CAN总线</font>混合动力骄车电控系统的设计与实现
基于AT90CAN128单片机的某车型CAN总线系统设计
引言 现场总线技术 是目前自动化控制领域发展比较迅速的一门技术,其中CAN(Controller Area Network)总线 是在国际上应用最广泛的现场总线之一。近几年随着汽车电子行业的发展,现代汽车中CAN总线已经成为必须采用的装置之一。本文以ATMEL公司新近生产的一款内置CAN控制器的单片机——AT90CAN128为基础,设计了一款车载CAN总线系统,通过CAN智能测控仪表对车中部分单元参数量进行实时监控,使各单元之间协调运转。另外,传输线束大大简化,可靠性得到了极大的提高,有效节约了线束安装空间和系统成本。 1 AT90CAN128特性概述 1.1 基本特性 AT90CAN128 是基于AVR RISC
[单片机]
基于AT90CAN128单片机的某车型<font color='red'>CAN总线</font>系统设计
CAN总线协议及概念
现在的汽车已经不再仅仅是一种死气沉沉的交通工具了。计算机的发明,也让汽车有了一个职能的心。跟中 嵌入式 的计算机核心应用到汽车当中。那么如何规范这个核心的工作呢?这就需要CAN总线协议来帮忙了。现在让我们来了解一下这方面的知识吧。 1,CAN总线协议基本概念: (1),报文:总线上的信息以不同格式的报文发送,但长度有限。当总线开放时,任何连接的单元均可开始发送一个新报文。 (2),信息路由:在CAN系统中,一个CAN节点不使用有关系统结构的任何信息,这里包含一些重要的概念:系统灵活性——节点可以在不要求所有节点及其应用层改变任何软件或硬件的情况下,被接于CAN网络。报文 通信 ——一个报文的内容由其标示符ID命名,ID并不指
[嵌入式]
CAN总线学习系列之八——CAN节点与CPU连接的硬件调试
在软硬件联调的时候,必须首先要确保硬件是否工作正常。 硬件正常是整个调试工作的基础,在进行软件调试之前首先需要仔细检查硬件连接。保证每一个连接是正确的,没有虚焊。而在所有连接中CPU与CAN控制器的连接又是最重要的。所以我们采用软件方法对CAN控制器与CPU的连接接口进行了检测测试。检测步骤如下: (1)       CAN节点上电复位后,检测SJA1000的复位管脚电平应为高电平,反之说明SJA1000的复位电路不正常。 (2)       向SJA1000的测试寄存器写入AAH,再读SJA1000的测试寄存器,结果应该是AAH,如果不是,说明数据线,地址线,控制线的连接有问题。 (3)       向SJA1000的测试寄存器写
[嵌入式]
基于ARM7和CAN总线的电子送经卷取系统设计
  本文利用性价比高的主控器ARM7-LPC2194、CAN接收器PCA82C250和TLP2631,设计了一种基于ARM7的纺织机送经和卷取系统,实现了送经卷取系统总线的网络节点设计,较好地解决了纺织机的电子送经和卷曲系统的数据传输问题。另外,本文系统的通信方案,对于其它工业测控领域也是可取的。   针对纺织机电子送经和卷取系统的数据传输效率低等问题,设计了一套基于CAN总线的送经和卷取的系统,该系统以CAN总线为通信方式,利用ARM主控制器,设计了电子送经和卷取系统的CAN总线通信硬件电路和相关软件,实现了主控结点与卷取驱动器和送经驱动器的高效通信,结果表明了该方法的有效性和可靠性。   电子送经卷取系统是纺织工艺流程的一
[电源管理]
基于ARM7和<font color='red'>CAN总线</font>的电子送经卷取系统设计
基于控制器的模块化独立光伏发电控制系统
引言 随着能源日益紧缺和环保压力不断增大,光伏发电技术以其资源丰富、清洁环保、受地域限制小等优点,越来越受到人们的重视。根据对现有光伏发电系统的调查分析,储能蓄电池的使用寿命是导致系统故障和失效的重要因素之一。传统的独立光伏发电系统一般采用单个充电控制器控制太阳能电池板对蓄电池进行充电。该方法基本能够满足小容量蓄电池的要求,但不能胜任大容量蓄电池或蓄电池组。大容量的蓄电池或蓄电池组充电时需要的充电电流较大,充电过程中充电控制器投入/切出充电频繁,对蓄电池冲击较大,易损坏蓄电池。当前,大容量蓄电池和蓄电池组正被逐渐广泛使用,因此,需要更加有效、可靠的充电控制方案。CAN总线有组态灵活、结构简单、可靠性高、通信速度快等特点,可以
[单片机]
基于控制器的模块化独立光伏发电控制系统
基于CAN总线的大容量汉字火灾楼层显示器报警系统方案设计
   1 引言   火灾楼层显示器作为火灾自动报警系统的重要组成部分,是一种安装在楼层或独立防火区中的数字式火灾报警显示装置。它通过报警总线与火灾报警控制器相连,处理并显示报警总线上的数据。火灾楼层显示器中的内置单片机将接收到的总线信息进行判断、分析和处理,将报警的探测器地址编号转换成相应的火警地点信息(例如房间号和房间类型等),连同火警类型一道通过液晶显示出来,同时发出声光报警信号,通知失火区域的人员。   目前国内现有的火灾楼层显示器大都以51单片机作为MCU。因为ROM寻址空间所限,火灾楼层显示器大都只能显示火警所在楼层号和地址号,无法以直观的汉字信息提示情况各异的具体火警地点。如果将汉字信息通过总线分发到各个楼层
[嵌入式]
CAN总线在汽车车身控制中的应用
引言 20世纪80年代以来,随着集成电路和单片机在汽车上的广泛应用,汽车上的电子控制单元越来越多,例如电子燃油喷射装置、防抱死制动装置(ABS)、安全气囊装置、电控门窗装置和主动悬架等等。在这种情况下,如果仍采用常规的布线方式,即电线一端与开关相接,另一端与用电设备相通,将导致车上电线数目的急剧增加,使得电线的质量占整车质量的4%左右。另外,电控系统的增加虽然提高了轿车的动力性、经济性和舒适性,但随之增加的复杂电路也降低了汽车的可靠性,增加了维修的难度。为此,改革汽车电气技术的呼声日益高涨。因此,一种新的概念——车用控制器局域网络CAN应运而生。 CAN是控制器局域网络(Controller Area Network)的简称
[汽车电子]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

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

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