收藏 分享(赏)

CAN总线原理.doc

上传人:HR专家 文档编号:7521414 上传时间:2019-05-20 格式:DOC 页数:4 大小:19KB
下载 相关 举报
CAN总线原理.doc_第1页
第1页 / 共4页
CAN总线原理.doc_第2页
第2页 / 共4页
CAN总线原理.doc_第3页
第3页 / 共4页
CAN总线原理.doc_第4页
第4页 / 共4页
亲,该文档总共4页,全部预览完了,如果喜欢就下载吧!
资源描述

1、一、概述 对于一般控制,设备间连锁可以通过串行网络完成。因此,BOSCH 公司开发了 CAN 总线(Controller Area Network),并已取得国际标准化组织认证(ISO11898),其总线结构可参照 I SO/OSI 参考模型。同时 ,国际上一些大的半导体厂商也积极开发出支持 CAN 总线的专用芯片。通过 CAN 总线, 传感器、控制器和执行器由串行数据线连接起来。它不仅仅是将电缆按树形结构连接起来,其通信协议相当于 ISO/OSI 参考模型中的数据链路层,网络可根据协议探测和纠正数据传输过程中因电磁干扰而产生的数据错误。CAN网络的配制比较容易,允许任何站之间直接进行通信 ,

2、而无需将所有数据全部汇总到主计算机后再行处理。 二、CAN 在国外的发展 对机动车辆总线和对现场总线的需求有许多相似之处,即较低的成本、较高的实时处理能力和在恶劣的强电磁干扰环境下可靠的工作。奔驰 S 型轿车上采用的就是 CAN 总线系统;美国商用车辆制造商们也将注意力转向 CAN 总线;美国一些企业已将 CAN 作为内部总线应用在生产线和机床上。同时,由于 CAN 总线可以提供较高的安全性,因此在医疗领域、纺织机械和电梯控制中也得到广泛应用。三、CAN 的工作原理 当 CAN 总线上的一个节点(站)发送数据时,它以报文形式广播给网络中所有节点。对每个节点来说,无论数据是否是发给自己的 ,都对

3、其进行接收。每组报文开头的 11 位字符为标识符,定义了报文的优先级,这种报文格式称为面向内容的编址方案。在同一系统中标识符是唯一的,不可能有两个站发送具有相同标识符的报文。当几个站同时竞争总线读取时, 这种配置十分重要。 CAN 总线的报文发送和接收参见图 1。当一个站要向其它站发送数据时,该站的 CPU 将要发送的数据和自己的标识符传送给本站的 CAN 芯片, 并处于准备状态;当它收到总线分配时, 转为发送报文状态。CAN 芯片将数据根据协议组织成一定的报文格式发出,这时网上的其它站处于接收状态。每个处于接收状态的站对接收到的报文进行检测,判断这些报文是否是发给自己的,以确定是否接收它。由

4、于 CAN 总线是一种面向内容的编址方案, 因此很容易建立高水准的控制系统并灵活地进行配置。我们可以很容易地在 CAN 总线中加进一些新站而无需在硬件或软件上进行修改。当所提供的新站是纯数据接收设备时,数据传输协议不要求独立的部分有物理目的地址。它允许分布过程同步化,即总线上控制器需要测量数据时 ,可由网上获得 ,而无须每个控制器都有自己独立的传感器。 四、位仲裁 要对数据进行实时处理,就必须将数据快速传送 ,这就要求数据的物理传输通路有较高的速度。在几个站同时需要发送数据时,要求快速地进行总线分配。实时处理通过网络交换的紧急数据有较大的不同。一个快速变化的物理量,如汽车引擎负载, 将比类似汽

