<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > SHARC DSP與SJA1000的CAN總線(xiàn)接口設計

SHARC DSP與SJA1000的CAN總線(xiàn)接口設計

作者: 時(shí)間:2011-04-07 來(lái)源:網(wǎng)絡(luò ) 收藏

本文引用地址:http://dyxdggzs.com/article/150885.htm

A21062和簡(jiǎn)化的相應程序如下:
1) #define ADDR 0x400000
2) bit set mode2 FLG1O|FLG2O;
//設置Flag1,Flag2為輸出
3) r1=0x00047800; dm(SYSCON)=r0;
//設置外部空間大小
4) r0=0x21a8c429;dm (WAIT)=r0;
//用2個(gè)軟等待訪(fǎng)問(wèn)MS0
5) bit set astat ASTAT_FLG1;
//Flag1=1,
6) r0=addr;dm(ADDR)=r0; //寫(xiě)入要訪(fǎng)問(wèn)的的內部地址
7) bit clr astat ASTAT_FLG1;
//Flag1=0
8) bit clr astat ASTAT_FLG2;
//Flag2=0,CS=0
9) i0=ADDR;r0=dm(i0,0);
//讀取相應地址的數據
10) r1=3;dm(i0,0)=r1;
//寫(xiě)入數據到SJA1000相應地址
11) bit set astat ASTAT_FLG2;
//Flag2=1,CS=1,5

為說(shuō)明方便,對各條指令編號。運行指令5、7、8、11各花費25ns,運行指令6、9、10各花費100ns,所以完成一次讀或寫(xiě)需300ns。

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

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

運行指令8、9、11、13各花費100ns,運行指令10、12、14各花費75ns,所以完成一次讀或寫(xiě)需525ns。速度比前文的簡(jiǎn)化設計要慢一點(diǎn),但這種設計更利于擴展,適合于多個(gè)外設,同時(shí)節省了兩個(gè)Flag引腳。當SJA1000工作在最大傳輸速度1Mbit/s時(shí),由于在一個(gè)數據幀中會(huì )插入約42bit其它幀信號,所以完成8bit傳輸的時(shí)間約為50s。前兩種設計的速度分別是其167倍和95倍。所以這兩種設計都能滿(mǎn)足SJA1000的傳輸速度要求。

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

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

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


上一頁(yè) 1 2 下一頁(yè)

評論


相關(guān)推薦

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

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>