SAEJ1939协议解析及工程实践

原创 汽车电子与软件 2023-08-07 19:13


作者:窦明佳

出品:汽车电子与软件


01

前言


在网络通信设计领域大家讨论比较多的是CAN(FD)Ethernet,但是对于J1939协议的讨论比较少,但J1939协议在目前的商用车及工程机械行业却在大范围应用,在乘用车领域J1939协议栈也有使用,比如GB/T 27930-《电动汽车非车载传导式充电机与电池管理系统之间的通信协议》规定充电桩与BMS之间的通信协议就是采用SAE J1939,关于J1939GB/T 27930标准中的应用我们在下面着重介绍,同时结合工程实践介绍CANoe.J1939的常用功能,并对J1939 DM1报文及多帧传输方式进行介绍,最后介绍了下AUTOSAR架构中的J1939协议栈,希望对J1939协议的初学者有所帮助。


02

J1939 协议介绍


整个SAE J1939协议组包含如下标准:

  • SAE J1939 Serial Control and Communication Heavy Duty Vehicle Network-Top Level Document;

  • SAE J1939-21  Data Link Layer;

  • SAE J1939-31 Network Layer;

  • SAE J1939-71 Application Layer;

  • SAE J1939-73 Application Layer-Diagnostic;

  • SAE J1939-74 Application-Configurable Messaging;

  • SAE J1939-75 Application Layer-Generator Sets;

  • SAE J1993-81 Network Management;


整个标准的内容比较多,我也没有深入研究,只是站在项目使用的角度对SAE 1939-21(数据链路层)PDU格式、参数组概念、传输协议,以及J1939-71(应用层)规定的SPN(可疑参数编号)、PGN(参数组),还有J1939-73中规定的DM1报文、DTC格式等有所了解。下面我们就站在项目实际使用过程需要掌握的基本概念角度为大家介绍如下内容:



2.1帧结构


J1939采用29位ID的扩展帧格式,其整个帧格式相对CAN标准帧在ID域有较大差异外,其他域基本一致,都包含帧起始、仲裁场、控制 场、数据场、CRC场、ACK场、帧结束。

 
图1:CAN标准帧格式



 图2:CAN扩展帧格式



2.2 协议数据单元(PDU)


每个CAN数据帧报文一个协议数据单元PDU(Protocol Data Unit),根据J1939-21的定义协议数据单元由7个部分组成,分别是优先级、保留位、数据页、PDU格式、PDU特定、源地址和数据域,具体详见如下定义:


图3:J1939 PDU结构


ØP(优先级):优先级包含3位,位于ID的最前面,用来优化报文传输中的传输延迟,一条报文的优先级可以从最高0设置到最低7;

ØEDP(扩展数据页):备今后开发使用,当前均设置为0;

ØDP(数据页):应用层在分配参数组编号PGN时,DP=0中的报文分配完以后,允许分配DP=1中的报文,当前所有报文的DP都设置为0,即所有报文的PGN都分配在DP0页中;

ØPF(PDU Format):PF域一共8位,它的取值确定了一条报文的PDU格式。PDU格式一共有两种:PDU1和PDU2,当PF的值在0~239(0x00-0xEF),则表明为PDU1格式,若PF的值在240~255(0XF0-0xFF)之间,则标明为PDU2格式;

ØPS(PDU Specific):PS场一共8位,PS场的内容取决于PF场的取值,若为PDU1格式,则该场表示的为帧的目标地址,若为PDU2格式,则表明为组扩展GE(用于扩展PGN的个数)


ØGE(组扩展):当PF场为PDU2格式,及PF场的高四位全部置位1(PF≥240),则PS场即为GE(组扩展),其与PF场的低四位一起可提供每个数据页4096(212)中参数组,加上PDU1格式的240个参数组,因为对于数据页0共有4096+240=4336个参数组。

ØDA(Destination Address):目标地址,对于单播报文可指定目标地址,任何源地址与该目标地址不同的节点可忽略此报文,当DA场定义为FF时,则为全局目标地址,则要求所有节点对该报文都要做出监听和响应。

ØSA(Source Address):源地址,给定的一个源地址在网络中应当只有一个设备与其对应,在SAE J1939-71中对商用车常用控制器的源地址进行了定义,在J1939通信设计时可以参考,若目前网络拓扑中定义的节点标准中未规定可在128-247范围内来自定义。

