J1939协议理解
J1939数据协议的格式理解
J1939数据协议的格式理解
(一)J1939数据包的格式。
见“图表1”
图表 1
格式定义:
P:优先级
R:保留位
DP:数据页
PF:PDU数据格式域,(8位的数据域)当数据大小低于240时为PDU1格式;当大于240
时为PDU2格式。
PS:PDU细节,为一个8位的数据域,在PDU1数据格式下PS表示的是一个地址;在PDU2
数据格式下,PS表示的是一个组扩展值。
SA:源地址
Data Field:数据域为0-8字节的数据。
参数组的计算:
通常我们只用到PDU1的数据格式,其参数组号(PGN)的计算方法为:
PGN=PF*256+PS
例如:PF=240;PS=4则PGN=240*256+4=61444 “614444”为J1939协议的数据参数组号,根据协议可以查到该参数组号的详细描述。
图表 2
可以在J1939协议中查找数据参数组号为61444的数据信息也可以在具体的发动机的数据表中来查询该书剧组编号的信息。
1939 故障诊断协议
J1939故障诊断协议本协议旨在明确在J1939通讯协议下,故障诊断过程中各方的责任、权利和义务,以确保故障诊断的准确性和高效性。
本协议适用于采用J1939通讯协议进行故障诊断的所有相关方。
一、协议范围本协议适用于使用J1939通讯协议进行故障诊断的车辆、设备和系统,包括但不限于商用车、工业设备和农业机械等。
二、术语定义1.J1939通讯协议:一种用于车辆通信的网络协议,广泛应用于商用车、工业设备和农业机械等领域。
2.故障诊断:通过对车辆、设备和系统的运行状态进行监测和分析,识别并定位故障的过程。
3.故障码:用于标识特定故障的一组代码,便于故障诊断和维修。
三、协议内容1.故障诊断流程(1)相关方应遵循J1939通讯协议的标准和规范进行故障诊断。
(2)在故障诊断过程中,相关方应确保数据的准确性和完整性,并及时共享必要的信息。
(3)故障诊断完成后,相关方应提供详细的故障报告和维修建议。
— 1 —2.故障码管理(1)相关方应建立统一的故障码管理体系,确保故障码的准确性和一致性。
(2)相关方应及时更新和维护故障码数据库,以便在故障诊断过程中快速准确地识别故障。
3.技术支持和培训(1)相关方应提供必要的技术支持和培训,确保故障诊断人员具备相应的技能和能力。
(2)相关方应定期评估故障诊断人员的技能水平,并提供必要的培训和提高计划。
四、协议执行和监督1.本协议的执行和监督由相关方共同负责。
2.相关方应定期评估协议的执行情况,并对存在的问题进行及时改进和优化。
3.对于违反本协议规定的行为,相关方有权采取相应的措施予以纠正和处理。
五、附则1.本协议未尽事宜可由相关方另行协商补充。
2.本协议的修改和终止应由相关方共同协商决定。
3.本协议自签署之日起生效,有效期为______年。
到期后可根据实际情况进行续签或修改。
— 2 —。
j1939协议
j1939协议
J1939协议是一种面向车辆电子控制系统的通信协议。
它是由美国卡车制造商和发动机制造商联合制定,主要用于汽车、卡车和工程机械等领域中各种电子设备之间的通讯。
J1939协议采用了CAN总线通讯方式,并且在CAN 数据
帧中设置有特定的标识符和数据格式,以保证各个设备之间的通讯与协同。
J1939协议可应用于各种车辆控制系统中的所有
功能,例如:发动机控制、变速器控制、制动系统、显示器、灯光控制等。
通过J1939协议,一个设备可以与其他设备进行双向通信。
J1939协议定义了许多参数集(PGN)和服务集(SPN)。
PGN包含协议中的所有信息,是通信的最小单位,用于定义消
息的内容和分区。
例如,PGN65265(0x00FEE1)是汽车接近传感器信息的标准信息,包含了车辆的距离、速度和车道信息。
而SPN则是一个16位的数字,用于表示参数的识别号。
它指
定了每个参数的编码方式、数据格式和范围等信息。
例如,SPN100(0x0064)表示刹车踏板信号的实际值。
J1939协议在实际应用中具有广泛的应用,例如车辆故障诊断、车辆远程监控、车辆自动驾驶等。
通过使用J1939协议,车辆控制系统中的各个设备可以高效地协同工作,有效地提高了汽车的安全性和可靠性。
同时,也为汽车制造商提供了更多的数据和故障诊断信息,促进了汽车制造和维修的进一步发展。
j1939协议
j1939协议J1939协议是一种用于重型商用车辆之间通信的协议。
该协议基于CAN总线,旨在提供一种标准化的数据通信方式,以便不同设备之间可以相互交换信息。
J1939协议定义了一套规范,包括消息格式、数据结构和网络管理等方面的内容。
它为商用车辆提供了一种灵活的通信方式,使不同的设备可以通过CAN总线发送和接收信息。
J1939协议的消息格式是基于CAN数据帧的,由一个11位的标识符和一个8字节的数据字段组成。
标识符用于标识不同类型的消息,而数据字段则用于传输实际的数据。
在J1939协议中,有一些预定义的消息格式,如DM1、DM2和TPDT等。
这些消息格式包含了与车辆故障诊断和数据传输相关的信息。
通过这些消息格式,设备可以向车辆发送警告信息,并接收来自车辆的故障诊断数据。
除了消息格式外,J1939协议还定义了一套数据结构和网络管理规则。
数据结构用于描述不同类型的数据,在传输过程中保持一致性和可靠性。
而网络管理规则用于管理CAN总线的通信,包括网络初始化、错误处理和带宽分配等。
J1939协议在重型商用车辆中有广泛的应用。
例如,它可以用于车辆的故障诊断系统,通过发送故障码来检测和诊断车辆的故障。
它还可以用于车辆的监控系统,通过传输车辆状态数据来实时监测车辆的性能。
此外,J1939协议还支持数据传输和实时控制。
通过发送和接收数据报文,设备可以实现实时的数据传输和控制功能。
例如,它可以用于车辆的制动系统,通过发送制动指令来控制车辆的制动力。
总体而言,J1939协议为重型商用车辆提供了一种标准化的数据通信方式。
它通过定义消息格式、数据结构和网络管理规则,使不同设备之间可以方便地进行信息交换。
这种通信方式不仅提高了车辆的性能和可靠性,还为车辆的故障诊断和数据传输提供了便利。
J1939协议
J1939协议一、协议目的本协议旨在规范和定义J1939协议的通信规则和数据格式,以便确保各种车辆和设备之间的互操作性和数据交换的一致性。
二、协议范围本协议适用于使用J1939协议进行通信的各种车辆和设备,包括但不限于商用车辆、农业机械、建筑设备、发电机组、船舶和工业自动化设备等。
三、术语和定义1. J1939协议:一种用于车辆和设备之间的通信的协议,基于CAN总线技术。
2. 数据帧:J1939协议中的数据传输单元,包含源地址、目标地址、数据内容等信息。
3. 参数组:J1939协议中的一种数据结构,用于封装和传输特定的数据项。
4. PGN:参数组号码(Parameter Group Number),用于唯一标识一个参数组。
5. SPN:信号参数号码(Suspect Parameter Number),用于唯一标识一个参数组中的一个信号。
四、协议规则1. 数据帧格式1.1 数据帧由CAN总线上的标准帧组成,帧格式为11位标识符。
1.2 数据帧包含11位标识符、数据长度代码(DLC)、数据字节和CRC校验码。
1.3 数据帧的标识符中包含源地址、优先级、数据页、PGN等信息。
1.4 数据帧的DLC定义了数据帧中数据字节的数量。
1.5 数据帧的CRC校验码用于验证数据的完整性。
2. 参数组格式2.1 参数组由一个PGN和一个或多个SPN组成。
2.2 PGN由18位标识符的前3个字节组成。
2.3 SPN由16位标识符的后两个字节组成。
2.4 参数组中的数据按照大端字节序排列。
3. 数据传输3.1 数据传输通过CAN总线进行。
3.2 数据帧的发送和接收由源地址和目标地址进行控制。
3.3 数据传输的优先级由数据帧的标识符中的优先级字段确定。
3.4 数据传输的频率和时序由应用层协议定义。
4. 错误处理4.1 错误帧:当接收到错误的数据帧时,应立即发送错误帧作为响应。
4.2 错误处理机制:错误处理机制应能够检测和处理数据传输过程中的错误,包括但不限于传输错误、接收错误和校验错误等。
saej1939标准介绍
saej1939标准介绍
SAE J1939标准是一种用于商用车辆和重型设备之间进行通信的控制器局域网络(CAN)协议。
这个标准由SAE国际制定,旨在提供一种统一的通信协议,以便不同制造商的电子控制单元(ECU)能够相互通信,实现数据交换和系统集成。
SAE J1939标准涵盖了许多方面,包括物理层、数据链路层、网络层和应用层。
物理层定义了电气特性和连接器规范,以确保不同设备之间的互操作性。
数据链路层负责错误检测和纠正,网络层管理数据包的路由和优先级,而应用层定义了通信的参数和消息格式。
这个标准广泛应用于卡车、拖车、农业和建筑设备等商用车辆领域,用于实现发动机控制、传感器监测、车辆诊断、车载通信和其他功能。
通过采用SAE J1939标准,不同制造商的设备可以更容易地集成到统一的车辆系统中,提高了设备的互操作性和可靠性。
总的来说,SAE J1939标准是一种重要的通信协议,它促进了商用车辆和重型设备之间的数据交换和系统集成,为整个行业带来了许多便利和效益。
J1939协议理解
J1939协议理解 今天读了 J1939协议的介绍文档,下面主要说说我的理解: 1、网络应用分为几个层 物理层 SAE J1939-11 数据链路层SAE J1939-21 网络层 SAE J1939-31 应用层 SAE J1939-71 故障诊断SAE J1939-73 网络管理层SAE J1939-81 2、下面主要说说数据链路层和应用层 数据链路层:为物理连接之间提供可靠的数据传输。
包括发送 步、顺序控制、 出错控制和流控制。
CAN 数据帧所必需的同首先要明白几个概念PGN :参数组编号 帧(Frame ):组成一个完整信息的一系列有序的数据位。
帧又被划分成几个域,每个 域包括了预定义类型的数据。
CAN 数据帧(CAN Data Frame ):组成 开始以帧结束(EOF )结尾。
标准帧(Standard Frame ):CAN2.0A 扩展帧(Extended Frame ):CAN2.0 BCAN 协议帧所必需的有序位域, 以帧起始(SOF )规范中定义的使用 11位标识符的CAN 数据帧。
规范中定义的使用 29位标志符的CAN 数据帧。
当一条报文包含参数组的数据长度包(Packet ):一个单一的 CAN 数据帧就是一个包。
小于等于8个字节时,这样的报文也称为包。
报文(Message ):指一个或多个具有相同参数组编号的(PGN )数据帧。
也就是说只要一个或多个 CAN 数据帧具有相同的 PGN 号,那他们就是属于一个报文。
):当具有相同参数组编号的所有数据需要使用多个 J1939报文。
每个CAN 数据帧拥有相同的标识符,多包报文(Mult ip acket Messages CAN 数据帧来传输时使用的一种 但在每个包中数据不同。
协议数据单元PDU 的格式it■kPDU 1PDUy■ M 嶋1 EDP0P PFDATAL L13时t 伽」PGN25仪苛歆幷PDU是J1939传输数据的格式,它基于CAN协议的扩展帧传输方式。
J1939协议
J1939协议协议名称:J1939协议一、引言J1939协议是一种用于重型商用车辆和柴油发动机之间通信的标准协议。
它定义了数据通信、电气连接和网络管理的规范,以实现不同设备之间的互操作性和数据交换。
本协议旨在提供一种统一的通信标准,以便各种设备能够有效地进行数据交换和协同工作。
二、范围本协议适用于重型商用车辆、柴油发动机及其相关设备,包括但不限于卡车、挖掘机、拖拉机、发电机组等。
它涵盖了数据通信、网络拓扑、通信速率、传输协议、数据格式和故障诊断等方面的规范。
三、术语和定义3.1 J1939:指J1939协议的简称。
3.2 数据链路层:指协议栈的一部分,负责提供可靠的数据传输和错误检测。
3.3 物理层:指协议栈的一部分,负责定义电气连接和传输介质的规范。
四、数据通信4.1 数据格式4.1.1 数据帧:J1939协议使用数据帧进行数据传输,每个数据帧包含一个标识符和一个数据字段。
4.1.2 标识符:数据帧的唯一标识,用于区分不同的数据源和数据类型。
4.1.3 数据字段:数据帧中的有效数据,用于传输实际的信息内容。
4.2 数据传输4.2.1 数据链路层:J1939协议使用数据链路层提供可靠的数据传输,包括数据帧的发送和接收、错误检测和纠正等功能。
4.2.2 物理层:J1939协议定义了多种物理层规范,包括CAN总线、RS-485等,用于实现数据的物理传输。
五、网络管理5.1 地址分配5.1.1 节点地址:J1939协议使用29位的节点地址进行设备的唯一标识,节点地址由网络管理器进行分配。
5.1.2 功能地址:J1939协议定义了一些特殊的功能地址,用于广播和特定功能的通信。
5.2 网络拓扑5.2.1 单总线拓扑:J1939协议支持单总线拓扑,即所有设备通过一个总线进行通信。
5.2.2 多总线拓扑:J1939协议还支持多总线拓扑,即多个总线之间通过网关进行通信。
六、故障诊断6.1 DTC码6.1.1 DTC码:指故障诊断码,用于标识设备故障的类型和位置。
J1939协议理解
J1939协议理解今天读了J1939协议的介绍文档,下面主要说说我的理解:1、网络应用分为几个层物理层 SAE J1939-11数据链路层 SAE J1939-21网络层 SAE J1939-31应用层 SAE J1939-71故障诊断 SAE J1939-73网络管理层 SAE J1939-812、下面主要说说数据链路层和应用层数据链路层:为物理连接之间提供可靠的数据传输。
包括发送CAN 数据帧所必需的同步、顺序控制、出错控制和流控制。
首先要明白几个概念PGN:参数组编号帧(Frame): 组成一个完整信息的一系列有序的数据位。
帧又被划分成几个域,每个域包括了预定义类型的数据。
CAN 数据帧(CAN Data Frame):组成CAN 协议帧所必需的有序位域,以帧起始(SOF)开始以帧结束(EOF)结尾。
标准帧(Standard Frame):CAN2.0A规范中定义的使用11 位标识符的CAN 数据帧。
扩展帧(Extended Frame):CAN2.0 B规范中定义的使用29 位标志符的CAN 数据帧。
包(Packet):一个单一的CAN 数据帧就是一个包。
当一条报文包含参数组的数据长度小于等于8个字节时,这样的报文也称为包。
报文(Message):指一个或多个具有相同参数组编号的(PGN)数据帧。
也就是说只要一个或多个CAN数据帧具有相同的PGN号,那他们就是属于一个报文。
多包报文(Multipacket Messages):当具有相同参数组编号的所有数据需要使用多个CAN 数据帧来传输时使用的一种J1939报文。
每个CAN 数据帧拥有相同的标识符,但在每个包中数据不同。
协议数据单元PDU的格式PDU是J1939传输数据的格式,它基于CAN协议的扩展帧传输方式。
即它的标识符是29位的。
优先级:最高0(000)设置到最低7(111 )。
所有控制报文的缺省优先级是3(011 )。
扩展数据页(EDP)和数据页(DP)的关系:什么是第0页PGN,什么是第1页PGN?作用有什么不同?还不是太清楚PDU1和PDU2时的参数组编号(PGN)数目在说说J1939的标识符合CAN协议的对应格式:J1939的29位标识符格式CAN协议扩展帧格式首先,J1939的标识符是29位的,所以它使用的是CAN协议的扩展帧格式来传输数据。
诊断协议解析-J1939
J1939诊断协议解析目录目录 (2)1 范围 (3)1.1 文档说明 (3)1.2 文档范围 (3)2 规范性引用文件 (3)3 术语和定义及缩写 (3)3.1术语定义 (3)3.2英文缩写 (6)4 协议定义 (6)4.1总体架构 (6)4.2数据链路层 (6)4.2.1消息/帧格式 (6)4.2.2 协议数据单元(PDU) (7)4.2.3消息类型 (9)4.2.4传输协议功能 (9)4.3应用层——诊断 (11)4.3.1诊断故障码定义 (11)4.3.2激活状态的诊断故障码DM1 (12)附录 (16)1 范围1.1 文档说明针对每个模块的诊断功能的开发,除了本文档以外可能还需要另一个单独针对此模块的文档——《XX模块诊断内容》,这个文档定义了DM1 服务中的故障码,以及其他需要单独说明的内容。
即:1) 一个电器模块的诊断功能开发需要的全部文档包括——本文档以及《XX模块诊断内容》1.2 文档范围2 规范性引用文件下列文件中的条款通过本协议的引用而成为本协议的条款。
凡是注日期的引用文件,其随后所有的修改单(不包括勘误的内容)或修订版均不适用于本协议,然而,鼓励根据本协议达成协议的各方研究是否可使用这些文件的最新版本。
凡是不注日期的引用文件,其最新版本适用于本协议。
SAE 1939-21:2001 商用车控制系统局域网络(CAN)通信协议第四部分数据链路层SAE 1939-73:2004 商用车控制系统局域网络(CAN)通信协议第六部分应用层-诊断3 术语和定义及缩写本协议引用SAE J1939-21及SAE J1939-73中术语及定义。
本协议涉及到的英文缩写:3.1术语定义●帧Frame组成一个完整消息的一系列数据位。
帧又被划分成几个域,每个域包括了预定义类型的数据。
●CAN 数据帧CAN Data Frame组成传输数据的CAN 协议帧所必需的有序位域,以帧起始(SOF)开始以帧结束(EOF)结尾。
浅析J1939协议附下载
浅析J1939协议附下载SAE J1939协议是基于CAN2.0B协议之上的应⽤层协议,但是SAE J1939协议并不仅仅是个应⽤层协议,她对物理层,数据链路层,⽹络层,应⽤层,故障诊断,⽹络层管理层等都做了详细的规定,只不过这其中很多规定都跟CAN2.0B⼀致。
我们这⾥只介绍J1939的应⽤层,对软件开发来说已经⾜够。
对熟悉CAN2.0B协议的⼩伙伴来说,其实只要掌握下⾯⼏个关键点,J1939就瞬间不再神秘。
J1939协议是基于CAN2.0B的应⽤层协议,所有J1939报⽂都是使⽤29位标志符。
CAN报⽂中我们有11位标志符的标准帧也有29位标志符的扩展帧,在J1939协议中,我们所有报⽂都是29位标志符, 数据域则跟CAN报⽂的数据没有区别。
CAN报⽂是基于ID的,⽽J1939协议是基于PGN的。
这⼀点⼏乎就是J1939协议的全部内容。
CAN2.0B使⽤29位的标志符来区分不同的报⽂,J1939对这29标志符进⾏了重新的分类和解释。
打个不是很恰当的⽐⽅,以前CAN2.0B协议根据⼈的体重来区分不同的⼈,只要⼀样重(ID)就认为是相同的⼈群,体重越瘦的就越是受CAN2.0B协议喜欢(优先级越⾼),现在J1939也是测量体重,只不过是把⼈的脑袋,躯⼲,双⼿,双腿分别测量,然后对这⼏个重量进⾏某种运算(⽐如脑袋重量的平⽅,躯⼲重量与双⼿重量乘积,以及双腿重量这三个数字之和), 只要运算的结果(PGN)⼀致,就认为这些⼈是⼀个⼈群。
也就是说,J1939对CAN2.0B中的29位标志进⾏了重新解释,我们使⽤下⾯这张图来说明⼀下:J1939对CAN ID进⾏了重新划分,加上最多8个字节的数据域,构成了J1939 的协议数据单元(Protocol Data Unit, PDU),其中前3位表⽰优先级位(Priority, P),之后是扩展数据页位(Extended Data Page, EDP),数据页位(Data Page,DP), PDU格式位(PDU Format, PF), PDU特定域位(PDU Specific, PS), 源地址位(Source Address,SA) 以及数据域(Data Filed)。
sae1939协议的架构
sae1939协议的架构SAE J1939协议是一种用于车辆和重型机械设备之间进行通信的协议。
它是一种基于控制器局域网络(CAN)的协议,旨在提供可靠的数据交换和通信。
SAE J1939协议的架构可以从以下几个方面来进行说明:1. 物理层,SAE J1939协议使用CAN总线作为物理层的通信介质。
CAN总线是一种串行通信协议,可以用于多个节点之间的数据传输。
2. 数据链路层,在SAE J1939协议中,数据链路层负责将数据分成较小的数据包,并添加必要的校验和和控制信息。
这些数据包被称为Protocol Data Units(PDU),并且可以通过CAN总线进行传输。
3. 网络层,SAE J1939协议的网络层定义了节点之间的通信规则和协议。
每个节点在网络中都有唯一的地址,并且可以通过广播或点对点方式进行通信。
网络层还定义了一些重要的参数,如数据传输速率、消息优先级和节点状态等。
4. 传输层,传输层负责确保数据的可靠传输。
它使用一种称为Transport Protocol(TP)的机制来处理大型数据包的分段和重组。
传输层还提供了错误检测和纠正的功能,以确保数据的完整性。
5. 应用层,SAE J1939协议的应用层定义了一套标准的数据格式和消息类型,用于不同节点之间的数据交换。
这些消息类型包括车辆状态、传感器数据、控制命令等。
应用层还定义了一些标准的参数和参数组,用于描述和识别不同的数据和功能。
总体而言,SAE J1939协议的架构是一个分层的结构,每一层都有不同的功能和责任。
它提供了一种标准化的方式,使得车辆和重型机械设备之间可以进行可靠的数据交换和通信。
这种协议的使用可以提高设备的互操作性和系统的可靠性,同时也方便了设备的维护和故障排除。
J1939协议
J1939协议一、引言J1939协议是一种用于重型商用车辆和工程机械的通信协议,旨在实现不同设备之间的数据交换和通信。
本协议的目标是提供一种标准化的通信架构,以确保各种设备的互操作性和数据一致性。
本协议详细规定了通信的物理层、数据链路层和应用层的要求和规范。
二、物理层1. 传输介质J1939协议支持多种传输介质,包括双绞线、光纤和无线电等。
传输介质的选择应根据具体应用场景和要求进行合理选择。
2. 传输速率J1939协议支持不同的传输速率,包括250kbps、500kbps和1Mbps等。
传输速率的选择应根据实际需求和设备性能进行合理配置。
3. 连接器和接口J1939协议规定了连接器和接口的类型和规范,以确保设备之间的正确连接和通信。
连接器和接口应符合相关标准,并具备良好的可靠性和稳定性。
三、数据链路层1. 帧格式J1939协议定义了数据链路层的帧格式,包括帧起始符、帧ID、数据长度、数据域和校验等。
帧格式的定义应符合J1939协议的规定,并确保数据的正确传输和解析。
2. 帧类型J1939协议定义了不同类型的帧,包括数据帧、远程帧和错误帧等。
不同类型的帧应根据具体应用场景和通信需求进行合理选择和配置。
3. 流控制J1939协议支持流控制机制,以确保数据的可靠传输。
流控制应根据具体应用场景和数据交换需求进行合理配置和管理。
四、应用层1. 数据格式J1939协议规定了应用层数据的格式和结构,包括数据标识符、数据长度和数据内容等。
数据格式的定义应符合J1939协议的规定,并确保数据的正确解析和处理。
2. 数据解析J1939协议规定了数据的解析方法和算法,以确保设备能够正确解析和处理接收到的数据。
数据解析的方法和算法应根据具体应用场景和数据格式进行合理选择和配置。
3. 数据交换J1939协议定义了数据交换的方法和规范,包括数据的发送和接收等。
数据交换的方法和规范应根据具体应用场景和通信需求进行合理配置和管理。
CAN总线J1939协议
可靠的错误处理和检错机制;
发送的信息遭到破坏后,可自动重发;
节点在错误严重的情况下具有自动退出总线的功能;
报文不包含源地址或目标地址,仅用标志符来指示功能信息、优先级信息。
CAN总线特点J1939通信协议原理
J1939是一个高速通讯网络,它支持ECUs间的实时闭路控制功能,这些ECUs在汽车上可能是物理分布的。J1939能执行所有的J1708/J1587功能,除此之外还有控制系统支持。
J1939使用CAN协议,当总线空转的时候,该协议允许任何ECU传送网络上的信息。每个信息包括一个标识符,该标识符确定信息优先权,谁先发送它,以及它包含什么数据。对于每个ECU单元,访问网络的机会是相同的,但在多个ECU同事要求传输信息时,有最高优先权的信息优先。
J1939提供了完全的网络定义,该定义使用在CAN协议中定义的29位标识符(CAN扩展帧)。CAN协议格式由28位到0位传输,而J1939协议格式的标识符由1位到32位传输,共32位。
ቤተ መጻሕፍቲ ባይዱ
CAN特性
低成本;
极高的总线利用率;
很远的数据传输距离(长达10km)
高速的数据传输速率(高达1Mbit/s)
J1939协议
J1939协议协议名称:J1939协议一、引言J1939协议是一种用于车辆网络通信的标准协议,旨在实现车辆之间的数据交换和通信。
本协议旨在规范J1939协议的标准格式和通信规则,以确保车辆系统之间的互操作性和数据交换的准确性。
二、范围本协议适用于所有实施J1939协议的车辆和设备,包括但不限于汽车、卡车、摩托车、农用车辆和工程机械等。
三、术语和定义在本协议中,以下术语和定义适用:1. J1939协议:一种用于车辆网络通信的标准协议,基于CAN总线通信。
2. CAN总线:控制器局域网络,一种广泛应用于汽车电子系统的串行通信协议。
3. 数据帧:在J1939协议中用于传输数据的基本单元,包括标识符、数据域、校验码等。
4. 源地址:发送数据帧的设备的唯一标识符。
5. 目标地址:接收数据帧的设备的唯一标识符。
6. 参数组:在J1939协议中,用于组织和传输特定类型数据的一组数据帧。
四、数据帧格式J1939协议的数据帧由以下部分组成:1. 标识符:包括源地址、目标地址、优先级和数据页等信息。
2. 数据域:包含实际传输的数据。
3. 校验码:用于验证数据的完整性。
4. 结束符:表示数据帧的结束。
五、通信规则1. 数据帧的发送和接收必须遵循以下规则:a. 发送设备必须在总线空闲时发送数据帧。
b. 接收设备必须在接收到数据帧后进行确认应答。
c. 发送设备必须在一定时间内接收到应答,否则重新发送数据帧。
2. 数据帧的优先级:a. 数据帧的优先级由标识符中的优先级字段确定,数值越小,优先级越高。
b. 高优先级的数据帧可以打断低优先级的数据帧传输。
3. 数据帧的过滤:a. 接收设备可以根据标识符中的源地址和目标地址进行数据帧的过滤。
b. 只有满足过滤条件的数据帧才会被接收设备接收和处理。
六、参数组1. 参数组是J1939协议中用于组织和传输特定类型数据的一组数据帧。
2. 参数组由一个首帧和多个数据帧组成,首帧包含参数组的标识符和数据长度等信息。
J1939协议简介
J1939协议简介缩写ACK Acknowledgment:应答BAM Broadcast Announce Message:广播通知消息CAN ontroller Area Network:控制器局域网CRC Cyclic Redundancy Check:循环冗余校验CTS Clear-To-Send:清除发送DA Destination Address:目标地址DLC Data Length Code:数据长度代码DP Data Page:数据页EOF End of Frame:框架结束或帧结束ID Identifier:标志符IDE Identifier Extension Bit:标志符扩展位LLC Logical Link Control:逻辑连接控制LSB Least Significant Byte or Least Significant Bit:最小有意义位或字节MAC Medium Access Control:媒体通道控制MF Manufacturer:制造商MSB Most Significant Byte or Most Significant Bit:最大有意义位或字节NA not Allowed:不应答NACK Negative-Acknowledgment:错误应答P Priority:优先级PDU Protocol Data Unit:协议数据单元PF PDU Format:协议数据单元格式PGN Parameter Group Number:参数组代码PS PDU Specific:协议数据单元细节GE Group Extension:组扩展DA Destination Address:目标单元地址R Reserved:保留RTR Remote Transmission Request:远程传输请求RTS Request-To-Send:发送请求SA Source Address:原地址SOF Start of Frame:帧开始SRR Substitute Remote Request:替代远程请求TP Transport Protocol:传送协议T h Hold Time:保持时间T r Response Time:响应时间un Undefined:没有定义CAN2.0B包含两种格式的说明:标准格式和扩展格式。
j1939协议
j1939协议J1939协议是一种用于车辆通信的标准协议。
它是由SAE (美国汽车工程师协会)制定的一种协议,旨在为汽车电子控制系统提供统一的通信标准,以实现不同厂商制造的车辆控制器之间的交互和协调。
J1939协议已经被广泛应用于汽车、重型车辆、农业机械、工程机械等领域。
J1939协议的设计使其适用于各种应用场合,并提供了一些基本的功能。
例如,它支持多种物理层接口,包括CAN和其他现有的数据总线;它提供了一系列标准的报文格式,允许通信的控制器进行简单的数据交换;它还提供了一些必要的通信保障和错误处理机制,以确保通信的可靠性和正确性。
在J1939协议中,每一个控制器被称作“节点”,每个节点都有唯一的标识符。
这个标识符是一个29位的数值,在J1939协议中称为“源地址”(SA)。
当一个节点需要发送数据时,它首先要选择一个接收方,然后构建一个符合J1939协议格式的报文,并将其发送出去。
接收方在接收到报文后,将会根据协议规定的方式对报文进行解析和处理。
J1939协议的报文格式分为四个部分:先导字节、ID、数据段和CRC。
其中,ID部分是最重要的部分,它可以用来描述报文的类型、发送方和接收方等信息。
数据段则包含了实际的数据,可以是控制命令、传感器数据或者是故障信息等内容。
CRC部分则用来检验报文的正确性,以保证传输的设备是正常的。
J1939协议中,每个节点都有不同的功能和角色。
例如,某些节点可能负责采集数据,将其传输到其他节点;某些节点可能负责接收控制命令,并将其转发到系统中的其他节点。
为了让这些不同的节点能够协同工作,J1939协议规定了一些标准的数据格式和交互方式。
除了基本的通信功能之外,J1939还提供了一些高级的功能,如故障诊断和管理。
在汽车电子控制系统中,各个控制器可能会出现各种故障,为了避免这些故障对整个系统造成影响,J1939协议定义了一套故障诊断和管理系统。
通过这个系统,各个控制器可以及时地发现和处理故障,保证整个系统的可靠性和安全性。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
J1939协议理解
今天读了J1939协议的介绍文档,下面主要说说我的理解:
1、网络应用分为几个层
物理层SAE J1939-11
数据链路层SAE J1939-21
网络层SAE J1939-31
应用层SAE J1939-71
故障诊断SAE J1939-73
网络管理层SAE J1939-81
2、下面主要说说数据链路层和应用层
数据链路层:为物理连接之间提供可靠的数据传输。
包括发送CAN 数据帧所必需的同步、顺序控制、
出错控制和流控制。
首先要明白几个概念
PGN:参数组编号
帧(Frame): 组成一个完整信息的一系列有序的数据位。
帧又被划分成几个域,每个域包括了预定义类型的数据。
CAN 数据帧(CAN Data Frame):组成CAN 协议帧所必需的有序位域,以帧起始(SOF)开始以帧结束(EOF)结尾。
标准帧(Standard Frame):CAN2.0A规范中定义的使用
11 位标识符的CAN 数据帧。
扩展帧(Extended Frame):CAN2.0 B规范中定义的使用29 位标志符的CAN 数据帧。
包(Packet):一个单一的CAN 数据帧就是一个包。
当一条报文包含参数组的数据长度小于等于8个字节时,这样的报文也称为包。
报文(Message):指一个或多个具有相同参数组编号的(PGN)数据帧。
也就是说只要一个或多个CAN数据帧具有相同的PGN号,那他们就是属于一个报文。
多包报文(Multipacket Messages):当具有相同参数组编号的所有数据需要使用多个CAN 数据帧来传输时使用的一种J1939报文。
每个CAN 数据帧拥有相同的标识符,但在每个包中数据不同。
协议数据单元PDU的格式
PDU是J1939传输数据的格式,它基于CAN协议的扩展帧传输方式。
即它的标识符是29位的。
优先级:最高0(000)设置到最低7(111 )。
所有控制报文的缺省优先级是3(011 )。
扩展数据页(EDP)和数据页(DP)的关系:
什么是第0页PGN,什么是第1页PGN?作用有什么不同?还不是太清楚
PDU 格式(PF)和PDU 特定域(PS)的关系
PDU 格式
(PF)
PDU
格式
PDU 特定域
(PS)
PF<240
PDU1
格式
PS是目标地址
(DA)
PF=240‾255
PDU2
格式
PS是组扩展
(GE)值
PDU1和PDU2时的参数组编号(PGN)数目
EDP DP PF PS PDU1时参数组编号0
0或者
1
0-239
目标地
址
2X240(PF的值)=480 EDP DP PF PS PDU2时参数组编号0
0或
者1
240-255
共16个数
组扩展值
0-255
(共256
个数)
2X16X256=8192在说说J1939的标识符合CAN协议的对应格式:
J1939的29位标识符格式
CAN协议扩展帧格式
首先,J1939的标识符是29位的,所以它使用的是CAN协议的扩展帧格式来传输数据。
29位的标识符在寄存器中的存放位置,正好对应CAN的
ID28-ID0的29位。
我们主要在ID18和ID17直接有两个位,SRR和IDE要求是必须写1的,它不包括在我们的J1939的标识符,还
有ID0的后一位RTR位也不包括在我们的标识符中,这一位是无效位,应该写0。
标识符对应的CAN扩展帧的位数:
优先权3位-----------------ID28 ID27 ID26
扩展数据页EP-------------ID25
数据页DP-------------------ID24
PDU格式PF------------- ID23~ID16
PDU特定域PS----------ID15~ID8
源地址SA-----------------ID7~ID0
如果ECU读回来一串数据怎么判断参数组编号PGN呢?
首先,把数据的前29个字节(标识符)提取出来。
然后进行解析,解析方式:
把ID28~ID24提取出来组成一个字节(对应优先权位、EP、DP)把ID23~ID16提取出来组成一个字节(对应PF的8位)
把ID15~ID8提取出来组成一个字节(对应PS的8位)
上述ID25~ID8就组成了数据的PGN(参数组编号)
例如:
收到的前29个字节是0x67,0x98,0x1c,0xa2
看看它们的存储方式:
BI
T7
6543210
ID R0ID
28
ID
27
ID
26
ID
25
ID
24
ID
23
ID
22
ID
21 01100111
0x
67
ID R1ID
20
ID
19
ID
18
SR
R=1
ID
E=1
ID
17
ID
16
ID
15 10011000
0x
98
ID R2ID
14
ID
13
ID
12
ID1
1
ID
10
ID
9
ID
8
ID
7
把ID28~ID24提取出来,其中标识符只包括ID25和ID24,即PGN的第一个字节是00(二进制),
把ID23~ID16提取出来,组成二进制的:11110000(PF字节的8位)
把ID15~ID8提取出来,组成00001110(对应PS的8位)把上述3个字节连接起来组成一个二进制的数:00 11110000 00001110,把它转换成16进制就是0XF00E,转换成十进制是:61454,这就是它的PGN号。
3、应用层
应用层为应用过程访问OSI 环境提供了一种方法,包括支持应用的管理功能和通用的机制。
它以PGN和SPN的方式具体规定了车辆使用的每个参数的数据长度,数据类型,分辨率和数据范围等。
应用层报文使用PGN作为一组参数的标号。
一组参数称为“参数组”(PG),PGN是其唯一的标识号。
参数组内有一个或多个具体的参数,每个具体参数都有一个唯一的标号,称为“怀疑参数编号”,即SPN。
以一个实例讲解PGN的使用
以PGN65213为例,首先是它的J1939的协议定义:
假定我们只使用了协议中的前3个参数,预计风扇转速比,风扇驱动器状态,风扇转速。
下面是这3个参数在字节中的存储方式,预计风扇转速比是一个字节的,它占用了byte1的8位,风扇驱动器状态是4个字节的,占用了byte2的后四位,风扇转速是2字节的,占用的byte3和byte4. 其他没有使用的位要写1.
他们每一个参数对应一个SPN,在SPN中都有它的斜率和分辨率的规定。
例如第一个参数Estimated Percent Fan Speed,我们看它的SPN号是975,我们再来查看SPN975的内容,发现他是一个表示百分比的数,范围是0%到100%,分辨率是0.4%,偏移量是0。
如果我们想写个50%进去,怎么把50%转换为二进制数放到字节中呢,
计算方式:50%/分辨率+偏移量=要写入的字节数,我们来计算下
50%/0.4%+0=125,这个数是十进制的,把它转换为二进制就是:0111 1101,我们把这数放到字节1中就可以了。
4、。