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”加入微信交流群
(仅限专业人士,添加备注单位+姓名)


汽车电子与软件 主要介绍汽车电子软件设计相关内容,每天分享一篇技术文章!
评论
  • 多人同时共享相同无线网络,以下场景是否是您熟悉的日常?姐姐:「妈~我在房间在线上课,影音一直断断续续的怎么上课啊!」奶奶:「媳妇啊~我在在线追剧,影片一直卡卡的,实在让人生气!」除此之外,同时间有老公在跟客户开在线会议,还有弟弟在玩在线游戏,而妈妈自己其实也在客厅追剧,同时间加总起来,共有五个人同时使用这个网络!我们不论是在家里、咖啡厅、餐厅、商场或是公司,都会面临到周遭充斥着非常多的无线路由器(AP),若同时间每位使用者透过手机、平板或是笔电连接到相同的一个网络,可想而知网络上的壅塞及相互干扰
    百佳泰测试实验室 2025-03-06 16:50 24浏览
  • ASL6328芯片支持高达 6.0 Gbps 运行速率的交流和直流耦合输入T-MDS 信号,具备可编程均衡和抖动清理功能。ASL6328 是一款单端口 HDMI/DVI 电平转换 / 中继器,具有重新定时功能。它包含 TypeC双模式 DP 线缆适配器寄存器,可用于识别线缆适配器的性能。抖动清理 PLL(锁相环)能够消除输入抖动,并完全重置系统抖动容限,因此能更好地满足更高数据速率下 HDMI 抖动合规性要求。设备的运行和配置可通过引脚设置或 I2C 总线实现。自动断电和静噪功能提供了灵活的电
    QQ1540182856 2025-03-06 14:26 84浏览
  • 文/Leon编辑/cc孙聪颖2025年全国两会进行时,作为“十四五”规划收官之年,本届两会释放出坚定目标、稳中求进、以进促稳等信号。其中,企业家们的建议备受关注,关系到民营经济在2025年的走向。作为国内科技制造业的“老兵”,全国人大代表、TCL集团创始人及董事长李东生在本届两会中提出三份代表建议,包括《关于优化中国科技制造业融资环境的建议》、《关于加强AI深度伪造欺诈管理的建议》和《关于降低灵活就业人员社会保险参保门槛的建议》,表现出对科技制造、AI发展和劳动者保障方面的关注。会后,李东生接受
    华尔街科技眼 2025-03-06 19:41 20浏览
  • 随着自动驾驶技术的迅猛发展,构建高保真、动态的仿真场景成为了行业的迫切需求。传统的三维重建方法在处理复杂场景时常常面临效率和精度的挑战。在此背景下,3D高斯点阵渲染(3DGS)技术应运而生,成为自动驾驶仿真场景重建的关键突破。一、3DGS技术概述与原理1、3DGS的技术概述3DGS是一种基于3D高斯分布的三维场景表示方法。通过将场景中的对象转化为多个3D高斯点,每个点包含位置、协方差矩阵和不透明度等信息,3DGS能够精确地表达复杂场景的几何形状和光照特性。与传统的神经辐射场(NeRF)方法相比,
    康谋 2025-03-06 13:17 113浏览
  • 在六西格玛项目中,团队的选择往往决定了最终的成败。合适的团队成员不仅能推动项目顺利进行,更能确保最终成果符合预期。因此,组建六西格玛团队时,必须挑选最合适的人才,确保他们具备必要的能力和特质。团队主管的关键特质每个精益六西格玛项目都需要一位主管来带领团队。他们不仅需要具备领导力,还要能够分析数据、制定策略,并与管理层和团队成员高效沟通。团队主管的核心职责包括:领导团队行动:能够激励成员,确保团队朝着既定目标前进。数据分析能力:精通数据处理和分析,能基于数据做出决策。沟通协调:能够在管理层和团队之
    优思学院 2025-03-06 12:51 92浏览
  • 案例1 2008款保时捷卡宴车行驶中发动机偶发熄火故障现象 一辆2008款保时捷卡宴车,搭载4.8 L 自然吸气发动机,累计行驶里程约为21万km。车主反映,该车行驶中发动机偶发熄火;重新起动,发动机能够起动着机,只是起动时间延长,且组合仪表上的发动机故障灯异常点亮。 故障诊断接车后试车,发动机起动及怠速运转正常。用故障检测仪检测,发动机控制单元(DME)中存储有故障代码“P0335 曲轴位置传感器A电路”,由此怀疑曲轴位置传感器信号偶尔异常,导致发动机熄火。用虹科Pico汽车示波器测
    虹科Pico汽车示波器 2025-03-05 11:00 62浏览
  • 服务器应用环境与客户需求PCIe 5.0高速接口技术的成熟驱动着生成式AI与高效能运算等相关应用蓬勃发展。在随着企业对服务器性能的要求日益严苛,服务器更新换代的周期也持续加快。在此背景下,白牌与DIY(Do It Yourself)服务器市场迎来了新的发展契机,但同时也面临着更趋复杂的技术挑战。传统上,白牌与DIY服务器以其高度客制化与成本效益优势受到市场青睐。然而,随着PCIe 5.0等高速技术的导入,服务器系统的复杂度大幅提升,对组装技术与组件兼容性也就提出更高的要求。举个简单的例子来说,P
    百佳泰测试实验室 2025-03-06 17:00 33浏览
  • 在当今竞争激烈的市场环境中,企业不仅需要优化成本,还需积极响应国家的能源政策,减少对环境的影响。提升工业能源效率正是实现这一双重目标的关键。中国近年来大力推进“双碳”目标(碳达峰、碳中和),并出台了一系列政策鼓励企业节能减排。通过宏集CODRA的Panorama解决方案,企业可以获得专为这一目标设计的SCADA工具,实时监控和调整所有工业设备的能耗。特别是其中的能源管理模块,能够有效分析数据,预防故障,避免能源浪费。Panorama的优化技术宏集CODRA提供的解决方案,尤其是Panorama
    宏集科技 2025-03-06 11:25 112浏览
  • 1. 背景在汽车电子系统测试中,CANoe作为主流的仿真测试工具,常需与云端服务器、第三方软件或物联网设备进行交互。随着CANoe与外部软件、服务器或设备交互越来越多,直接使用Socket进行通信往往不能满足使用需求,依托于CANoe 的连接功能集(Connectivity Feature Set),以及Distributed Object(DO)功能,可以仿真HTTP节点,实现设备与服务器等之间的通信,保证数据处理的可靠性和便捷性。本文详细解析如何利用CANoe搭建HTTP测试环境,并提供典型
    北汇信息 2025-03-05 11:56 86浏览
  • 引言嘿,各位电动汽车的爱好者们!咱们今儿个就来聊聊电动汽车里那些“看不见,摸不着”,但又至关重要的零部件。要说电动汽车这玩意儿,那可真是科技含量满满,各种高精尖的技术都往里堆。但要让这些高科技玩意儿协同工作,稳定可靠地运转,那就得靠一些幕后英雄,比如说——电容器。你可能会想,电容器?这不就是电子电路里常见的元件嘛,能有多重要? 哎,你可别小瞧了这小小的电容器。在电动汽车的心脏地带——高压直流转换器(DC-DC转换器)里,车规级的电容器那可是扮演着举足轻重的角色。 今天,咱们就聚焦分析三星电机车规
    贞光科技 2025-03-05 17:02 86浏览
  • 文/Leon编辑/侯煜‍2008至2021年间,创维以高举高打的凌厉之势,果断进行投资,一度成为中国市场大屏OLED产业的旗手,引领着显示技术的发展方向。但近年来,创维在 OLED 领域的发展轨迹却逐渐模糊,态度陷入暧昧不明的混沌状态。究其根源,一方面,创维对过往的押注难以割舍,在技术革新与市场变化的浪潮中,不愿轻易推翻曾经的战略布局;另一方面,早期在大屏OLED 技术研发、市场推广等环节投入的巨额资金,已然形成沉没成本,极大地限制了创维在显示技术路线上的重新抉择。但市场瞬息万变,为适应激烈的行
    华尔街科技眼 2025-03-05 20:03 144浏览
  • 产品质量合格率偏低会引起质量成本(也称“劣质成本”)的大幅增加。质量成本通常分为内部损失成本和外部损失成本两部分。内部损失成本是指产品交付前因质量不合格造成的损失,包括返工、报废等;外部损失成本是指产品交付后因质量问题导致的损失,如退货、召回等。此外,质量问题还会影响生产效率,带来额外人工和停工损失。下面分别介绍各类损失的具体计算方法和公式。直接成本损失(内部故障成本)直接成本是由于产品在出厂前质量不合格所造成的看得见的损失。常见的直接损失包括返工、报废以及由此产生的额外原材料消耗等。返工成本:
    优思学院 2025-03-05 15:25 77浏览
  • 概述随着工业4.0的深入推进,制造业对自动化和智能化的需求日益增长。传统生产线面临空间不足、效率低下、灵活性差等问题,尤其在现有工厂改造项目中,如何在有限空间内实现高效自动化成为一大挑战。此次项目的客户需要在现有工厂基础上进行改造,空间有限。为此,客户选择了SCARA型线性轴机器人作为执行设备。然而,SCARA机器人的高效运行离不开强大的控制系统支持。宏集凭借其先进的智能控制系统,为客户提供了高效、灵活的自动化解决方案,确保SCARA机器人在有限空间内发挥最大效能。一、客户需求在此次改造项目中,
    宏集科技 2025-03-06 11:27 115浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