新聞中心

EEPW首頁(yè) > 汽車(chē)電子 > 設(shè)計(jì)應(yīng)用 > 基于C8051F040的CAN總線智能節(jié)點(diǎn)的設(shè)計(jì)

基于C8051F040的CAN總線智能節(jié)點(diǎn)的設(shè)計(jì)

——
作者:潘佚 時(shí)間:2007-01-26 來(lái)源:《現(xiàn)代電子技術(shù)》 收藏


控制器局域網(wǎng)can(controller aera network)是德國(guó)bosch公司在80年代初為解決現(xiàn)代汽車(chē)中大量的控制與測(cè)試儀器之間的數(shù)據(jù)交換而提出的一種串行數(shù)據(jù)通信協(xié)議。他是多主總線,通信介質(zhì)可以是雙絞線,通信速率可達(dá)1m/s,最遠(yuǎn)通信距離可達(dá)10km。can具有極高的可靠性,高實(shí)時(shí)性特點(diǎn)特別適合工業(yè)過(guò)程監(jiān)控設(shè)備的互連,已被公認(rèn)是最有前途的現(xiàn)場(chǎng)總線之一。can總線的高速采集系統(tǒng)具備dcs(分布式控制系統(tǒng))的主要特征,可代替dcs。

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

cygnal公司的51系列單片機(jī)c8051f040是集成在一塊芯片上的混合信號(hào)系統(tǒng)級(jí)單片機(jī),在一個(gè)芯片內(nèi)集成了構(gòu)成一個(gè)單片機(jī)數(shù)據(jù)采集或控制的智能節(jié)點(diǎn)所需要的幾乎所有模擬和數(shù)字外設(shè)以及其他功能部件,代表了目前8位單片機(jī)控制系統(tǒng)的發(fā)展方向。芯片上有1個(gè)12位多通道adc,2個(gè)12位dac,2個(gè)電壓比較器,1個(gè)電壓基準(zhǔn),1個(gè)32kb的flash存儲(chǔ)器,與mcs-51指令集完全兼容的高速cip-51內(nèi)核,峰值速度可達(dá)25mips,并且還有硬件實(shí)現(xiàn)的uart串行接口和完全支持can2.0a和can2.0b的can控制器。本文將介紹帶有在片can的cygnal公司的混合信號(hào)片上系統(tǒng)(soc)級(jí)單片機(jī)c8051f040作為微處理器的can智能節(jié)點(diǎn)設(shè)計(jì)的硬件和軟件方案。

1 典型c8051f404的can總線網(wǎng)絡(luò)結(jié)構(gòu)

典型c8051f404的can總線網(wǎng)絡(luò)結(jié)構(gòu)如圖1所示。一個(gè)典型的can節(jié)點(diǎn)由帶有can控制器的微處理器和can收發(fā)器構(gòu)成。can收發(fā)器建立can控制器和物理總線之間的連接,控制邏輯電平信號(hào)從can控制器到達(dá)物理總線的物理層,反之也一樣。can控制器執(zhí)行can協(xié)議,用于信息緩沖和濾波。f040的can控制器支持完全的can2.0a和can2.0b。

上位機(jī)通過(guò)can適配卡與各個(gè)can節(jié)點(diǎn)通訊。在應(yīng)用中,上位機(jī)可以發(fā)送命令到節(jié)點(diǎn),收集數(shù)據(jù),修改過(guò)程參數(shù),各節(jié)點(diǎn)可以將采集到的數(shù)據(jù)送到上位機(jī)進(jìn)行復(fù)雜的數(shù)學(xué)計(jì)算或是保存打印,實(shí)現(xiàn)更加優(yōu)越的信息處理功能。

2 c8051f040的can控制器結(jié)構(gòu)

f040的所有can協(xié)議功能都由獨(dú)立的can控制器而不是由51處理器來(lái)完成。因此,can通信占用cpu帶寬很小,51處理器只需要通過(guò)特殊功能寄存器(sfr)配置can控制器,數(shù)據(jù)過(guò)濾器就可以了。

2.1 can控制器各部分功能

can core:can協(xié)議控制器和發(fā)送/接收轉(zhuǎn)換寄存器;

message ram:存儲(chǔ)message objects和標(biāo)志碼,can控制器共有32個(gè)message object可供配置來(lái)用于發(fā)送或接收數(shù)據(jù);

registers:用于控制和配置c_can模塊的所有寄存器;

message handler:控制數(shù)據(jù)在can core的接收/發(fā)送轉(zhuǎn)換寄存器和message object之間的傳輸,以及中斷的產(chǎn)生。

2.2 can寄存器分類(lèi)

can寄存器可分為以下4類(lèi):

(1)can控制器協(xié)議寄存器:用于can控制、中斷、錯(cuò)誤控制、總線狀態(tài)控制和測(cè)試模塊;

