當(dāng)前位置:首頁(yè) > 電源 > 數(shù)字電源
[導(dǎo)讀]本文討論了DSP與CAN控制器SJA1000的總線接口的差別,提出了SJA1000和SHARC系列DSP接口設(shè)計(jì)的簡(jiǎn)單方法和通用方法。

摘 要: 本文討論了DSP與CAN控制器SJA1000的總線接口的差別,提出了SJA1000和SHARC系列DSP接口設(shè)計(jì)的簡(jiǎn)單方法和通用方法。測(cè)試表明,這種方法的穩(wěn)定性好,傳輸效率高。
關(guān)鍵詞: SHARC DSP; SJA1000; CAN現(xiàn)場(chǎng)總線

引言
     當(dāng)前,有一些微處理器將CAN控制器嵌入到系統(tǒng)之中,但是仍有大量人們比較熟悉的微處理器并不帶有CAN控制器。采用微處理器和CAN控制器組合的設(shè)計(jì)成為必要,而且,CAN控制器具有完成CAN總線通信協(xié)議所要求的全部必要功能,因此,CAN控制器與其它微處理器的接口設(shè)計(jì)成為設(shè)計(jì)CAN總線系統(tǒng)的首要工作。本文重點(diǎn)介紹以SHARC DSP為核心的、基于SJA1000的CAN總線接口設(shè)計(jì)。

 

 

 

 


圖1 SJA1000和CAN總線的連接

 

 

 

 

圖2 ADSP21062和SJA1000的簡(jiǎn)化設(shè)計(jì)圖

 

 

 

 


圖3 基于CPLD的ADSP21062和SJA1000設(shè)計(jì)圖

 

 

 

 

 


圖4 CPLD的邏輯圖

SJA1000簡(jiǎn)介
    SJA1000是一種獨(dú)立的CAN控制器,用于移動(dòng)目標(biāo)和一般工業(yè)環(huán)境中的控制器局域網(wǎng)絡(luò)(CAN)。它是Philips公司早期CAN控制器PCA82C200(Basic CAN)的替代品,而且增加了一種新的工作模式(PeliCAN),這種模式支持具有很多新功能的CAN2.0B協(xié)議。

    SJA1000與微處理器的接口主要由8根數(shù)據(jù)和地址分時(shí)復(fù)用線完成:AD0~AD7、ALE/AS、、/E、、、MODE和,其中MODE為接口方式選擇信號(hào),可設(shè)置成Intel方式或Motorola方式。兩者的區(qū)別在于:Intel模式下,處理器對(duì)SJA1000寫時(shí),用、作為讀、寫數(shù)據(jù)信號(hào),ALE下降沿鎖存地址(此時(shí)地址信號(hào)要保證基本的建立保持時(shí)間),僅在讀、寫數(shù)據(jù)時(shí)為低;Motorola模式下,讀、寫信號(hào)用區(qū)分(高電平讀、低電平寫),用/E選通數(shù)據(jù)(下降沿鎖存),AS和CS類似于Intel的ALE和。目前流行的MCS51/96系列單片機(jī)提供了方便快捷的直接Intel方式接口,出于普遍性的考慮,本文以下的接口設(shè)計(jì)都是基于Intel模式的。
    
DSP的接口信號(hào)和時(shí)序
    與早期的處理器不同,DSP芯片的片外引腳都采用地址線和數(shù)據(jù)線分離的設(shè)計(jì)方法,不再使用地址數(shù)據(jù)分時(shí)復(fù)用線,也沒有ALE信號(hào),這樣就給CAN控制器與DSP的接口帶來(lái)一定困難,且不同的DSP外部引腳和時(shí)序也略有區(qū)別。要設(shè)計(jì)CAN控制器與DSP的接口,首先必須比較DSP與CAN控制器的時(shí)序。
本文選用的DSP為ADSP21062,主頻為40MHz,單周期(零等待)訪問存儲(chǔ)器時(shí),要求存儲(chǔ)器的響應(yīng)(讀或?qū)?周期小于17ns,但許多存儲(chǔ)器或外設(shè)的響應(yīng)速度沒有這么快,于是就要通過加等待來(lái)延長(zhǎng)訪問時(shí)間。ADSP2106x支持兩種等待方式,即內(nèi)等待(軟等待)和外等待(硬等待)。
  
