1.?车载LIN总线诞生背景和使用场景
2. LIN总线硬件接口
3. Lin总线协议
4. 总结
LIN:Local Interconnect Network,本地连接网络
由于汽车电子电器架构很复杂,汽车上的电子ECU非常多。这会导致汽车局域网络的线束越来越多。线束的增加导致成本上升以及接线不良等造成的电子故障增加,这对于汽车的品质和可靠性都有很大影响。
所以有些外围ECU对于通信速率以及可靠性要求都不高的,引入LIN总线。LIN总线是单线通信,成本比CAN总线更低。所以在未来很长一段时间内,LIN、CAN、ETH都会是车载通信总线必不可少的,三者都各自有自己的使用场景,当前无法取缔某一种总线。
LIN总线大部分使用在车窗防夹控制器、天窗控制器、座椅控制器等外围ECU。
和大部分通讯总线一样,LIN总线也是由LIN控制器、LIN收发器组成。LIN的控制器是基于SCI(UART)数据格式,采用单主控制器/多从设备的模式,是UART的一种特殊模式。一般控制器会集成在MCU内部,外置一个Lin收发器。也有一些MCU直接把LIN控制器和收发器都集成到MCU内部,只需要配置寄存器就可以使能Lin通信。
LIN采用UART功能传输,需要传送包括1位起始位和1位停止位,共10位数据。传送按照LSB方式从最低位开始传输。
起始位和停止位用于判断报文的开始与结束。起始位的逻辑值为"0",电压值为GND,停止位的逻辑值为"1",电压为电源电压。逻辑值1为隐形值,0为显性值。
LIN总线采用的是单线传输形式,网络中单主机 多从机。总线电平一般为12V,传输速率最高限制为20kbps。由于物理层的限制,一个LIN网络最多可以连接16个节点。LIN 机群由?1 个主机任务和几个从机任务组成。主机节点同时包含主机任务和从机任务。
从机任务不能直接向总线发送数据,需要接收到主节点发送的帧头后,根据帧头所包含的信息来判断:
帧由一个帧头(由主机任务提供)和一个帧响应(由从机任务提供)组成。主机负责发送帧头,从机负责接收帧头并作出解析,然后决定是发送应答,还是接收应答或不回复。
帧头结构包括同步间隔段、同步段、PID段(受保护ID)段,应答部分包括数据段与效验和段。其中“0”为显性电平、“1”为隐性电平。在总线上实行“线-与”:当总线有至少一个节点发送显性电平时,总线呈现显性电平;所有节点均发送隐性电平或者不发送信息时,总线呈隐性电平,即显性电平起着主导作用。
LIN线拓扑结构是主从结构的星型模型,所有传输都是master发起,slave不可以主动发起请求,,想要获取某个变量值,就需要不断轮询读对应的报文。
PID并不是从机地址,而是报文id,换个说法,一个slave从机可以提供多个报文id的服务,比如一个车灯控制ECU,可以提供灯控制、状态、故障码、软硬件版本信息等多个LIN ID服务。而slave从机地址是隐性的与其所提供的报文ID是有个对应关系的。
同步间隔段至少是由13位的显性电平组成,代表一帧的开始,其中同步间隔段的间隔符至少为1位隐形电平。
同步段
LIN同步以下降沿为判断标志,采用字节0x55(01010101b)进行同步。在从机节点上可以不采用高精度的时钟,由此带来的偏差,需要通过同步段来进行调整。
受保护的ID的前6位叫做帧的ID,加上两个奇偶效验码后称作受保护的ID。帧ID标识了帧的类别和目的地。从机任务会根据帧头ID作出反应(接收/发送/忽略应答)。
帧ID有6个比特,其值的范围是0x00~0x3f。可分为4类:
数据段
数据段可以包含1-8个字节,其中包含有两种数据类型,信号(singal)和诊断消息(diagnostic messages)。信号由信号携带帧传递,诊断消息由诊断帧传递。
检验和段
效验和段是为了对帧传输内容进行效验。效验分为标准型效验与增强型效验。采用标准型还是增强型是由主机节点管理,发布节点和收听节点根据帧ID来判断采用哪种效验和。
根据LIN 2.1规范,Lin的帧类型有以下几种:
不同帧的帧ID范围不同:
无条件帧(0-0x3B)
最常用的帧,无条件帧是具有单一发布节点的,无论信号是否发生变化,帧头均会被无条件应答的帧。
虚线箭头代表帧头发送,实线箭头代表帧应答。
事件触发帧
事件触发帧的标识符为0到0x3B。事件触发帧必须有一个独立的ID,该ID可以与多个无条件帧相关联。在事件触发帧时隙内发送帧头,只有当相关联的无条件帧内有信号被更新时,才发送帧应答。如果没有帧响应,帧头被忽略。帧响应可由多个节点发送,发生冲突时切换到“冲突解决调度表”,之后再切换回到原来的调度表。
事件触发帧是主机节点在一个帧间隙中查询各从机节点的信号是否发生变化时使用的帧。当存在多个发布节点时,通过冲突解决进度表来解决冲突。
当从机节点信号发生变化的频率较低的时候,主机任务一次次地查询各个节点信息会占用一定的带宽。为了减小带宽的占用,引入了事件触发帧的概念。
其主要原理就是:
偶发帧
偶发帧表示共用一个时隙、在需要时才被发送的一组普通帧。标识符为0到0x3B。
偶发帧是主机节点在同一帧时隙中当自身信号发生变化时向总线启动发送的帧。
当存在多个关联的应答信号变化时,通过预先设定的的优先级来仲裁。与事件触发帧类似,偶发帧也定义了一组无条件帧。规定偶发帧只有由主机节点发布。
偶发帧的传输可能出现三种情况:
1)当关联的无条件帧没有信号发生变化,这时主机连帧头也不需要发送。
2)当关联的一个无条件帧信号发生变化则发送该帧。
3)当有多个无条件帧发生信号变化时,则按照事先规定的优先级依次发送。
诊断帧
诊断帧包括主机请求帧和从机应答帧,主要用于配置、识别和诊断。主机请求帧ID=0x3c,由主机节点发送帧头和帧应答;从机应答帧ID=0x3d,由主机节点发送帧头 从机节点发送帧应答。数据段规定为8个字节,一律采用标准效验和。
保留帧
保留帧的ID=0x3e与0x3f,为将来扩张需求用。
LIN总线作为低成本的车载低速总线,相对而言协议比较简单,常规产品中使用的比较多的就是无条件帧和诊断帧。后续会更新:
LIN,Interconnect Network,适用于速度和可靠性要求不高、低成本的场合,LIN的使用场景包括车窗、天窗、座椅、门锁、空调、照明等舒适性相关的地方
不同协议的网络需要网关相连接,所以LIN网络与CAN总线相连时,需要加入CAN-LIN网关,这个网关一般由LIN网络的主机节点充当
LIN是单线总线,最大传输速率为20kbps,它采用的是一主多从的概念,就是一个LIN网络只会有一个主机,多个从机
由于物理层限制,一个LIN网络最多有16个节点,那么除去一个主机节点是有且唯一,从机节点的数量就是1到15个
主机节点(Master Node)包含主机任务(Master Task)和从机任务(Slave Task),从机节点(Slave Node)只有从机任务(Slave Task)
主机任务负责
从机任务不能够主动发送数据,需要接收主机发送的帧头,根据帧头所包含的信息判断:
帧包括帧头和应答两个部分,主机节点里的主机任务负责发送帧头,主机节点或从机节点里的从机任务接收帧头,并对帧头所包含的信息进行解析,然后决定是发送应答,还是接收应答,还是不作任何反应
帧的结构
帧头包括同步间隔段、同步段和PID段
同步间隔段的作用:
这里就要讲到LIN总线的显性电平和隐性电平
上图中,值0为显性电平,值1为隐性电平,当总线上有大于等于一个节点发送显性电平时,总线呈显性电平;当所有的节点都发送隐性电平或不发送信息时,总线呈隐性电平,所以能看出显性电平起主导作用
同步间隔段由同步间隔和同步间隔段间隔符组成,同步间隔是至少13位的显性电平,除了同步间隔段,没有任何其他情况会发出大于9个的显性电平,那么13个显性电平的同步间隔段,就可以作为一个帧的开始的标志
同步间隔段间隔符是一个隐性电平
在讲同步段之前,先了解一个概念,字节域
字节域以显性电平开始,以隐性电平结束,是一种标准的UART数据传输格式
在LIN的帧中,除了同步间隔段以外,其他各段都是以字节域的格式传输的
这里也可以看到数据段里的各byte字节,也是按照字节域的格式传输的
LIN总线为了节约成本,没有采用高精度时钟,采用了精度和成本相对较低的时钟,这样就会导致从机节点与主机节点的时钟误差,而同步段就是为了调整从机节点数据的位速率与主机节点一致
“PID,Protected Identifier Field,受保护的ID
”
为什么叫受保护的ID?
PID有8个bit,其中只有前6个bit是实际位,叫帧ID,后面两个bit是前6个bit奇偶校验后得到的值,叫奇偶校验位
从机任务是根据收到的帧ID作出反应的,所以需要验证帧ID是否正确,就是根据奇偶校验位,这也就是为什么叫作PID的原因
校验位P0 = ID0 @ ID1 @ ID2 @ ID3 @ ID4
校验位P1 = ~(ID1 @ ID2 @ ID3 @ ID4 @ ID5)
@表示异或运算,~表示取反
“由此可以看出,PID不可能出现全0或全1的情况,如果从机任务收到了0xFF或0x00,可以判断为传输错误
”
根据帧ID的不同,将LIN帧分为
应答包括数据段和校验和段
数据段是节点发送的数据,1到8个字节不等,它承载着信号或诊断消息两种数据类型
信号由信号携带帧传递,一个帧ID对应的数据段可能包含一个或多个信号,发送信号的节点称为发布节点,接收信号的节点称为收听节点
一般情况下,对于一个帧中的应答,总线上只存在一个发布节点,否则就会出现错误
但是对于事件触发帧,可能存在0个、1个或多个发布节点
诊断消息由诊断帧传递
校验和段是对数据段内容进行校验,它只有1个字节
校验和根据不同的场景分为:标准型校验和、增强型校验和
采用哪种校验和是由主机节点管理的,发布节点和收听节点根据帧ID判断采用哪种校验和
计算方法很简单:数据段内的各字节依次相加,如果有进位,则加到低位,最终得出的值取反
收听节点如何校验呢?同样地,把数据段内的各字节依次相加,如果有进位,则加到低位,得到的值不取反,与接收到的校验和相加,最终得到0xFF,校验无误
这里有几个需要注意的时间,由于帧里面的各段间有间隔,这也是要花掉时间的
所以
帧头的余量T_Header_Rest包含字节间间隔,规定为T_Header_Nominal的百分之40
应答的余量T_Response_Rest包含应答间隔以及字节间间隔,规定为T_Response_Nominal的百分之40
N_data为数据段内的字节数
无条件帧的帧头从主机任务发出后,必定有从机任务应答,也就是说必定有从机任务发出无条件帧中的信号,无论信号是否发生变化
有且只有一个从机任务对无条件帧的帧头作出应答,发出信号
从这里是否可以明白一些东西
“主机节点里的主机任务负责发送帧头,主机节点和从机节点里从机任务根据事先设计好的规则,负责对接收到的帧头信息进行分析,以确定自己是否要把这个帧的数据发出去,或是否要接收这个帧的数据(来自其他从机任务的)
”
这和CAN总线通信还是很不一样的,后面我会进行分析和总结
无条件帧的典型应用场景如下
这里其实有很多的细节没画出来
第一个场景
“
”
从上面的分析中我们能总结出LIN总线通信方式
“
”
第二个场景
“
”
第三个场景
“
”
当节点里的信号发生变化的频率较低时,再用无条件帧一遍又一遍地让它应答,这样做很不合适,因为会占用LIN总线的带宽
与无条件帧不论信号是否发生变化必定有从机任务应答不同,事件触发帧只有信号发生变化才需要应答,所以事件触发帧允许无节点应答(只有帧头无应答),也允许两个以上的节点对帧头作应答
当两个以上的节点同时应答时,不会被视为错误,但是主机节点需要解决这个冲突,怎么办呢?
主机节点的主机任务需要立刻中断当前的进度表,然后启动冲突解决进度表,调用这些冲突信号关联的无条件帧,发送帧头,获得应答
由上图可以看出
“
”
可以总结出
“
”
事件触发帧的信号发生变化才应答的特点,很适合应用在对车门的开关状态进行检测的场景
对于事件触发帧来说,由于有可能有多个节点应答,如何知道是哪个节点发来的应答呢?
这个其实也简单
“既然应答冲突时会轮询调用事件触发帧的所有对应的无条件帧,说明一个无条件帧代表一个节点,那么只需要把事件触发帧的应答中第一个字节设置为无条件帧的PID即可
”
由于事件触发帧的长度固定,所以各节点的应答固定,那么对应的无条件帧的应答长度也就固定了
所以
与事件触发帧对应的所有无条件帧需要满足
事件触发帧是主机节点为了获取从机节点的信号状态而发送的帧
那么主机节点里的信号状态又要如何让从机节点知道呢
这里就引入了偶发帧,偶发帧可以当作是主机节点的事件触发帧
当主机节点的信号发生变化时,主机节点的主机任务就会发送偶发帧的帧头,主机节点的从机任务收到帧头后,发送信号,其他从机节点根据自身需要选择是否接收(其实也是分析帧ID后判断的)
上面说的是一个应答,一个偶发帧可能对应多个应答信号,如果同时有多个应答时,怎么办?
和解决事件触发帧的应答冲突一样,一个偶发帧也关联多个无条件帧,每个无条件帧对应一个应答,当同时有多个应答时,主机节点会根据LDF(LIN的数据库文件)中定义好的优先级顺序,依次在同一时隙时发送
偶发帧的无条件帧的发送方式,和事件触发帧的还有所不同
事件触发帧的无条件帧是启用的冲突解决进度表来发送,会一个挨着一个发送,冲突解决进度表中的所有无条件帧发送完毕后,才会重新回到主进度表中继续调度
而偶发帧的应答冲突时,并不会启动冲突解决进度表,还是在主表内,在这个偶发帧的时隙时,调用优先级最高的无条件帧,然后等下一个轮询,又轮到了偶发帧的机会时,再调用优先级次高的无条件帧
由于是主机节点的信号,如果它的信号没有变化,偶发帧都没必要发出去,因为信号没变化,从机节点也没必要判断是否要接收,那主机节点也没必要发偶发帧的帧头,那么这个时隙就会保持沉默
诊断帧分为:主机请求帧、从机应答帧
帧ID = 0x3C
应答由主机节点的从机任务发布
帧ID = 0x3D
应答由从机节点的从机任务发布
保留帧的帧ID为0x3E和0x3F,为将来扩展用