ØData(数据域):J1939的数据域长度可以定义超过8个字节,超过8个字节可通过传输协议的连接管理能力来建立和关闭多包参数组的通信。


2.3 参数组编号(PGN)


PGNJ1939标准中的唯一帧标识符,在SAE J1939-71中通过PGN可唯一标识一帧报文,PGN的长度为18位,包含扩展数据页、数据页、PDU格式以及PDU特定字段值。


图4:J1949 PGN结构



2.4 可疑参数编号SPN


可疑参数编号(SPN)是SAE分配给参数组(PGN)中特定参数的编号,它们用作数据字节中CAN信号的标识符,SPN 是一个 19 位数字,其范围从 0 到 524287。从520192到524287的范围被保留给专有参数。除字母数字数据外,SPN 解释始终从 LSB 为 MSB(从右到左)。SPN 可能存在于多个 PGN 中。PGN对 SPN 进行分组。


图5:SAE J1939-71 对PGNSPN的定义示例


03

J1939协议在GB/T 27930中的应用


GB/T 27930 规定充电机与BMS之间的通信物理层采用SAE J1939-11 -《商用车控制系统局域网CAN通信协议 第11部分:物理层,250Kbit/s,屏蔽双绞线》,规定数据链路层选用的是PDU1格式,同时规定PGN的第二字节PDU格式(PF)高字节和低字节均为00H,同时规定充电机的源地址为56H(86),BMS的源地址为F4H(244),并规定该地址固定在ECU的程序代码中,包括服务工具在内的任何手段不能改变其源地址。


有了上面的定义,结合标准中对充电过程中各个阶段报文的PGN定义,就可以得到对应的报文ID,因此标准通篇没有提及报文的ID,都是给的PGN。例如如下充电握手阶段的报文:


 
 6:GB/T27930 充电报文



3.1  J1939 DBC编辑


在编辑GB/T 27930的DBC文件时,如果CANoe带J1939配置,可在CAN DB++Editor直接编辑PGN、Source、Priority、Destination从而自动生成报文ID。


图7:CANdb++Editor J1939 DBC编辑界面



3.2 J1939多帧传输


但是对于数据长度超过8个字节的报文,例如上面BMS和车辆辨识报文BRM数据长度为49个字节时,需要用到SAE J1939-21的传输协议,传输协议的功能分为两个部分:消息的拆包与重组,连接管理。


8BMS和充电机辨识报文BRM

1)消息拆包与重组:大于8字节的数据不能通过一个单独的CAN数据帧来传输,需要被拆分为多个数据包,使用单独的数据帧一次传送,接收者则负责按编号将多个数据包重组为长数据,并传给应用程序。


2)连接管理:连接管理包含三个过程,建立连接、数据传输、连接关闭。


9:J1939-21 多帧传输流程

Ø建立连接:当某个节点要传输一组大于8字节的数据时,就会发起请求连接,请求中包含整个数据包的大小,要传送消息的帧数,以及它设定的参数群编号,然后等待接收方做出响应。


10:多帧传输传输层建立连接报文

Ø数据传输:当建立连接之后,当发送者接收到允许发送的信号后,发送者将按顺序将拆装后的数据一次发送到CAN网路上,数据帧的第一个字节用于表示当前数据包的编号。

11:多帧报文数据传输报文

Ø连接关闭:当数据被正确发送后,接收方会回传一个数据包,数据包内容包括:结束应答编号、整个消息的大小、接收的帧数以及参数组编号。

12:多帧传输的连接关闭报文



04

J1939 DTC



4.1 J1939 DM1报文格式


对于商用车的诊断,不像乘用车UDS被广泛使用,现在很多商用车的控制器没有做UDS诊断,其故障发送机制大部分会按照SAE J1939-73 DM1报文的格式发送,DM1报文的PGN固定为00FECA16,如下为DM1报文的格式定义:


图13:DM1报文结构


图14:DM1报文中DTC的格式定义


激活诊断故障码DM1的发送规则为有DTC激活时,DM1就会立即发送,此后每秒发送一次,如果在1秒内发生新的DTC,则DM1应立即发送且发送先于原DTC,以反应新的DTC,DM1发送应包含当前所有的DTC。当有多个DTC存在时,a=灯状态,b=SPN,c=FMI,d=CM和OC,则报文的格式为a,b,c,d,b,c,d……使用传输协议,存在0个DTC时,字节1=0,字节2=0xFF,字节3——6=0,字节7-8=0Xff。

