基于多路模拟开关的CAN总线通信协议设计毕业论文.doc

上传人:laozhun 文档编号:4141690 上传时间:2023-04-07 格式:DOC 页数:38 大小:455.50KB
返回 下载 相关 举报
基于多路模拟开关的CAN总线通信协议设计毕业论文.doc_第1页
第1页 / 共38页
基于多路模拟开关的CAN总线通信协议设计毕业论文.doc_第2页
第2页 / 共38页
基于多路模拟开关的CAN总线通信协议设计毕业论文.doc_第3页
第3页 / 共38页
基于多路模拟开关的CAN总线通信协议设计毕业论文.doc_第4页
第4页 / 共38页
基于多路模拟开关的CAN总线通信协议设计毕业论文.doc_第5页
第5页 / 共38页
点击查看更多>>
资源描述

《基于多路模拟开关的CAN总线通信协议设计毕业论文.doc》由会员分享,可在线阅读,更多相关《基于多路模拟开关的CAN总线通信协议设计毕业论文.doc(38页珍藏版)》请在三一办公上搜索。

1、基于多路模拟开关的CAN总线通信协议设计摘要 以stm32107vc单片机为背景,以多路模拟开关为基础,以利用CAN总线较强的实时性,较远的传输距离,较强的电磁干扰能力,以及极低传送错误率的特点并添加多路模拟开关实时控制的优化功能用于各种生产现场为目的,详细介绍了CAN总线的特点和通信方式,并以此搭建了各节点间的通信。详细介绍了CAN总线节点间通信的软件及协议设计,通过程序控制CAN收发器,配置接收中断以及过滤器,根据报文中的ID过滤不需要的信息,并向其他节点发送信息,通过CPU 的GPIO向模拟开关发送高低电平,来实现模拟开关在不同情况下打开或关闭通信线路,用来将整个CAN总线上连接的节点分

2、划到各个小局域网中,控制总线上的数据流量,避免不必要的信息传播,减少CAN总线的负担,提高了效率。关键词 stm32107vc CAN总线 过滤器 多路模拟开关 GPIOCAN BUS Communication Protocol Design Based On Multi-Channel Analog SwitchAbstract Based on the stm32107vc single-chip microcomputer as the background,based on the multi-channel analog switch,to take advantage of th

3、e characteristics of CAN buss strong real-time, far transmission distance, strong ability of electromagnetic interference,and the very low transmission error rate, and add a optimization function of multi-channel analog switch control in real time, used for various production site for the purpose, i

4、ntroduced the CAN bus characteristics and communication way, and to set up the communication between each node. Introduced the CAN bus node communication between software and protocol design, through program control the CAN transceiver, configuration and receive interrupt filter, according to the me

5、ssage ID of the filter doesnt need to information, and send information to the other node, through the GPIO CPU to send high and low level to the analog switch, to achieve the analog switch on or off line in different circumstances, used to connect on the CAN bus node partition to the small local ar

6、ea network, control the data flow on the bus, avoid unnecessary information dissemination, reduce the burden of the CAN BUS, improved the efficiency.Key Words stm32107vc CAN BUS filter multi-channel analog switch GPIO目 录引 言IX第一章 绪 论11.1 CAN总线11.1.1 CAN总线的概念11.1.2 CAN总线的应用11.1.3多路模拟开关11.2本文的主要工作设计基于多

7、路模拟开关的CAN总线通信协议1第二章 CAN总线系统结构及特点22.1 CAN总线网络结构22.2 CAN总线系统结构22.3 CAN总线的特点4第三章 CAN总线的通信方式63.1 CAN总线上的电平信号63.2 数据交换原理63.3 实时数据传送73.4 消息的帧格式(Frame format)73.5 STM32的CAN总线接收与发送133.5.1 工作模式133.5.2 工作流程143.6 CAN总线的传输速率与传输距离17第四章 多路模拟开关184.1多路模拟开关的用途及构成184.2多路模拟开关的特点184.3 多路模拟开关的工作原理19第五章 多路模拟开关控制CAN总线通信设计

