0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于高速處理器和虛擬儀器技術(shù)實現(xiàn)汽車CAN節(jié)點測試儀設(shè)計

電子設(shè)計 ? 來源:郭婷 ? 作者:電子設(shè)計 ? 2019-01-02 08:28 ? 次閱讀

引 言

Controller Area Network(控制器局域網(wǎng),縮寫為CAN),是為解決汽車電子控制單元間的信息通信而由德國Bosch公司提出的一種總線標(biāo)準(zhǔn),以其卓越的性能、極高的可靠性和低廉的價格,現(xiàn)在已經(jīng)在汽車領(lǐng)域獲得廣泛應(yīng)用。

為了保證汽車CAN總線節(jié)點安全、穩(wěn)定運(yùn)轉(zhuǎn),同時為了提高大批量生產(chǎn)的效率,必須在生產(chǎn)過程中對CAN節(jié)點產(chǎn)品進(jìn)行測試,開發(fā)基于CAN總線的汽車CAN節(jié)點測試儀顯得十分重要。本文通過選擇高速處理器和采用虛擬儀器技術(shù)保證測試儀的通用性,使其只需通過軟件更新便可測試多個CAN節(jié)點。

CAN協(xié)議簡介

CAN協(xié)議建立在ISO/OSI 7層開放互連參考模型基礎(chǔ)之上,為了方便應(yīng)用,同時保證各節(jié)點間無差錯的數(shù)據(jù)傳輸,僅定義了ISO/OSI模型中最下面的兩層:數(shù)據(jù)鏈路層和物理層,應(yīng)用層協(xié)議由用戶自行定義,也可采用一些國際組織制訂的標(biāo)準(zhǔn)協(xié)議。

CAN是一個典型的以半雙工方式通信的串行總線結(jié)構(gòu)形式,一個節(jié)點發(fā)送信息,多個節(jié)點接收信息。不同于主從式總線,CAN采用一種稱作廣播式的存取工作方式,是一種對等式的總線網(wǎng)。在CAN總線的通信協(xié)議中,各節(jié)點地址沒有主/從的概念,也沒有任何與節(jié)點地址相關(guān)的信息存在。信息以報文的形式出現(xiàn),其數(shù)據(jù)結(jié)構(gòu)如圖1所示。

仲裁域用來表明消息的類型和消息的優(yōu)先級,CAN總線上的節(jié)點將根據(jù)標(biāo)識符決定是否需要讀取信息包中的數(shù)據(jù),從而避免了不必要的節(jié)點處理總線上信息的頻繁中斷,提高了數(shù)據(jù)傳輸速率,保證了數(shù)據(jù)出錯率極低。

系統(tǒng)硬件設(shè)計

測試儀的硬件設(shè)計主要包括三部分:處理器及其存儲器電路、CAN總線接口電路、RS232接口電路。

處理器采用ATMEL公司基于ARM920T內(nèi)核的AT91RM9200,該處理器運(yùn)行頻率高達(dá)180MHz,可外擴(kuò)32MB Flash和64MB RAM,使其可以滿足大多數(shù)汽車CAN節(jié)點的測試需求。片上集成了許多標(biāo)準(zhǔn)接口,如USB主/從接口、以太網(wǎng)RS-232,使其可以簡單得與PC機(jī)相連,測試數(shù)據(jù)可以實時地上傳到PC機(jī),借助PC機(jī)強(qiáng)大的處理性能和豐富的數(shù)據(jù)處理軟件,進(jìn)行在線監(jiān)測及數(shù)據(jù)處理。

AT91RM9200包括一個高速片上SRAM工作區(qū)及一個低等待時間的外部總線接口,以完成應(yīng)用所要求的片外存儲器和內(nèi)部存儲器映射外設(shè)配置的無縫連接。外擴(kuò)存儲器包括1片S29GL256N Flash和2片K4S561632A-TC/L80 SDRAM,F(xiàn)lash容量為32MB,SDRAM容量為64MB。

基于高速處理器和虛擬儀器技術(shù)實現(xiàn)汽車CAN節(jié)點測試儀設(shè)計

