當(dāng)前位置:首頁 > 單片機 > 單片機
[導(dǎo)讀]摘要:分析雙通道低成本A/D轉(zhuǎn)換器CS5550的接口特點,以ATmegal6單片機為例設(shè)計CS5550與單片機的接口電路。經(jīng)過對ATmegal6單片機SPI口的分析,詳細討論使用硬件SPI接口和軟件模擬SPI兩種方式的程序設(shè)計,并給出相應(yīng)的

摘要:分析雙通道低成本A/D轉(zhuǎn)換器CS5550的接口特點,以ATmegal6單片機為例設(shè)計CS5550與單片機的接口電路。經(jīng)過對ATmegal6單片機SPI口的分析,詳細討論使用硬件SPI接口和軟件模擬SPI兩種方式的程序設(shè)計,并給出相應(yīng)的軟件流程圖。最后對CS5550的兩種接口方式進行比較。
關(guān)鍵同:模數(shù)轉(zhuǎn)換器;CS5550;單片機;接口程序

    現(xiàn)代智能化儀器儀表中A/D轉(zhuǎn)換器和單片機是重要組成部分。串行MD轉(zhuǎn)換器的串口信號線數(shù)目較少,在數(shù)據(jù)采樣速率較低的系統(tǒng)中有利于降低硬件間連線的復(fù)雜度,節(jié)省單片機的接口資源。在CS5550的性能特點及其片上串行接口的基礎(chǔ)上,給出CS5550與單片機的接口程序設(shè)計方案。

1 CS5550的主要性能及接口特點
    CS5550是Cirrus Logic公司推出的一款雙通道低成本△-∑型A/D轉(zhuǎn)換器,內(nèi)部集成有2個△-∑A/D轉(zhuǎn)換器、2個放大器、1個串行接口以及1個溫漂為25 ppm/℃的2.5 V參考電壓源。CS5550在兩個通道上都具有24位寄存器,其中通道1具有13位有效位,通道2具有10位有效位口。
    CS5550片上集成有1個雙向數(shù)字串行接口,包括(片選信號)、SDI(數(shù)據(jù)輸入)、SDO(數(shù)據(jù)輸出)和SCLK(串行時鐘)4條控制線。該串口與標(biāo)準(zhǔn)SPI接口協(xié)議兼容,可與帶有SPI接口的單片機傳輸數(shù)據(jù)。另外,CS5550還有一個中斷輸出引腳,可通過配置其屏蔽寄存器(Mask Register)來設(shè)定中斷,并可通過軟件修改配置寄存器中的“IMODE IINV”位來決定中斷的產(chǎn)生方式(高/低電平或上升/下降沿有效)。

2 單片機的SPI接口與CS5550連接
    SPI接口是由Motorola公司最先推出的,目前很多型號的單片機都集成有SPI接口,如ATMEL公司的ATmega8、PIC公司的PICl6F877、Analog Devices公司的ADuC812等。用戶可使用單片機所提供的SPI接口與CS5550直接連接。這里以ATmegal6單片機為例討論使用單片機的SPI接口實現(xiàn)讀寫CS5550的操作。
2.1 ATmegal6的SPI接口及其與CS5550的連接
    ATmegal6單片機內(nèi)部的SPI接口可完成全雙工、3線同步數(shù)據(jù)傳輸。它支持主/從機操作模式,作為主機時具有倍速模式(CK/2);具有寫碰撞標(biāo)志檢測、傳輸結(jié)束中斷標(biāo)志、7種可編程的比特率,并可設(shè)置LSB或MSB首先發(fā)送。在實際使用該SPI接口時,需要將MOSI(主機輸出從機輸入)、MISO(主機輸入從機輸出)、SCK(串行時鐘)、(從機選擇)引腳依次與CS5550的SDI、SDO、SCLK、引腳相連,如圖1所示。


    ATmegal6單片機中與SPI接口相關(guān)的寄存器有3個: SPCR(SPI控制寄存器)、SPSR(SPI狀態(tài)寄存器)、SPDR(SPI數(shù)據(jù)寄存器)。其中,SPCR寄存器設(shè)置SPI接口的中斷、數(shù)據(jù)順序、主/從模式及串行時鐘的相關(guān)特性;而SPSR寄存器中包括有SPI中斷標(biāo)志位(SPIF)、寫碰撞標(biāo)志位和倍速模式選擇位,SPSR中的SPIF位將在SPI接口串行數(shù)據(jù)發(fā)送完成時置“l(fā)”,若此時用戶已使能SPI接口中斷且全局中斷被打開。則會產(chǎn)生SPI接口中斷。應(yīng)該指出的是,在SPI接口數(shù)據(jù)接收完成時該SPIF位不會被置“1”,即沒有接收結(jié)束標(biāo)志位。串行時鐘的產(chǎn)生由硬件自動完成;每當(dāng)有新數(shù)據(jù)寫入SPDR寄存器中,SPI接口會自動產(chǎn)生SCK信號將SPDR中的數(shù)據(jù)發(fā)送出去,同時將讀取的數(shù)據(jù)存入SPDR的緩沖寄存器中。