8、205.1目的205.2电路设计205.3实验过程215.4软件实现215.4.1初始化配置225.4.2 收发实现245.4.3 主函数26结 论27致谢语28参考文献29附录:30引 言CAN是控制器局域网络(Controller Area Network, CAN)的简称,属于现场总线(Fieldbus)的范畴,是众多的属于现场总线标准之一,是由研发和生产汽车电子产品著称的德国BOSCH公司开发了的,并最终成为国际标准(ISO118?8)。是国际上应用最广泛的现场总线之一。 在北美和西欧,CAN总线协议已经成为汽车计算机控制系统和嵌入式工业控制局域网的标准总线,并且拥有以CAN为底层协议

9、专为大型货车和重工机械车辆设计的J1939协议。它适用于工业控制系统,具有通信速率高、可靠性强、连接方便、性能价格比高等诸多特点。它是一种有效支持分布式控制或实时控制的串行通信网络,以其短报文帧及CSMA/CD-AMP(带有信息优先权及冲突检测的载波监听多路访问)的MAC(媒介访问控制)方式而倍受工业自动化领域中设备互连的厚爱。近年来,其所具有的高可靠性和良好的错误检测能力受到重视,被广泛应用于汽车计算机控制系统和环境温度恶劣、电磁辐射强和振动大的工业环境。由于CAN总线的广泛应用,人们对其要求越来越多,对其的需求也不断变化,基于多路模拟开关的CAN总线通信协议,实现了生产现场局域网中各个节点

10、在不同需求时可以自动选择是否至于相邻的节点通信以提高通信效率,减轻通信压力,使CAN总线变得更加灵活多变,以满足不同的需求。第一章 绪 论 1.1 CAN总线1.1.1 CAN总线的概念CAN是控制器局域网络1(Controller Area Network, CAN)的简称,属于现场总线(Fieldbus)的范畴,是众多的属于现场总线标准之一,是由研发和生产汽车电子产品著称的德国BOSCH公司开发了的,并最终成为国际标准(ISO118?8)。是国际上应用最广泛的现场总线之一。在北美和西欧,CAN总线协议已经成为汽车计算机控制系统和嵌入式工业控制局域网的标准总线,并且拥有以CAN为底层协议专为

11、大型货车和重工机械车辆设计的J1939协议。1.1.2 CAN总线的应用CAN总线适用于工业控制系统,具有通信速率高、可靠性强、连接方便、性能价格比高等诸多特点2。近年来,其所具有的高可靠性和良好的错误检测能力受到重视,被广泛应用于汽车计算机控制系统和环境温度恶劣、电磁辐射强和振动大的工业环境。1.1.3多路模拟开关模拟开关3是一种在数字信号控制下将模拟信号接通或断开的原件或电路, 从多个模拟输入信号中切换选择所需输入通道模拟输入信号电路。多路模拟开关一般由开关原件和控制电路两部分组成。可以方便迅速的断开,接通电路,以实现各种功能的优化。1.2本文的主要工作设计基于多路模拟开关的CAN总线通信

12、协议使用两块stm32107vc主板搭建起CAN总线通信网络,将多路模拟开关加入CAN总线通信系统中,使用GPIO控制多路模拟开关的通断控制CAN总线上不同节点的通信通道的断与开,依照各种生产现场的不同情况,灵活的设计和控制各个节点的通信,避免不必要的通信广播到所有节点,以提高通信效率,减轻通信压力,使CAN总线变得更加灵活多变,以满足不同的需求。减少为之后复杂的通信模型做基础。第二章 CAN总线系统结构及特点2.1 CAN总线网络结构CAN总线已用于生活的各个方面,比如工厂生产线,汽车控制系统等,在汽车控制系统中CAN总线的作用就是将整车中各种不同的控制器连接起来,实现信息的可靠共享,并减少

13、整车线束数量。可以设想一种极端情况,如图2.1所示:组合开关组合灯具电磁阀雨刷电机仪表图2.1 汽车CAN总线网络示意图Fig.2.1 Car CAN bus network diagram对于一般的CAN总线网络4,其网络结构图可以简化为图2所示节点1节点2节点1节点3节点4CAN-busCANHCANLCANHCANLCANHCANLCANHCANL图2.2 CAN总线网络拓扑结构图Fig.2.2 CAN bus network topological structure2.2 CAN总线系统结构CAN数据传输系统中每个节点的内部增加了一个CAN控制器,一个CAN收发器;每个节点外部连接了

