日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 汽車電子 > 汽車電子
[導讀] 引言:隨著汽車電子控制單元功能的增加及升級換代的需要,診斷功能已經(jīng)成為ECU不可或缺的重要組成部分,因此,深入研究診斷協(xié)議及其實現(xiàn)非常必要?;贙線的ISO14230和基于CAN總線的ISO15765是業(yè)內(nèi)廣泛采用的兩種診

 

引言:
隨著汽車電子控制單元功能的增加及升級換代的需要,診斷功能已經(jīng)成為ECU不可或缺的重要組成部分,因此,深入研究診斷協(xié)議及其實現(xiàn)非常必要?;?span xml:lang="EN-US">K線的ISO14230和基于CAN總線的ISO15765是業(yè)內(nèi)廣泛采用的兩種診斷標準1,K線是ISO9141定義的診斷通信總線,ISO14230ISO9141的基礎上將K線電壓擴展到24V,并擴展了診斷服務。相比較于CAN總線,K線診斷既能滿足要求,又能節(jié)約成本,在國產(chǎn)車上得到大規(guī)模應用。不同于CAN總線有專門的協(xié)議驅(qū)動器,用戶直接進行應用程序的編寫而不用管理底層的通信,K線沒有專門的協(xié)議驅(qū)動器,一般要在SCI模塊的基礎上用軟件實現(xiàn)其底層通信管理,筆者為某國產(chǎn)車設計了一款帶K線診斷功能的車身控制模塊,結(jié)合ISO14230規(guī)范,首先分析K線診斷協(xié)議驅(qū)動器的功能,然后介紹協(xié)議驅(qū)動器的關鍵設計技術,最后用CANoe進行測試。
1 協(xié)議驅(qū)動器功能
ISO14230-1定義了K線物理層協(xié)議,ISO14230-2定義了數(shù)據(jù)鏈路層協(xié)議,ISO14230-3定義了應用層協(xié)議2,其與OSI模型對應關系如表1所示。
OSI模型
K線診斷協(xié)議
應用層
ISO14230-3
表述層
N/A
會話層
N/A
傳輸層
N/A
網(wǎng)絡層
N/A
數(shù)據(jù)鏈路層
ISO14230-2
物理層
ISO14230-1
1 ISO14230OSI模型的對應關系
物理層定義了邏輯位與物理電平的對應關系,同時定義了信號位的上升時間和下降時間,數(shù)據(jù)鏈路層協(xié)議定義了K線數(shù)據(jù)格式、診斷報文格式、定時參數(shù)及通信錯誤判定及處理機制,應用層協(xié)議定義了基于請求/響應的診斷過程及各項診斷服務。做為待診斷ECU節(jié)點,K線協(xié)議驅(qū)動器實現(xiàn)的主要功能包括:
1、診斷報文的封裝和發(fā)送、接收和解析,根據(jù)報文格式填充/提取SID和數(shù)據(jù);
2、通過初始化過程建立與診斷儀之間的診斷通信;
3、保持正確的幀間定時、字節(jié)間定時,檢測診斷儀報文的定時錯誤及其它通信錯誤;
4、根據(jù)診斷儀的診斷請求和ECU當前狀態(tài)返回相應的診斷響應,管理診斷會話;
下面結(jié)合數(shù)據(jù)鏈路層的協(xié)議分析及其數(shù)據(jù)結(jié)構、驅(qū)動程序的設計介紹下K線診斷協(xié)議驅(qū)動器的原理及實現(xiàn)。
2 協(xié)議驅(qū)動器設計
K線基于異步串行通信接口,在底層傳輸上采用8N1格式的SCI串行數(shù)據(jù)鏈路格式:8個數(shù)據(jù)位+1個停止位、無奇偶校驗,由于K線在物理層上是單根線,在發(fā)送時也會觸發(fā)接收中斷,所以K線報文的發(fā)送和接收解析統(tǒng)一在SCI接收中斷處理函數(shù)中以狀態(tài)機的形式實現(xiàn)3。下面從報文收發(fā)及解析、初始化、定時管理三個方面介紹下數(shù)據(jù)鏈路層的實現(xiàn)。
2.1 報文收發(fā)及解析
K線診斷報文結(jié)構如表2所示:
報文頭
數(shù)據(jù)字段
校驗和
Fmt
Tgt
Src
Len
Sid
Data
CS
最大4個字節(jié)
最大63字節(jié)或255字節(jié)
1個字節(jié)
             