CAN總線接口電路包括總線控制器和物理層接口兩個部分,實現(xiàn)測試儀與被測試CAN節(jié)點的CAN總線通信,這是實現(xiàn)測試的前提。CAN總線控制器采用PHILIPS公司的SJA1000,它有著更好的性能和穩(wěn)定性,支持CAN2.0A/B協(xié)議,有兩種工作模式:Basic CAN和Peli CAN,可同時支持11位和29位標(biāo)識碼,能掛載更多CAN節(jié)點。物理層接口選用TJA1054實現(xiàn),它可以連接高達(dá)32個節(jié)點,內(nèi)建斜率控制功能及CANL和CANH總線輸出的良好匹配使電磁輻射EME很低,具有優(yōu)異的總線故障管理能力,總線故障時自動切換到單線模式,故障修復(fù)后自動復(fù)位到差分模式,同時提供對電源和地的短路保護(hù)功能,特別適合于汽車內(nèi)部的CAN通訊。

RS232接口電路即測試儀與PC的通信接口,AT91RM9200內(nèi)部帶有UART控制器,可以方便得與PC機(jī)連接,對測試信息進(jìn)行在線監(jiān)測,數(shù)據(jù)存儲。

軟件設(shè)計

軟件設(shè)計包括上位機(jī)程序和下位機(jī)程序兩個部分。上位機(jī)程序在NI公司專門針對虛擬儀器開發(fā)設(shè)計的的Labwindows/CVI平臺上開發(fā),包括USB通訊程序和測試程序兩個部分。labwindows/CVI包括對眾多總線(包括PCI、PCI Express、PXI、PCMCIA、USB、以太網(wǎng)、GPIB、串口和IEEE 1394)的支持,可以方便得開發(fā)RS232通訊程序。測試程序包括人機(jī)交互界面(即儀器面板)和測試記錄兩個部分,Labwindows/CVI提供了豐富的控件,可以迅速開發(fā)儀器面板,省去了在下位機(jī)上開發(fā)人機(jī)交互界面(主要是指LCD和按鍵),所開發(fā)的儀器面板界面。

下位機(jī)程序采用linux作為測試儀的操作系統(tǒng),采用較新的linux-2.6.13內(nèi)核,使軟件設(shè)計模塊化,便于移植。軟件主要包括通訊程序和測試程序兩大部分。通訊程序包括CAN總線通訊程序和USB通訊程序兩個部分,本文主要介紹一下CAN通訊程序。

CAN通訊程序包括SJA1000芯片的初始化、接收數(shù)據(jù)和發(fā)送數(shù)據(jù)。測試儀上電后進(jìn)行SJA1000的初始化,該操作必須正確可靠,這是接收數(shù)據(jù)和發(fā)送數(shù)據(jù)的前提。根據(jù)SJA1000的手冊,設(shè)計代碼如下:

writesja1000(MODADDR, 0x09);

//設(shè)置方式寄存器,進(jìn)入復(fù)位操作以初始化

writesja1000(CDRADDR, 0x88);

//設(shè)置時鐘分頻寄存器,選PeliCAN模式

writesja1000(AMR0ADDR, AMR0 );

//設(shè)置接收屏蔽寄存器0

writesja1000(AMR1ADDR, AMR1);

//設(shè)置接收屏蔽寄存器1

writesja1000(AMR2ADDR, AMR2);

//設(shè)置接收屏蔽寄存器2

writesja1000(AMR3ADDR, AMR3);

//設(shè)置接收屏蔽寄存器3

writesja1000(ACR0ADDR, ACR0);

//設(shè)置接收驗收代碼寄存器0

writesja1000(ACR1ADDR, ACR1);

//設(shè)置接收驗收代碼寄存器1

writesja1000(ACR2ADDR, ACR2);

//設(shè)置接收驗收代碼寄存器2

writesja1000(ACR3ADDR, ACR3);

//設(shè)置接收驗收代碼寄存器3

writesja1000(BTR0ADDR, 0x03);

//設(shè)置總線定時器0

writesja1000(BTR1ADDR, 0xFF);