14、两条CAN数据总线5。在系统中每个节点内部还装有一个数据传递终端。(1)CAN控制器。CAN控制器作用是接收控制单元中微处理器发出的数据,处理数据并传给CAN收发器。同时CAN控制器也接收收发器收到的数据,处理数据并传给微处理器。(2)CAN收发器。CAN收发器是一个发送器和接收器的组合,它将CAN控制器提供的数据转化成电信号并通过数据总线发送出去,同时它也接收总线数据,并将数据传到CAN控制器。CAN收发器电路图如图2.3所示图2.3 CAN收发器电路图Fig.2.3 CAN transceiver circuit diagram(3)数据传送终端。数据传送终端实际是一个电阻器,作用是避免数

15、据传输终了反射回来,产生反射波而使数据遭到破坏。(4)CAN数据总线。CAN数据总线是用于传输数据的双向数据线,分为CAN高(CAN_high)和低位(CAN_low)数据线。数据没有指定接收器,数据通过数据总线发送给各控制单元6。CAN总线结构如图2.4所图2.4 CAN总线结构图Fig.2.4 CAN bus structure2.3 CAN总线的特点(1)多主控制在总线空闲时,所有的单元都可开始发送消息(多主控制)。最先访问总线的单元可获得发送权(CSMA/CA 方式*1)。多个单元同时开始发送时,发送高优先级 ID 消息的单元可获得发送权。(2) 消息的发送在 CAN 协议中,所有的消

16、息都以固定的格式发送。总线空闲时,所有与总线相连的单元都可以开始发送新 消息。两个以上的单元同时开始发送消息时,根据标识符(Identifier 以下称为 ID)决定优先级。ID 并不 是表示发送的目的地址,而是表示访问总线的消息的优先级。两个以上的单元同时开始发送消息时,对各消 息 ID 的每个位进行逐个仲裁比较。仲裁获胜(被判定为优先级最高)的单元可继续发送消息,仲裁失利的 单元则立刻停止发送而进行接收工作。(3) 系统的柔软性 与总线相连的单元没有类似于“地址”的信息。因此在总线上增加单元时,连接在总线上的其它单元的软硬 件及应用层都不需要改变。 (4) 通信速度 根据整个网络的规模,可

17、设定适合的通信速度。 在同一网络中,所有单元必须设定成统一的通信速度。即使有一个单元的通信速度与其它的不一样,此单元也会输出错误信号,妨碍整个网络的通信。不同网络间则可以有不同的通信速度。 (5) 远程数据请求 可通过发送“遥控帧”请求其他单元发送数据。 (6)错误检测功能 错误通知功能错误恢复功所有的单元都可以检测错误(错误检测功能)。 检测出错误的单元会立即同时通知其他所有单元(错误通知功能)。 正在发送消息的单元一旦检测出错误,会强制结束当前的发送。强制结束发送的单元会不断反复地重新发送 此消息直到成功发送为止(错误恢复功能)。 (7) 故障封闭 CAN 可以判断出错误的类型是总线上暂时

18、的数据错误(如外部噪声等)还是持续的数据错误(如单元内部 故障、驱动器故障、断线等)。由此功能,当总线上发生持续数据错误时,可将引起此故障的单元从总线上隔离出去。 (8) 连接 CAN 总线是可同时连接多个单元的总线。可连接的单元总数理论上是没有限制的。但实际上可连接的单元 数受总线上的时间延迟及电气负载的限制。降低通信速度,可连接的单元数增加;提高通信速度,则可连接的单元数减少。第三章 CAN总线的通信方式3.1 CAN总线上的电平信号总线空闲时,CAN_H和CAN_L上的电压为2.5V在数据传输时,显性电平(逻辑 0):CAN_H 3.5V CAN_L 1.5V隐性电平(逻辑 1):CAN

19、_H 2.5V CAN_L 2.5V如图3.1所示为总线电平示意图总线输出的差分电压=- (3-1)当隐性时,输出差分电压为 =2VVcan-LVdiffVdiffVcan-H隐性位隐性位显性位时间tV图3.1 CAN总线电平信号Fig.3.1 CAN bus levelsignal当显性时,输出差分电压为 =0V3.2 数据交换原理CAN是一种基于广播的通讯机制,广播通讯依靠报文(Message)的传送机制来实现,因此CAN并未定义站及站地址,而仅仅定义了报文,这些报文依靠报文确认区(Identifier)来进行识别,一个消息报文确认区在一个网络中必须是唯一的,它不但描述了某一报文的意义,而

