當(dāng)前位置:首頁 > 工業(yè)控制 > 電子設(shè)計(jì)自動(dòng)化

  引 言

  串行外圍設(shè)備接口(Serial Peripheral Interface,SPI)總線技術(shù)是Motorola公司推出的一種高速同步串行輸入/輸出接口,近年來廣泛應(yīng)用于外部移位寄存器、D/A轉(zhuǎn)換器、 A/D轉(zhuǎn)換器、串行EEPROM、LED顯示器等外部設(shè)備的拓展。SPI總線是一種三線同步總線(CLK、SI-MO、SOMI),可以共享,便于組成帶多個(gè)SPI接口的控制系統(tǒng)。其傳輸速率可編程,連接線少,具有良好的拓展性。

  ADS1178是一款典型的具有SPI接口的A/D轉(zhuǎn)換器,它可以方便地與帶有SPI接口的處理器或控制器相連接。OMAP-L137是一款處理能力強(qiáng)、外接存儲(chǔ)空間大、集成度高、外設(shè)管理方便的新型工控芯片。

  目前,ADS1178與OMAP-L137的數(shù)據(jù)通信主要通過SPI接口直接連接實(shí)現(xiàn)。通過配置,使OMAP-L137工作在主模式,ADS1178工作在從模式,由OMAP-L137提供用來進(jìn)行數(shù)據(jù)傳輸?shù)臅r(shí)鐘。但是,采用此模式結(jié)合EDMA進(jìn)行數(shù)據(jù)接收時(shí),每接收一組采樣數(shù)據(jù)都需要通過中斷來改變接收數(shù)據(jù)的存放地址,即完成N組數(shù)據(jù)的接收需要N個(gè)中斷來完成,這會(huì)給系統(tǒng)的資源管理帶來很大的麻煩。

  本設(shè)計(jì)使OMAP-L137、ADS1178的SPI接口工作在從模式,由CPLD作主片來提供進(jìn)行數(shù)據(jù)傳輸?shù)臅r(shí)鐘。在準(zhǔn)確、快速完成數(shù)據(jù)傳輸?shù)耐瑫r(shí),節(jié)省了處理器資源,方便了系統(tǒng)資源的管理。

  1 硬件設(shè)計(jì)

  1.1 芯片概述

  ADS1178是TI公司于2008年9月推出的一款A(yù)/D控制芯片,它采用△-∑模/數(shù)轉(zhuǎn)換器結(jié)構(gòu),可以達(dá)到16位的數(shù)據(jù)采集精度,并且擁有良好的交流特性。其帶寬達(dá)25 kHz,具有97 dB的信噪比和-105 dB的總諧波失真。在正常工作時(shí)每通道的功耗只有31 mW,支持8路通道同時(shí)采樣,并將數(shù)據(jù)依次連續(xù)地送上數(shù)據(jù)總線;在滿足實(shí)時(shí)同步采樣的同時(shí),還具有52 ksps的轉(zhuǎn)換速率。該芯片主要應(yīng)用于三相交流電的實(shí)時(shí)監(jiān)測(cè)、心電圖監(jiān)視器、質(zhì)量流量計(jì)、振動(dòng)系統(tǒng)的模態(tài)分析實(shí)驗(yàn)設(shè)計(jì),同時(shí)還支持SPI和幀同步兩種數(shù)據(jù)傳輸格式,并支持A/D間的級(jí)聯(lián)。

  OMAP-L137是TI司推出的針對(duì)工業(yè)控制領(lǐng)域的雙核處理器,它綜合了ARM和DSP兩個(gè)處理器各自在實(shí)時(shí)性和計(jì)算精度上的優(yōu)勢(shì)。兩個(gè)處理器的主頻均達(dá)到300MFHz(DSP的處理速度高達(dá)2 400MIPS/1 800MFLOPS)??梢酝饨?個(gè)存儲(chǔ)空間EMIFA和EMIFB,并且在片上有著非常豐富的外設(shè)資源,主要針對(duì)工業(yè)應(yīng)用環(huán)境的控制提供了EHRPWM、ECAP、EQEP、 EMAC等模塊,并在各控制模塊和各接口之間采用EDMA3模塊進(jìn)行數(shù)據(jù)傳遞。這大大減輕了雙核處理器的負(fù)擔(dān),占用很少的處理器資源,同時(shí)在兩個(gè)處理器之間開辟了一塊128 KB的共享存儲(chǔ)空間,可以使數(shù)據(jù)在雙核之間快速地進(jìn)行交換。

  1.2 硬件原理

  在SPI從模式下,設(shè)計(jì)使OMAP-L137、ADS1178作從片,CPLD作主片來提供進(jìn)行數(shù)據(jù)傳輸?shù)臅r(shí)鐘。OMAP-L137的SPI接口支持3針、4針、5針三種傳輸模式,這里采用3針模式(即CLK、SIMO、SOMI)。OMAP- L137引出一個(gè)GPIO口作同步信號(hào)線SYCN,ADS1178的READY信號(hào)線送給CPLD用來產(chǎn)生采樣時(shí)鐘,硬件連接如圖1所示。CLK用來傳遞接收和發(fā)送數(shù)據(jù)時(shí)的同步時(shí)鐘信號(hào),SIMO在OMAP-L137作主片時(shí)為輸出數(shù)據(jù)線,在OMAP-L137作從片時(shí)為輸人數(shù)據(jù)線。SOMI在此模式下不被采用。

  OMAP-L137的SPI接口工作在從模式的配置如下:SPIGCR1寄存器的低2位配置為00,選擇SPI工作在從模式;通過配置SPIPC0和 SPIPC1寄存器來選擇采用的針模式和引腳的信號(hào)方向,這里選擇使能CLK、SIMO、SOMI三根信號(hào)線,并分別配置為輸入、輸入和輸出;配置 SPIFMT0寄存器先輸出每組數(shù)據(jù)的“大端MSB”,根據(jù)ADS1178手冊(cè)中對(duì)數(shù)據(jù)輸出時(shí)序的要求,配置數(shù)據(jù)在CLK信號(hào)的下降沿輸出,使CLK信號(hào)工作在13MHz,同時(shí)配置現(xiàn)在的數(shù)據(jù)總線為16位。SPI的參考配置如表1所列。

  在采樣數(shù)據(jù)送到OMAP-L137的SPI接口時(shí),可以啟動(dòng)EDMA模塊來對(duì)采樣數(shù)據(jù)進(jìn)行搬移。EDMA的觸發(fā)事件為SPI的每一通道數(shù)據(jù)(16位)的接收中斷,相當(dāng)于完成一組(8通道)數(shù)據(jù)的傳輸需要8個(gè)觸發(fā)事件。EDMA的參數(shù)相關(guān)配置如圖2所示。其中,OPT、DSTCINT、SRCCIND和 CCNT都需要根據(jù)應(yīng)用情況來進(jìn)行參數(shù)配置。

  2 軟件設(shè)計(jì)

  2.1 CPLD程序設(shè)計(jì)

  CPLD中主要實(shí)現(xiàn)ADS1178對(duì)數(shù)據(jù)格式的要求。在檢測(cè)到READY信號(hào)的電平變化后,以外部時(shí)鐘ECLK為時(shí)鐘基準(zhǔn),產(chǎn)生128個(gè)時(shí)鐘周期 (CLK)分別送給OMAP-L137和ADS1178,來完成8通道的數(shù)據(jù)傳輸。圖3為等效原理圖,CPLD程序流程如圖4所示。

  2.2 采樣程序設(shè)計(jì)

  代碼調(diào)試中的主要工作是測(cè)試同步采樣A/D的8路通道。SPI和EDMA的參考配置及使能在上面已經(jīng)完成。當(dāng)ADS1178開始數(shù)據(jù)采集時(shí),通過GPIO口由OMAP-L137先向ADS1178發(fā)送一個(gè)由低變高的同步信號(hào)來通知 ADS1178開始工作。當(dāng)ADS1178完成了數(shù)據(jù)轉(zhuǎn)換時(shí),向OMAP-L137發(fā)送一個(gè)由高到低的READ-Y信號(hào),通知OMAP-L137數(shù)據(jù)已經(jīng)準(zhǔn)備就緒,等待主芯片的時(shí)鐘將數(shù)據(jù)送到數(shù)據(jù)線上;并在CPLD送出采樣時(shí)鐘后,等待EDMA的數(shù)據(jù)接收中斷,當(dāng)中斷到來時(shí)完成數(shù)據(jù)的采集工作。采樣程序流程如圖5所示。

  3 系統(tǒng)測(cè)試

  通過示波器可以觀測(cè)到CLK(圖6中上面的曲線)和SIMO(圖6中下面的曲線)引腳的波形圖。采樣結(jié)果放在數(shù)組Adresult中,如圖7所示。

  從圖6和圖7中可以看出,采用SPI從模式的數(shù)據(jù)傳輸方法,可以通過CPLD上的程序設(shè)計(jì)得到128個(gè)連續(xù)的采樣時(shí)鐘,數(shù)據(jù)傳遞的連續(xù)性好,每組時(shí)鐘之間不存在時(shí)鐘間隔。在程序處理的后續(xù)階段,通過配置EDMA的接收事件就可以連續(xù)接收多組數(shù)據(jù),在數(shù)據(jù)全部接收到OMAP-L137中時(shí)觸發(fā)一次中斷便可完成接收工作,從而節(jié)省了處理器資源。

  4 結(jié) 論

  在OMAP-L137與ADS1178的實(shí)時(shí)采集數(shù)據(jù)傳遞問題上,采用SPI主模式進(jìn)行數(shù)據(jù)接收時(shí),每接收一組數(shù)據(jù)后都需要通過中斷資源來變更接收地址。而本文通過SPI從模式進(jìn)行數(shù)據(jù)接收,可以在接收完多組數(shù)據(jù)后僅用一次接收中斷便結(jié)束工作,節(jié)約了處理器資源,并且實(shí)際測(cè)試表明,傳輸數(shù)據(jù)的連續(xù)性和實(shí)時(shí)性較好。由此看出,采用SPI從模式配合CPLD來處理OMAP-L137與ADS1178數(shù)據(jù)通信問題無疑是一種很好的解決方案。

本站聲明: 本文章由作者或相關(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日 /美通社/ -- 英國汽車技術(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日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(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中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

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

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(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)與中國電影電視技術(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)閉