在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>DSP>DSP與CAN控制器SJA1000的總線接口的差別

DSP與CAN控制器SJA1000的總線接口的差別

2017-10-30 | rar | 0.3 MB | 次下載 | 1積分

資料介紹

 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的接口帶來一定困難,且不同的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總線的連接
  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
  為說明方便,對(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無效
  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í)間約為50ms。前兩種設(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è),判斷是來自哪一個(gè)外設(shè),這樣就可以擴(kuò)展更多的中斷。
  結(jié)語
  SJA1000接口為地址/數(shù)據(jù)復(fù)用模式,DSP處理器通常為地址/數(shù)據(jù)總線分離的結(jié)構(gòu),本文提供了兩種不同接口的思路和方法。測(cè)試表明,這種方法確實(shí)可行,傳輸效率高。
  選擇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í)間最長為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,無地址鎖存操作。SJA1000的WR直接受DSP的WR信號(hào)控制。由Flag2直接控制CS。其連接如圖2所示。
?
下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評(píng)論

查看更多

下載排行

本周

  1. 1電子電路原理第七版PDF電子教材免費(fèi)下載
  2. 0.00 MB  |  1489次下載  |  免費(fèi)
  3. 2單片機(jī)典型實(shí)例介紹
  4. 18.19 MB  |  91次下載  |  1 積分
  5. 3S7-200PLC編程實(shí)例詳細(xì)資料
  6. 1.17 MB  |  27次下載  |  1 積分
  7. 4筆記本電腦主板的元件識(shí)別和講解說明
  8. 4.28 MB  |  18次下載  |  4 積分
  9. 5開關(guān)電源原理及各功能電路詳解
  10. 0.38 MB  |  9次下載  |  免費(fèi)
  11. 6基于AT89C2051/4051單片機(jī)編程器的實(shí)驗(yàn)
  12. 0.11 MB  |  4次下載  |  免費(fèi)
  13. 7基于單片機(jī)和 SG3525的程控開關(guān)電源設(shè)計(jì)
  14. 0.23 MB  |  3次下載  |  免費(fèi)
  15. 8基于單片機(jī)的紅外風(fēng)扇遙控
  16. 0.23 MB  |  3次下載  |  免費(fèi)

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234313次下載  |  免費(fèi)
  3. 2PADS 9.0 2009最新版 -下載
  4. 0.00 MB  |  66304次下載  |  免費(fèi)
  5. 3protel99下載protel99軟件下載(中文版)
  6. 0.00 MB  |  51209次下載  |  免費(fèi)
  7. 4LabView 8.0 專業(yè)版下載 (3CD完整版)
  8. 0.00 MB  |  51043次下載  |  免費(fèi)
  9. 5555集成電路應(yīng)用800例(新編版)
  10. 0.00 MB  |  33562次下載  |  免費(fèi)
  11. 6接口電路圖大全
  12. 未知  |  30319次下載  |  免費(fèi)
  13. 7Multisim 10下載Multisim 10 中文版
  14. 0.00 MB  |  28588次下載  |  免費(fèi)
  15. 8開關(guān)電源設(shè)計(jì)實(shí)例指南
  16. 未知  |  21539次下載  |  免費(fèi)

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935053次下載  |  免費(fèi)
  3. 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
  4. 78.1 MB  |  537791次下載  |  免費(fèi)
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420026次下載  |  免費(fèi)
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234313次下載  |  免費(fèi)
  9. 5Altium DXP2002下載入口
  10. 未知  |  233045次下載  |  免費(fèi)
  11. 6電路仿真軟件multisim 10.0免費(fèi)下載
  12. 340992  |  191183次下載  |  免費(fèi)
  13. 7十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
  14. 158M  |  183277次下載  |  免費(fèi)
  15. 8proe5.0野火版下載(中文版免費(fèi)下載)
  16. 未知  |  138039次下載  |  免費(fèi)
主站蜘蛛池模板: 色老头网站久久网 | 一级黄色免费毛片 | 59日本人xxxxxxxxx69 | 天天操夜夜艹 | 狠狠色依依成人婷婷九月 | 免费毛片网 | 五月婷婷基地 | 四虎影视永久在线 yin56xyz | 久久噜噜噜久久亚洲va久 | 午夜视频1000 | 色噜噜噜| 手机在线看a | 欧美一级片手机在线观看 | 天天舔天天干天天操 | 最刺激黄a大片免费观看下截 | 韩国三级视频 | 综合网在线| 国产 麻豆 欧美亚洲综合久久 | 一级片一级片一级片 | 成人精品视频在线观看播放 | 久久这里精品青草免费 | 九九全国免费视频 | 国产精品怡红院永久免费 | 欧美老汉色 | 免费网站在线视频美女被 | 亚洲高清视频一区 | 天天综合在线观看 | 美女黄页网站免费进入 | 久热网 | 久久在线免费观看 | 国模视频在线 | 美女被免费网站91色 | 亚洲精品私拍国产福利在线 | 丁香婷五月 | 欧美日本一区二区 | 性做久久久久久久 | 一级在线观看 | 1300部小u女视频免费 | 久久久噜噜噜www成人网 | 欧美专区一区二区三区 | 拍拍拍成人免费高清视频 |