2 K線診斷報文結(jié)構
K線報文由報文頭、數(shù)據(jù)字段及校驗和組成。報文頭包含格式字節(jié)Fmt、目標地址Tgt、源地址Src和可選附加長度信息Len,Fmt指定目標地址的形式(物理地址/功能地址),當報文頭中不包含可選Len字段時指定數(shù)據(jù)字段的長度;數(shù)據(jù)字段包括服務標識符Sid和數(shù)據(jù)Data,其長度由FmtLen決定;CS為單字節(jié)校驗和。設計報文結(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ù)據(jù)是報文中的哪個組成部分,msgdatalen用于數(shù)據(jù)字段字節(jié)數(shù)的統(tǒng)計,done表示該報文是否發(fā)送或接收完成,其它成員變量與報文結(jié)構組成部分一一對應。 
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){
        k_curmsg.done=1;  
      }
    }else{
      k_curmsg.checksum=ch;
      k_curmsg.done=1;  
    }
      break;
  }   if((k_REQ==k_drvhandle.mode)&&(k_FMT!=k_curmsg.state)){
    TimerStart(k_REP_P4MS,k_TP4,0,1); 
  }  
} 
2.2 初始化
在開始診斷服務之前,診斷儀必須對ECU進行初始化,通過ECU的響應獲取ECU支持的報文頭格式和定時參數(shù),建立診斷通訊4。初始化過程如圖1所示,診斷儀發(fā)送一個25ms ’0’、25ms’1’WuP(WakeUp Pattern),然后發(fā)送STC(StartCommunication) RequestECU檢測出WuP并接收到正確的STC Request后返回STC Response,該報文的Data字段為由兩個字節(jié)構成的“關鍵字(Key Word)”,指定了ECU所支持的報文頭和定時參數(shù)信息,如Key Word指定為0x8fea即表示在報文頭中采用附加長度信息Len表示數(shù)據(jù)字段長度,同時采用默認的定時參數(shù)。
 
1 初始化過程
初始化之前K線處于空閑狀態(tài),ECU禁止SCI功能并使能SCIRXD引腳為IO模式,檢測到下降沿時通過定時器統(tǒng)計RXD引腳的IO低電平的持續(xù)時間,檢測到上升沿時開始統(tǒng)計RXD引腳的IO高電平持續(xù)時間,判斷是否為有效的WuP;也可以設置SCI的波特率為200bps,判斷是否能接收到數(shù)據(jù)0xf00xf0在總線上表現(xiàn)為5051),檢測出正確的WuP后,使能SCI功能,設置波特率為10400bps,等待診斷儀發(fā)送的STC Request,接收到請求后返回STC Response肯定響應,建立診斷通訊。
2.3 定時管理
ISO14230定義了4個定時參數(shù)管理字節(jié)間定時和報文間定時,診斷儀和ECU需要共同遵守這些定時約束以保證正常的診斷通訊,表2給出了這4個定時參數(shù)的含義及取值區(qū)間。

參數(shù)變量
描述
最小值(ms)
最大值(ms)
P1
ECU響應的字節(jié)間時間間隔
0
20
P2
診斷儀請求和ECU響應之間的時間間隔,或兩個ECU響應之間的時間間隔
25
50
P3
ECU響應和診斷儀請求之間的時間間隔
55
5000
P4
診斷儀請求的字節(jié)間時間間隔
0
20

2 定時參數(shù)
P1P4是報文內(nèi)字節(jié)間定時,P2P3為報文間定時。診斷儀在初始化完成后或接收到診斷響應后需要在P3時間內(nèi)發(fā)送診斷請求,否則ECU端退出診斷會話,斷開診斷通訊,K線協(xié)議驅(qū)動器重啟,等待診斷儀發(fā)出下一個WuPSTC RequestECU在接收到診斷請求后,需要在P2時間內(nèi)返回診斷響應, P2ECU控制,通常采用25ms的固定值,當診斷請求報文中的Fmt字段指定目標地址為“功能地址”時,P2的取值需要用一個隨機數(shù)發(fā)生器來產(chǎn)生,因為對于功能尋址的診斷儀請求來說,可能多個ECU都會返回響應,如果采用固定的P2參數(shù)的話,可能會因為多個ECU競爭總線而出現(xiàn)總線沖突問題,P2采用隨機數(shù),ECU不會在同一時間返回響應,從而避免了總線競爭問題。
3 協(xié)議驅(qū)動器測試
協(xié)議驅(qū)動器在Vector公司的CANoe軟硬件平臺上進行測試,進行基于K線的KWP2000服務測試時,將KWP2000.dllKLineCPL.dll模塊加入CANoe仿真環(huán)境,CANoe模擬診斷儀節(jié)點,并使用一個代理節(jié)點來實現(xiàn)CAN網(wǎng)絡和K線之間的報文轉(zhuǎn)發(fā),此時CANoe使用計算機的串口,并通過串口/K線轉(zhuǎn)換器與ECU相連,診斷實現(xiàn)框架如圖2所示。
 