20、且还定义了报文的优先级,当很多站都在访问总线时,优先级是很重要的,因此,CAN是通过报文的确认区来决定报文的优先级的7。CAN使用地址访问的方法,使网络系统的配置变得非常灵活,用户很容易可以增加一个新的站到一个已经存在CAN网络里,而不用对已经存在的站进行任何硬件或软件上的修改,但必须此新增的站为完全的接收者,这样它将不会对网络上各节点的通讯产生影响。每个节点的收发器都会接收总线上的数据,但是要检查判断此数据是否是所需要的数据,如果不是将忽略掉。3.3 实时数据传送在实时处理系统中,通过网络交换紧急报文存在很大的不同:一个迅速改变的值,如发动机负载必须频繁的进行传送且要求延迟比其它的值如发动机

21、温度要小。发送的报文都要和其它的不太紧急的报文进行优先级的比较,在系统设计中,报文的优先级体现在写入报文确认区的二进制值,这些值不能被动态的改变。确认区中的值越小,其报文的优先级越高(也就是0比1的优先级高)。3.4 消息的帧格式(Frame format)通信是通过以下5种类型的帧进行的8。数据帧遥控帧错误帧过载帧帧间隔另外,数据帧和遥控帧有标准格式和扩展格式两种格式。标准格式有11个位的标识符(Identifier:以下称ID),扩展格式有29个位的ID。各种帧的用途如表1所示,帧帧用途数据帧用于发送单元向接收单元传送数据的帧。遥控帧用于接收单元向具有相同ID的发送单元请求数据的帧错误帧用

22、于当检测出错误时向其它单元通知错误的帧过载帧用于接收单元通知其尚未做好接收准备的帧。帧间隔用于将数据帧及遥控帧与前面的帧分离开来的帧表1 帧的种类及用途3.4.1 数据帧 数据帧由7个不同的位场组成:帧起始(Start of Frame)、仲裁场(Arbitration Frame)、控制场(Control Frame)、数据场(Data Frame)、CRC场(CRC Frame)、应答场(ACK Frame)、帧结尾(End of Frame)。数据场的长度为0到8位。报文的数据帧一般结构如图3.2所示。帧起始仲裁场控制场数据场CRC场ACK场帧结束数据帧图3.2 数据帧格式Fig.3.2

23、 data frame format下面具体分析数据帧的每一个位场 帧起始 帧起始(SOF)标志数据帧或远程帧的开始,仅由一个“显性”位组成。只有在总线空闲时才允许节点开始发送(信号)。所有节点必须同步于首先开始发送报文的节点的帧起始前沿。 仲裁场 仲裁场由标识符和远程发送请求位(RTR位)组成。RTR位在数据帧中为显性,在远程帧中为隐性。控制场控制场由6个位组成,标准格式和扩展格式的控制场格式不同。标准格式里的帧包括数据长度代码、IDE位(为显性位,见上文)及保留位r0。扩展格式里的帧包括数据长度代码和两个保留位:r1和r0。其保留位必须发送为显性,但是接收器认可“显性”和“隐性”位的任何组

24、合。 数据长度代码DLC,如表2所示表2 数据长度代码DLC数据字节的数目数据长度代码DLC3DLC2DLC1DLC00dddd1dddr2ddrd3ddrr4drdd5drdr6drrd7drrr8rddd数据长度代码指示了数据场里的字节数量。其中:d“显性”, r“隐性”,数据帧允许的数据字节数为0,1,7,8。其他的数值不允许使用。数据场数据场由数据帧里的发送数据组成。它可以为08个字节,每字节包含了8个位,首先发送最高有效位。循环冗余码CRC场CRC场包括CRC序列(CRC Sequence),其后是CRC界定符(CRC Delimiter)。应答场(ACK Field)应答场长度为2

