新聞中心

EEPW首頁 > 汽車電子 > 設計應用 > 淺談K線診斷協(xié)議驅動器的設計

淺談K線診斷協(xié)議驅動器的設計

作者: 時間:2012-10-08 來源:網絡 收藏

引言:

本文引用地址:http://m.butianyuan.cn/article/196353.htm

隨著汽車電子控制單元功能的增加及升級換代的需要,診斷功能已經成為ECU不可或缺的重要組成部分,因此,深入研究診斷及其實現(xiàn)非常必要。基于K線的ISO14230和基于CAN總線的ISO15765是業(yè)內廣泛采用的兩種診斷標準【1】,K線是ISO9141定義的診斷通信總線,ISO14230在ISO9141的基礎上將K線電壓擴展到24V,并擴展了診斷服務。

相比較于CAN總線,K線診斷既能滿足要求,又能節(jié)約成本,在國產車上得到大規(guī)模應用。不同于CAN總線有專門的,用戶直接進行應用程序的編寫而不用管理底層的通信,K線沒有專門的,一般要在SCI模塊的基礎上用軟件實現(xiàn)其底層通信管理,筆者為某國產車設計了一款帶K線診斷功能的車身控制模塊,結合ISO14230規(guī)范,首先分析K線診斷協(xié)議的功能,然后介紹協(xié)議驅動器的關鍵設計技術,最后用CANoe進行測試。

1 協(xié)議驅動器功能

ISO14230-1定義了K線物理層協(xié)議,ISO14230-2定義了數(shù)據鏈路層協(xié)議,ISO14230-3定義了應用層協(xié)議【2】,其與OSI模型對應關系如表1所示。

 ISO14230與OSI模型的對應關系

表1 ISO14230與OSI模型的對應關系

物理層定義了邏輯位與物理電平的對應關系,同時定義了信號位的上升時間和下降時間,數(shù)據鏈路層協(xié)議定義了K線數(shù)據格式、診斷報文格式、定時參數(shù)及通信錯誤判定及處理機制,應用層協(xié)議定義了基于請求/響應的診斷過程及各項診斷服務。做為待診斷ECU節(jié)點,K線協(xié)議驅動器實現(xiàn)的主要功能包括:

1、診斷報文的封裝和發(fā)送、接收和解析,根據報文格式填充/提取SID和數(shù)據;

2、通過初始化過程建立與診斷儀之間的診斷通信;

3、根據診斷儀的診斷請求和ECU當前狀態(tài)返回相應的診斷響應,管理診斷會話;

4、保持正確的幀間定時、字節(jié)間定時,檢測診斷儀報文的定時錯誤及其它通信錯誤;

下面結合數(shù)據鏈路層的協(xié)議分析及其數(shù)據結構、驅動程序的設計介紹下K線診斷協(xié)議驅動器的原理及實現(xiàn)。

2 協(xié)議驅動器設計

K線基于異步串行通信接口,在底層傳輸上采用8N1格式的SCI串行數(shù)據鏈路格式:8個數(shù)據位+1個停止位、無奇偶校驗,由于K線在物理層上是單根線,在發(fā)送時也會觸發(fā)接收中斷,所以K線報文的發(fā)送和接收解析統(tǒng)一在SCI接收中斷處理函數(shù)中以狀態(tài)機的形式實現(xiàn)【3】。下面從報文收發(fā)及解析、初始化、定時管理三個方面介紹下數(shù)據鏈路層的實現(xiàn)。

2.1 報文收發(fā)及解析

K線診斷報文結構

表2 K線診斷報文結構

K線報文由報文頭、數(shù)據字段及校驗和組成。報文頭包含格式字節(jié)Fmt、目標地址Tgt、源地址Src和可選附加長度信息Len,F(xiàn)mt指定目標地址的形式(物理地址/功能地址),當報文頭中不包含可選Len字段時指定數(shù)據字段的長度;數(shù)據字段包括服務標識符Sid和數(shù)據Data,其長度由Fmt和Len決定;CS為單字節(jié)校驗和。設計報文結構體如下:

typedef struct

{

k_state state;

uchar fmt;

uchar tgt_addr;

uchar src_addr;

uchar datalen;

uchar sid;

uchar *data;

uchar checksum;

uchar msgdatalen;

uchar done;

}k_msg;

typedef enum{

k_FMT=0,

k_TGTADDR,

k_SRCADDR,

k_DATALEN,

k_SID,

k_DATA,

k_CS

}k_state;

成員變量state表示當前K線通信數(shù)據是報文中的哪個組成部分,msgdatalen用于數(shù)據字段字節(jié)數(shù)的統(tǒng)計,done表示該報文是否發(fā)送或接收完成,其它成員變量與報文結構組成部分一一對應。

void k_ifc_rx(void)

{

k_u8 ch,SciSr1;

SciSr1=Kline_periph[SCISR1];

ch=Kline_periph[SCIDRL];

TimerStop(k_TP4);

switch(k_curmsg.state){

case k_FMT:

if(k_REP==k_drvhandle.mode){

if(ch==k_curmsg.fmt){

k_curmsg.state=k_TGTADDR;

k_SendChar(k_curmsg.tgt_addr);

}

}else{

k_curmsg.state=k_TGTADDR;

k_curmsg.fmt=ch;

}

break;

case k_TGTADDR:

...

break;

case k_SRCADDR:

...

break;

case k_DATALEN:

if(k_REP==k_drvhandle.mode){

if(ch==k_curmsg.datalen){

k_curmsg.msgdatalen=0;

k_curmsg.state=k_SID;

k_SendChar(k_curmsg.sid);

}

}else{

k_curmsg.msgdatalen=0;

k_curmsg.datalen=ch;

free(k_curmsg.data);

k_curmsg.data=malloc(k_curmsg.datalen);

k_curmsg.state=k_SID;

}

break;

case k_SID:

if(k_REP==k_drvhandle.mode){

if(ch==k_curmsg.sid){

k_curmsg.msgdatalen++;

if(k_curmsg.msgdatalen==k_curmsg.datalen){

k_curmsg.state=k_CS;

k_SendChar(k_curmsg.checksu);

}else{

k_curmsg.state=k_DATA;

k_SendChar(k_curmsg.data[0]);

}

}

}else{

k_curmsg.sid=ch;

k_curmsg.msgdatalen++;

if(k_curmsg.datalen==k_curmsg.msgdatalen){

k_curmsg.state=k_CS;

}else{

k_curmsg.state=k_DATA;

}

}

break;

case k_DATA:

...

break;

case k_CS:

k_curmsg.state=k_FMT;

if(k_REP==k_drvhandle.mode){

if(ch==k_curmsg.checksum){


上一頁 1 2 下一頁

關鍵詞: 協(xié)議 驅動器

評論


相關推薦

技術專區(qū)

關閉