<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > DSP芯片TMS320C30與A/D轉(zhuǎn)換器MAX153和D/A轉(zhuǎn)換器MX7545接口的設(shè)計(jì)

          DSP芯片TMS320C30與A/D轉(zhuǎn)換器MAX153和D/A轉(zhuǎn)換器MX7545接口的設(shè)計(jì)

          作者: 時(shí)間:2018-09-11 來源:網(wǎng)絡(luò) 收藏
          MAX153和MX是美國MAXIM公司近幾年推出的8位A/D轉(zhuǎn)換器和12位D/A轉(zhuǎn)換器。MAX153具有高達(dá)1MSPS的采樣率,MX具有4MSPS的數(shù)/模轉(zhuǎn)換速度。

          MAX153和MX可以很容易地與一般微處理器接口,而不需要過多地考慮時(shí)序問題。然而,當(dāng)它們同時(shí)與高速數(shù)字信號(hào)處理器()接口時(shí),就需要從軟硬件的設(shè)計(jì)上仔細(xì)考慮時(shí)序問題和其它問題。

          本文引用地址:http://www.ex-cimer.com/article/201809/388844.htm

          下面先簡單介紹一下MAX153和MX7545的工作模式,隨后以它們與TMSC30數(shù)字信號(hào)處理器的接口為例,詳細(xì)介紹接口的軟硬件設(shè)計(jì)方法。

            1 MAX153的工作模式

            根據(jù)MODE管腳上信號(hào)的不同,MAX153有兩種不同的工作模式。當(dāng)MODE接地(0V)時(shí),轉(zhuǎn)換器處于RD工作模式;當(dāng)MODE接高電平(+5V)時(shí),轉(zhuǎn)換器處于WR-RD工作模式。限于篇幅,下面將只介紹WR-RD工作模式。

            從圖1可以看出,轉(zhuǎn)換器在WR的下降沿開始啟動(dòng),當(dāng)WR變高時(shí),高4位的數(shù)據(jù)已轉(zhuǎn)換完畢且已送到輸出緩沖器,同時(shí)低4位數(shù)據(jù)開始轉(zhuǎn)換,380ns后INT變低,表明低四位數(shù)據(jù)轉(zhuǎn)換也已完成。數(shù)據(jù)的讀取有兩種方式,這里僅介紹最快工作模式下的數(shù)據(jù)讀取方式。

            圖1所示的是由外部信號(hào)控制的轉(zhuǎn)換時(shí)序圖。在這種讀取數(shù)據(jù)的模式中,RD信號(hào)提前有效,可以獲得最快的轉(zhuǎn)換時(shí)間。一般RD在WR的上升沿250ns后變?yōu)榈?就可以完成轉(zhuǎn)換獲得數(shù)據(jù)。INT在RD的下降沿變?yōu)榈?之后,隨著RD或CS的上升沿而變?yōu)楦摺?

            2 MX7545的工作模式

            與一般的D/A轉(zhuǎn)換器一樣,MX7545也有電流和電壓兩種工作模式。其中,電流工作模式又分為單極性和雙極性兩種,這里只介紹單極性電流工作模式。

            不論是電流工和模式還是電壓工作模式,MX7545的工作時(shí)序是一樣的,如圖2所示。其中,MX7545在一個(gè)轉(zhuǎn)換周期內(nèi),片選信號(hào)CS有效時(shí)間tcs需要180ns,寫信號(hào)WR的有效時(shí)間tWR需要160ns。

            3 硬件接口

            根據(jù)汽車防撞雷達(dá)系統(tǒng)的要求,在發(fā)送三角波調(diào)頻信號(hào)的同時(shí)需采集雷達(dá)的回波信號(hào)。由于系統(tǒng)資源的限制,我們把A/D和D/A同時(shí)配置在TMSC30的擴(kuò)展總線上。TMSC30是TI公司的通用芯片,有很強(qiáng)的浮點(diǎn)/定點(diǎn)數(shù)據(jù)運(yùn)算能力和很高的處理速度,特別適合于實(shí)時(shí)數(shù)據(jù)采集及運(yùn)算處理(如FFT,FIR,IIR濾波等)。圖3是該接口的硬件連接圖。圖中,XA[8~10]為擴(kuò)展總線的地址線中的3條,經(jīng)過譯碼器(74LS138)譯碼后,其輸出Y1、Y2分別接到MX7545和MAX153的片選信號(hào)(CS)端,分別作為他們的片選信號(hào)。RD/WR為TMS320C30擴(kuò)展總線的讀寫控制信號(hào),IOSTRB為擴(kuò)展總線的選通脈沖,XD[0~11]為擴(kuò)展總線的數(shù)據(jù)總線。A/D和D/A的讀寫信號(hào)由的擴(kuò)展總線的讀寫信號(hào)和選通信號(hào)來決定,它們的關(guān)系可由下式表示:

            /WR=RD/WR+IOSTRB

            /RD=RD/WR+IOSTRB

            當(dāng)A/D工作時(shí),Y2尋址選中MAX153。DSP的寫信號(hào)有效時(shí),A/D轉(zhuǎn)換啟動(dòng);DSP的讀信號(hào)有效時(shí),A/D輸出數(shù)據(jù)。當(dāng)D/A工作時(shí),Y1尋址使MX7545有效。DSP的寫信號(hào)有效時(shí),D/A轉(zhuǎn)換啟動(dòng)。MAX153工作于最快的轉(zhuǎn)換方式,口地址是;MAX7545工作于通用的單極性電流工作模式,口地址是804100。從圖中可以看出,其硬件電路是較為簡單的。

            4 時(shí)序的配合和程序的編制

            下面將介紹D/A的通用電流工作模式下和A/D在最快工作模式下與TMS320C30 DSP接口的時(shí)序配合問題。

            4.1 時(shí)序配合問題

            從系統(tǒng)硬件電路的接法和工作時(shí)序上,可以分析啟動(dòng)轉(zhuǎn)換和讀取數(shù)據(jù)的時(shí)序關(guān)系。一個(gè)假寫操作便可使A/D的/WR有效,即可啟動(dòng)轉(zhuǎn)換。就DSP的擴(kuò)展總線的信號(hào)線IOSTRB選通的端口而言,讀寫都需兩個(gè)時(shí)鐘周期。當(dāng)DSP采用33.3MHz的時(shí)鐘時(shí),每個(gè)時(shí)鐘周期H1為60ns(即主時(shí)鐘的二分頻)。從圖1可見,啟動(dòng)轉(zhuǎn)換時(shí)間tWR的最小需要250ns,故需要插入總線等待周期。若插入4個(gè)等待周期,此時(shí)tWR為60×5=300ns,除去高速譯碼器的傳輸延遲17ns,實(shí)際WR的脈沖寬度遠(yuǎn)大于MAX153所規(guī)定的tWR的最小脈寬250ns,因而啟動(dòng)A/D轉(zhuǎn)換是可靠的。

            由圖1可知,MAX153要求的轉(zhuǎn)換時(shí)間tRD須大于250ns,故這里需要加入300ns的延遲時(shí)間,此時(shí)讀取A/D轉(zhuǎn)換的數(shù)據(jù)也是可靠的。接著讀取并轉(zhuǎn)換A/D數(shù)據(jù),然后向D/A送數(shù)據(jù)。從圖2可以看出,tCS至少需要180ns,tWR至少需要160ns,故設(shè)置4個(gè)總線等待周期也是完全可滿足要求的。

           4.2 匯編程序編寫

            由于此電路用于汽車防撞雷達(dá)信號(hào)的采集和處理系統(tǒng)中,故此電路應(yīng)完成的功能是:在發(fā)送雷達(dá)所需的三角波的同時(shí)采集雷達(dá)的回波信號(hào),即二者須同時(shí)完成。具體程序如下:


          上一頁 1 2 下一頁

          關(guān)鍵詞: 320C 7545 DSP 320

          評(píng)論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();