(2)信息目標(biāo)(message object)接口寄存器:配置32個(gè)信息目標(biāo)(msg obj),從目標(biāo)接收和發(fā)送數(shù)據(jù)。8051處理器通過(guò)他來(lái)讀寫(xiě)can message ram;

(3)信息處理寄存器:只讀寄存器。為51cpu提供信息目標(biāo)的狀態(tài),如信息有效標(biāo)志,發(fā)送請(qǐng)求狀態(tài),新數(shù)據(jù)標(biāo)志和中斷標(biāo)志;

(4)c8051處理器特殊功能寄存器(sfr):c8051處理器控制的5個(gè)寄存器,直接讀寫(xiě)can協(xié)議寄存器,通過(guò)can數(shù)據(jù)寄存器(can0dath和can0datl)和can地址寄存器(can0adr)間接讀寫(xiě)其他can控制器。

3 can節(jié)點(diǎn)的硬件設(shè)計(jì)

設(shè)計(jì)采用的接口芯片使用ti公司的3.3vcan收發(fā)器sn65hvd230,他與pca82c250的引腳兼容。sn65hvd230有3種工作模式:高速,傾斜和低功耗模式,由rs腳的連接方式來(lái)確定。由于f040自帶了can控制器,外圍電路極為簡(jiǎn)潔。

4 can通訊軟件設(shè)計(jì)

為避免51 cpu讀寫(xiě)message ram與can 信息收發(fā)之間產(chǎn)生沖突,cpu不直接讀寫(xiě)message object,而是通過(guò)專(zhuān)門(mén)的寄存器(ifx interface registers)來(lái)配置信息目標(biāo)。

一個(gè)完整的信息目標(biāo)的結(jié)構(gòu)如表1所示。



can通訊協(xié)議的最大特點(diǎn)之一就是廢除了傳統(tǒng)的站地址編碼,而使用信息塊標(biāo)志碼。id28-0,xtd和dir用來(lái)定義信息標(biāo)志碼,以及定義即將發(fā)送數(shù)據(jù)幀的類(lèi)型(遠(yuǎn)程幀或標(biāo)準(zhǔn)幀),并且與mask28-0,mxtd和mdir一起用來(lái)作為將要接收數(shù)據(jù)幀的過(guò)濾器。一個(gè)已接收到的信息被放在有效的(msgval=1)、具有匹配標(biāo)志碼的message object里。只有當(dāng)xtd=1時(shí),遠(yuǎn)程幀才被放入message object,xtd=0時(shí),標(biāo)準(zhǔn)幀被放入message object。當(dāng)多于一個(gè)的有效message object與收到的信息匹配,則該條信息被放入號(hào)碼最小的message object里。data0-data7是8個(gè)數(shù)據(jù)字節(jié)。can通訊初始化和法數(shù)據(jù)幀的軟件流程如圖4所示。

can通訊軟件設(shè)計(jì)主要包括3個(gè)模塊:can通訊初始化、接收數(shù)據(jù)和發(fā)送數(shù)據(jù)模塊。信息目標(biāo)的初始化程序代碼(c語(yǔ)言)如下:

當(dāng)微處理器接收數(shù)據(jù)采用中斷方式,接收message object初始化時(shí)將rxie位置1。當(dāng)程序進(jìn)入到can中斷服務(wù)子程序時(shí),先判斷can狀態(tài)寄存器的rxok位是否已置位,若已置位,則說(shuō)明can控制器已經(jīng)成功接收到一個(gè)數(shù)據(jù)幀(因?yàn)閏an通訊有多個(gè)中斷源,而中斷向量只有一個(gè)),這時(shí)再調(diào)用相應(yīng)的函數(shù),取出數(shù)據(jù)幀中有用的字節(jié)進(jìn)行處理或執(zhí)行相應(yīng)的操作。源程序代碼如下:

5 結(jié)語(yǔ)

c8051f040是完全集成的混合信號(hào)系統(tǒng)級(jí)單片機(jī),具有與8051指令集完全兼容的cip-51內(nèi)核,代表了8位單片機(jī)的發(fā)展方向。他不但集成了構(gòu)成監(jiān)控系統(tǒng)的常用外設(shè),而且還集成了高可靠性、高性能的can總線控制模塊。本文使用該芯片設(shè)計(jì)的can節(jié)點(diǎn)模塊集成度高、性能穩(wěn)定,實(shí)時(shí)性好、軟件設(shè)計(jì)簡(jiǎn)潔,在工業(yè)生產(chǎn)和儀器開(kāi)發(fā)領(lǐng)域具有廣泛的應(yīng)用前景。本文給出的硬件和軟件設(shè)計(jì)方案均已通過(guò)實(shí)際測(cè)試,并成功運(yùn)用于大洋協(xié)會(huì)“十五”攻關(guān)項(xiàng)目:小型底棲生物標(biāo)本自動(dòng)分離系統(tǒng)的通訊模式中。



關(guān)鍵詞:

評(píng)論


相關(guān)推薦

技術(shù)專(zhuān)區(qū)

關(guān)閉