5、车引擎温度这样相对变化较慢的物理量更频繁地传送数据并要求更短的延时。 CAN 总线以报文为单位进行数据传送, 报文的优先级结合在 11 位标识符中,具有最低二进制数的标识符有最高的优先级。这种优先级一旦在系统设计时被确立后就不能再被更改。总线读取中的冲突可通过位仲裁解决。如图 2 所示,当几个站同时发送报文时 ,站 1 的报文标识符为 011111;站 2 的报文标识符为 0100110;站 3 的报文标识符为 0100111。所有标识符都有相同的两位 01,直到第 3 位进行比较时, 站 1 的报文被丢掉,因为它的第 3 位为高,而其它两个站的报文第 3 位为低。站 2 和站 3 报文的 4

6、、5、6 位相同,直到第 7 位时,站 3 的报文才被丢失。注意,总线中的信号持续跟踪最后获得总线读取权的站的报文。在此例中, 站2 的报文被跟踪。这种非破坏性位仲裁方法的优点在于,在网络最终确定哪一个站的报文被传送以前,报文的起始部分已经在网络上传送了。所有未获得总线读取权的站都成为具有最高优先权报文的接收站,并且不会在总线再次空闲前发送报文。 CAN 具有较高的效率是因为总线仅仅被那些请求总线悬而未决的站利用,这些请求是根据报文在整个系统中的重要性按顺序处理的。这种方法在网络负载较重时有很多优点,因为总线读取的优先级已被按顺序放在每个报文中了,这可以保证在实时系统中较低的个体隐伏时间。 对

7、于主站的可靠性,由于 CAN 协议执行非集中化总线控制,所有主要通信, 包括总线读取 (许可)控制,在系统中分几次完成。这是实现有较高可靠性的通信系统的唯一方法。五、CAN 与其它通信方案的比较 在实践中,有两种重要的总线分配方法 :按时间表分配和按需要分配。在第一种方法中 ,不管每个节点是否申请总线,都对每个节点按最大期间分配。由此, 总线可被分配给每个站并且是唯一的站,而不论其是立即进行总线存取或在一特定时间进行总线存取。这将保证在总线存取时有明确的总线分配。在第二种方法中,总线按传送数据的基本要求分配给一个站 ,总线系统按站希望的传送分配(如:Ethernet CSMA/CD)。因此,当

8、多个站同时请求总线存取时,总线将终止所有站的请求,这时将不会有任何一个站获得总线分配。为了分配总线, 多于一个总线存取是必要的。 CAN 实现总线分配的方法,可保证当不同的站申请总线存取时,明确地进行总线分配。这种位仲裁的方法可以解决当两个站同时发送数据时产生的碰撞问题。不同于 Ethernet 网络的消息仲裁,CAN 的非破坏性解决总线存取冲突的方法,确保在不传送有用消息时总线不被占用。甚至当总线在重负载情况下,以消息内容为优先的总线存取也被证明是一种有效的系统。虽然总线的传输能力不足,所有未解决的传输请求都按重要性顺序来处理。在 CSMA/CD 这样的网络中,如 Ethernet,系统往往

9、由于过载而崩溃 ,而这种情况在 CAN 中不会发生。六、CAN 的报文格式 在总线中传送的报文,每帧由 7 部分组成, 见图 3。CAN 协议支持两种报文格式 ,其唯一的不同是标识符(ID)长度不同, 标准格式为 11 位, 扩展格式为 29 位。 TB17125002.GIF; 在标准格式中,报文的起始位称为帧起始 (SOF),然后是由 11 位标识符和远程发送请求位 (RTR)组成的仲裁场。RTR 位标明是数据帧还是请求帧 ,在请求帧中没有数据字节。 控制场包括标识符扩展位(IDE),指出是标准格式还是扩展格式。它还包括一个保留位 (ro),为将来扩展使用。它的最后四个字节用来指明数据场中

10、数据的长度(DLC)。数据场范围为08 个字节,其后有一个检测数据错误的循环冗余检查(CRC)。 应答场(ACK)包括应答位和应答分隔符。发送站发送的这两位均为隐性电平( 逻辑 1),这时正确接收报文的接收站发送主控电平(逻辑 0)覆盖它。用这种方法,发送站可以保证网络中至少有一个站能正确接收到报文。 报文的尾部由帧结束标出。在相邻的两条报文间有一很短的间隔位,如果这时没有站进行总线存取,总线将处于空闲状态。七、数据错误检测 不同于其它总线,CAN 协议不能使用应答信息。事实上,它可以将发生的任何错误用信号发出。CAN 协议可使用五种检查错误的方法, 其中前三种为基于报文内容检查。 1.循环冗