SJA1000和CAN總線的連接
     選擇82C250作為收發(fā)器,選擇6N137高速光電隔離器實(shí)現(xiàn)系統(tǒng)和CAN總線的隔離。其連接方法如圖1所示。這種設(shè)計(jì)既能做好電氣隔離,又能保證數(shù)據(jù)的傳輸速度。

CAN控制器與DSP的接口設(shè)計(jì)方法
    SJA1000的數(shù)據(jù)和地址信號(hào)為分時(shí)復(fù)用,而DSP為數(shù)據(jù)、地址信號(hào)分離的結(jié)構(gòu),而且DSP不提供ALE信號(hào),設(shè)計(jì)的關(guān)鍵就是DSP要把SJA1000的地址當(dāng)成數(shù)據(jù)寫入并同時(shí)產(chǎn)生ALE信號(hào)。分析讀寫信號(hào)所要求的最短有效時(shí)間,由于讀低電平到數(shù)據(jù)有效的時(shí)間最長(zhǎng)為50ns,所以要保證讀信號(hào)有效時(shí)間至少50ns,ADSP21062在用2個(gè)軟等待時(shí),其低電平時(shí)間為62.5ns(25ns/2+2×25ns),剛好能滿足要求。

ADSP21062和SJA1000接口的簡(jiǎn)化設(shè)計(jì)
    在外圍設(shè)備連接不多的情況下,接口電路可以使用幾個(gè)邏輯門實(shí)現(xiàn)。由于訪問外部數(shù)據(jù)時(shí),數(shù)據(jù)總線的低16位未用,所以使用的數(shù)據(jù)線從DATA16起始。當(dāng)Flag1=1時(shí),SJA1000的WR始終為1,其ALE為DSP的WR的反向,當(dāng)DSP把地址當(dāng)成數(shù)據(jù)寫入SJA1000時(shí),低電平DSP的WR信號(hào)會(huì)轉(zhuǎn)換成高電平的ALE,并在ALE的下降沿把數(shù)據(jù)鎖存。當(dāng)Flag1=0時(shí),ALE始終為0,無(wú)地址鎖存操作。SJA1000的WR直接受DSP的WR信號(hào)控制。由Flag2直接控制CS。其連接如圖2所示?! ?BR>
    ADSP21062和SJA1000簡(jiǎn)化接口設(shè)計(jì)的相應(yīng)程序如下:
1) #define CANADDR 0x400000
2) bit set mode2 FLG1O|FLG2O;
//設(shè)置Flag1,F(xiàn)lag2為輸出
3) r1=0x00047800; dm(SYSCON)=r0; 
//設(shè)置外部空間大小
4) r0=0x21a8c429;dm (WAIT)=r0; 
//用2個(gè)軟等待訪問MS0
5) bit set astat ASTAT_FLG1;
 //Flag1=1,
6) r0=addr;dm(CANADDR)=r0;  //寫入要訪問的SJA1000的內(nèi)部地址
7) bit clr astat ASTAT_FLG1;
//Flag1=0
8) bit clr astat ASTAT_FLG2; 
//Flag2=0,CS=0
9) i0=CANADDR;r0=dm(i0,0);
//讀取SJA1000相應(yīng)地址的數(shù)據(jù)
10) r1=3;dm(i0,0)=r1; 
//寫入數(shù)據(jù)到SJA1000相應(yīng)地址
11) bit set astat ASTAT_FLG2;
//Flag2=1,CS=1,5

    為說(shuō)明方便,對(duì)各條指令編號(hào)。運(yùn)行指令5、7、8、11各花費(fèi)25ns,運(yùn)行指令6、9、10各花費(fèi)100ns,所以完成一次讀或?qū)懶?00ns。

基于CPLD的ADSP21062和SJA1000接口設(shè)計(jì)
    在連接多個(gè)外圍設(shè)備時(shí),其譯碼電路比較復(fù)雜,可以使用CPLD完成邏輯譯碼控制。利用地址數(shù)據(jù)信號(hào)產(chǎn)生CAN的ALE、CS等信號(hào)。其優(yōu)點(diǎn)在于使用多個(gè)總線設(shè)備時(shí),可用一片CPLD完成所有總線設(shè)備的譯碼,這種方法有更好的適用性。其連接方法如圖3所示。

    DSP的程序設(shè)計(jì)如下:
1) #define CANNCS  0x400100
//清CANCS的地址,對(duì)此地址操作使CAN的CS無(wú)效
2) #define CANCS   0x400200//置CANCS的地址,對(duì)此地址操作使CAN的CS有效
3) #define CANALE  0x400500
//置CANALE的地址,對(duì)此地址操作使CAN的ALE可變化
4) #define CANNALE 0x400600
//清CANALE的地址,對(duì)此地址操作使CAN的ALE恒為低
5) #define CANRW   0x400900
//對(duì)此地址操作完成CAN數(shù)據(jù)的讀、寫
6) r1=0x00047800; dm(SYSCON)=r0; //設(shè)置外部空間大小
7) r0=0x21a8c429;dm (WAIT)=r0; 
//用2個(gè)軟等待訪問MS0
8) r7=0x07;dm(CANALE)=r7;
//ALEhigh=1,CANALE為CANWE的取反
9) r4=addr;dm(CANRW)=r4; 
//寫入要訪問的SJA1000的內(nèi)部寄存器空間地址
10) r7=dm(CANNALE); 
//ALEhigh=0,CANALE總為0
11) r7=0x07;dm(CANCS)=r7; 
//CANCS=0
12) r3=dm(CANRW);  
//讀取SJA1000相應(yīng)地址的數(shù)據(jù)
13) r1=3;dm(CANRW)=r1; 
//寫入數(shù)據(jù)到SJA1000相應(yīng)地址
14) r7=dm(CANNCS);  
//CANCS=1

    運(yùn)行指令8、9、11、13各花費(fèi)100ns,運(yùn)行指令10、12、14各花費(fèi)75ns,所以完成一次讀或?qū)懶?25ns。速度比前文的簡(jiǎn)化設(shè)計(jì)要慢一點(diǎn),但這種設(shè)計(jì)更利于擴(kuò)展,適合于多個(gè)外設(shè)接口,同時(shí)節(jié)省了兩個(gè)Flag引腳。當(dāng)SJA1000工作在最大傳輸速度1Mbit/s時(shí),由于在一個(gè)數(shù)據(jù)幀中會(huì)插入約42bit其它幀信號(hào),所以完成8bit傳輸?shù)臅r(shí)間約為50s。前兩種設(shè)計(jì)的速度分別是其167倍和95倍。所以這兩種設(shè)計(jì)都能滿足SJA1000的傳輸速度要求。

CPLD程序設(shè)計(jì)
    圖4中,用74138進(jìn)行譯碼,生成ALE、CS等信號(hào)。當(dāng)執(zhí)行指令6時(shí),設(shè)置了外部空間的大小,在訪問地址0x400000~0x4fffff時(shí)會(huì)使能MS0,74138的G2AN將有效。當(dāng)?shù)刂稟11~A8=0001,Y1N=0,CANCS的清零由DSP的RD控制,RD信號(hào)的低電平將使CANCS=0,指令11完成此功能。當(dāng)?shù)刂稟11~A8=0010,數(shù)據(jù)D19~D16=1000,則Y2N=0,DSP的WR信號(hào)的將使CANCS=1,指令14完成此功能;當(dāng)?shù)刂稟11~A8=0101,數(shù)據(jù)D19~D16=0111,則Y5N=0,DSP的WR信號(hào)沿將使ALEhigh=1,此時(shí)CANWE始終保持1,CANALE為WR取反,指令8完成此功能;當(dāng)?shù)刂稟11~A8=0110,則Y6N=0,RD信號(hào)的低電平將使ALEhigh=0,此時(shí)CANALE始終保持0,CANWE為WR,指令10完成此功能。

    ADSP21062僅有3個(gè)外部中斷,在掛多個(gè)外設(shè)時(shí)就顯得資源緊張。圖4中,低電平有效或下降沿有效的中斷信號(hào)可以用與的關(guān)系連接到一個(gè)中斷上,DSP在響應(yīng)中斷后,讀相應(yīng)的多個(gè)外設(shè),判斷是來(lái)自哪一個(gè)外設(shè),這樣就可以擴(kuò)展更多的中斷。

結(jié)語(yǔ)
     SJA1000接口為地址/數(shù)據(jù)復(fù)用模式,DSP處理器通常為地址/數(shù)據(jù)總線分離的結(jié)構(gòu),本文提供了兩種不同接口的思路和方法。測(cè)試表明,這種方法確實(shí)可行,傳輸效率高。

本站聲明: 本文章由作者或相關(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)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