25、个位,包含应答间隙(ACK Slot)和应答界定符(ACK Delimiter)。在ACK场(应答场)里,发送节点发送两个“隐性”位。当接收器正确地接收到有效的报文,接收器就会在应答间隙(ACK Slot)期间向发送器发送一“显性”位以示应答。帧结尾(标准格式以及扩展格式)每一个数据帧和远程帧均由一标志序列界定。这个标志序列由7个“隐性”位组成。 3.4.2远程帧作为接收器的节点,可以通过向相应的数据源节点发送远程帧激活该源节点,让该源节点把数据发送给接收器。远程帧也有标准格式和扩展格式,而且都由6个不同的位场组成:帧起始、仲裁场、控制场、CRC场、应答场、帧结尾。 与数据帧相反,远程帧的RT

26、R位是“隐性”的。它没有数据场,数据长度代码DLC的数值是不受制约的(可以标注为容许范围08里的任何数值),此数值是相应于数据帧的数据长度代码。远程帧结构如图3.3所示。 帧起始仲裁场控制场CRC场ACK场帧结束远程帧图3.3 远程帧结构Fig.3.3 Remote frame structure 3.4.3错误帧错误帧由两个不同的场组成,如图3.4所示。第一个场是不同节点提供的错误标志(ErrorFlag)的叠加,第二个场是错误界定符。为了能正确地终止错误帧,“错误认可”的节点要求总线至少有长度为3个位时间的总线空闲(如果“错误认可”的接收器有局部错误的话)。因此,总线的载荷不应为100%。

27、错误叠加标志错误界定符错误帧图3.4错误帧结构Fig.3.4 Error frame structure错误标志有两种形式的错误标志:激活错误标志和认可错误标志(有的文献译为:“主动”和“被动”错误标志或“活动”和“认可”错误标志)。l“激活错误”标志由6个连续的“显性”位组成。 “认可错误”标志由6个连续的“隐性”的位组成,除非被其他节点的“显性”位重写。检测到错误条件的“错误激活”的节点通过发送“激活错误”标志指示错误。错误标的格式破坏了从帧起始到CRC界定符的位填充规则(参见“编码”),或者破坏了ACK场或帧结尾场的固定格式。所有其他的节点由此检测到错误条件,并与此同时开始发送错误标志。

28、所形成的“显性”位序列就是把各个节点发送的不同的错误标志叠加在一起的结果,这个序列的总长度最小为6个位,最大为12个位。检测到错误条件的“错误认可”的节点通过发送“认可错误”标志指示错误,“错误认可”的节点等待6个相同极性的连续位,当这6个相同的位被检测到时,“认可错误”标志的发送就完成。错误界定符错误界定符包括8个“隐性”的位。错误标志传送了以后,每一个节点就发送一个“隐性”的位,并一直监视总线直到检测出一个“隐性”的位为止,然后就开始发送其余7个“隐性”位。3.4.4过载帧过载帧(OverloadFrame)包括两个位场:过载标志和过载界定符,其结构如图3.5所示。超载标志叠加超载界定符超

29、载帧图3.5 过载帧结构Fig.3.5 Overload frame structure有三种过载的情况会引发过载标志的传送:l 接收器的内部情况,需要延迟下一个数据帧和远程帧。l 在间歇(Intermission)的第一和第二字节检测到一个“显性”位。l 如果CAN节点在错误界定符或过载界定符的第8位(最后一位)采样到一个显性位,节点会发送一个过载帧。该帧不是错误帧,错误计数器不会增加。根据过载情况1而引发的过载帧只允许起始于所期望的间歇的第一个位时间,而根据情况2和情况3引发的过载帧应起始于所检测到“显性”位之后的位。通常为了延时下一个数据帧或远程帧,两种过载帧均可产生。 过载标志(Ove

30、rloadFlag)过载标志由6个“显性”的位组成。过载标志的所有形式和“激活错误”标志的一样。过载标志的格式破坏了间歇场的固定格式。因此,所有其他的节点都检测到过载条件并与此同时发出过载标志。如果有的节点在间歇的第3个位期间检测到“显性”位,则这个位将解释为帧的起始。 过载界定符(OverloadDelimiter)过载界定符包括8个“隐性”的位。过载界定符的形式和错误界定符的形式一样。过载标志被传送后,节点就一直监视总线直到检测到一个从“显性”位到“隐性”位的跳变。此时,总线上的每一个节点完成了过载标志的发送,并开始同时发送其余7个“隐性”位。3.4.5 帧间隔数据帧(或远程帧)与先行帧的