2.2軟件設(shè)計
    對CS5550的所有操作都是通過讀寫ATmegal6單片機的內(nèi)部寄存器來完成的。在使用單片機的SPI接口之前,要對其進行初始化。這里采用查詢方式來發(fā)送數(shù)據(jù),故將SPCR中的最高位SPIE置“0”,禁止中斷。使能SPI接口(SPE=1)。因CS5550的數(shù)據(jù)傳輸為MSB首先發(fā)送,故使DORD=O。將ATmegal6選擇為主機模式(MSTR=1)。選擇SPI工作模式0(CPOL=0,CPHA=0)。配置串行時鐘設(shè)置為單片機晶振頻率的1/16(SPRl=0,SPR0=1)。綜合以上對SPCR各位的分析,應(yīng)配置SPCR=Ox5l。另外還要對SPI接口相應(yīng)的引腳方向進行配置:定義MOSI為輸出、MISO為輸入(SPI主機模式下由硬件自動配置為輸入),SCLK為輸出、為輸出,SPI接口初始化后就可以與CS5550通信。
    由于直接采用單片機的SPI接口讀寫CS5550,字節(jié)中每一位的發(fā)送/接收均由硬件完成,這樣可簡化控制和數(shù)據(jù)采集程序:向CS5550發(fā)送命令字節(jié)時只需將其直接寫入SPDR寄存器即可;而讀取返回數(shù)據(jù)時只需讀取SPDR寄存器即可。為使SPI通信能夠可靠、穩(wěn)定地運行,這里有兩個問題需要注意:一個問題是在向SPDR寄存器寫數(shù)據(jù)之前,應(yīng)首先查詢SPSR寄存器中的SPIF位,以確保發(fā)送中的數(shù)據(jù)不會被新寫入的數(shù)據(jù)所破壞。用C語言編寫程序時可以使用類似的“while(!SPSR_SPIF):”的形式等待數(shù)據(jù)發(fā)送結(jié)束;另一個問題是,由于ATmegal6單片機的SPI接口無接收結(jié)束標(biāo)志位,在讀取SPDR寄存器之前應(yīng)插入延時程序以確保讀回數(shù)據(jù)的完整性和準(zhǔn)確性。該程序流程如圖2所示。

3 使用軟件模擬SPI接口
    在實際應(yīng)用中,可能會出現(xiàn)所選用的單片機沒有集成SPI接口或是SPI接口被其他功能所占用而又仍然需要使用SPI協(xié)議與外圍器件通信的情況,這時就必須采用軟件模擬的方式來實現(xiàn)SPI通信。一般來說,可以使用單片機的任何4個I/O接口與CS5550連接。但為便于與前一種方法(使用硬件SPI接口)進行比較,這里仍采用圖1所示的電路連接方式。在編寫SPI接口程序前,要對使用到的I/O端口進行配置:PB5為輸出(MOSI),PB6為輸入(MISO),PB7為輸出(SCK),PB4為輸出()。其中PB7端口初值為“0”,PB4端口初值為“l(fā)”。為了模擬SPI數(shù)據(jù)寄存器,這里定義3個unsigned char型變量SPI_transmit_buffer、SPI_receive_buffer和trans-mit_counter分別用來存放需要發(fā)送的數(shù)據(jù)、接收到的數(shù)據(jù)和已發(fā)送數(shù)據(jù)的位數(shù)。每一位數(shù)據(jù)的發(fā)送接收必須嚴(yán)格按照CS5550數(shù)據(jù)手冊上的時序要求來編寫,否則會造成數(shù)據(jù)傳輸錯誤。CS5550的讀寫時序如圖3所示。


    從圖3及其數(shù)據(jù)手冊中的相關(guān)說明可知。CS5550讀取SDI線上的命令發(fā)生在SCK的上升沿,而其會在SCK下降沿發(fā)生后20 ns(典型值)之內(nèi)將下一位數(shù)據(jù)發(fā)送到SDO線上。根據(jù)以上分析,可以得到圖4所示的SPI接口函數(shù)編寫流程。


    若仍以實現(xiàn)CS5550單次轉(zhuǎn)換、單片機讀取其數(shù)據(jù)寄存器為例,則CS5550的采集函數(shù)編寫流程圖與第3部分中的圖2相同,只需要利用這個軟件模擬的SPI接口函數(shù)替換前面流程中對SPDR寄存器的讀寫即可。

4 硬件設(shè)計與軟件模擬SPI接口的比較
    從上述討論看出,硬件SPI接口的工作獨立于CPU內(nèi)核,這使得SPI數(shù)據(jù)的收發(fā)與CPU內(nèi)核運算并行執(zhí)行,提高單片機的工作效率。由于數(shù)據(jù)的收發(fā)完全由硬件完成,軟件的編寫不涉及具體收發(fā)細節(jié),程序簡單、速度快。而采用軟件模擬實現(xiàn)SPI接口的方法則具有端口定義靈活、使用方便的特點。可以在不增加硬件成本的情況下,給不含SPI接口的單片機增加SPI通信功能。但軟件模擬SPI需要占用CPU處理時間,故一般只在通信數(shù)據(jù)量不太大的情況下使用。

5 結(jié)束語
    模數(shù)轉(zhuǎn)換器和單片機在智能化儀表的應(yīng)用廣泛,本文討論的CS5550與單片機的兩種接口方式具有普遍意義,對其他類似的設(shè)計提供參考。目前,以上兩種方法均已被應(yīng)用到某基于CS5550的工業(yè)測溫儀表中,取得較好效果。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

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

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