CAN總線(xiàn)分布式系統(tǒng)適配卡和控制單元設(shè)計(jì)
出處:RANQIGUO 發(fā)布于:2007-09-20 14:27:26

2 CAN適配卡的設(shè)計(jì)

CAN適配卡的硬件組成框圖如圖2所示,由ISA接口、雙口RAM、CPU、CAN通信控制器SJA1000、CAN總線(xiàn)接口82C250等組成。由于帶有片上CAN控制器的單片機(jī)都含較多的I/O線(xiàn)、定時(shí)/計(jì)數(shù)器、A/D等功能,往往較復(fù)雜,因此微處理器使用價(jià)廉的AT89C51單片機(jī)。為了進(jìn)一步提高抗干擾措施,在2個(gè)CAN器件之間使用了由高速隔離器件6N137構(gòu)成的隔離電路。光耦兩側(cè)應(yīng)采用DC-DC隔離電源。硬件電路中使用82C250的目的是為了增大通信距離。要實(shí)現(xiàn)PC機(jī)和CAN控制器之間的數(shù)據(jù)傳送,必須在PC機(jī)和適配卡上的MPU之間建立起雙向的數(shù)據(jù)交換通道。通過(guò)ISA總線(xiàn)實(shí)現(xiàn)單片機(jī)系統(tǒng)與主機(jī)之間的數(shù)據(jù)交換有多種實(shí)現(xiàn)方法。本適配卡采用集成雙口RAM實(shí)現(xiàn)數(shù)據(jù)交換。由于CAN信號(hào)傳輸采用短幀結(jié)構(gòu)(8字節(jié)數(shù)據(jù)),雙口RAM的容量要求并不大,本卡選用2K×8位的帶中斷請(qǐng)求信號(hào)INT和忙信號(hào)BUSY的IDT7132。具體的連接電路如圖3、圖4所示。上位PC機(jī)對(duì)雙口RAM的尋址方式采用I/O尋址方式,使用的控制線(xiàn)為IOW和IOR。為避免產(chǎn)生讀寫(xiě)錯(cuò)誤,使用雙口RAM的關(guān)鍵是處理好爭(zhēng)用現(xiàn)象。IDT7132提供了中斷判優(yōu)和硬件判優(yōu)兩種方式。當(dāng)兩端口爭(zhēng)用同一地址單元時(shí),由片內(nèi)硬件電路,根據(jù)兩邊的地址、片選、讀寫(xiě)信號(hào)到達(dá)先后順序,裁決哪個(gè)端口有使用權(quán)。如左端口優(yōu)先使用,則自動(dòng)將右端口的BUSYR信號(hào)拉為低電平,通知右側(cè)暫停讀寫(xiě)操作。在本適配卡中,由于8031沒(méi)有READY信號(hào),可以將此信號(hào)接至8031的P1.0上。當(dāng)8031發(fā)出讀寫(xiě)IDT7132命令時(shí),根據(jù)P1.0口的值就可判斷對(duì)IDT7132讀寫(xiě)是否存在沖突。當(dāng)P1.0的值為0時(shí),存在沖突,必須重發(fā)讀寫(xiě)IDT7132的命令。由于ISA總線(xiàn)既沒(méi)有READY信號(hào),也沒(méi)有通用的I/O引腳,因此將BUSYL信號(hào)通過(guò)三態(tài)門(mén)接至ISA數(shù)據(jù)線(xiàn)的位D0。用ISA總線(xiàn)的一個(gè)空閑I/O端口打開(kāi)三態(tài)門(mén),通過(guò)D0讀取BUSYL的狀態(tài)。

SJA1000為CAN總線(xiàn)微控制器,是PHILIPS公司的PCA82C200的替代產(chǎn)品,可完成CAN總線(xiàn)的物理層和數(shù)據(jù)鏈路層的所有功能。SJA1000內(nèi)部RAM由寄存器組和報(bào)文緩沖區(qū)組成。發(fā)送緩沖區(qū)和接收緩沖區(qū)共用同一段CAN地址16H~18H,共3個(gè)單元,能存儲(chǔ)一條將在CAN總線(xiàn)上發(fā)送或接收的完整的報(bào)文。具有64字節(jié)擴(kuò)展接收緩沖器RXFIFO,其CAN地址為32H~95H(地址為96H~109H的區(qū)域是存放發(fā)送信息的備份),有了64字節(jié)的REFIFO,CPU可以在處理一個(gè)報(bào)文的同時(shí)繼續(xù)接收其他到來(lái)的報(bào)文;具有接收濾波器,它把報(bào)文頭中的標(biāo)識(shí)符(ID)和驗(yàn)收碼寄存器中的內(nèi)容進(jìn)行比較,以判斷該報(bào)文是否被接收。如果被接收,報(bào)文存入RXFIFO。CAN信息幀格式及單濾波方式的驗(yàn)收濾波器流程圖如圖5所示。

