云途YTM32系列微控制器的LIN通信协议引擎LinFlexD外设模块应用详解
本文基于云途YTM32系列微控制器介绍LIN通信协议引擎LinFlexD外设模块:
LINFlexD外设简介
LINFlexD工作机制
初始化
主机模式
从机模式
错误状态标志位
超时错误(Timeout Error)
ID过滤机制
接收器检测帧间隔段和帧间隔段分隔符
产生波特率
自动同步波特率机制
唤醒管理机制
软件
参考文献
LINFlexD外设简介
YTM32微控制器的LINFlexD外设模块,实现了LIN协议控制器的功能,可以支持LIN总线协议的主机和从机功能。如图1所示。
图1 LINFlexD在LIN总线系统中的位置
LINFlexD 可以实现使用较少 CPU 介入的情况下,高效管理大量的 LIN 通信帧:
在主机 Master 模式下,当软件触发了通信过程(发送帧头),LINFlexD 硬件可以自行继续发送或者捕获数据流(应答数据),直至软件重新启动下一个通信过程(主机启动),或者收到一个校验和(接收模式)。
在从机 Slave 模式下,LINFlexD 中设计了一组帧头过滤器(ID Filter),可以配置由硬件自动匹配从总线上捕获到的帧头,仅当识别到本机预设处理的帧头,才启动数据通信过程(从机任务)。
LINFlexD 内部还集成了一个8字节的缓冲区,用于存放硬件自动发送或者接收的数据段内容。
LINFlexD 硬件外设支持LIN v1.3、v2.0、v2.1、v2.2协议。可以在配置帧头信息的 LINFlexD_BIDR[CCS]寄存器位中指定将要发送或者接收的帧使用扩展性校验和还是经典款校验和。
LINFlexD 还支持 UART 模式,用于实现常规的 UART 通信。本文主要面向 LIN 通信引擎介绍,关于 UART 介绍,可见后续文章。
LINFlexD工作机制
初始化
手册中对 LINFlexD 的工作模式划分为:初始化模式(Initialization)、常规工作模式(Normal)和休眠模式(Sleep)。在硬件复位后,LINFlexD 处于休眠模式以节约用电。若要配置 LINFlexD 开始工作,需要先通过软件配置,切换至初始化模式,在初始化模式下进行一些专属的配置后,再切换至常规工作模式,才能顺利启动 LINFlexD 外设。这个初始化模式,相当于为配置 LINFlexD 外设设计了一个同步锁,或者说关键区,使得在初始化阶段配置 LINFlexD 外设的各项功能时都不会立刻生效,以避免产生不确定的不安全状态,最后退出初始化模式,硬件同步一并打开所有的配置功能,稳当。
初始化模式(Initializaiton,INIT)
软件配置寄存器LINFlexD_LINCR1[INIT]=1,切换至初始化模式。当然,还可以通过配置LINFlexD_LINCR1[INIT]=0,退出初始化模式(至Normal模式?)。
进入初始化模式后,LINFlexD 引擎同 LIN 总线的传输将全部停掉(木头人不许动),并且推送总线上位高电平(隐形信号)。如果在某个总线传输的过程中进入初始化模式,则该传输将被打断并退出。所以说,在切入初始化状态之前,软件一定要先查一下 LINFlexD 的状态标志位,确保不会打断正在进行的传输,再进入初始化模式。
在初始化模式下,可以对 LINFlexD 外设进行初始化配置:
配置通信波特率
启用 LINFlexD 模式(停用UART模式)
选择主机模式或者从机模式
配置校验和控制位
若是从机模式,还需要预先填写好可以捕获的ID的列表
常规工作模式(Normal Mode,NM)
在初始化模式中,配置寄存器LINFlexD_LINCR1[INIT]=0,切换至常规工作模式。
在常规工作模式下,LINFlexD 可以执行正常的收发通信。
休眠模式(Sleep Mode,SM)
配置软件寄存器LINFlexD_LINCR1[SLEEP]=1,切换至休眠模式。当然,也可以通过配置LINFlexD_LINCR1[SLEEP]=0,退出休眠模式(至Normal模式)。
进入休眠模式后,LINFlexD引擎就暂停工作,等待唤醒事件到来后,自动切回正常模式响应外部的通信请求。
如果软件在 LIN 总线上检测到一个 150us 的唤醒脉冲,可以请求 LINFlexD 从休眠模式唤醒。
回环工作模式(Loop Back Mode)
通过配置寄存器LINFlexD_LINCR1[LPKM]=1启用回环模式。回环工作模式可用于自测试通信协议,当启动回环模式后,芯片内部的Tx和Rx引脚相连,通过Tx发送的信号会直接被反馈会接收通道(忽略Rx引脚的输入)。如图2所示。
图2 LINFlexD的回环模式
主机模式
通过配置寄存器LINFlexD_LINCR1[MME]=1,设定本设备为主机模式工作。
发送帧头
根据LIN协议的描述,LIN总线的上通信,都是由主机(具体是主机节点的主机任务)发送帧头开始的。当发送帧头时,由软件先写入LINFlexD_BIDR寄存器中的字段,包括:ID(6位的帧ID,硬件自动补完校验位)、DFL(数据段长度)、DIR(帧通信的方向)及CCS(启用经典校验的控制位,后续硬件自动生成校验字节)。然后,设置寄存器LINFlexD_LINCR2[HTRQ]=1,请求发送帧头。在启动发送帧头之后,在发送完成本帧之前,不要人为修改LINFlexD_BIDR寄存器中的内容,LINFlexD 从总线上捕获到已经发送帧的ID会被自动复制到LINFlexD_BIDR寄存器中。
发送数据
当主机节点执行发布任务时(发送数据到总线),主机节点上运行的从任务(主机节点上的主任务仅发送帧头)会继续发送数据部分。因此,软件需要在发起发送帧头的请求之前,就将需要发送的数据准备好,将数据存放至消息缓冲区LINFlexD_DATA[]中,同时,需要在LINFlexD_BIDR[DFL]寄存器中指定将要发送字节数据的数量,硬件根据软件在LINFlex_BIDR[CCS]控制位的配置(这个数据位可能是总线上捕获到的帧头中的信息),自动计算经典校验和或是增强校验和。
当应答的数据发送成功后,会置位硬件标志位LINFlexD_LINSR[DTF],但如果发送过程中出现错误,标志位LINFlexD_LINSR[DTF]不会置位,LINFlexD_LINSR寄存器的其它对应标志位会置位。
应答数据的方向(发送?或是接收)由寄存器LINFlexD_BIDR[DIR]设定,但哪怕是发送过程,将数据发送上总线后,也会监听总线,将总线上的数据捕获下来并存入数据缓冲区中。
接收数据
当主机节点从从机节点读取数据时,应先发出一个帧头(约定为读操作的ID)。从机节点捕获到帧头之后,会向总线上发送应答数据,此时主机节点(的从机任务)会从总线上捕获数据,并将数据内容存放至数据缓冲区中,寄存器LINFlexD_LINSR寄存器中对应的标志位也会置位。
当应答的数据接收成功后,会置位硬件标志位LINFlexD_LINSR[DRF],但如果发送过程中出现错误,标志位LINFlexD_LINSR[DRF]不会置位,LINFlexD_LINSR寄存器的其它对应标志位会置位。
抛弃数据
若用户需要抛弃发送帧头之后捕获到的应答数据,可预先设置寄存器LINFlexD_LINCR2[DDRQ]=1。这对应的是LIN通信中,实现“不应答”的操作。
注意:哪怕是在主机模式中,也是分为主机任务和从机任务两部分,主机任务仅负责发送帧头,主机模式中的从机任务和下文描述的从机模式一致,都是通过 LINFlexD_BIDR寄存器中捕获的帧头信息同自己的ID Filter进行匹配,从而启动对应的发送或接收数据的过程。
从机模式
通过配置寄存器LINFlexD_LINCR1[MME]=0,设定本设备为从机模式工作。
发送应答数据
当从LIN总线上捕获到主机任务发送的帧头后,根据对ID的定义,若要求本节点提供应答数据,则硬件标志位LINFlexD_LINSR[HRF]寄存器会置位,并产生一个接收中断。此时,软件需要尽快填写将要发送的数据到数据缓冲区中:
读LINFlexD_BIDR寄存器,判定接收到帧头的ID
向LINFlexD_DATA寄存器中填入将要发送的数据
写LINFlexD_BIDR寄存器,写入CCS(校验和计算方式)、DIR(数据方向),以及DFL(数据长度)寄存器。
设置寄存器LINFlexD_LINCR[DTRQ]请求发送数据后,软件才能清零LINFlexD_LINSR[HRF]标志位。为了确保LINFlexD_LINCR[DTRQ]寄存器控制位能够起作用,需要先保持LINFlexD_LINSR[HRF]置位,这是为了防止LINFlexD_LINCR[DTRQ]不会被意外地被置位,而必须跟在发送一个帧头的操作之后进行(增加了一个操作约束条件)。在接收数据过程中,LINFlexD_LINSR[RXBUSY]寄存器保持置位,此时LINFlexD_BIDR[DIR]和LINFlexD_LINCR[DTRQ]位不能被软件置位。
当需要使用ID过滤器时(Identifier Filter),可配置LINFlexD_IFER寄存器启用过滤器功能。若命中其中一个过滤器时,硬件会产生一个发送中断,此时,硬件可从寄存器LINFlexD_IFMI中保存的指针从RAM从自动搬运数据内容到LINFlexD_DATA寄存器缓冲区中。
使用ID过滤器可以减少软件从LINFlexD_BIDR寄存器中读ID、判定、配置数据长度和校验和类型的过程。
如果 LINFlexD 外设模块中需要使用的过滤器不够应用中使用,还可以通过设置过滤器掩码的方式,模糊匹配ID,以实现匹配更多ID的效果。
同主机模式相同,本机发送的数据,也会被捕获至本机的接收缓冲区中。
接收应答数据
当收到主机任务发送的帧头后,若要求本节点接收应答数据,则硬件标志位LINFlexD_LINSR[HRF]寄存器会置位,并产生一个接收中断。此时,软件需要尽快读BIDR寄存器,从中读帧ID进行匹配,并写入数据段长度(在收到第一个数据字节的停止位之前)。当收到校验和之后,LINFlexD_LINSR[RMB]寄存器位会置位,并会产生一个接收中断,此时,软件可从LINFlexD_DATA寄存器缓冲区中读数,读数完成后,需要软件清零LINFlex_LINSR[RMB]寄存器位,以释放接收数据缓冲区。
当至少一个配置为接收的ID过滤器被激活命中,将在收到校验和之后,产生一个接收中断。在接收到ID的时候不会产生中断。
如果使用软件方式过滤ID,当HRF标志位置位时,若要抛弃数据(不应答),可以通过写LINFlexD_LINCR[DDRQ]寄存器实现。若使用软件过滤机制,软件需要在接收到校验和之前设定校验的类型(配置LINFlexD_BIDR[CCS])。
错误状态标志位
LINFlexD 硬件集成了协议栈的业务逻辑,但由于总线上是多设备仲裁运行的环境,有时硬件总线的行为不是完全按照预期的情形运作,时不时就会报错。LINFlexD 对处理不了的情况设计了对应的监测机制,对于硬件无法处理的情况,会尽量及时地报错,上报给软件,交由应用逻辑裁决。
LINFlexD_LINESR寄存器中包含了 LINFlexD 外设能够检测到的所有错误标志位,分别对应检测各自的错误机制。LINFlexD_LINESR寄存器的位定义,如图3所示。
图3 LINFlexD_LINESR寄存器的位定义
总线拉低超时错误(Stuck at Zero Timeout Error,SZF)
发生Stuck-at-zero超时错误。大体上是描述LIN总线被意外地长时间拉低(显式电平),后续无法传输数据的状态。详见下文超时错误机制。
输出比较标志(Output Compare Flag,OCF)
输出比较事件是LINFlexD在管理超时机制中产生的一个事件。
在主机模式下,当LINFlexD_LINTCSR[CNT]中的计数值同LINFlexD_LINOCR[OC2]寄存器的设定值相等时,起OCF标志位。
在从机模式下,当LINFlexD_LINTCSR[CNT]中的计数值同LINFlexD_LINOCR[OC2]或LINFlexD_LINOCR[OC1]寄存器的设定值相等时,起OCF标志位。
当在LINFlexD_LINTCSR[MODE] = 0(LIN模式)并且LINFlexD_LINTCSR[IOT] = 1, 若OCF标志位被置位,则LINFlexD进入Idle状态。
当在LINFlexD_LINTCSR[MODE] = 0(LIN模式), OCF由处于初始化模式下的硬件外设自动清零。
当在LINFlexD_LINTCSR[MODE] = 1(输出比较模式), OCF单纯表示输出比较的状态,同LIN的通信状态无关。
位错误(Bit Error,BEF)
位错误可能发生在发送过程中(发送帧头和发送应答数据),当从总线上读回的值同发送的值不一致时,会出现位错误。检测每个数据位的意义在于,确保收发器的延迟时间小于一个可以接受的容限(位时间的长度再减去6个功能时钟周期),例如:
1个位时间 t_bittime = 20k bps = 50μs
6个功能时钟周期@80MHz = 75ns
则允许的收发器延迟时间 = t_bittime - 6 * t_ipg_baud_clk = 49.925μs
这个49.925μs将用于选型合适的LIN收发器。
在发送的间隔段中不检测位错误。
如果出现位错误的情况,若此时已经配置了LINFlexD_LINCR2[IOBE]=1(Idle on Identifier Parity Error),LINFlexD的接收状态机会立刻退出接收帧头的状态变成Idle。若是LINFlexD_LINCR2[IOBE]=0,发送过程将继续,不管位错误。如果配置了LINFlexD_LINIER[BEIE]=1,则此时会产生中断。一种极端的情况,如果不配置退出、不配置中断,哪怕出现了位错误,仍可坚持完成发送过程。
校验和错误(Checksum Error,CEF)
当接收机收到数据帧及校验和字节后,会自动计算校验和,当计算结果同数据内容不一致时,会抛弃收到的数据包,同时会起一个CEF标志位。如果预先配置寄存器LINFlexD_LINIER[CEIE]=1,则对应还可以产生一个中断。
如果是LINFlexD发出的数据包,因LINFlexD在发送过程中会自动计算校验和,所以若再用 LINFlexD 收到数据包仍会产生校验和错误,那就要查看传输线路是否受到较大的干扰。如果发送方的校验和是人工计算的,那也要再确认软件计算校验和的方法是否正确。
帧头错误(Header Error)
从机任务在接收帧头过程中发现的错误,都算是帧头错误。这些错误包括
(1)帧间隔段分隔符错误(Break Delimiter Error, SDEF)
这个分隔符的长度应至少为1位的时间,否则时间太短,接收方会丢弃当前帧头的同步段,进而丢弃整个帧。如果LINFlexD_LINIER[HEIE]=1,则此时会触发一个中断。
(2)同步段错误(Sync Field Error,SFEF)
同步段错误的情况在是否开启自动同步的配置(LINCR1[LASE]=1)时是不同的。
当启用自动同步机制时,SFEF标志位标识两种情况:超出LIN规范(14%偏差)之外的同步段偏差错误,或者测量同步段已经溢出,分频器打满也除不下来。SFEF不会检测同步段值的错误(不是0x55)。当停用自动同步机制时,同步字段被当做一个普通的字节被接收,此时会判定改值是否为0x55,如果不是这个值,则会报错,后续的整个LIN帧都会被抛弃。
(3)ID校验错误(Identifier Parity Error,IDPEF)
PID段中包含6个比特的ID和2个比特的校验码,IDPEF检测的就是这6个比特的ID和2个比特校验码的一致性。在从机任务中,当LINFlexD收到帧头的PID段后,将6比特的ID值送至BIDR寄存器后,会由硬件自动计算核验校验码。如果出现不一致的情况,若此时已经配置了LINFlexD_LINCR2[IOPE]=1(Idle on Identifier Parity Error),LINFlexD的接收状态机会立刻退出接收帧头的状态变成Idle。
帧错误(Frame Error,FEF)
帧错误标识的是在当前接收字节(LIN帧的同步段、ID段、数据段、校验和段)的停止位检测到一个显性信号(本应为隐形信号,拉高电平),此时LINFlexD会抛弃当前接收到的帧,然后返回到Idle状态。如果预先配置了LINFlexD_LINIER[FEIE]=1,则会产生一个中断。
当出现帧错误时,导致错误的字节数据仍会被送入数据缓冲区(毕竟已经送进去了),但LINFlexD_LINSR[DRF]标志位(数据接收完成标志位)不会置位。
缓冲区溢出(Buffer Overrun,BOF)
当收到一个新的数据时,若标志位LINFlexD_LINSR[RMB]=1尚为清零(数据缓冲区满,软件可读),则判定为缓冲区溢出,报错。此时还需通过寄存器LINFlexD_LINCR1[RBLM]的配置值,确定如何处理新数据:
若LINFlexD_LINCR1[RBLM]=0,则之前未被都走的数据包将会被新的数据包覆盖,旧的数据包将被丢失。
若LINFlexD_LINCR1[RBLM]=1,则之前未被都走的数据包将会被保持,新的数据包将被丢失。在从机模式下,如果再未读完数的情况下来了新的LIN帧,不仅仅是数据,连带帧ID也会被一同抛弃。
噪声标志(Noise Flag,NF)
当接收器检测到噪声时,起本标志位。关于噪声,是在检测开始信号和间隔符信号时,进行连续3次隔点采样,未能达到判决条件时,即认定为总线上有噪声。
超时错误(Timeout Error)
当主机发送了帧头后,如果在指定的时间段内未收到应答数据,则会产生超时错误。LINFlexD外设内部设计了一个超时定时器(Timerout Counter),专门用于检测同超时相关的检测和响应事件。
图4 LINFlexD的超时报错机制
应答超时机制
主机模式:每当发送或者接收到ID段(帧头的最后一个字段)后,确切地说,是当DFL被硬件写入后,LINFlexD会自动将寄存器LINFlexD_LINOCR[OC2]载入到LINFlex_LINTOCR[CNT]寄存器,并启动内部的定时器开始倒计数,若在计数器计数清零之前未完成接收数据,则产生超时事件。这相当于是个看门狗。
从机模式:若使用ID过滤器过滤接收数据帧,同主机模式类似,当匹配到消息ID,硬件写入DFL寄存器时,载入LINFlexD_LINOCR[OC2]寄存器的值到定时器,开始计数。若未使用ID过滤器,则在收到数据帧并由软件进行识别后,人工写入DFL寄存器时,硬件载入LINFlexD_LINOCR[OC2]寄存器的值到定时器,启动定时器。
帧头超时机制
主机模式:由于帧头是由LINFlexD硬件自动产生的,正常情况下不会出现超时。
从机模式:在收到帧间隔符后,硬件从寄存器LINFlexD_LINOCR[OC1]到LINFlexD_TOCR[HTO],启动定时器。
注意,这里的定时器也可以用来检测其他的超时事件,但需要配置LINFlexD_LINTCSR[MODE]=0,然后软件向寄存器LINFlexD_LINTOCR中写入输出比较值。
总线拉低超时错误(Stuck at Zero Timeout Error)
如果显性信号在总线上保持的时间超过了100个比特的时间,就会起标志位LINFlexD_LINESR[SZF]。人工清零标志位后,如果显性信号未消除并继续,那么接下来只要连续保持87个比特的时间,就会再次激活标志位LINFlexD_LINESR[SZF]。
ID过滤机制
在LIN协议中,消息的ID号并不是对应节点的地址,而是标识消息中携带的内容(命令,或者消息类型)。发送器将消息广播到LIN总线,所有的接收机都能收到,接收机通过识别消息的ID,接收机们决定是继续收数据,或是发送数据应答(根据消息ID的含义做出反应),如果接收机不识别消息(不做处理),就会抛弃它。
为了实现这样的机制,LINFlexD外设设计了可配置的ID过滤器,以简化原本需要软件去匹配消息ID的工作,节约了CPU资源。LINFlexD中集成了16个过滤器,只有在初始化模式下才能配置他们,可以通过将LINFlexD_IFER[FACT]寄存器中的对应位置位,激活相应的过滤器,然后在每个过滤器专属的LINFlexD_IFCRn寄存器中配置各自过滤器的参数。
每个ID过滤器有两种可选的工作模式(通过寄存器IFMR[IFM]):
ID列表模式(Identifier List Mode)。若配置LINFlexD_IFMR[IFM]=0,则接收到LIN帧头的消息ID必须按位同IFCR_n寄存器中的完全相同才能满足匹配条件。
ID掩码模式(Identifier Mask Mode)。若配置LINFlexD_IFMR[IFM]=1,则IFCR_2n寄存器和IFCR_2n+1寄存器形成一个掩码模式,IFCR_2n中的ID是一个模板ID,IFCR_2n+1中的ID是一个掩码,当收到LIN帧头的消息ID后,先同掩码做个与运算,过滤掉不关心的位,然后再同模板ID进行匹配。在ID掩码模式下,LINFlexD_IFER[FACT]寄存器中是否激活IFCR_2n+1,已经不影响了,此时IFCR_2n+1总是被激活的。当需要本接收机相应的消息ID多于硬件ID过滤器支持的数量时,就需要用ID掩码模式扩展能识别ID的范围了。
无论在何种过滤器模式下,一旦编号为m的过滤器被匹配到,则值m+1将被硬件写入到IFMI寄存器中,而IFMI=0就表示没有当前还发生任何匹配事件。此时,软件可以通过读IFMI寄存器的值,识别是哪个过滤器被匹配到,进而从中查看识别到的消息ID。当完成一次匹配事件,LINFlexD硬件都会将匹配到的DFL、CCS和DIR寄存器的值,从IFCR寄存器复制到BIDR寄存器中(存放当前的帧头信息),此时至通信帧传输完成之前,BIDR寄存器都是只读,不能被软件写入。此时LINFlexD_BIDR[DIR]指示了应答数据的传输方向(相对主机):
若LINFlexD_BIDR[DIR]=1,表示数据方向为发送,可以产生一个发送中断(LINFlexD_LINIER[HRIE]=1),此时软件可以从IFMI寄存器中读ID过滤器的索引编号,然后向DATA缓冲区中填充将要发送的数据,然后再配置LINFlexD_LINCR2[DTRG]=1,启动传输。
若LINFlexD_BIDR[DIR]=0,表示数据方向为接收,在接收数据完毕后,包括校验和字节,并验证校验和无误后,可以产生一个接收中断(LINFlexD_LINIER[DRIE]=1),此时,软件可以从DATA缓冲区中读出接收到的数据。
如果没有匹配到任何过滤器(通过IFMI=0判定):
此时若已经配置了LINFlexD_LINCR1[BF]=1,则仍可产生一个接收中断。此时应由软件配置BIDR寄存器并启动传输(填充DATA数据缓冲区再配置LINFlexD_LINCR2[DTRQ]),或放弃接收(配置LINFlexD_LINCR2[DDRQ])。
若已经配置了LINFlexD_LINCR1[BF]=0,则接收机直接抛弃已经收到的帧头(包含消息ID),转入Idle状态,等待接收下一个帧间隔段(开始信号)。
注意,如果接收的消息ID同时匹配到了两个过滤器,一个处于列表模式,另一个处于掩码模式,则优先匹配到处于列表模式的过滤器。如果同时匹配到两个位于掩码模式的过滤器,则优先匹配到编号较小的过滤器。如果同时匹配到两个处于列表模式的过滤器,好吧,能将同一个ID写到两个列表模式下的过滤器,一定是写错了,但此时也会优先匹配到编号较小的过滤器。
接收器检测帧间隔段和帧间隔段分隔符
LINFlexD内部检测串行信号模式的方法非常有趣。接收器内部设计了一个10比特的移位采样寄存器,捕获收到的串行信号,LSB送入。移位寄存器中的比特位在平时是全0,当其中的值变为1110,然后在之后进行隔点采样(每两个连续的点取一个样本),连续3个样本中,有2个为0,即可判定是一个开始信号(帧间隔符)。类似的,为了检测帧间隔符分隔符,在继续检测到0001的模式,然后再之后进行隔点采样,连续3个样本中,有2个为1,即可判定是一个分隔符。如果只能检测到两个有效的样本,噪声标志位(Noise Flag)将会被置位。
图5 使用移位器检测开始信号和分隔符模式
关于检测模式的更细节的机制,可继续参见手册详述,因同用户使用关联不大,此处不再赘述。
产生波特率
配置LIN总线的(发送和接收)波特率,主要设计两个寄存器:LINFlexD_LINIBRR和LINFlexD_LINFBRR,分别对应分频因子的整数部分和小数部分。
当LINFlexD_UARTCR[ROSE]=1(only for UART mode),baudrate = f_clksrc / ( OSR x LDIV )
当LINFlexD_UARTCR[ROSE]=0(for LIN and UART mode),baudrate = f_clksrc / (16 x LDIV)
其中,f_clksrc是 LINFlexD 的功能时钟,在 SCU 外设模块中分配时钟源。LDIV是一个无符号的定点数,整数部分存放在20-bit的LINFlexD_LINIBRR寄存器中,小数部分存放在4-bit的LINFlexD_LINFBRR寄存器中。
当停用过采样功能,就不再使用LINFlexD_LINFBRR寄存器(可清零),此时LDIV仅使用整数部分,配置至LINFlexD_LINIBRR寄存器。
例如:
When ROSE = 0 (for LIN and UART mode): LDIV = 468.75 d, ipg_baud_clk = 36 MHz, LINIBRR = 468 d, LINFBRR = 12, Baud rate = 36 MHz / (16 × 468.75) = 4.8 K bit/s
When ROSE = 1 (only for UART mode): LDIV = 5 d, ipg_baud_clk = 80 MHz, LINIBRR = 5 d, OSR = 4, Baud rate = LIN_CLK / (OSR × LDIV) = 80 MHz / (4 × 5) = 4 M bit/s
自动同步波特率机制
若要通过测量LIN通信帧的同步段,可以先随便写两个波特率发生寄存器LINFlexD_LINIBRR和LINFlexD_LINFBRR,然后设定寄存器LINFlexD_LINCR1[LASE]=1启用自动同步机制。
唤醒管理机制
处于休眠中的LIN总线可以由其中任何节点发起唤醒请求。节点将LIN总线信号强制拉低(保持显性信号)保持250μs至5ms,每个从机节点将会检测到唤醒请求(一个长于150μs的低电平脉冲),并在释放显性信号的上升沿开始100ms以内准备好监听来自总线的命令。主机在检测到总线上的唤醒请求后也会醒过来,待从机准备好之后,主机将发送帧头以探查唤醒的源头和原因。如果在收到唤醒请求后的150ms内,主机没来得及发送帧头,则原本唤醒总线的从机节点可以试着再次发起一个新的唤醒请求。
使用LINFlexD产生一个唤醒请求,可以通过向 DATA0 寄存器写一个唤醒字符(0x0)并设定寄存器位LINFlexD_LINCR2[WURQ]。当写WURQ寄存器位时,DATA0中的数就已经被送上总线了。
使用LINFlexD检测LIN总线上的唤醒请求,可以有两种方式:
当AUTOWU=1,在休眠模式下,当检测到一个下降沿,LINFlexD_LINCR1[SLEEP]寄存器位由硬件清零(退出休眠模式),LINFlexD_LINCR1[WUF]标志位置位,如果此时LINFlexD_LINIER[WUIE]=1,则可以产生一个中断,此时 LINFlexD 处于常规工作模式并准备接收通信帧。
当AUTOWU=0,当检测到一个下降沿,LINFlexD_LINCR1[WUF]标志位置位,如果此时LINFlexD_LINIER[WUIE]=1,则可以产生一个中断,此时需要由软件决定是否要清零LINFlexD_LINCR1[SLEEP]寄存器位以返回常规工作模式。
图6 LIN的唤醒时序软件
YTMicro SDK中包含了LinFlexD的驱动程序,并提供了lin_master、lin_salve、lin_slave_filter等样例工程。
- |
- +1 赞 0
- 收藏
- 评论 0
本文由ll转载自云途 微信公众号,原文标题为:【车规MCU充电站】YTM32的LIN通信协议引擎LinFlexD外设模块详解,本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。
相关推荐
车规YTM32微控制器应用技术盘点(2024年上半年)
从2023年下半年开始接触国产车规YTM32微控制器,结合一线开发者的实际应用场景,云途高级现场技术支持经理苏勇撰写了一系列关于YTM32微控制器的系统架构、IP建模、技术方案应用要点以及汽车电子应用相关的技术文章。这些文章已经帮助相当多的YTM32开发者了解YTM32微控制器芯片和一些具体的项目。
如何给Keil IAR等IDE以及jlink添加云途MCU信息?
由于不同厂牌以及不同型号的MCU都有其特定的架构、外设、寄存器配置等特性,故在使用Keil、IAR等集成开发环境(IDE)进行嵌入式系统开发时,为了使IDE正确地编译代码、配置项目设置以及进行调试。需要添加这些信息到指定的IDE环境中。本文以添加云途MCU YTM32B1LE0的设备信息为例进行说明。
【经验】灵动微电子MM32F5270微控制器ADC注入通道的单周期采样的实现
灵动微电子MM32F5270微控制器的ADC可配置4个注入通道来扩展转换通道,那么可进行转换的通道最多可达20个。本文介绍MM32F5270平台ADC注入通道的单周期采样的实现。
“芯”光闪耀,云途MCU YTM32B1M系列助力智能ADB大灯应用,主频高达120MHz
相较于其他外饰灯,ADB大灯对MCU会有更高要求,以适应更复杂的算法和控制系统。云途半导体的YTM32B1M系列可以很好的满足这一需求。YTM32B1M为云途自主研发的基于Arm Cortex-M33的微控制器,主频高达120MHz,带有FPU/DSP,能够高效率处理复杂的浮点运算,适合运行复杂的算法。
【IC】云途首颗高端域控制器芯片YMT32B1HA0x获功能安全ASIL-D产品认证
2024年5月21日,江苏云途半导体有限公司的H系列首颗高端域控制器芯片YMT32B1HA0x获得由独立第三方国际权威汽车检验、检测和认证机构DEKRA德凯正式授予的ISO 26262 ASIL D功能安全产品认证证书。这是国内首个获得功能安全ASIL-D产品认证的车规级MCU产品。
战略共赢 软硬兼备|云途半导体与知从科技达成战略合作
江苏云途半导体有限公司(云途)与上海知从科技有限公司(以下简称“知从科技”)达成战略合作,共同推动智能汽车领域高端汽车电子应用的开发。云途半导体与知从科技将共同推动国产高性能车规级芯片在车身电子、车载灯控、汽车动力、智能底盘、功能安全控制器及域控制器等应用领域的推广。
云途半导体授权世强硬创代理,车规级MCU应用覆盖整车五大域
云途半导体全系列MCU产品能够满足车身、底盘、座舱、动力、自动驾驶等域控制的高端需求,覆盖整车五大域90%以上应用场景。
云途完成第四轮亿元融资,率先实现车规芯片(32位MCU芯片YTM32B1L系列)量产出货
2021年12月31日,苏州云途半导体有限公司正式对外宣布完成亿元A轮融资,云途自成立以来,仅用了15个月时间就获得资本四轮“加持”,本次A轮投资方包括联新资本,汇川技术、临芯投资、杭州金投产业,老股东小米长江基金跟投。
云途微控制器抽象层驱动(MCAL)快速入门指南
描述- 本指南介绍了云途微控制器抽象层(MCAL)软件包,旨在帮助用户快速入门AUTOSAR标准的汽车电子控制系统软件开发。指南详细介绍了MCAL软件的代码结构、支持的YTM32系列车规微控制器产品、驱动模块发布详情,包括支持的驱动模块和版本历史。此外,还提供了软件和硬件要求、驱动模块用户手册、创建新工程步骤、错误和警告解决方法、代码生成过程以及如何使用VSCode、Ninja、GCC工具链/Ozone进行构建和调试。
型号- YTM32B1MC03H0MFNR,YTM32B1HA01G0MLQT,=YTM32B1ME05G0MLHIT,YTM32B1MC03H0MFNIR,YTM32B1ME05GOMLHT,YTM32B1HA01G0MLUT,YTM32系列,YTM32B1HA0系列,YTM32B1HA01G0MLLT,YTM32B1MC03H0MLFT,YTM32B1ME0系列,YTM32B1ME05G0MLLT,YTM32B1MC0系列,YTM32B1MC03H0MLHT,YTM32B1MD1系列,YTM32B1ME05G0MLQT,YTM32B1HA0,YTM32B1MD14G0MLHT,YTM32B1ME0,YTM32B1MC0,YTM32B1MD1,YTM32B1MD14G0MLHIT,YTM32B1MD14G0MLLT,YTM32
云途半导体YTM32Z系列专用微马达SoC,集成度高可单芯片驱动一个直流无刷电机或步进电机
云途半导体再迎重大突破,成功推出新产品“Z”系列专用微马达SoC。在此之前,云途半导体先后实现了YTM32B1L、YTM32B1M两大系列的15颗型号芯片量产。YTM32Z系列的推出,意味着云途半导体已逐步形成了“通用MCU+专用SoC”全矩阵车规级产品的完整布局。
云途全系列车规MCU产品成功入选《国产车规芯片可靠性分级目录》
2024年9月25日至27日,第十一届汽车电子创新大会(2024 AEIF)暨汽车电子应用展在无锡太湖国际博览中心盛大举办,大会重磅发布了《国产车规芯片可靠性分级目录(2024)》和 “2024金芯奖·汽车电子创新评选”的获奖名单,云途半导体荣耀双双入选。
云途获A股上市公司保隆科技战略投资,首款车规MCU YTM32B1L系列产品量产
苏州云途半导体有限公司(下简称:云途)2021年获得A股上市公司保隆科技的战略投资。这是云途继同年八月底获得小米长江基金的战略投资后,在汽车产业链上的又一战略合作。本次投资将继续用于加速云途半导体的车规级MCU芯片的研发及量产投入,为进一步推进国产汽车半导体产业赋能。
云途受邀出席大联大汽车技术峰会分享车规级MCU应用方案,共建汽车“芯”未来
江苏云途半导体有限公司受邀参加了由大联大和盖世汽车联合主办的「驶向未来:预约下一个十五•五 驰骋世界」活动,云途AE总监&重庆研发中心总经理胡恩伟发表了主题为《生态共赢,加速国产替代——云途车规MCU应用软件开发生态分享》的演讲,与250+家境内外主要车厂、OEM商、第一、二阶供应商进行了深度的交流。
YTM32B1MD1X数据表
描述- YTM32B1MD1x系列是Yuntu Microelectronics推出的高性能微控制器,适用于汽车行业。该系列基于ARM Cortex-M33核心,提供高达120 MHz的频率,支持ASIL-B安全等级和高级安全模块。产品具备丰富的内存、外设和封装选项,支持多种电源模式,适用于严苛的电气环境。
型号- YTM32B1MD1X,YTM32B1MD1X SERIES,YTM32B1MD14G0MLHT,YTM32B1MD14G0MLHIT,YTM32B1MD14G0MLLT
电子商城
现货市场
服务
可定制板装式压力传感器支持产品量程从5inch水柱到100 psi气压;数字输出压力传感器压力范围0.5~60inH2O,温度补偿范围-20~85ºС;模拟和数字低压传感器可以直接与微控制器通信,具备多种小型SIP和DIP封装可选择。
提交需求>
可定制车规级电感的电流范围0.3~17.9A,尺寸最小1x0.55x0.5mm到最大12.5x12.5x6mm,工作频率100KHz~2MHz,感值范围:0.47uH~4.7mH。符合IATF16949和AECQ-200。SPQ为5K。
提交需求>
登录 | 立即注册
提交评论