31、隔离是通过帧间隔实现的,无论此先行帧类型如何(数据帧、远程帧、错误帧、过载帧)。所不同的是,过载帧与错误帧之前没有帧间空间,多个过载帧之间也不是由帧间隔隔离的。帧间隔包括间歇、总线空闲的位场。如果“错误认可”的节点已作为前一报文的发送器,则其帧间隔除了间歇、总线空闲外,还包括称作“挂起传送”(暂停发送)(SuspendTransmission)的位场。 对于不是“错误认可”的节点,或作为前一报文的接收器的节点。对于作为前一报文发送器的“错误认可”的节点。 间歇(Intermission)间歇包括3个“隐性”的位。间歇期间,所有的节点均不允许传送数据帧或远程帧,唯一要做的是标示一个过载条件。如果

32、CAN节点有一报文等待发送并且节点在间歇的第三位采集到一显性位,则此位被解释为帧的起始位,并从下一位开始发送报文的标识符首位,而不用首先发送帧的起始位或成为一接收器。 总线空闲(BusIdle)总线空闲的时间是任意的。只要总线被认定为空闲,任何等待发送报文的节点就会访问总线。在发送其他报文期间,有报文被挂起,对于这样的报文,其传送起始于间歇之后的第一个位。总线上检测到的“显性”的位可被解释为帧的起始。 挂起传送(SuspendTransmission)“错误认可”的节点发送报文后,节点就在下一报文开始传送之前或总线空闲之前发出8个“隐性”的位跟随在间歇的后面。如果与此同时另一节点开始发送报文(

33、由另一节点引起),则此节点就作为这个报文的接收器。3.5 STM32的CAN总线接收与发送3.5.1 工作模式bxCAN控制器有 3 个主要的工作模式:初始化、正常和睡眠模式9。初始化模式软件通过对 CAN_MCR 寄存器的 INRQ 位置 1,来请求 bxCAN 进入初始化模式,然后等待硬件对 CAN_MSR 寄存器的 INAK 位置 1 来进行确认。 软件通过对 CAN_MCR 寄存器的 INRQ 位清 0,来请求 bxCAN 退出初始化模式,当硬件对 CAN_MSR 寄存器 的 INAK 位清 0 就确认了初始化模式的退出。 当 bxCAN 处于初始化模式时,报文的接收和发送都被禁止,并

34、且 CANTX 引脚输出隐性位(高电平)。初始化 CAN 控制器,软件必须设置 CAN_BTR 和 CAN_MCR 寄存器。 正常模式 在初始化完成后,软件应该让硬件进入正常模式,同步 CAN 总线,以便正常接收和发送报文。软件通过对 INRQ 位清 0 来请求从初始化模式进入正常模式,然后要等待硬件对 INAK 位清 0 来确认。在跟 CAN 总线取得同步, 即在 CANRX 引脚上监测到 11 个连续的隐性位(等效于总线空闲)后,bxCAN 才能正常接收和发送报文。 过滤器初值的设置不需要在初始化模式下进行,但必须在它处在非激活状态下完成(相应的 FACT 位为 0)。而 过滤器的位宽和模

35、式的设置,则必须在进入正常模式之前,即初始化模式下完成。 睡眠模式(低功耗) 软件通过对 CAN_MCR 寄存器的 SLEEP 位置 1,来请求进入这一模式。在该模式下,bxCAN 的时钟停止了, 但软件仍然可以访问邮箱寄存器。 当 bxCAN 处于睡眠模式,软件想通过对 CAN_MCR 寄存器的 INRQ 位置 1,来进入初始化式,那么软件必须 同时对 SLEEP 位清 0 才行。 有 2 种方式可以唤醒(退出睡眠模式)bxCAN:通过软件对 SLEEP 位清 0,或硬件检测 CAN 总线的活动。 3.5.2 工作流程(1)发送消息应用程序选择 1 个空发送邮箱;设置标识符、数据长度和待发送