格式信息內(nèi)容如下:
| FF | RTR | X | X | DLC.3 | DLC.2 | DLC.1 | DLC.0 |

2.2 軟件設(shè)計(jì)
是由單片機(jī)將接收的數(shù)據(jù)寫(xiě)入雙口RAM后再寫(xiě)雙口RAM片內(nèi)地址為7FEH單元觸發(fā)的。二適配卡上單片機(jī)端的程序設(shè)計(jì),采用匯編發(fā)的。二是適配卡上單片機(jī)端的程序設(shè)計(jì),采用匯編語(yǔ)言編寫(xiě),分為主程序、INT0和INT1中斷服務(wù)程序。主程序主要完成對(duì)SJA1000的初始化。SJA1000的初始化是通過(guò)在復(fù)位期間對(duì)模式寄存器MOD(CAN地址為0,濾波和復(fù)位等方式選擇)、時(shí)鐘分配寄存器CDR(CAN地址為31H,選擇PeliCAN模式及時(shí)鐘輸出頻率)、濾波碼寄存器ACR0~ACR3(復(fù)位模式CAN地址為16H~18H,初始化時(shí)寫(xiě)入ID標(biāo)識(shí)符)、驗(yàn)收屏蔽寄存器AMR0~AMR3(復(fù)位模式CAN地址為20H~23H,初始化時(shí)設(shè)置是否屏蔽ACR相應(yīng)位)、總線(xiàn)定時(shí)寄存器BTR0(CAN地址為06H,設(shè)置波特率和同步跳轉(zhuǎn)寬度)和BTR1(CAN地址為07H,定義每個(gè)位周期長(zhǎng)度、采樣位置和每個(gè)采樣點(diǎn)的采樣數(shù)目)、輸出控制寄存器OCR(CAN地址為08H,選擇正常輸出控制模式)等寫(xiě)入控制字來(lái)確定其工作方式的。INT1中斷請(qǐng)求是由PC機(jī)將數(shù)據(jù)寫(xiě)入雙口RAM后再寫(xiě)雙口RAM片內(nèi)地址為7FFH單元觸發(fā)的。在INT12中斷服務(wù)程序中,首先讀取雙口RAM中的數(shù)據(jù),然后再將數(shù)據(jù)轉(zhuǎn)發(fā)給CAN控制器SJA1000,具體參見(jiàn)流程圖6。INT0中斷請(qǐng)求是由SJA1000發(fā)送或接收完1幀信息或接收數(shù)據(jù)超載或產(chǎn)生錯(cuò)誤中斷后產(chǎn)生的。INT0中斷服務(wù)程序流程如圖7所示。
控制單元的控制軟件采用匯編語(yǔ)言編程,主要包括初始化、數(shù)據(jù)采集、數(shù)據(jù)通信、I/O接口控制等功能。初始化包括對(duì)8255和SJA1000的初始化,使8255的PA、PB口作為輸入口,PC口各位通過(guò)置復(fù)位控制字可以單獨(dú)置位或復(fù)位,從而開(kāi)啟或停止一個(gè)繼電器的動(dòng)作。數(shù)據(jù)采集采用查詢(xún)方式工作,每一路模擬量連續(xù)采集3次,中值濾波后作為該傳感器的數(shù)據(jù)存入相應(yīng)的內(nèi)部RAM中,全部數(shù)據(jù)采集完后再檢測(cè)開(kāi)關(guān)狀態(tài)并存入相應(yīng)RAM中。隨后開(kāi)CPU中斷,進(jìn)入數(shù)據(jù)循環(huán)采集狀態(tài),等待CAN通信中斷的產(chǎn)生。本系統(tǒng)采用中斷方式實(shí)現(xiàn)AT89C52與SJA1000之間的通信。

