版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
精品文檔-下載后可編輯基于CAN總線與以太網(wǎng)的嵌入式網(wǎng)關(guān)設(shè)計-技術(shù)方案本文為一種工業(yè)現(xiàn)場總線與以太網(wǎng)互聯(lián)方法,介紹以太網(wǎng)與CAN現(xiàn)場總線之間協(xié)議轉(zhuǎn)換網(wǎng)關(guān)的設(shè)計與實現(xiàn),采用AT89C55作為主處理器,通過兩個接口芯片實現(xiàn)CAN總線與以太網(wǎng)的互連,分別給出其硬件結(jié)構(gòu)和軟件設(shè)計思想。為企業(yè)信息網(wǎng)絡(luò)與控制網(wǎng)絡(luò)集成提供一種可行的方法。
1硬件結(jié)構(gòu)
目前,對于CAN和以太網(wǎng)相連的嵌入式網(wǎng)關(guān)設(shè)計主要有兩種方法:一種是低檔MCU加接口芯片的設(shè)計方法,另一種是MCU加EOS(實時多任務(wù)操作系統(tǒng))再加接口芯片的設(shè)計方法。因CAN只采用了ISO/OSI參考模型的一、二層,協(xié)議相對簡單,比較適合用于低成本、速率要求不高的離散控制系統(tǒng)。從合理的成本和有效利用處理能力這兩方面考慮,該設(shè)計采用低檔MCU加接口芯片的方法,其硬件框圖見圖1。
圖1硬件原理圖
1.1主控芯片及以太網(wǎng)接口模塊
根據(jù)要求,該系統(tǒng)選擇了性能價格比較高的Atmel公司生產(chǎn)的AT89C55單片機。它是面向測控對象和嵌入式應(yīng)用的,所以它的體系結(jié)構(gòu)以及CPU、指令系統(tǒng)、外圍單元電路都是按照這種要求專門設(shè)計的。它內(nèi)部帶高達(dá)20KB的FLASH程序存儲器,AT89C55完全兼容8051指令集,片上FLASH方便了使用者進(jìn)行在線編程,工作速率可達(dá)33MHz,256B的內(nèi)部RAM,32個可編程的I/O口,3個16位的定時/計數(shù)器,8個中斷源,支持低功耗的空閑工作模式。以太網(wǎng)接口選用的是RTL8019AS芯片,它是由Realtek公司生產(chǎn)的一種高度集成的以太網(wǎng)控制器,能實現(xiàn)以太網(wǎng)媒介訪問層(MAC)和物理層(PHY)的全部功能。RTL8019AS內(nèi)部有兩個RAM區(qū)域:一是16KB,地址為0x4000~0x7fff,要接收和發(fā)送數(shù)據(jù)包必須通過DMA讀寫RTL8019AS內(nèi)部的16KB的RAM,它實際上是雙端口RAM,即有兩條總線與其連接,一條總線用于RTL8019AS讀/寫或?qū)?讀該RAM,即本地DMA;另一條總線用于單片機讀或?qū)懺揜AM,即遠(yuǎn)程DMA;二是32個字節(jié),地址為0x0000~0x001F,用于存儲以太網(wǎng)物理地址。主控芯片和以太網(wǎng)接口芯片的硬件接口原理圖見圖2。值得注意的是由于以太網(wǎng)的包可以超過1500個字節(jié),AT89C55的片內(nèi)RAM只有256個字節(jié),因此無法存儲這么大的包,所以這里擴展了一個32KB的外部RAM,這樣同時也能提高單片機的數(shù)據(jù)傳輸速度。
圖2以太網(wǎng)接口電路原理圖
1.2CAN接口模塊
組成CAN系統(tǒng)的主要器件是CAN控制器和收發(fā)器。該設(shè)計中,CAN接口模塊選用SJA1000芯片和PCA82C250芯片。SJA1000是一個獨立的CAN控制器,它是Philips公司另一個CAN控制器PCA82C200的替代產(chǎn)品,且增加了一種新的工作模式(PeliCAN),這種模式支持CAN2.0B協(xié)議。SJA1000主要完成CAN的通信協(xié)議,實現(xiàn)報文的裝配和拆分、接收信息的過濾和校驗等。
PCA82C250是CAN控制器與物理總線之間的接口,主要用于增強系統(tǒng)的驅(qū)動能力。采用收發(fā)器的系統(tǒng)中,節(jié)點數(shù)至少可以達(dá)到110個,同時還具有降低射頻干擾(RFI)和很強的抗電磁干擾(EMI)能力。在處理這部分電路時,有幾個地方要特別注意:
(1)晶振電路的問題。89C55和SJA1000都應(yīng)該有各自獨立的晶振電路,不能夠用SJA1000的時鐘輸出信號CLKOUT來驅(qū)動單片機。
(2)復(fù)位引腳的問題。雖然SJA1000的復(fù)位是低電平,但不能通過一個非門直接連接單片機的復(fù)位引腳。一般對解決復(fù)位引腳問題有兩種方式:種是使用單片機的I/O引腳控制SJA的復(fù)位引腳,其好處是單片機可以完全控制SJA的復(fù)位過程;第二種是采用適當(dāng)?shù)膹?fù)位芯片,為了降低成本,該設(shè)計采取的是種方法。
(3)RX1引腳的電位必須維持在約0.5VCC上,否則將不能形成CAN協(xié)議所要求的邏輯電平。
(4)一定要注意電纜的終端阻抗匹配,它直接影響CAN總線是否能正常工作和網(wǎng)絡(luò)性能。CAN接口模塊的硬件電路圖見圖3,在PCA82C250的RS腳上接有一個斜率電阻R,可根據(jù)總線通信速度適當(dāng)調(diào)整電阻的大小。
圖3CAN接口模塊的硬件電路圖
2通信模塊軟件設(shè)計
2.1SJA1000驅(qū)動程序的實現(xiàn)
SJA1000驅(qū)動程序是由SJA的初始化函數(shù)、發(fā)送函數(shù)、接收函數(shù)組成的,圖4所示為其流程圖。
圖4SJA1000驅(qū)動程序流程
(1)SJA1000的初始化。SJA1000在系統(tǒng)上電、硬件復(fù)位或主控制器發(fā)出復(fù)位命令后需要進(jìn)行初始化,以設(shè)定它的工作模式、通信速率、輸出控制方式和標(biāo)識符屏蔽格式等重要參數(shù)。CAN控制器SJA1000的初始化只能在復(fù)位模式下才能完成。程序的流程圖如圖4所示。
首先程序檢測CAN接口是否正常工作,即向SJA1000的測試寄存器寫入并讀出,校驗其結(jié)果是否一致,如果結(jié)果一致則進(jìn)入復(fù)位模式進(jìn)行初始化設(shè)置。在初始化的過程中,如果對某個寄存器的設(shè)置超過規(guī)定的時間還未完成,則認(rèn)為初始化失敗,初始化程序自動發(fā)送錯誤信號。
(2)數(shù)據(jù)的發(fā)送與接收。SJA1000芯片有一個報文發(fā)送緩沖區(qū)和兩個報文接收緩沖區(qū),用于CAN報文傳送。數(shù)據(jù)從CAN控制器SJA1000發(fā)送到CAN總線首先是由CAN控制器自動完成的,發(fā)送數(shù)據(jù)程序把數(shù)據(jù)存儲區(qū)中待發(fā)送的數(shù)據(jù)取出,組成信息幀,并將主機的ID地址填人幀頭;然后將信息幀發(fā)送到CAN控制器的發(fā)送緩沖區(qū);啟動發(fā)送命令即可。信息從CAN總線到CAN接收緩沖區(qū)也是由CAN控制器自動完成的。接收程序只需從接收緩沖區(qū)讀取要接收的信息,并將其存儲在數(shù)據(jù)存儲區(qū)即可。
2.2RTL8019AS驅(qū)動程序的實現(xiàn)
RTL8019AS的驅(qū)動程序和SJA的驅(qū)動程序一樣,有3種功能:芯片初始化、收包、發(fā)包。
(1)RTL8019AS的初始化。RTL8019AS的初始化過程比較復(fù)雜,但十分重要,它決定了通信過程中的一些重要參數(shù)。如設(shè)置相關(guān)工作模式的寄存器,分配和初始化接收及發(fā)送緩沖區(qū),初始化網(wǎng)卡接收地址等,其流程圖見圖5所示。
圖5RTL8019AS的初始化流程圖
(2)數(shù)據(jù)的發(fā)送與接收。因為在RTL8019AS的初始化程序中已經(jīng)完成了以太網(wǎng)的物理地址設(shè)置,并指定了發(fā)送緩沖區(qū)起始頁面地址寄存器TPSR.此外,RTL8019AS的CRC校驗自動生成器也被使能,所以RTL8019AS的數(shù)據(jù)包發(fā)送程序相對要簡單。在數(shù)據(jù)包的發(fā)送過程中,AT89C55只要通過遠(yuǎn)程DMA將待發(fā)送的數(shù)據(jù)包寫至RTL8019AS片內(nèi)SRAM的發(fā)送緩沖區(qū),并啟動發(fā)送過程即可。
在接收數(shù)據(jù)包時,有查詢和中斷兩種方式,鑒于AT89C55的處理能力有限,在該設(shè)計中采用查詢方式,根據(jù)判斷CURB==BNRY+1,可以判斷是否收到新的數(shù)據(jù)包,如果有則通過DMA讀操作從網(wǎng)卡芯片RAM讀出數(shù)據(jù)。
2.3網(wǎng)關(guān)協(xié)議轉(zhuǎn)換流程
嵌入式網(wǎng)絡(luò)接口實現(xiàn)兩種網(wǎng)絡(luò)的互連。當(dāng)以太網(wǎng)應(yīng)用層有數(shù)據(jù)要發(fā)送到CAN節(jié)點時,首先將數(shù)據(jù)發(fā)送到網(wǎng)關(guān),由以太網(wǎng)控制器協(xié)議轉(zhuǎn)換模塊解析完整的CAN協(xié)議數(shù)據(jù)包,通過CAN控制器發(fā)送到CAN總線。反之,當(dāng)CAN設(shè)備有數(shù)據(jù)要發(fā)送到用戶層時,首先將數(shù)據(jù)發(fā)送到透明網(wǎng)關(guān),由CAN控制器協(xié)議模塊將完整的CAN協(xié)議數(shù)據(jù)包存放在緩沖區(qū),再通知主控芯片,由它調(diào)用以太網(wǎng)控制協(xié)議轉(zhuǎn)換模塊,將完整的
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年三季度報天津地區(qū)A股負(fù)債合計排名前十大上市公司
- 2025版城市基礎(chǔ)設(shè)施建設(shè)委托合同范例大全3篇
- 2025年樹林資源綜合利用與循環(huán)經(jīng)濟(jì)承包合同范本3篇
- 2025年食堂食品安全風(fēng)險評估承包合同3篇
- 2025年山東貨運從業(yè)資格證500道題目及答案
- 2025版停薪留職合同模板:民營企業(yè)員工休整計劃書3篇
- 二零二五年度城市綠化工程項目采購安裝合同3篇
- 二零二五年度地質(zhì)勘探臨時駕駛員用工合同4篇
- 2025年度物流園區(qū)個人運輸承包服務(wù)協(xié)議2篇
- 2025年度模板木方項目合作協(xié)議范本大全3篇
- 土地買賣合同參考模板
- 2025高考數(shù)學(xué)二輪復(fù)習(xí)-專題一-微專題10-同構(gòu)函數(shù)問題-專項訓(xùn)練【含答案】
- 新能源行業(yè)市場分析報告
- 2025年天津市政建設(shè)集團(tuán)招聘筆試參考題庫含答案解析
- 自愿斷絕父子關(guān)系協(xié)議書電子版
- 你劃我猜游戲【共159張課件】
- 專升本英語閱讀理解50篇
- 中餐烹飪技法大全
- 新型電力系統(tǒng)研究
- 滋補類用藥的培訓(xùn)
- 北師大版高三數(shù)學(xué)選修4-6初等數(shù)論初步全冊課件【完整版】
評論
0/150
提交評論