//設(shè)置總線定時器1

writesja1000(OCRADDR, 0xAA);

//設(shè)置輸出寄存器

writesja1000(RBSAADDR, 0x00);

//設(shè)置接收數(shù)據(jù)緩沖區(qū)首地址

writesja1000(TXERRADDR, 0x00);

//清除發(fā)送錯誤寄存器

writesja1000(RXERRADDR, 0x00);

//清除接收錯誤寄存器

readsja1000(ECCADDR);

//清除錯誤代碼捕捉寄存器

writesja1000(IERADDR, 0xFF);

//打開中斷使能寄存器

writesja1000(MODADDR, 0x08);

//設(shè)置方式寄存器,進(jìn)入政黨操作模式以收發(fā)數(shù)據(jù)

writesja1000()和readsja1000()是封裝好的底層函數(shù),其具體實現(xiàn)如下:

static void writesja1000(unsigned char addr, unsigned char data)

{
*SJAADDR = addr;

*SJADATA = data;
}

static unsigned char readsja1000(unsigned char addr)

{
*SJAADDR = addr;

return *SJADATA;
}

其中SJADATA、SJAADDR分別是為讀/寫SJA1000的數(shù)據(jù)或地址所分配的AT91RM9200地址。

接收數(shù)據(jù)和發(fā)送數(shù)據(jù)均采用中斷來實現(xiàn),基于中斷的數(shù)據(jù)處理流程是CAN通訊程序的重點,其具體實現(xiàn)流程如圖4所示:

結(jié)束語

與傳統(tǒng)的8/16位單片機(jī)測試儀系統(tǒng)相比,本文介紹的測試儀基于32位ARM9處理器,運(yùn)行速度可高達(dá)180MHz,擴(kuò)展能力強(qiáng);采用Linux操作系統(tǒng),軟件更加模塊化,更新和移植更加方便,運(yùn)行更穩(wěn)定;采用虛擬儀器技術(shù)實現(xiàn)測試儀的操作面板,便于功能擴(kuò)展,通用性強(qiáng)。在對汽車CAN節(jié)點現(xiàn)場測試時,該測試儀運(yùn)行穩(wěn)定快速,保證了該產(chǎn)品的順利生產(chǎn)。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    19100

    瀏覽量

    228814
  • CAN
    CAN
    +關(guān)注

    關(guān)注

    57

    文章

    2694

    瀏覽量

    463149
  • 虛擬儀器
    +關(guān)注

    關(guān)注

    22

    文章

    775

    瀏覽量

    87273