36、数据;然后 CAN_TIxR 寄 存器的 TXRQ 位置 1,来请求发送。TXRQ 位置 1 后,邮箱就不再是空邮箱;而一旦邮箱不再为空,软件对邮箱 寄存器就不再有写的权限。TXRQ 位置 1 后,邮箱马上进入挂号状态,并等待成为最高优先级的邮箱,参见发送 优先级。一旦邮箱成为最高优先级的邮箱,其状态就变为预定发送状态。当 CAN 总线进入空闲状态,预定发送 邮箱中的报文就马上被发送(进入发送状态)。邮箱中的报文被成功发送后,它马上变为空邮箱,硬件相应地对 CAN_TSR 寄存器的 RQCP 和 TXOK 位置 1,来表明一次成功发送10。 如果发送失败,由于仲裁引起的就对 CAN_TSR 寄

37、存器的 ALST 位置 1,由于发送错误引起的就对 TERR 位置 1。 发送的优先级可以由标识符或发送请求次序决定: 由标识符决定。当有超过 1 个发送邮箱在挂号时,发送顺序由邮箱中报文的标识符决定。根据 CAN 协议,标识 符数值最低的报文具有最高的优先级。如果标识符的值相等,那么邮箱号小的报文先被发送。 由发送请求次序决定。通过对 CAN_MCR 寄存器的 TXFP 位置 1,可以把发送邮箱配置为发送 FIFO。在该模式 下,发送的优先级由发送请求次序决定。该模式对分段发送很有用。 时间触发通信模式: 在该模式下,CAN 硬件的内部定时器被激活,并且被用于产生时间戳,分别存储在 CAN_

38、RDTxR/CAN_TDTxR 寄存器中。内部定时器在接收和发送的帧起始位的采样点位置被采样,并生成时间戳。 (2)接收消息接收管理 接收到的报文,被存储在 3 级邮箱深度的 FIFO 中。FIFO 完全由硬件来管理,从而节省了 CPU 的处理负荷,简化了软件并保证了数据的一致性。应用程序只能通过读取 FIFO 输出邮箱,来读取 FIFO 中最先收到的报文。根 据 CAN 协议,当报文被正确接收(直到 EOF 域的最后 1 位都没有错误),且通过了标识符过滤,那么该报文被 认为是有效报文。 接收相关的中断条件 。* 一旦往 FIFO 存入 1 个报文,硬件就会更新 FMP1:0位,并且如果 C

39、AN_IER 寄存器的 FMPIE 位为 1,那么就 会产生一个中断请求。 * 当 FIFO 变满时(即第 3 个报文被存入),CAN_RFxR 寄存器的 FULL 位就被置 1,并且如果 CAN_IER 寄存器 的 FFIE 位为 1,那么就会产生一个满中断请求。 * 在溢出的情况下,FOVR 位被置 1,并且如果 CAN_IER 寄存器的 FOVIE 位为 1,那么就会产生一个溢出中断 请求。 标识符过滤 在 CAN 协议里,报文的标识符不代表节点的地址,而是跟报文的内容相关的。因此,发送者以广播的形式将报 文发送给所有的接受者。节点在接收报文时根据标识符的值决定是否需要该报文;如果需要,

40、就拷贝到 SRAM 里;如果不需要,报文就被丢弃且无需软件的干预。 为满足这一需求,bxCAN 为应用程序提供了 14 个位宽可变的、可配置的过滤器组(130),以便只接收那些软 件需要的报文。硬件过滤的做法节省了 CPU 开销,否则就必须由软件过滤从而占用一定的 CPU 开销。每个过滤 器组 x 由 2 个 32 位寄存器 CAN_FxR0 和 CAN_FxR1 组成。过滤器的模式的设置: 通过设置 CAN_FM0R 的 FBMx 位,可以配置过滤器组为标识符列表模式或屏蔽位模式。 为了过滤出一组标识符,应该设置过滤器组工作在屏蔽位模式。 为了过滤出一个标识符,应该设置过滤器组工作在标识符列