2 K線診斷框架
CAN總線診斷不同的是,K線診斷需要診斷儀通過初始化過程和ECU建立診斷通訊,診斷通訊的建立如圖3所示。建立診斷通訊后便可以像CAN診斷一樣進行診斷服務了,這方面論文很多,在此不再贅述。
 
3 建立診斷通訊
結(jié)語
本文實現(xiàn)的K線協(xié)議驅(qū)動器模塊經(jīng)過嚴格測試, 能夠高效完成K線診斷,性能和穩(wěn)定性達到預期設計要求。驅(qū)動器獨立于處理器和操作系統(tǒng),具有良好的通用性和靈活性,可以方便得集成到應用程序中,具有很高的實用價值和借鑒意義。
本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

柏林2025年9月9日 /美通社/ -- 2025年9月5日,納斯達克上市公司優(yōu)克聯(lián)集團(NASDAQ: UCL)旗下全球互聯(lián)品牌GlocalMe,正式亮相柏林國際消費電子展(IFA 2025),重磅推出融合企...

關鍵字: LOCAL LM BSP 移動網(wǎng)絡

深圳2025年9月9日 /美通社/ -- PART 01活動背景 當技術的鋒芒刺穿行業(yè)壁壘,萬物互聯(lián)的生態(tài)正重塑產(chǎn)業(yè)疆域。2025年,物聯(lián)網(wǎng)產(chǎn)業(yè)邁入?"破界創(chuàng)造"與"共生進化"?的裂變時代——AI大模型消融感知邊界,...

關鍵字: BSP 模型 微信 AIOT

"出海無界 商機無限"助力企業(yè)構建全球競爭力 深圳2025年9月9日 /美通社/ -- 2025年8月28日, 由領先商業(yè)管理媒體世界經(jīng)理人攜手環(huán)球資源聯(lián)合主辦、深圳?前海出海e站通協(xié)辦的...

關鍵字: 解碼 供應鏈 AI BSP

柏林2025年9月9日 /美通社/ -- 柏林當?shù)貢r間9月6日,在2025德國柏林國際電子消費品展覽會(International Funkausstellung...

關鍵字: 掃地機器人 耳機 PEN BSP

武漢2025年9月9日 /美通社/ -- 7月24日,2025慧聰跨業(yè)品牌巡展——湖北?武漢站在武漢中南花園酒店隆重舉辦!本次巡展由慧聰安防網(wǎng)、慧聰物聯(lián)網(wǎng)、慧聰音響燈光網(wǎng)、慧聰LED屏網(wǎng)、慧聰教育網(wǎng)聯(lián)合主辦,吸引了安防、...

關鍵字: AI 希捷 BSP 平板

上海2025年9月9日 /美通社/ -- 9月8日,移遠通信宣布,其自研藍牙協(xié)議棧DynaBlue率先通過藍牙技術聯(lián)盟(SIG)BQB 6.1標準認證。作為移遠深耕短距離通信...

關鍵字: 藍牙協(xié)議棧 移遠通信 COM BSP

上海2025年9月9日 /美通社/ -- 為全面落實黨中央、國務院和上海市委、市政府關于加快發(fā)展人力資源服務業(yè)的決策部署,更好發(fā)揮人力資源服務業(yè)賦能百業(yè)作用,8月29日,以"AI智領 HR智鏈 靜候你來&quo...

關鍵字: 智能體 AI BSP 人工智能

北京2025年9月8日 /美通社/ -- 近日,易生支付與一汽出行達成合作,為其自主研發(fā)的"旗馭車管"車輛運營管理平臺提供全流程支付通道及技術支持。此次合作不僅提升了平臺對百余家企業(yè)客戶的運營管理效率...

關鍵字: 一汽 智能化 BSP SAAS

深圳2025年9月8日 /美通社/ -- 晶泰科技(2228.HK)今日宣布,由其助力智擎生技制藥(PharmaEngine, Inc.)發(fā)現(xiàn)的新一代PRMT5抑制劑PEP0...

關鍵字: 泰科 AI MT BSP

上海2025年9月5日 /美通社/ -- 由上海市經(jīng)濟和信息化委員會、上海市發(fā)展和改革委員會、上海市商務委員會、上海市教育委員會、上海市科學技術委員會指導,東浩蘭生(集團)有限公司主辦,東浩蘭生會展集團上海工業(yè)商務展覽有...

關鍵字: 電子 BSP 芯片 自動駕駛
關閉