图15:CANoe DM1报文Trace



4.2 J1939 DM1报文多帧传输


当节点的当前激活故障码DTC数量大于1时,就需要用到SAE J1939-21的传输协议了,它首先发送一条广播公告消息(BAM),BAM消息包含了即将广播的长消息的参数组编号、消息大小和它被拆的数据包数目,然后使用PGN=60160来发送相关的数据。


                 图16:J1939 DM1报文多帧传输CANoe Trace



4.3 CANoe.J1939 DTC Monitor


CANoe.J1939 会有DTC Monitor可提供简单接口监控诊断协议,不需要程序设计即可显示/查询故障码,同时可显示MIL灯、DTC历史、激活DTC、DTC、冻结帧、设置等。

图17:CANoe.J1939 DTC Monitor界面


05

AUTOSAR架构中J1939协议栈


在整个AUTOSAR CP的架构中包含J1939相关的模块由J1939DCM,J1939 Nm、J1939 Rm、J1939 TP。


图18:AUTOSAR CP软件模块



5.1 诊断通信管理DCM(Diagnostic Communication Manager)


负责UDS和SAE J1939-73通信路径和诊断服务的执行,从而处理来自外部测试人员或OBD系统的诊断请求,它转发来自外部扫描工具的请求,并进一步负责封装响应的消息(DTC、状态信息),这些消息随后将传输到外部诊断扫描工具。


18 AUTOSAR 诊断相关模块



5.2 J1939网络管理


和AUTOSAR其他网络管理不同,J1939的网络管理并不是去处理ECU的睡眠与唤醒,而是给每一个ECU分配一个唯一的地址,在SAE J1939-81中定义0xEE00这个PGN值用来做地址声明,当ECU启动时ECU发出此声明表示自己期待分配某一地址,如果另一个ECU拥有同一个地址并且有更高的优先级,那么ECU需要在发送CannotClaimAddress后进入静默状态。




5.3 J1939 请求管理RM


J1939 Request Management用来管理请求消息的接收与发送,将请求数据转发给其他模块处理,以及对应确认消息的回复。上面提到的诊断功能,同样需要用到RM模块。




06

总结


因为商用车、工程机械行业不像乘用车具有很大的体量,同时其车品品类有很多,零部件供应商不可能针对每个OEM都定制开发,所以采用标准化的J1939协议可以尽量将PGN、SPN标准化,降低开发工作量及成本,提供零件的通用化率。但是这样同样带来了信息安全的风险,所有的通信都是明文公开的,所以现在智能商用车架构中,J1939协议只在底盘域、动力域使用,在座舱域、车身域、智驾域、网联域等已经很少用到,但是作为商用车企业的通信设计人员还是需要深入研究下J1939协议的。


END

添加微信”btighteast”加入微信交流群
(仅限专业人士,添加备注单位+姓名)


