AUTO SARCAN诊断实现
2)软体架构
AUTOAR架构中和诊断相关的模组如图2所示。
FIM模组的作用是根据DEM(DiagnosticEventManager)报告的事件状态使能或禁止软体构件内部的功能实体。PDURouter(协议数据单元路由器)模组仅负责转发DCM(DiagnosticCommunicationManager)和CANTP(CANTransportLayer)之间的I_PDU(交互层协议数据单元),不会对数据进行任何修改。CANInterface模组、CANDriver模组和CANTransceiver模组负责L_PDU(数据链路层协议数据单元)的传输。
DEM、DCM和CANTP是AUTOSAR架构中和诊断相关的核心模组。
3)DCM
DCM模组遵循ISO14229-1、ISO15031-5、ISO15765-4和SAEJ1979标準,能直接处理0x10、0x27和0x3E服务。收到AUTOSAR支援的OBD服务或其他UDS服务时,靠叫DEM、软体构件或者其他BSW模组提供的介面进行响应。
AUTOSAR建议用叁个功能模组组成DCM,分别是DSL(DiagnosticSessionLayer)、DSD(DiagnosticServiceDispatcher)和DSP(DiagnosticServiceProcessing)。其中DSL负责处理PDURouter传来的诊断请求,管理会话层和应用层定时参数,处理会话状态的切换等。DSD负责将DSL传来的诊断请求转发给DSP,同时将DSP传来的诊断响应报文传给DSL。DSP负责分析接收到的诊断请求报文,检查其报文格式以及其请求的子功能。只有在诊断请求报文的服务标识符、子功能、报文格式等条件都满足的情况下,DSP才会处理收到的请求报文,并将处理结果整理成诊断响应报文发给PDURouter。
4)DEM
DCM模组遵循的标準与DCM相同,负责直接处理与DTC相关的服务,如UDS中的0x19服务(响应报文由DCM发送出去)。当软体构件中的MonitorFunction检测到故障或BSW模组检测到故障时,将通知DEM模组处理和储存‘诊断事件’(由EventID进行标识)。如果故障确诊,唿叫NVRAMManager(非挥发性记忆体管理器)提供的介面将其存取到非挥发性记忆体中,同时通知应用层进行故障指示。DEM的状态图如图3所示:
图3DEM状态图
5)CANTP模组
遵循ISO15765-2标準。负责诊断报文的寻址、拆包与打包,以及网路层定时参数的管理。所以,该模组向下传输的是N_PDU(网路层协议数据单元)。
第一、由于严格分层,除了CANDriver和CANTransceiver模组要依赖于硬体,AUTOSAR与诊断相关的模组几乎完全独立于硬体。按照此架构开发完成的诊断程式码能够摆脱硬体的束缚,具有最大程度的再使用性。
第二、AUTOSAR目前不支援SAEJ1939。
第叁、暂时不能直接将AUTOSAR软体架构用于Bootloder程式的开发。
综上所述,AUTOSAR标準仍旧处于发展和完善阶段,但随着目前汽车ECU软体开发矛盾的加剧,开发难度不断增大,开发週期却不断缩短,AUTOSAR将成为必然趋势。
评论