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


汽车电子与软件 主要介绍汽车电子软件设计相关内容,每天分享一篇技术文章!
评论 (0)
  •  霍尔效应的检测需通过实验手段测量霍尔电压、载流子浓度等参数,并分析材料电学特性。以下是具体检测方法及流程:一、核心检测方法1、‌直流(DC)霍尔测试‌‌原理‌:通过恒定磁场和电流测量霍尔电压,适用于常规半导体材料(如硅、砷化镓)。‌步骤‌:向样品通入直流电流,施加垂直磁场,用高精度电压表直接测量霍尔电压,并排除热电压等干扰信号。2、‌交流磁场(AC)霍尔测试‌‌适用场景‌:针对低迁移率材料(如某些有机半导体),霍尔电压远小于误差电压时使用。‌技术要点‌:利用锁相放大器提取交流磁场下的
    锦正茂科技 2025-04-21 11:39 40浏览
  • 导读在智能汽车技术发展浪潮中,车辆控制系统的智能化、网络化已成为行业发展的必然趋势。虹科PEAK智行定位车控系统,集成了尖端科技,能够实现车辆全方位监控与控制。从实时GPS定位到CAN/CAN FD信号处理,虹科方案不仅提升了车辆的智能化水平,更在安全性和效率上迈出了革命性的一步。虹科PEAK智行定位车控系统,通过CAN/CAN FD信号实现车辆的精准控制,包括加减速、转弯、倒退等动作,模拟真实车辆平台的动态表现。该系统搭载了虹科各型号设备,通过紧密协作,实时反映车辆位置、总线报文等信息,实现车
    虹科汽车智能互联 2025-04-21 16:04 64浏览
  •  霍尔效应自发现以来,已渗透至多个行业领域,其核心应用可归纳为以下几类:一、‌电子与半导体行业‌1、‌半导体器件开发与测试‌① 通过测量霍尔系数和电阻率,判断器件的导电类型(N型/P型)及载流子浓度分布,优化器件设计和制造工艺‌。② 监控晶圆掺杂水平和表面缺陷,提高集成电路良率‌。2、‌磁场传感器制造与校准‌测试霍尔传感器的灵敏度、线性度、响应时间等参数,确保其在汽车、工业控制等场景下的可靠性‌。3、‌电磁测量仪器‌基于霍尔电压与磁场强度的线性关系,开发高斯计、电流表、功率计等‌。二、
    锦正茂科技 2025-04-21 13:17 45浏览
  •   海上安全事件应急处置系统平台深度解析   一、平台概述   北京华盛恒辉海上安全事件应急处置系统平台融合现代信息技术、通信技术、GIS、大数据分析及 AI 等技术,旨在快速响应船舶碰撞、火灾、溢油等海上突发事件,实现科学决策与高效资源调配,保障海上生命财产安全、减少环境污染。   应用案例   目前,已有多个海上安全事件应急处置系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润海上安全事件应急处置系统。这些成功案例为海上安全事件应急处置系统的推广和应用提供了有力支持
    华盛恒辉l58ll334744 2025-04-21 15:21 82浏览
  • 导读在汽车测试和现代工业领域,功耗控制与效率优化是工程师们不断追求的目标。虹科PCAN Router系列设备以其卓越的性能和灵活性,为CAN/CAN FD网络中的报文转换提供了高效解决方案。本文将探讨虹科PCAN Router系列设备如何在保持高效工作的同时,通过低功耗模式和高效唤醒功能,满足对能耗有严格要求的应用场景。虹科PCAN Router系列网关1 低功耗模式的优势与实现在实际的工作场景中,可能会出现一些对功耗要求存在限制的情况。鉴于此,可以灵活设置虹科PCAN Router系
    虹科汽车智能互联 2025-04-21 15:45 59浏览
  •   有效数据智能分拣系统详解   北京华盛恒辉有效数据智能分拣系统融合人工智能、大数据分析与机器学习等前沿技术,实现海量数据自动化分类、筛选、整理及分配。凭借强大的数据处理效能,助力企业精准提取关键信息,优化决策流程,提升运营效率。以下从系统架构、核心功能、技术特性、应用场景及发展趋势展开解读。   应用案例   目前,已有多个有效数据智能分拣系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润有效数据智能分拣系统。这些成功案例为有效数据智能分拣系统的推广和应用提供了有力支持。
    华盛恒辉l58ll334744 2025-04-21 16:46 97浏览
  • 导读在当今快速发展的智能通讯领域,时间敏感网络(TSN)已成为确保网络通信高可靠性和低延迟的关键技术。IEEE 802.1 Qci作为TSN的一个重要组成部分,提供了一套强大的机制来管理网络流量,确保关键数据流的优先级和带宽得到保障。本文将深入探讨IEEE 802.1 Qci协议的基本概念、工作原理以及虹科提供的Qci解决方案,帮您理解如何通过精确的流量控制来提升网络的稳定性和效率。虹科TSN解决方案01# 技术简介时间敏感网络(TSN)通过IEEE 802.1 Qci标准定义了一种关
    虹科工业智能互联 2025-04-21 16:17 70浏览
  •   海上安全事件应急处置系统解析   北京华盛恒辉海上安全事件应急处置系统是为应对船舶碰撞、火灾等海上突发事件打造的综合管理体系,通过技术与协同机制,实现快速响应救援、优化资源配置,守护海上生命、财产与环境安全。以下从系统构成、功能、技术、应用及趋势展开阐述。   应用案例   目前,已有多个海上安全事件应急处置系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润海上安全事件应急处置系统。这些成功案例为海上安全事件应急处置系统的推广和应用提供了有力支持。   一、系统构成
    华盛恒辉l58ll334744 2025-04-21 15:50 66浏览
  •   有效数据智能分拣系统平台深度解析   一、系统概述   北京华盛恒辉有效数据智能分拣系统平台融合人工智能、机器视觉、物联网及大数据分析技术,为物流包裹、数据信息等提供高效精准的智能化分拣处理方案。通过自动化设备与智能算法协同运作,取代传统人工分拣模式,显著提升分拣效率、降低错误率,满足电商、快递及供应链不断增长的业务需求。   应用案例   目前,已有多个有效数据智能分拣系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润有效数据智能分拣系统。这些成功案例为有效数据智能分
    华盛恒辉l58ll334744 2025-04-21 16:22 111浏览
  • 导读Linux驱动程序领域再添新成员,PLIN驱动程序现已正式发布。这一新驱动程序为使用LIN接口的用户提供了一个便捷、高效的解决方案。本文将展示如何安装PLIN驱动程序,以及如何在Linux环境下进行基本的PLIN通信操作,确保您能够快速掌握并应用这一新工具。继我们在Linux环境下成功推出CAN/CAN FD接口驱动程序后,现在我们为LIN接口带来了同样兼容Linux的驱动程序。免费软件包中不仅包含了驱动程序本身,还提供实用工具和一份易于理解的快速入门指南。用户下载后,需要根据当前使用的Li
    虹科汽车智能互联 2025-04-21 14:56 58浏览
  • 精益生产咨询师证/精益管理专业人员证/精益生产工程师证虽然在名称上有一些差异,但其实实际区别并不大,目前类似的证书以ILSSI-CLMP较为得到国际上的认可,当然,你不会因为有一张精益生产咨询师证,而会有人马上请你做咨询师,因为除了知识之外,你还要有充足经验、热诚、沟通能力等等,这些也是我们招聘咨询师的基本要求。那么,有没有必要取得CLMP证书呢?这主要取决于你自己对职业发展的规划和自我提升的意志。CLMP是什么?CLMP的全称是Certified Lean Management Profess
    优思学院 2025-04-21 14:29 42浏览
  • 北京贞光科技有限公司作为紫光同芯授权代理商,深耕电子元器件领域数十载,专为汽车与工业客户提供车规级安全芯片及配套服务。公司整合硬件供应、软件SDK与技术支持为一体,配备专业团队提供选型咨询与现场指导,助力客户实现完整的芯片应用解决方案。在全球芯片供应链重构的大背景下,我国车规级芯片产业正迎来前所未有的发展机遇。北京贞光科技有限公司作为紫光同芯授权代理商,深耕电子元器件领域数十载,专为汽车与工业客户提供车规级安全芯片及配套服务。公司整合硬件供应、软件SDK与技术支持为一体,配备专业团队提供选型咨询
    贞光科技 2025-04-21 16:10 67浏览
  •   电磁信号模拟系统深度解析   一、系统概述   北京华盛恒辉电磁信号模拟系统作为半实物仿真测试系统,广泛应用于无线通信、军事训练等多领域。它通过软硬件结合,构建逼真电磁信号环境,用于测试电子设备在复杂电磁干扰下的性能表现。   应用案例   目前,已有多个电磁信号模拟系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润电磁信号模拟系统。这些成功案例为电磁信号模拟系统的推广和应用提供了有力支持。   二、系统组成   装备模型库:涵盖雷达、通信设备等各类装备平台及电子装
    华盛恒辉l58ll334744 2025-04-21 10:48 93浏览
  •   电磁信号模拟平台解析   北京华盛恒辉电磁信号模拟平台作为模拟复杂电磁环境的系统,在无线通信、电子对抗等多领域广泛应用。以下从功能、技术特性、应用场景及发展趋势展开详细解读。   应用案例   目前,已有多个电磁信号模拟平台在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润电磁信号模拟平台。这些成功案例为电磁信号模拟平台的推广和应用提供了有力支持。   一、核心功能   复杂电磁环境建模:构建贴近真实的电磁环境,涵盖各类干扰因素。   多通道信号模拟:模拟多通道电磁信号
    华盛恒辉l58ll334744 2025-04-21 15:10 88浏览
  • 一、‌基础原理验证与分析‌1、‌理解霍尔效应基本机制‌通过实验观察磁场中导体或半导体材料的电荷偏转现象,验证霍尔电压与磁场强度、电流方向的关系,直观认识洛伦兹力对载流子的作用‌。2、‌探索磁电效应关联性‌研究霍尔效应与材料电学特性(如载流子类型、浓度)的关联,揭示半导体材料的导电机制(如N型/P型半导体)。二、‌参数测量与标定‌1、‌关键物理量测量‌掌握霍尔元件灵敏度(KH)、霍尔系数(RH)、电导率(σ)及载流子迁移率(μ)的测量方法,为半导体材料性能评估提供数据支持。2、‌磁场强度与分布测定
    锦正茂科技 2025-04-21 13:03 35浏览
我要评论
0
1
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