資料介紹
當(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ì)。
SJA1000簡介
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模式下,處理器對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的接口帶來一定困難,且不同的DSP外部引腳和時(shí)序也略有區(qū)別。要設(shè)計(jì)CAN控制器與DSP的接口,首先必須比較DSP與CAN控制器的時(shí)序。
本文選用的DSP為ADSP21062,主頻為40MHz,單周期(零等待)訪問存儲(chǔ)器時(shí),要求存儲(chǔ)器的響應(yīng)(讀或?qū)懀┲芷谛∮?7ns,但許多存儲(chǔ)器或外設(shè)的響應(yīng)速度沒有這么快,于是就要通過加等待來延長訪問時(shí)間。ADSP2106x支持兩種等待方式,即內(nèi)等待(軟等待)和外等待(硬等待)。
SJA1000和CAN總線的連接
選擇82C250作為收發(fā)器,選擇6N137高速光電隔離器實(shí)現(xiàn)系統(tǒng)和CAN總線的隔離。其連接方法如圖1所示。這種設(shè)計(jì)既能做好電氣隔離,又能保證數(shù)據(jù)的傳輸速度。

圖1 SJA1000和CAN總線的連接
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í)間最長為50ns,所以要保證讀信號(hào)有效時(shí)間至少50ns,ADSP21062在用2個(gè)軟等待時(shí),其低電平時(shí)間為62.5ns(25ns/2+2×25ns),剛好能滿足要求。
ADSP21062和SJA1000接口的簡化設(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,無地址鎖存操作。SJA1000的WR直接受DSP的WR信號(hào)控制。由Flag2直接控制CS。其連接如圖2所示。

ADSP21062和SJA1000簡化接口設(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 clrastat 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
為說明方便,對各條指令編號(hào)。運(yùn)行指令5、7、8、11各花費(fèi)25ns,運(yùn)行指令6、9、10各花費(fèi)100ns,所以完成一次讀或?qū)懶?00ns。
SJA1000簡介
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模式下,處理器對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的接口帶來一定困難,且不同的DSP外部引腳和時(shí)序也略有區(qū)別。要設(shè)計(jì)CAN控制器與DSP的接口,首先必須比較DSP與CAN控制器的時(shí)序。
本文選用的DSP為ADSP21062,主頻為40MHz,單周期(零等待)訪問存儲(chǔ)器時(shí),要求存儲(chǔ)器的響應(yīng)(讀或?qū)懀┲芷谛∮?7ns,但許多存儲(chǔ)器或外設(shè)的響應(yīng)速度沒有這么快,于是就要通過加等待來延長訪問時(shí)間。ADSP2106x支持兩種等待方式,即內(nèi)等待(軟等待)和外等待(硬等待)。
SJA1000和CAN總線的連接
選擇82C250作為收發(fā)器,選擇6N137高速光電隔離器實(shí)現(xiàn)系統(tǒng)和CAN總線的隔離。其連接方法如圖1所示。這種設(shè)計(jì)既能做好電氣隔離,又能保證數(shù)據(jù)的傳輸速度。

圖1 SJA1000和CAN總線的連接
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í)間最長為50ns,所以要保證讀信號(hào)有效時(shí)間至少50ns,ADSP21062在用2個(gè)軟等待時(shí),其低電平時(shí)間為62.5ns(25ns/2+2×25ns),剛好能滿足要求。
ADSP21062和SJA1000接口的簡化設(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,無地址鎖存操作。SJA1000的WR直接受DSP的WR信號(hào)控制。由Flag2直接控制CS。其連接如圖2所示。

ADSP21062和SJA1000簡化接口設(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 clrastat 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
為說明方便,對各條指令編號(hào)。運(yùn)行指令5、7、8、11各花費(fèi)25ns,運(yùn)行指令6、9、10各花費(fèi)100ns,所以完成一次讀或?qū)懶?00ns。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 基于SJA1000的CAN節(jié)點(diǎn)設(shè)計(jì)
- SJA1000獨(dú)立CAN控制器英文資料
- SJA1000獨(dú)立CAN控制器中文資料
- SJA1000獨(dú)立CAN控制器的應(yīng)用指南資料免費(fèi)下載 38次下載
- DSP與CAN控制器SJA1000的總線接口的差別 5次下載
- SJA1000 獨(dú)立的CAN 控制器應(yīng)用指南 32次下載
- CAN總線控制器SJA1000的初始化程序設(shè)計(jì) 12次下載
- 基于SJA1000的CAN網(wǎng)絡(luò)控制系統(tǒng)節(jié)點(diǎn)設(shè)計(jì) 87次下載
- SJA1000控制器在多電機(jī)綜合保護(hù)器中的應(yīng)用
- 基于CAN總線智能節(jié)點(diǎn)設(shè)計(jì)
- SJA1000 Stand-alone CAN contro
- SJA1000獨(dú)立的CAN控制器應(yīng)用指南
- SJA1000,CAN控制器性能典型應(yīng)用電路的介紹以及基于S
- CAN總線節(jié)點(diǎn)電路的設(shè)計(jì)與實(shí)現(xiàn)
- SJA1000 在CAN 總線系統(tǒng)節(jié)點(diǎn)的應(yīng)用
- 基于MAX232轉(zhuǎn)換器和SJA1000CAN總線控制器實(shí)現(xiàn)遠(yuǎn)程通信網(wǎng)絡(luò)的設(shè)計(jì) 4k次閱讀
- 基于SJA1000和光纖收發(fā)一體模塊實(shí)現(xiàn)CAN總線光纖傳輸接口的設(shè)計(jì) 4.3k次閱讀
- 兩款CAN總線控制器的對比和應(yīng)用場景分析 7.9k次閱讀
- 基于獨(dú)立通信控制器SJA1000實(shí)現(xiàn)對CAN總線位定時(shí)參數(shù)進(jìn)行研究 4.3k次閱讀
- 基于單片機(jī)、SJA1000和總線技術(shù)實(shí)現(xiàn)裝備器材庫監(jiān)控系統(tǒng)的設(shè)計(jì) 2.8k次閱讀
- sja1000引腳和功能 2.3w次閱讀
- 基于VxWorks操作系統(tǒng)實(shí)現(xiàn)PC/104-CAN適配卡的驅(qū)動(dòng)系統(tǒng)設(shè)計(jì) 4.5k次閱讀
- 基于FPGA的VHDL語言設(shè)計(jì)控制器SJA1000的IP軟核設(shè)計(jì) 3.6k次閱讀
- 基于C8051F120的支持多協(xié)議總線集成器的設(shè)計(jì)方案 2k次閱讀
- 基于單片機(jī)和CAN控制器sja1000實(shí)現(xiàn)分布式監(jiān)控系統(tǒng)設(shè)計(jì) 1.8k次閱讀
- 利用TL16C554和SJA1000芯片實(shí)現(xiàn)4路UART總線與CAN總線的通訊設(shè)計(jì) 5.4k次閱讀
- 基于Lenze9326變頻器和SJA1000芯片實(shí)現(xiàn)多臺(tái)異步電機(jī)協(xié)調(diào)控制的設(shè)計(jì) 2.3k次閱讀
- 采用CAN總線控制器SJA1000實(shí)現(xiàn)控制電路接口的設(shè)計(jì) 8.8k次閱讀
- 一種CAN總線與以太網(wǎng)互連系統(tǒng)的設(shè)計(jì)方案 5k次閱讀
- 基于DSP和CAN總線的RTU的設(shè)計(jì) 2.1k次閱讀
下載排行
本周
- 1MDD品牌三極管BC807數(shù)據(jù)手冊
- 3.00 MB | 次下載 | 免費(fèi)
- 2MDD品牌三極管BC817數(shù)據(jù)手冊
- 2.51 MB | 次下載 | 免費(fèi)
- 3MDD品牌三極管D882數(shù)據(jù)手冊
- 3.49 MB | 次下載 | 免費(fèi)
- 4MDD品牌三極管MMBT2222A數(shù)據(jù)手冊
- 3.26 MB | 次下載 | 免費(fèi)
- 5MDD品牌三極管MMBTA56數(shù)據(jù)手冊
- 3.09 MB | 次下載 | 免費(fèi)
- 6MDD品牌三極管MMBTA92數(shù)據(jù)手冊
- 2.32 MB | 次下載 | 免費(fèi)
- 7STM32G474 HRTIME PWM 丟波問題分析與解決
- 1.00 MB | 次下載 | 3 積分
- 8新能源電動(dòng)汽車高壓線束的銅鋁連接解決方案
- 2.71 MB | 次下載 | 2 積分
本月
- 1愛華AIWA HS-J202維修手冊
- 3.34 MB | 37次下載 | 免費(fèi)
- 2NB-IoT芯片廠商的資料說明
- 0.31 MB | 22次下載 | 1 積分
- 3PC5502負(fù)載均流控制電路數(shù)據(jù)手冊
- 1.63 MB | 22次下載 | 免費(fèi)
- 4H110主板CPU PWM芯片ISL95858HRZ-T核心供電電路圖資料
- 0.63 MB | 6次下載 | 1 積分
- 5UWB653Pro USB口測距通信定位模塊規(guī)格書
- 838.47 KB | 5次下載 | 免費(fèi)
- 6技嘉H110主板IT8628E_BX IO電路圖資料
- 2.61 MB | 4次下載 | 1 積分
- 7蘇泊爾DCL6907(即CHK-S007)單芯片電磁爐原理圖資料
- 0.04 MB | 4次下載 | 1 積分
- 8蘇泊爾DCL6909(即CHK-S009)單芯片電磁爐原理圖資料
- 0.08 MB | 2次下載 | 1 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935137次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191439次下載 | 10 積分
- 5十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183353次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81602次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73822次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65991次下載 | 10 積分
電子發(fā)燒友App





創(chuàng)作
發(fā)文章
發(fā)帖
提問
發(fā)資料
發(fā)視頻
上傳資料賺積分
評論