11、余检查(CRC) 在一帧报文中加入冗余检查位可保证报文正确。接收站通过 CRC 可判断报文是否有错。 2.帧检查 这种方法通过位场检查帧的格式和大小来确定报文的正确性,用于检查格式上的错误。 3.应答错误 如前所述,被接收到的帧由接收站通过明确的应答来确认。如果发送站未收到应答, 那么表明接收站发现帧中有错误,也就是说 ,ACK 场已损坏或网络中的报文无站接收。CAN 协议也可通过位检查的方法探测错误。 4.总线检测 有时,CAN 中的一个节点可监测自己发出的信号。因此,发送报文的站可以观测总线电平并探测发送位和接收位的差异。 5.位填充 一帧报文中的每一位都由不归零码表示,可保证位编码的最大

12、效率。然而, 如果在一帧报文中有太多相同电平的位,就有可能失去同步。为保证同步 ,同步沿用位填充产生。在五个生。在五个连续相等位后,发送站自动插入一个与之互补的补码位; 接收时,这个填充位被自动丢掉。例如,五个连续的低电平位后 ,CAN 自动插入一个高电平位。CAN 通过这种编码规则检查错误,如果在一帧报文中有 6 个相同位,CAN 就知道发生了错误。 如果至少有一个站通过以上方法探测到 一个或多个错误,它将发送出错标志终止当前的发送。这可以阻止其它站接收错误的报文,并保证网络上报文的一致性。当大量发送数据被终止后,发送站会自动地重新发送数据。作为规则 ,在探测到错误后 23 个位周期内重新开

13、始发送。在特殊场合,系统的恢复时间为 31 个位周期。 但这种方法存在一个问题,即一个发生错误的站将导致所有数据被终止, 其中也包括正确的数据。因此,如果不采取自监测措施 ,总线系统应采用模块化设计。为此 ,CAN 协议提供一种将偶然错误从永久错误和局部站失败中区别出来的办法。这种方法可以通过对出错站统计评估来确定一个站本身的错误并进入一种不会对其它站产生不良影响的运行方法来实现,即站可以通过关闭自己来阻止正常数据因被错误地当成不正确的数据而被终止。八、CAN 的可靠性 为防止汽车在使用寿命期内由于数据交换错误而对司机造成危险,汽车的安全系统要求数据传输具有较高的安全性。如果数据传输的可靠性足

14、够高,或者残留下来的数据错误足够低的话,这一目标不难实现。从总线系统数据的角度看 ,可靠性可以理解为 ,对传输过程产生的数据错误的识别能力。 残余数据错误的概率可以通过对数据传输可靠性的统计测量获得。它描述了传送数据被破坏和这种破坏不能被探测出来的概率。残余数据错误概率必须非常小,使其在系统整个寿命周期内,按平均统计时几乎检测不到。计算残余错误概率要求能够对数据错误进行分类 ,并且数据传输路径可由一模型描述。如果要确定 CAN 的残余错误概率,我们可将残留错误的概率作为具有 8090 位的报文传送时位错误概率的函数,并假定这个系统中有 510 个站,并且错误率为 1/1000,那么最大位错误概率为 1013 数量级。例如,CAN 网络的数据传输率最大为 1Mbps,如果数据传输能力仅使用 50%,那么对于一个工作寿命 4000 小时、平均报文长度为 80 位的系统,所传送的数据总量为 91010。在系统运行寿命期内,不可检测的传输错误的统计平均小于 102 量级。换句话说,一个系统按每年 365 天, 每天工作 8 小时,每秒错误率为 0. 7 计算,那么按统计平均,每 1000 年才会发生一个不可检测的错误。

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报