需要說(shuō)明的是,CAN2.0A或CAN 2.0B協(xié)議只是一個(gè)低層的規(guī)范,用戶(hù)還需要定制簡(jiǎn)單的應(yīng)用層協(xié)議。應(yīng)用層協(xié)議的任務(wù)一方面是將要發(fā)送的數(shù)據(jù)分類(lèi)、拆卸、合并,確定發(fā)送對(duì)象,再根據(jù)CAN的數(shù)據(jù)鏈路層協(xié)議規(guī)范填寫(xiě)CAN的各個(gè)信息幀;另一方面是根據(jù)應(yīng)用層協(xié)議解釋接收數(shù)據(jù)的具體含義,并進(jìn)行相應(yīng)的處理。
版權(quán)與免責(zé)聲明
凡本網(wǎng)注明“出處:維庫(kù)電子市場(chǎng)網(wǎng)”的所有作品,版權(quán)均屬于維庫(kù)電子市場(chǎng)網(wǎng),轉(zhuǎn)載請(qǐng)必須注明維庫(kù)電子市場(chǎng)網(wǎng),http://www.hbjingang.com,違反者本網(wǎng)將追究相關(guān)法律責(zé)任。
本網(wǎng)轉(zhuǎn)載并注明自其它出處的作品,目的在于傳遞更多信息,并不代表本網(wǎng)贊同其觀點(diǎn)或證實(shí)其內(nèi)容的真實(shí)性,不承擔(dān)此類(lèi)作品侵權(quán)行為的直接責(zé)任及連帶責(zé)任。其他媒體、網(wǎng)站或個(gè)人從本網(wǎng)轉(zhuǎn)載時(shí),必須保留本網(wǎng)注明的作品出處,并自負(fù)版權(quán)等法律責(zé)任。
如涉及作品內(nèi)容、版權(quán)等問(wèn)題,請(qǐng)?jiān)谧髌钒l(fā)表之日起一周內(nèi)與本網(wǎng)聯(lián)系,否則視為放棄相關(guān)權(quán)利。
- ARM技術(shù)架構(gòu)與應(yīng)用開(kāi)發(fā)實(shí)踐指南2026/1/6 10:40:19
- 嵌入式實(shí)時(shí)操作系統(tǒng)(RTOS)選型與移植技術(shù)指南2025/12/31 10:42:31
- 工業(yè)嵌入式系統(tǒng):通信接口技術(shù)選型與抗干擾設(shè)計(jì)實(shí)踐2025/12/15 14:36:53
- 深入解析嵌入式 OPENAMP 框架:開(kāi)啟異核通信新時(shí)代2025/7/22 16:27:29
- 一文快速了解OPENWRT基礎(chǔ)知識(shí)2025/7/14 16:59:04
- 編碼器的工作原理及作用1
- 超強(qiáng)整理!PCB設(shè)計(jì)之電流與線(xiàn)寬的關(guān)系2
- 三星(SAMSUNG)貼片電容規(guī)格對(duì)照表3
- 電腦藍(lán)屏代碼大全4
- 國(guó)標(biāo)委發(fā)布《電動(dòng)汽車(chē)安全要求第3部分:人員觸電防護(hù)》第1號(hào)修改單5
- 通俗易懂談上拉電阻與下拉電阻6
- 繼電器的工作原理以及驅(qū)動(dòng)電路7
- 電容單位8
- 跟我學(xué)51單片機(jī)(三):?jiǎn)纹瑱C(jī)串口通信實(shí)例9
- 一種三極管開(kāi)關(guān)電路設(shè)計(jì)10
- 高速PCB信號(hào)完整性(SI)設(shè)計(jì)核心實(shí)操規(guī)范
- 鎖相環(huán)(PLL)中的環(huán)路濾波器:參數(shù)計(jì)算與穩(wěn)定性分析
- MOSFET反向恢復(fù)特性對(duì)系統(tǒng)的影響
- 電源IC在惡劣環(huán)境中的防護(hù)設(shè)計(jì)
- 連接器耐腐蝕性能測(cè)試方法
- PCB電磁兼容(EMC)設(shè)計(jì)與干擾抑制核心實(shí)操規(guī)范
- 用于相位噪聲測(cè)量的低通濾波器設(shè)計(jì)與本振凈化技術(shù)
- MOSFET在高頻開(kāi)關(guān)中的EMI問(wèn)題
- 電源IC在便攜式設(shè)備中的設(shè)計(jì)要點(diǎn)
- 連接器結(jié)構(gòu)設(shè)計(jì)常見(jiàn)問(wèn)題分析









