[導(dǎo)讀]本文設(shè)計(jì)的CAN總線通信板完成了PC/104與CAN總線的通信轉(zhuǎn)換,改變了傳統(tǒng)的應(yīng)用CAN控制器加外部控制器的設(shè)計(jì)方法,在設(shè)計(jì)CAN核的基礎(chǔ)上,將通信板中所有數(shù)字信號(hào)處理部分都放在FPGA內(nèi)部來實(shí)現(xiàn),使通信速度得到很大提高。無論是在傳輸速率還是在抗干擾、抗震性等方面,CAN核應(yīng)用的綜合性能都得到了很大的提高。
隨著電子技術(shù)、計(jì)算機(jī)應(yīng)用技術(shù)和EDA技術(shù)的不斷發(fā)展,利用FPGA進(jìn)行數(shù)字系統(tǒng)的開發(fā)已被廣泛應(yīng)用于通信、航天、醫(yī)療電子、工業(yè)控制等領(lǐng)域,F(xiàn)PGA成為當(dāng)今硬件設(shè)計(jì)的首選方式之一。PC/104是一種專門為嵌入式控制而定義的工業(yè)控制總線,以其獨(dú)特的堆棧式結(jié)構(gòu)、低功率等優(yōu)點(diǎn),得到了廣泛的應(yīng)用。作為主流的現(xiàn)場(chǎng)總線,工業(yè)控制局域網(wǎng)CAN(Controller Area Network)總線抗干擾能力強(qiáng),易于組網(wǎng),具有非常廣闊的應(yīng)用前景。獨(dú)特的PC/104總線與CAN總線的結(jié)合,進(jìn)一步拓寬了CAN總線的應(yīng)用領(lǐng)域。
1基于FPGA的CAN核設(shè)計(jì)
本設(shè)計(jì)采用了Altera公司的Cyclone III系列FPGA EP3C25,開發(fā)平臺(tái)采用了Altera公司的Quartus II軟件。CAN核的設(shè)計(jì)以SJA1000功能結(jié)構(gòu)為基礎(chǔ)。
CAN核的功能框圖如圖1所示。該CAN總線控制器IP核,遵循CANbus 2.0標(biāo)準(zhǔn),其功能和寄存器操作與SJA1000兼容。IP核采用VHDL編碼,并采用容錯(cuò)設(shè)計(jì),可抑制存儲(chǔ)性器件的數(shù)據(jù)位翻轉(zhuǎn),大大提高了IP核的可靠性。CAN核可在FPGA中實(shí)現(xiàn),也可以實(shí)現(xiàn)為ASIC。其中包含3個(gè)主要模塊:寄存器組(can_registers),位時(shí)序邏輯(can_btl),位流處理器(can_bsp)。
寄存器組(CAN Register):外部微處理器可以通過地址直接訪問這些寄存器。發(fā)送數(shù)據(jù)時(shí),微處理器將要發(fā)送的數(shù)據(jù)寫入發(fā)送緩沖器,置位命令寄存器的發(fā)送請(qǐng)求位來啟動(dòng)發(fā)送。接收到數(shù)據(jù)后,核心控制器將其存在接收緩沖器,并通知位控制器將其取走。同時(shí),CAN寄存器中還有1個(gè)64字節(jié)的接收FIFO,可以1次存儲(chǔ)至少2個(gè)數(shù)據(jù)幀。
位時(shí)序邏輯(BTL):用來監(jiān)視CAN總線并處理與CAN總線相關(guān)的位時(shí)序。在消息的開始處,當(dāng)位時(shí)序邏輯檢測(cè)到總線上由隱性位(recessive)到顯性位(dominant)的跳變時(shí),就會(huì)將其內(nèi)部邏輯同步到位流,稱之為硬同步;隨后,在接收消息的過程中,檢測(cè)到隱性位到顯性位的跳變時(shí),便會(huì)重同步到位流,稱之為軟同步。位時(shí)序邏輯還要根據(jù)總線定時(shí)寄存器0和總線定時(shí)寄存器1的值來決定每個(gè)位周期采樣點(diǎn)的位置,以補(bǔ)償傳輸延遲和相位漂移所造成的誤差;同時(shí),根據(jù)總線定時(shí)寄存器1的設(shè)置采取相應(yīng)的采樣模式(單次采樣或3次)對(duì)總線上的數(shù)據(jù)采樣。
位流處理器(BSP):根據(jù)其實(shí)現(xiàn)的功能分為3個(gè)模塊:數(shù)據(jù)接收模塊、數(shù)據(jù)發(fā)送模塊和錯(cuò)誤處理模塊。數(shù)據(jù)接收模塊將從位時(shí)序邏輯送過來的采樣數(shù)據(jù)去除位填充后送到移位寄存器進(jìn)行串并轉(zhuǎn)換,之后對(duì)并行數(shù)據(jù)進(jìn)行CRC校驗(yàn),在消息接收完時(shí)發(fā)送應(yīng)答信號(hào),表示接收無誤。最后將接收到的消息的特征碼與驗(yàn)收屏蔽寄存器的內(nèi)容進(jìn)行比較,以決定是否將接收的消息寫入接收FIFO。數(shù)據(jù)接收模塊將要發(fā)送的數(shù)據(jù)組成幀并進(jìn)行CRC計(jì)算,之后送入移位寄存器進(jìn)行并串轉(zhuǎn)換,然后將串行數(shù)據(jù)編碼(位填充)后送到總線上。錯(cuò)誤監(jiān)視模塊根據(jù)協(xié)議規(guī)范中描述的錯(cuò)誤監(jiān)視機(jī)制檢測(cè)系統(tǒng)錯(cuò)誤,并設(shè)置相應(yīng)的寄存器,通知設(shè)備控制器。模塊根據(jù)協(xié)議描述的12種錯(cuò)誤監(jiān)視規(guī)則,在適當(dāng)情況下對(duì)計(jì)數(shù)器進(jìn)行加、減或清除??刂破鞲鶕?jù)這兩個(gè)計(jì)數(shù)器的值以及錯(cuò)誤限制寄存器的值來決定自己的故障狀態(tài):錯(cuò)誤激活(Error Active),錯(cuò)誤認(rèn)可(Error Passire)或總線關(guān)閉(Bus off On)。
2硬件電路設(shè)計(jì)
根據(jù)系統(tǒng)的總體設(shè)計(jì)方案,因?yàn)楝F(xiàn)有的CAN總線收發(fā)器最大的工作頻率為1 MHz,在提高CAN的通信速度后,現(xiàn)有的CAN總線收發(fā)器就不能滿足需要了,因此改用RS485收發(fā)器。由于RS485收發(fā)器是差分傳輸,不能完成通信卡的自發(fā)自收功能,因此需要外置的CAN Hub。另外,要進(jìn)行光纖傳輸,要完成光的邏輯總線結(jié)構(gòu),也需要外置Hub。因此,本硬件設(shè)計(jì)分為CAN通信板的設(shè)計(jì)和CAN Hub的設(shè)計(jì)兩部分。
(1)CAN通信板硬件電路設(shè)計(jì)
CAN通信板的核心器件是FPGA,同時(shí)完成“雙光雙電”通信,硬件通信板結(jié)構(gòu)如圖2所示。
作為PC/104系統(tǒng)的模塊,要接在PC/104總線上,所以要在數(shù)據(jù)、地址、控制總線上與PC/104標(biāo)準(zhǔn)規(guī)定的總線標(biāo)準(zhǔn)一致。
本設(shè)計(jì)要進(jìn)行四冗余設(shè)計(jì),在設(shè)計(jì)中要添加4個(gè)CAN核,選用Altera公司Cyclone II系列的FPGA EP3C25。
由于PC/104的工作電壓為5 V,而FPGA的工作電壓為3.3 V,因此在PC/104和FPGA之間要加入1個(gè)電平轉(zhuǎn)換器74LVC245來保護(hù)FPGA。
(2)光收發(fā)電路
本系統(tǒng)的高速光發(fā)射器采用HFBR-1414低功耗高速光發(fā)射器件,其光發(fā)射波長(zhǎng)為820 nm。此發(fā)射器能夠與以下4種光纖配合使用:50/125 μm、62.5/125 μm、100/140 μm、200 μm(HCS)。HFBR-1414采用了雙鏡片的光學(xué)系統(tǒng),光發(fā)射效率高,當(dāng)驅(qū)動(dòng)電流為60 mA時(shí),在50/125 μm光纖上可得到-15 dBm的光功率。光接收器采用HFBR-2412,其內(nèi)部集成了光電二極管、直流電路和開集電極的肖特基晶體管。HFBR-2412光接收器能與光發(fā)射器HFBR-1414及50/125 μm、62.5/125 μm、100/140 μm、200 μm(HCS)的光纖配合使用,最高通信速率可達(dá)5 MB。由于采用了開集電極電路,此接收器兼容TTL及CMOS電平。該電路的通信距離最遠(yuǎn)可達(dá)1.7 km。
為提高CAN通信板的抗震性,抗干擾性等綜合性能,采用了雙面布線設(shè)計(jì)。該通信板尺寸規(guī)格嚴(yán)格按照PC/104板的要求做。
(3)冗余設(shè)計(jì)及CAN Hub設(shè)計(jì)
該通信板設(shè)計(jì)了4路冗余,工作時(shí)只有1路CAN通道進(jìn)行工作,采用高位片選的方式進(jìn)行工作通道的選擇,其片選模塊在FPGA內(nèi)部設(shè)計(jì)完成。
(4)GAN Hub的設(shè)計(jì)
由于本系統(tǒng)采用“雙光雙電”四冗余的電路設(shè)計(jì),為提高通信速度,采用485收發(fā)器代替標(biāo)準(zhǔn)的CAN收發(fā)器。光是“點(diǎn)對(duì)點(diǎn)”的傳輸,485收發(fā)器是差分傳輸,在形式上都無法構(gòu)成總線式結(jié)構(gòu)。因此,引入CAN Hub來對(duì)信號(hào)進(jìn)行處理,在邏輯上達(dá)到總線式的結(jié)構(gòu)。
3軟件設(shè)計(jì)
CAN通信板的正常工作離不開強(qiáng)大的軟件支持,本系統(tǒng)中控制部分的核心采用PC/104嵌入式計(jì)算機(jī)系統(tǒng)。PC/104嵌入式計(jì)算機(jī)擁有可以和PC機(jī)媲美的強(qiáng)大功能,CAN通信板軟件部分的開發(fā)和設(shè)計(jì)就是在PC/104計(jì)算機(jī)上完成的,采用C語言進(jìn)行設(shè)計(jì)。C語言具有通用性、高效性和實(shí)時(shí)性,能滿足儀器的實(shí)時(shí)性要求。在設(shè)計(jì)過程中采用了模塊化、結(jié)構(gòu)化的設(shè)計(jì)方法,把軟件按功能分成若干個(gè)模塊,這些模塊既有一定的獨(dú)立性,又有一定聯(lián)系。每個(gè)模塊的編制要求相對(duì)獨(dú)立,以便對(duì)各模塊進(jìn)行檢驗(yàn)調(diào)試和修改、維護(hù)。這種框架模式的程序可以保證良好的通用性、可維護(hù)性、可擴(kuò)展性、移植性、互換性和獨(dú)立性。
由于CAN核的內(nèi)部結(jié)構(gòu)和SJA1000一樣,因此,開發(fā)時(shí)就像面對(duì)SJA1000一樣,編寫起來簡(jiǎn)單方便。本設(shè)計(jì)采用中斷處理的方式來進(jìn)行任務(wù)的處理。在中斷到來后進(jìn)行相應(yīng)的處理就可以了。
通信板初始化流程如圖3所示。
數(shù)據(jù)發(fā)送流程如圖4所示,數(shù)據(jù)接收流程如圖5所示。
4系統(tǒng)的仿真
采用Modelsim進(jìn)行仿真。
系統(tǒng)的測(cè)試平臺(tái)(TestBench),例化了模塊can4core和1個(gè)CAN核cantop,并仿真它們之間的通信。
本仿真完全按照CAN核正常工作過程進(jìn)行,仿真過程如下:
①初始化設(shè)置。首先進(jìn)行時(shí)間寄存器的設(shè)置和數(shù)據(jù)格式的設(shè)置。通過平臺(tái)對(duì)本系統(tǒng)設(shè)計(jì)模塊和CAN核進(jìn)行設(shè)置。
②同步測(cè)試。包括硬同步測(cè)試和重新同步測(cè)試。一個(gè)硬同步后,內(nèi)部的位時(shí)間以同步段重新開始。硬同步使引起硬同步的跳變沿位于重新開始的位時(shí)間同步段之內(nèi)。
③空FIFO測(cè)試(test_empty_fifo_ext)。該測(cè)試通過接收2個(gè)數(shù)據(jù)幀,然后讀取接收緩沖器,接著清空緩沖器,再讀取緩沖器,反復(fù)清空和讀取,看FIFO中的數(shù)據(jù)是否被完全清除。
④滿FIFO測(cè)試(test_full_fifo_ext)。首先清空寄存器,然后通過不斷地接收數(shù)據(jù)幀來填滿FIFO并讀取信息,檢測(cè)是否能正常工作。
⑤總線空閑測(cè)試(bus-off-test)。通過不斷發(fā)送數(shù)據(jù)來使總線處于忙狀態(tài),致使總線產(chǎn)生錯(cuò)誤,測(cè)試中斷寄存器是否能檢測(cè)到錯(cuò)誤,以及錯(cuò)誤清除后CAN核能否繼續(xù)正常工作。
⑥Basic CAN模式發(fā)送幀檢測(cè)。測(cè)試CAN核能否正常發(fā)送幀。
⑦寄存器測(cè)試。通過不停地讀寫寄存器,檢測(cè)CAN核寄存器是否正常工作。
⑧總線上數(shù)據(jù)的傳輸。仿真過程中重要的一點(diǎn)就是總線上是否能夠正常傳輸數(shù)據(jù)信息。
經(jīng)過仿真可以看到該CAN通信板突破了SJA1000在速度方面的限制,傳輸速度可達(dá)2 MHz,有效傳輸速率得到了大幅提高,工作性能良好。
結(jié)語
本文設(shè)計(jì)的CAN總線通信板完成了PC/104與CAN總線的通信轉(zhuǎn)換,改變了傳統(tǒng)的應(yīng)用CAN控制器加外部控制器的設(shè)計(jì)方法,在設(shè)計(jì)CAN核的基礎(chǔ)上,將通信板中所有數(shù)字信號(hào)處理部分都放在FPGA內(nèi)部來實(shí)現(xiàn),使通信速度得到很大提高。無論是在傳輸速率還是在抗干擾、抗震性等方面,CAN核應(yīng)用的綜合性能都得到了很大的提高。
欲知詳情,請(qǐng)下載word文檔
下載文檔
本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
Canalys統(tǒng)計(jì)數(shù)據(jù)顯示,2022年第三季度全球智能手機(jī)市場(chǎng)遭遇連續(xù)三季度下跌,同比下降9%。三星通過大力開展促銷活動(dòng)來減少渠道庫存,市場(chǎng)份額達(dá)到22%,領(lǐng)先市場(chǎng)。在市場(chǎng)低迷期間,由于市場(chǎng)對(duì)iPhone手機(jī)的需求相對(duì)具...
關(guān)鍵字:
智能手機(jī)
CAN
iPhone
OPPO
摘要:為解決傳統(tǒng)自動(dòng)化生產(chǎn)線生產(chǎn)效率低、自動(dòng)化程度低、生產(chǎn)線復(fù)雜等問題,設(shè)計(jì)了一種自動(dòng)化程度高且簡(jiǎn)單的自動(dòng)化機(jī)械手臂,并根據(jù)設(shè)計(jì)進(jìn)行仿真實(shí)驗(yàn)。實(shí)驗(yàn)結(jié)果表明,該設(shè)計(jì)在自動(dòng)化生產(chǎn)實(shí)踐中取得了較好的效果,提高了生產(chǎn)效率,達(dá)到了...
關(guān)鍵字:
機(jī)械手臂
設(shè)計(jì)
仿真
廣州2022年10月18日 /美通社/ -- 10月15日,第 132 屆中國進(jìn)出口商品交易會(huì)("廣交會(huì)")于"云端"開幕。本屆廣交會(huì)上高新技術(shù)企業(yè)云集,展出的智能產(chǎn)品超過140,...
關(guān)鍵字:
中國智造
BSP
手機(jī)
CAN
互聯(lián)網(wǎng)內(nèi)容的主要介質(zhì)在過去的幾十年中完成了從文字到圖片再到視頻的轉(zhuǎn)變。在不斷變化中,一以貫之的是人們對(duì)體驗(yàn)更好,更真實(shí)、更豐富網(wǎng)絡(luò)生活的追求。如今,視頻和游戲內(nèi)容都在向著更高刷新率與分辨率的方向發(fā)展,終端設(shè)備也在積極普及...
關(guān)鍵字:
元宇宙
Wi-Fi 7
通信
摘要:基于數(shù)字孿生技術(shù),依托Unity引擎開發(fā)虛擬調(diào)試應(yīng)用。通過機(jī)器人工作站實(shí)例進(jìn)行虛擬調(diào)試仿真,基于socket通信,通過三菱PLC對(duì)虛擬機(jī)器人工作站進(jìn)行虛擬調(diào)試,檢測(cè)工作站結(jié)構(gòu)設(shè)計(jì)的合理性、信號(hào)配置和邏輯設(shè)計(jì)的正確性...
關(guān)鍵字:
數(shù)字孿生
虛擬調(diào)試
仿真
此前,印度政府曾在推特上公布“國家寬帶使命”計(jì)劃,并表示將于今年10月1日在印度正式推出5G服務(wù),引發(fā)了不少網(wǎng)友的關(guān)注。然而,近日CNMO了解到,此條推文現(xiàn)已被刪除。業(yè)內(nèi)人士表示,印度可能尚未準(zhǔn)備好從10月1日開始推出5...
關(guān)鍵字:
印度
5G
通信
最近為什么越來越多的研究開始利用FPGA作為CNN加速器?FPGA與CNN的相遇究竟能帶來什么神奇效果呢?原來,F(xiàn)PGA擁有大量的可編程邏輯資源,相對(duì)于GPU,它的可重構(gòu)性以及高功耗能效比的優(yōu)點(diǎn),是GPU無法比擬的;同時(shí)...
關(guān)鍵字:
FPGA
可編程邏輯資源
GPU
FPGA的應(yīng)用領(lǐng)域包羅萬象,我們今天來看看在音樂科技領(lǐng)域及醫(yī)療照護(hù)的智能巧思。
關(guān)鍵字:
FPGA
科技領(lǐng)域
智能
如果獲批,百悅澤 ®將成為歐盟地區(qū)獲批用于慢性淋巴細(xì)胞白血病治療的布魯頓氏酪氨酸激酶(BTK)抑制劑中唯一在頭對(duì)頭試驗(yàn)中較標(biāo)準(zhǔn)治療獲得優(yōu)效性的藥物 憑借較標(biāo)準(zhǔn)治療顯著更低的房顫和房撲發(fā)生率 ...
關(guān)鍵字:
神州
BSP
EMI
CAN
麥格納(MAGNA)正在進(jìn)行一項(xiàng)1.2億美元的投資,在印度班加羅爾建立和運(yùn)營(yíng)一座全新工程中心,旨在為出行電動(dòng)化提供支持。該設(shè)施占地約2.2萬平方米,預(yù)計(jì)將于2023年第一季度開業(yè),屆時(shí)該中心將聘請(qǐng)眾多經(jīng)驗(yàn)豐富的工程師和技...
關(guān)鍵字:
工程師
仿真
電動(dòng)汽車
軟件
最近某項(xiàng)目采用以太網(wǎng)通信,實(shí)踐起來有些奇怪,好像設(shè)計(jì)成只能應(yīng)答某類計(jì)算機(jī)的ICMP(ping)命令, 某類計(jì)算機(jī)指的是Windows特定系統(tǒng),其他系統(tǒng)發(fā)送ping都不能正確識(shí)別。
關(guān)鍵字:
嵌入式Linux
FPGA
協(xié)議
近兩年,國外廠商的FPGA芯片價(jià)格飆升,由于價(jià)格,貨期,出口管制等多方面因素的影響,很多公司都在尋找FPGA國產(chǎn)化替代方案。我工作中正在使用的幾款芯片也面臨停產(chǎn)的風(fēng)險(xiǎn),用一片少一片,了解到國產(chǎn)FPGA發(fā)展的也不錯(cuò),完全自...
關(guān)鍵字:
FPGA
芯片
EDA
北京2022年10月8日 /美通社/ -- 日前,全球領(lǐng)先的IT基礎(chǔ)設(shè)施提供商浪潮信息加入龍蜥社區(qū)并成為理事單位,致力于攜手社區(qū)生態(tài)伙伴,共同推動(dòng)開源操作系統(tǒng)的全產(chǎn)業(yè)鏈協(xié)同創(chuàng)新和產(chǎn)業(yè)化應(yīng)用。 龍蜥社區(qū)成立于2020...
關(guān)鍵字:
開源
操作系統(tǒng)
通信
大數(shù)據(jù)
(全球TMT2022年10月8日訊)IT基礎(chǔ)設(shè)施提供商浪潮信息加入龍蜥社區(qū)并成為理事單位,致力于攜手社區(qū)生態(tài)伙伴,共同推動(dòng)開源操作系統(tǒng)的全產(chǎn)業(yè)鏈協(xié)同創(chuàng)新和產(chǎn)業(yè)化應(yīng)用。 龍蜥社區(qū)成立于2020年9月,是國內(nèi)...
關(guān)鍵字:
操作系統(tǒng)
開源
通信
裝機(jī)量
(全球TMT2022年9月30日訊)Tata Communications在印度浦那推出了專用私有5G"全球卓越中心"(CoE),為企業(yè)加速"工業(yè)4.0"應(yīng)用和能力。這家新的CoE是一個(gè)敏捷、安全的室內(nèi)設(shè)施,用來測(cè)試和...
關(guān)鍵字:
通信
5G
COMMUNICATIONS
圖像分析
蘇州2022年9月30日 /美通社/ -- 藝卓中國發(fā)布23.8英寸FlexScan EV2480–一款超窄邊框全高清(1920 x 1080)IPS顯示器,配備USB Ty...
關(guān)鍵字:
CAN
FLEX
顯示器
USB-C
上海2022年9月29日 /美通社/ -- 9月26日下午,藍(lán)科與普華永道共同策劃的【日企財(cái)務(wù)沙龍】在位于上海湖濱路的普華永道創(chuàng)新中心順利舉辦。 "CFO在未來應(yīng)該被稱作首席未來官(Chief Future...
關(guān)鍵字:
數(shù)字化
NET
CAN
FUTURE
客戶可以針對(duì)圖形和仿真基礎(chǔ)部署Supermicro服務(wù)器,以大規(guī)模建構(gòu)及運(yùn)行元宇宙應(yīng)用——系統(tǒng)將支持多達(dá)8個(gè)NVIDIA L40 GPU、ConnectX-7 SmartNI...
關(guān)鍵字:
NVIDIA
MICRO
SUPER
仿真
廈門2022年9月27日 /美通社/ -- 近日,卓越職場(chǎng)研究機(jī)構(gòu)(Great Place to Work®)公布了2022年亞洲最佳職場(chǎng)?(Best Workplaces in Asia?)榜單,鈴盛(Ring...
關(guān)鍵字:
CENTRAL
BSP
通信
VIDEO