收藏 人收藏

    評論

    相關(guān)推薦

    虛擬儀器課件,虛擬儀器電子教案

    應(yīng)用 虛擬儀器軟件開發(fā)平臺 虛擬儀器測試信號分析與處理技術(shù)[hide]下載地址:虛擬儀器
    發(fā)表于 06-22 12:08

    虛擬儀器能否實現(xiàn)網(wǎng)絡(luò)測試?

    虛擬儀器能否實現(xiàn)網(wǎng)絡(luò)測試?能,虛擬儀器充分利用了計算機(jī)技術(shù),也包括網(wǎng)絡(luò)技術(shù),目前的
    發(fā)表于 09-06 22:46

    虛擬儀器技術(shù)

    本文轉(zhuǎn)自湖南銀河電氣有限公司: 官網(wǎng)虛擬儀器技術(shù)一、虛擬儀器技術(shù)的定義  虛擬儀器技術(shù)就是利用高
    發(fā)表于 05-29 15:47

    基于虛擬儀器的呼吸機(jī)測試

      引 言  隨著測試技術(shù)和總線技術(shù)的發(fā)展,以虛擬儀器為標(biāo)志的自動測試系統(tǒng)開始出現(xiàn)。所謂虛擬儀器
    發(fā)表于 04-30 09:40

    虛擬儀器汽車行業(yè)檢測的應(yīng)用

    系統(tǒng)。  虛擬儀器汽車車內(nèi)測試系統(tǒng)(IVDAS)中的應(yīng)用  汽車車內(nèi)測試系統(tǒng)(IVDAS)作為最常見的汽車電子測試應(yīng)用之一,優(yōu)于傳統(tǒng)的車內(nèi)
    發(fā)表于 05-15 09:40

    怎樣采用CAN總線和虛擬儀器進(jìn)行汽車測試儀設(shè)計?

    CAN總線是什么?如何進(jìn)行汽車測試儀設(shè)計?怎樣采用CAN總線和虛擬儀器進(jìn)行汽車
    發(fā)表于 04-13 06:11

    虛擬儀器對軍用測試技術(shù)有什么影響?

    虛擬儀器發(fā)展趨勢如何?虛擬儀器對軍用測試技術(shù)有什么影響?
    發(fā)表于 05-07 07:06

    基于虛擬儀器技術(shù)構(gòu)建的汽車檢測儀該如何去設(shè)計?

    虛擬汽車檢測儀的結(jié)構(gòu)是如何構(gòu)成的?PCI2006數(shù)據(jù)采集的編程是如何去實現(xiàn)的?基于虛擬儀器技術(shù)構(gòu)建的
    發(fā)表于 06-15 06:41

    虛擬儀器測試儀器從硬件到軟件

    虛擬儀器測試儀器從硬件到軟件:從虛擬儀器的概念出發(fā), 介紹了虛擬儀器的研究現(xiàn)狀, 詳細(xì)說明了虛擬儀器的結(jié)構(gòu)系統(tǒng)、特點及其應(yīng)用前景。指出
    發(fā)表于 06-22 14:17 ?27次下載

    虛擬儀器技術(shù)研究——網(wǎng)絡(luò)頻率特性測試儀的開發(fā)

    本文詳細(xì)介紹了一種基于虛擬儀器技術(shù)的網(wǎng)絡(luò)頻率特性測試儀的原理、組成及其功能,包括基于直接數(shù)字頻率合成技術(shù)(DDS) 和鎖相環(huán)技術(shù)的掃頻信號源
    發(fā)表于 08-15 08:20 ?18次下載

    多路并行動態(tài)測試虛擬儀器的設(shè)計

    動態(tài)測試儀器是大型復(fù)雜結(jié)構(gòu)動態(tài)性能測試的必需儀器,它的功能較多,實現(xiàn)難度較大。本文重點論述應(yīng)用虛擬儀器
    發(fā)表于 12-26 11:37 ?12次下載

    虛擬儀器技術(shù)的RLC測試儀

    虛擬儀器技術(shù)的RLC測試儀 針對傳統(tǒng)RLC測試儀體積大、成本高等問題,運(yùn)用虛擬儀器技術(shù),根據(jù)伏
    發(fā)表于 03-30 15:55 ?40次下載

    虛擬儀器技術(shù)汽車CAN節(jié)點測試儀設(shè)計

          Controller Area Network(控制局域網(wǎng),縮寫為CAN),是為解決汽車電子控制單元間的信息通信而由德國Bosch公司提出的一種總線標(biāo)準(zhǔn),以其卓越的
    發(fā)表于 11-26 11:43 ?522次閱讀
    <b class='flag-5'>虛擬儀器</b><b class='flag-5'>技術(shù)</b>的<b class='flag-5'>汽車</b><b class='flag-5'>CAN</b><b class='flag-5'>節(jié)點</b><b class='flag-5'>測試儀</b>設(shè)計

    虛擬儀器簡介

    虛擬儀器簡介      虛擬儀器(Virtual Instruments簡稱VI)技術(shù)發(fā)展非常迅速,所有測量測試儀器的主要功能可由①數(shù)據(jù)采集②數(shù)據(jù)
    發(fā)表于 12-03 22:34 ?1289次閱讀

    基于虛擬儀器技術(shù)高速多通道信號采集系統(tǒng)設(shè)計

    虛擬儀器技術(shù)以其開發(fā)高效、投入成本低等優(yōu)點,在動態(tài)測試及控制領(lǐng)域應(yīng)用越來越廣泛。文中基于虛擬儀器技術(shù)設(shè)計的的
    發(fā)表于 07-16 16:12 ?39次下載