汽车电子与软件 主要介绍汽车电子软件设计相关内容,每天分享一篇技术文章!
评论
  • 全球智能电视时代来临这年头若是消费者想随意地从各个通路中选购电视时,不难发现目前市场上的产品都已是具有智能联网功能的智能电视了,可以宣告智能电视的普及时代已到临!Google从2021年开始大力推广Google TV(即原Android TV的升级版),其他各大品牌商也都跟进推出搭载Google TV操作系统的机种,除了Google TV外,LG、Samsung、Panasonic等大厂牌也开发出自家的智能电视平台,可以看出各家业者都一致地看好这块大饼。智能电视的Wi-Fi连线怎么消失了?智能电
    百佳泰测试实验室 2024-12-12 17:33 54浏览
  • 一、SAE J1939协议概述SAE J1939协议是由美国汽车工程师协会(SAE,Society of Automotive Engineers)定义的一种用于重型车辆和工业设备中的通信协议,主要应用于车辆和设备之间的实时数据交换。J1939基于CAN(Controller Area Network)总线技术,使用29bit的扩展标识符和扩展数据帧,CAN通信速率为250Kbps,用于车载电子控制单元(ECU)之间的通信和控制。小北同学在之前也对J1939协议做过扫盲科普【科普系列】SAE J
    北汇信息 2024-12-11 15:45 112浏览
  • 时源芯微——RE超标整机定位与解决详细流程一、 初步测量与问题确认使用专业的电磁辐射测量设备,对整机的辐射发射进行精确测量。确认是否存在RE超标问题,并记录超标频段和幅度。二、电缆检查与处理若存在信号电缆:步骤一:拔掉所有信号电缆,仅保留电源线,再次测量整机的辐射发射。若测量合格:判定问题出在信号电缆上,可能是电缆的共模电流导致。逐一连接信号电缆,每次连接后测量,定位具体哪根电缆或接口导致超标。对问题电缆进行处理,如加共模扼流圈、滤波器,或优化电缆布局和屏蔽。重新连接所有电缆,再次测量
    时源芯微 2024-12-11 17:11 109浏览
  • 本文介绍瑞芯微RK3588主板/开发板Android12系统下,APK签名文件生成方法。触觉智能EVB3588开发板演示,搭载了瑞芯微RK3588芯片,该开发板是核心板加底板设计,音视频接口、通信接口等各类接口一应俱全,可帮助企业提高产品开发效率,缩短上市时间,降低成本和设计风险。工具准备下载Keytool-ImportKeyPair工具在源码:build/target/product/security/系统初始签名文件目录中,将以下三个文件拷贝出来:platform.pem;platform.
    Industio_触觉智能 2024-12-12 10:27 62浏览
  • 应用环境与极具挑战性的测试需求在服务器制造领域里,系统整合测试(System Integration Test;SIT)是确保产品质量和性能的关键步骤。随着服务器系统的复杂性不断提升,包括:多种硬件组件、操作系统、虚拟化平台以及各种应用程序和服务的整合,服务器制造商面临着更有挑战性的测试需求。这些挑战主要体现在以下五个方面:1. 硬件和软件的高度整合:现代服务器通常包括多个处理器、内存模块、储存设备和网络接口。这些硬件组件必须与操作系统及应用软件无缝整合。SIT测试可以帮助制造商确保这些不同组件
    百佳泰测试实验室 2024-12-12 17:45 53浏览
  • 铁氧体芯片是一种基于铁氧体磁性材料制成的芯片,在通信、传感器、储能等领域有着广泛的应用。铁氧体磁性材料能够通过外加磁场调控其导电性质和反射性质,因此在信号处理和传感器技术方面有着独特的优势。以下是对半导体划片机在铁氧体划切领域应用的详细阐述: 一、半导体划片机的工作原理与特点半导体划片机是一种使用刀片或通过激光等方式高精度切割被加工物的装置,是半导体后道封测中晶圆切割和WLP切割环节的关键设备。它结合了水气电、空气静压高速主轴、精密机械传动、传感器及自动化控制等先进技术,具有高精度、高
    博捷芯划片机 2024-12-12 09:16 85浏览
  • 在智能化技术快速发展当下,图像数据的采集与处理逐渐成为自动驾驶、工业等领域的一项关键技术。高质量的图像数据采集与算法集成测试都是确保系统性能和可靠性的关键。随着技术的不断进步,对于图像数据的采集、处理和分析的需求日益增长,这不仅要求我们拥有高性能的相机硬件,还要求我们能够高效地集成和测试各种算法。我们探索了一种多源相机数据采集与算法集成测试方案,能够满足不同应用场景下对图像采集和算法测试的多样化需求,确保数据的准确性和算法的有效性。一、相机组成相机一般由镜头(Lens),图像传感器(Image
    康谋 2024-12-12 09:45 75浏览
  • 首先在gitee上打个广告:ad5d2f3b647444a88b6f7f9555fd681f.mp4 · 丙丁先生/香河英茂工作室中国 - Gitee.com丙丁先生 (mr-bingding) - Gitee.com2024年对我来说是充满挑战和机遇的一年。在这一年里,我不仅进行了多个开发板的测评,还尝试了多种不同的项目和技术。今天,我想分享一下这一年的故事,希望能给大家带来一些启发和乐趣。 年初的时候,我开始对各种开发板进行测评。从STM32WBA55CG到瑞萨、平头哥和平海的开发板,我都
    丙丁先生 2024-12-11 20:14 73浏览
  • 习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记
    youyeye 2024-12-12 10:13 40浏览
  • 习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记
    youyeye 2024-12-11 17:58 86浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