41、表模式。 应用程序不用的过滤器组,应该保持在禁用状态。 过滤器优先级规则: 位宽为 32 位的过滤器,优先级高于位宽为 16 位的过滤器; 对于位宽相同的过滤器,标识符列表模式的优先级高于屏蔽位模式; 位宽和模式都相同的过滤器,优先级由过滤器号决定,过滤器号小的优先级高。接收邮箱(FIFO) 在接收到一个报文后,软件就可以访问接收 FIFO 的输出邮箱来读取它。一旦软件处理了报文(如把它读出来), 软件就应该对 CAN_RFxR 寄存器的 RFOM 位进行置 1,来释放该报文,以便为后面收到的报文留出存储空间。中断 bxCAN 占用 4 个专用的中断向量。通过设置 CAN 中断允许寄存器 CA

42、N_IER ,每个中断源都可以单独允许和禁用。 * 发送中断可由下列事件产生: 发送邮箱 0 变为空,CAN_TSR 寄存器的 RQCP0 位被置 1。 发送邮箱 1 变为空,CAN_TSR 寄存器的 RQCP1 位被置 1。 发送邮箱 2 变为空,CAN_TSR 寄存器的 RQCP2 位被置 1。* FIFO0 中断可由下列事件产生: FIFO0 接收到一个新报文,CAN_RF0R 寄存器的 FMP0 位不再是00。 FIFO0 变为满的情况,CAN_RF0R 寄存器的 FULL0 位被置 1。 FIFO0 发生溢出的情况,CAN_RF0R 寄存器的 FOVR0 位被置 1。* FIFO1

43、中断可由下列事件产生: FIFO1 接收到一个新报文,CAN_RF1R 寄存器的 FMP1 位不再是00。 FIFO1 变为满的情况,CAN_RF1R 寄存器的 FULL1 位被置 1。 FIFO1 发生溢出的情况,CAN_RF1R 寄存器的 FOVR1 位被置 1。* 错误和状态变化中断可由下列事件产生: 出错情况,关于出错情况的详细信息请参考 CAN 错误状态寄存器(CAN_ESR) 。 唤醒情况,在 CAN 接收引脚上监视到帧起始位(SOF)。 CAN 进入睡眠模式。 3.6 CAN总线的传输速率与传输距离 CAN总线上任意两个节点之间的最大传输距离与其位速率相关。如表3所示表3 传输速

44、率与最大传输距离的关系位速率/kbps10005002501251005020105最大距离/m4013027053062013003300670010000第四章 多路模拟开关4.1多路模拟开关的用途及构成(1)用途多路模拟开关是一种在数字信号控制下将多路模拟信号接通或断开的元件或电路。(2)构成多路模拟开关一般由开关原件和控制(驱动)电路两部分组成。如图4.1所示控制电路开关元件图4.1 模拟开关结构图Fig.4.1 Analog switch structure 4.2多路模拟开关的特点 在该设计中使用的是TI的TS3A24159 DGS双路模拟开关,一下模拟开关均为TS3A24159

45、DGS双路模拟开关11。* 能指定闭合开关* 接通状态下低电阻(0.3)* 低电荷注入* 优秀的接通电阻匹配* 低总谐波失真* 1.65 v至3.6 v单电源工作* 封闭性能超过100毫安* 极低的通断时间(on/off 20ns/12ns)4.3 多路模拟开关的工作原理TS3A24159 DFGS双路模拟开关引脚,及内部结构如图4.2所示图4.2 模拟开关的引脚及内部结构Fig.4.2 pins and the internal structure analog switch 由图4.2 可知,COM为开关的公共端,NO,NC为选择端,IN为输入控制端,当IN引脚输入高或低电平时COM引脚相

46、应的接通NO或NC引脚。其功能如表4 所示表4 多路模拟开关TS3A24159 DGS功能表INNC to COMNO TO COM低ONOFF高OFFON从表4 可知当IN引脚是低电平是NC和COM是联通的,NO和COM是断开的,当IN为高电平时,则反之。用万用表测得模拟开关断开时电阻非常大,闭合时电阻为0.6 ,可见效果很好。第五章 多路模拟开关控制CAN总线通信设计5.1目的由于CAN总线被广泛用于各种生产现场,而各种生产现场对通信的要求各不相同,若只是用原始的CAN总线来实现各个生产现场的通信,可能会引起各种不便,如果在CAN总线通信协议的基础上添加上多路模拟开关模块,就可以利用多路模拟开关的灵活以及方便性,

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

当前位置:首页 > 办公文档 > 其他范文


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号