BoschCAN用户手册中文版._第1页
BoschCAN用户手册中文版._第2页
BoschCAN用户手册中文版._第3页
BoschCAN用户手册中文版._第4页
BoschCAN用户手册中文版._第5页
已阅读5页,还剩16页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1. C_CAN 用户手册 1术语和缩写Terms and AbbreviationsThis document uses the following terms and abbreviations.这个文档使用到以下的术语和缩写。Term MeaningCAN Controller Area Network控制器局域网BSP Bit Stream Processor位流处理器BTL Bit Timing Logic位时间机制CRC Cyclic Redundancy Check Register循环冗余码校验冗余DLC Data Length Code数据长度编码EML Error Management Logic错误管理机制FSM Finite State Machine有限动作状态TTCAN Time Triggered CAN 时间触发通讯的控制器局域网 2. C_CAN 用户手册 2Functional Description 功能简介C_CAN 是可以作为单独或集成 ASIC 一部分的 CAN 总线模块。用硬件描述语言描述 C_CAN 综合到逻辑器件。它包含 CAN 内核、消息 RAM、消息处理状态机、控制寄存器和模块接口。CAN 内核通信符合 CAN 协议规范 2.0A 和 2.0B。在使用中位速率可以编程达到 1M/S。硬件连接物理层需在接收发射器。在 CAN 网络中通信,每个消息目标需要设定,接收的消息目标和识别符掩码存储到消息 RAM 中。所有关于消息处理是在消息处理状态器中完成。这些功能包括消息过滤、CAN 内核与消息 RAM 之间的通信和消息发送中断请求并产生中断模块。C_CAN 中的寄存器组可以通过接口模块被外器 CPU 访问。这些寄存器用于控制或配置 CAN 内核和消息处理状态机,并存储到消息 RAM。在 C_CAN 模块中的接口模块可以定制成适合于用户使用的模块接口。C_CAN 具有以下的功能特性:支持 CAN 协议怎版本 2.0A 和版本 2.0B位速度达到 1M/S32 个消息目标(在消息 RAM 中有 32 个可以自定义接收或发送的消息目标)每个消息目标有自己的识别符掩码可编程的 FIFO 模式(消息目标在 FIFO 中连续存放)可屏蔽中断对于时间触发的 CAN 应用可以取消自动重传模式在自己测试操作可以设计成循环模式(重复发关这一个消息)兼容摩托罗拉公司 HC08 的 8 位单处理模块接口对 ARM 内核有 2 个 16 位的接口模式给 AMBA ABB 总路线3. C_CAN 用户手册 3模式结构 Block DiagramCAN CoreCAN 内核CAN 协议控制器和接收与发送移位寄存器完成消息的并行或串行转换Message RAM消息 RAN存储消息目标和识别符掩码Registers寄存器所有寄存器用于控制和配置 C_CAN 模块Message Handler消息状态处理机控制数据在 CAN 内核接收与发送移位寄存器与消息 RAM之间的传送,也在控制和配置寄存器中产生中断Module Interface 模块接口到目前为止,C_CAN 模块被分成种不同的接口。一种是对于摩托罗拉HC08 控制器的位接口,和二种来自 ARM 的 AMBA APB 总线的 16 位接口4. C_CAN 用户手册 4操作模式 Operating Modes、初始化程序 Software Initialization初始化程序开始前必须置 CAN 控制器中的控制寄存器中的 Init 位,或者由软件或硬件复位还是总线关闭。当 Init 被置位,所有与 CAN 传送的消息被停止。 CAN 总线的 CAN_TX状态为隐性(HIGH),错误处理寄存器状态不变,Init 置位不会改变任何配置寄存器。初始化 CAN 控制器时,处理器(CPU)必须设置位定时寄存器和每个消息对象。如何一个消息对象不需要,设置此消息的 MsgVal 没有效(0)即可。否则初始化全部消息对象。当 CAN 控制寄存器中的 Init 和 CCE 两者都置位时,配置位定时的位定时寄存器和位扩展定时寄存器才被激活。仅由处理器(CPU)复位 Init 才完成软件初始化。然后,在得到使用总线权和发送消息之前等待总线空闲时(产生 11 个连续隐性位),位流处理器(BSP)同步传数据。初始化消息对象时不需要将 Init 置位,可以在 CAN 控制器不工作的时候进行。在位流处理器(BSP)开始消息传输之前,所有消息对像需要初始化一个单独的识别符或初始消息无效。在正常工作期间改变消息对象的配置时,处理器(CPU)修改配置前先设置消息对象的 MsgVal 无效(0) 。修改配置完成,MsgVal 由处理器(CPU)l 置位,消息才有效。2、CAN 报文传送 CAN Message Transfer一旦初始化 C_CAN 和 Init 复位(设置为 0),C_CAN 的 CAN 内核同时自我检测总线和在总线上开始传送消息。如果接收到的消息符合本节点过虑的要求(通过消息状态处理机过滤),存储到相应的消息目标对象。整个消息包括仲裁识别位、数据长度(DLC)和 8 个字节数据都存储到消息目标对象。如果使用识别符(ID)掩码(屏蔽码),消息目标对象中的仲裁位可以被屏蔽(不仲裁相应被屏蔽的识别符位)。不管什么时候,处理器(CPU)可以通过 CAN 接口寄存器读或写每一条消息(报文)。在并发操作中,消息状态处理机保证数据可靠性。传送的消息(报文) 由处理器(CPU)更新。如果永久性的消息目标对象(仲裁位和控制位在初始化配置时被设定)存在消息(报文),仅数据位被处理器更新,然后将 TxRqst 和 NewDat 位置位,消息即开始传送。如几个 (个别)传送的消息配置成相同的消息对象目标(消息对象的编码值无效),这些消息传送请求前必须以对全部消息进行初始化设置。很多消息对象目标传送可以在同一时间请求,消息对象对像的先后顺序由自身的优级确定,消息可以随时更新或设置为无效,甚于在发送请求还在等待时候。消息未发送而被更新则旧的数据将丢弃。依照消息对象的配置,传送消息被自动请求,由接收带匹配识别符的远程帧。3、取消自动重传 Disabled Automatic Retransmission依据 CAN 规范,在传送期间仲裁已经丢失或干拢错误时,C_CAN 提供了自动重传帧的机制。在帧传送成功之前,帧传送服务不能被使用都证实。传送失败意味自动重传机制使能。当 C_CAN 工作在时间触发 CAN 环境时,自动重传机制也可以取消。编程 CAN 控制器中的 DAR 置位(1)取消自动重传机制。在这种操作模式中,程序必须考虑在消息缓冲控制寄存器中 TxRqst 和 NewDat 不同的情况。当每个消息报缓冲发送请求开始位(TxRqst)被复位 (0),,然而 NewDat 位依然置位(1).当传送成功后 NewDat 位复位,当传送失败 (仲裁丢失或传送错误 )NewDat依然不变( 置位 1),重新传送由处理器(CPU)置位 TxRqst 为 1。4、测试模式 Test Mode由处理器(CPU)设置 CAN 控制寄存器中的 Test 位置 1,进入测试模式。在测试模式中,测试寄存器中的 Tx1、Tx0、Lback、Silent 和 Basic 需在写。Rx监听 CAN_RX 引能脚的状态,并且仅读。当测试模式位 TEST 复位为 0,所有测试寄存器中的功能全部取消。5、无负载模式/只听模式 Silent ModeCAN 内核可以通过编程设置测试寄存器中的 Silent 置 1,运行于无负载模式。在无负载模式中,C_CAN 能接收有效数帧和有远程帧,但它仅发送确定接收位在 CAN 总线上,以及它不能发送。如 CAB 内核需要发送一个显性位(ACK 应答位,超载标志,激活错误标志),此位在内部自动更改以至 CAN 内核监听这个显性位(0), 尽管 CAN 总是出现在隐性状态。无负载模式可以用于分析 CAN 总线运行情况,在没有使用总线时通过传送一个显性位(应答位、错误帧)。在 ISO 11898-1,无负载模式被叫做总线监听模式。只听模式成功接收到消息也不会作应答,错误计数器停止,不传送消息,所以可以作位定时波特率软件自区配设置。6、循环模式/自检测模式 Loop Back Mode由编程测试寄存器位 Lback 置位(1),CAN 内核进入测试循环模式(控制寄存器中的 TEST=1)。在循环模式中, CAN 内核自我协商传送消息同时接收消息和存储通过过虑的消息到接收缓冲区。此模式提供了自我测试的功能,不受外部干拢影响。在循环模式中,CAN内核忽略应答信号错误(接收位采样在数据帧或远程帧应答场内)。在这个模式中,CAN 内核从自己的 Tx 输出执行一个反馈信号到 Rx 输入。实际上 CAN 内核把 CAN_RX 输入引脚断开。传送消息时监听 CAN_TX 引脚。自检测模式检测所有节点,没有任何活动的节点使用自接收命令,即使没有应答,CAN 也可会成功发送。7、循环结合无负载模式 Loop Back combined with Silent Mode编程 Lback 和 Silent 同时置位 (1),CAN 运行在在循环无负载模式。这种模式使用于自我测试(Hot Selftes),意味着 C_CAN 能在没有正常的 CAN 系统连接到 CAN_Tx 和 CAN_Rx 引脚上时,自测试运。在这个模式中, CAN_RX引脚被断开和 CAN_TX 引脚输出隐性(1)。8、Basic 模式 Basic Mode编程测试寄存器中的 Basic 位置位(1) ,内核工作于 Basic 模式。在这个模式中 C_CAN 模块工作是没有消息 RAM。IF1 使用作发送缓冲区。IF1 寄存器中的内容请求发送,由写 IF1 命令请求寄存器中的 Busy 位置位(1)。当 Busy 位置位时 IF1 寄存器锁定。Busy 位指示发送状态。一旦 CAN 总线空闲,CAN 内核移位处理器载入 IF1 寄存器中的内容并始传送。当成功发送,Busy 位复位(0),并释放 IF1 寄存器。在任何时候,未成功发送可以被中止,通过设置 IF1 命令请求寄存器中的Busy 位复位(0)。如果处理器对 Busy 进行复位,以防仲裁丢失或产生错误取消,可能需要重传消息。IF2 使用作接收缓冲区。从位移寄存器接收的消息内容存储到 IF2 寄存器,没有经过过滤。除些之外,移位寄存器中的内容在发送消息时被监听,每次读消息目标对象都初始化写 IF2 命令请求寄存器的 Busy 位为 1。移位寄存器的内容存储到IF2 寄存器。在 Basic 模式中,所有消息对象目标相关的控制、状态位和 Ifx 命令掩码寄存器控制位的赋值都被关闭。消息命令请求寄存器数值是无效。IF2 消息控制寄存器中的 NewDat 和 MsgLst 位依然保留他们的功能。 DLC3-0 显示接收数据长度(DLC),其他控制位读出为 0。在 Basic 模式中 CAN_WAIT_B 输出准备功能取消(总是为 1)。9、软件控制 CAN_TX 引脚 Software control of Pin CAN_TX在 CAN 发送时 CAN_TX 的四种输出功能都可以用到。除此之外,缺省值下进行串行数据输出,它能驱动 CAN 采样信号点而监听 CAN 内核位定时和能驱动连续的隐性或显示性值。最后的 2 个功能,结合可读 CAN_RX 引脚,可以使用检测 CAN 总线的物理层。CAN_TX 引脚输出模式选择通过编程测试寄存器中的 TX1 和 TX0 位。3 种 CAN_TX 引脚接口测试功能都带有所在 CAN 协议功能。选择 CAN 消息发送或循环测试模式(自检测模式)、无负载模式、Basic 模式,CAN_TX 必须放弃缺省值功能。5. C_CAN 用户手册 5 编程模式 Programmers ModelC_CAN 模块分配 256 位地址空间。这些寄存器组织成 16 位寄存器,高字节存放在奇数地址和低字节存放在偶数地址空间。双接口寄存器(IF1 和 IF2)控制处理器(CPU)访问消息目标对象 RAM,它们用于缓冲发送数据和从消息对象 RAM 读对数据。避免处理器(CPU)访问消息目标对象 RAM 和消息接收或发送之间冲突。5.1 硬件复位描述 Hardware Reset Description硬件复位以后(各寄存器的复位值依上表),除了总线关闭状态被复位(0),输出引脚 CAN_TX 复位为隐性(1)。软件初始化时 CAN 控制寄存器值为0x0001(Init = 1)。C_CAN 对 CAN 总线不会产生影响,直到处理器复位 Init 为0。在硬件复位,存储在消息对象 RAM 中的数据不会受到影响。上电,消息目标对象 RAM 的内容依情况而定。CAN 控制相关寄存器 CAN Protocol Related Registers在 CAN 内核中有涉及到 CAN 控制器的寄存器。它们控制 CAN 的工作模式、CAN 位定时器的配置和提供消息状态。1、CAN 控制寄存器(地址 0x01 & 0x00) CAN Control Register (addresses 0x01 & 0x00)Test 测试模式使能1 测试模式0 正常模式CCE 配置更改使能1 处理器(CPU)写存储到位定时器有效(当 Init = 1)0 处理器(CPU)不写存储位定时寄存器DAR 取消自动重传使能1 自动重传取消0 错误消息(报文) 自动重传EIE 错误中断使能1 使能 在状态寄存器中的 Boff 或 Ewarn 发生变化将发生中断0 取消 不会产生错误状态中断SIE 中断状态改变使能1 使能 当消传送成功或监测 CAN 总线错误将产生一个中断0 取消 不产生状态中断IE 模块中断使能1 使能 中断使 IRQ_B 为低,IRQ_B 依然为低直到所以中断被处理0 取消 模块中断 IRQ_B 总是为高Init 初始化模式1 初始化开始0 正常模式注意:总线的关闭状态不受 Init 的置位或复位而改变,总线关闭,CAN 总线自检测置位 Init 位,停止所以总线活动。一旦处理顺(CPU)清除 Init 位,总线将等待产生 129 个总线空闲状态(129*11 个隐性位),在恢复正常运行之前。总线恢复正常结束后,错误管理计数器将清零。在每次对 Init 位重新复位以后,将会等侍监听连续 11 隐性位的时间,Bit0Eraor 代码将写到状态寄存器。使能处理器(CPU)检测总线正接受显性位或连续干拢并监听总线关闭状态。提示:C8051 系列单片机中的 CAN 总线也是采用 BOSCH CAN 协议。其操作过程一样,但是在 CAN 寄存器中加多了一位。位 4: CANIF:CAN 中断标志。写 = 忽略。0:未发生 CAN 中断。1:发生了 CAN 中断。CANIF 由 CAN 控制器控制,当 CAN 控制器中所有的中断条件都被清除后,该标志被清02、状态寄存器(地址 0x03 & 0x02) Status Register (addresses 0x03 & 0x02)BOff 总线关闭状态1 总线在关闭状态0 总线正常状态Ewarn 警告状态1 在错误管理器(EML) 中至少有一个错误计数器达到了 96 次限制警告0 错误或警告二个都没有达到 96 次的限制Epass 产生错误1 在 CAN 总线协议中定义 CAN 内核运行在错误的状态0 CAN 内核使能错误RxOk 成功接收消息1 一旦此位被由处理器(CPU)置位,消息接收成功(依赖于过虑器的结果)0 自从此位由处理器(CPU)置位后,没成功接收消息,这位永远由处理器(CPU) 复位TxOk 成功发送消息1 自从处理器(CPU)对此位复位以后,成功发送消息 (没有错误和至少一个节点应答)0 自从 CPU 对此位复位以后,没有消息已发送成功,这位永远由 CPU 复位LEC 最近错误代码0 No Error::有错误1 Stuff Error:填充错误,在接收消息中部分标准是超过 5 个连续位产生是不充许。2 Earm Error:帧错误,接收帧固定格式部分是个错误形式3 Ack Error:应答错误,CAN 内核发送信息没有任何一个节点应答4 Bit1Error:在消息发送期间(除仲裁域),设备想发送一个隐性位,但监听为显性位5 Bit0Error:在消息发送期间(或应答位、激活错误标志、超载标志 ),设备想发送一个显示位(数据或识别符逻辑值 0),但是监听到总线的值为隐性位。关闭总线恢复每次都要监听一个连续 11 个隐性位状态,这使能处理器(CPU)去监听处理总线关闭恢复序列(指示总线没有干拢位或连续干拢)6 CRCError:CRC 检测较验出接收到的数据是错误的。经过 CRC 校验接收进来的消息与未准的数据不能匹配7 Unsed:当 LEC 显示为 “7”时,自从处理器(CPU)写到数到 LEC 以后,总线就没有任何事件发生。LEC 域保存显示 CAN 总线上最近发生错误类型编码,在成功传送(发送或接收) 消息并且没有错误时这个域全部清 0,当处理器(CU)检测更新时,未使用的编码“7”可以写入 LEC。状态中断Status Interrupts状态中断产生由 Boff 位和 Ewarm 位(错误中断 )或由 RxOK 位、TxOK位和 LEC(状态改变中断)装载,并在 CAN 控制寄存器中的相应使能位置位有效使能。Epass 位改变或写 RxOK、TxOK,或 LEC 也不会产生状态中断。读状态寄存器将清除在中断寄存器中状态中断值(8000H) ,如果没有中断时。3、错误计数器(地址 0x05 & 0x04 )Error Counter (addresses 0x05 & 0x04)RP 消极接收错误1 接收错误计数器已经达到由 CAN 协议定义错误消极状态0 接收错误计数器没有达到错误消极状态REC6-0 接收错误计数器接收错误计数器实际状态,其值在 0127TEC7-0 发送错误计数器发送错误计数器实际状态,其值在 02554、位定时寄存器(地址 0x07 & 0x06) Bit Timing Register (addresses 0x07 & 0x06)TSeg1 采样点前的定时段Tseg1 有可变值为 0x010xF,即是115, 这个值通过硬件译码成比 1 更大的值被使用。TSeg2 采样点后的定时段Tseg2 有可变值 0x00x7,即

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论