當(dāng)前位置:首頁 > 智能硬件 > 智能硬件
[導(dǎo)讀]本文所進(jìn)行是為提高ADC轉(zhuǎn)換的精度、加快工作速度的研究,主要介紹AVR單片機的SPI與MAX187的接口設(shè)計,提供了軟件編程實現(xiàn)。

摘  要:本文所進(jìn)行是為提高ADC轉(zhuǎn)換的精度、加快工作速度的研究,主要介紹AVR單片機SPI與MAX187的接口設(shè)計,提供了軟件編程實現(xiàn)。
關(guān)鍵字:SPI、AVR單片機、MAX187

1、AVR單片機的SPI接口

    SPI(Serial Peripheral Interface---串行外設(shè)接口)總線系統(tǒng)是一種同步串行外設(shè)接口,允許MCU與各種外圍設(shè)備以串行方式進(jìn)行通信、數(shù)據(jù)交換,廣泛應(yīng)用于各種工業(yè)控制領(lǐng)域。基于此標(biāo)準(zhǔn),SPI系統(tǒng)可以直接于各個廠家生產(chǎn)的多種標(biāo)準(zhǔn)外圍器件直接接口。SPI接口通常包含有4根線:串行時鐘(SCK)、主機輸入/從機輸出數(shù)據(jù)線(MISO)、主機輸出/從機輸入數(shù)據(jù)線(MOSI)和低電平有效的從機選擇線SS。在從機選擇線SS使能的前提下,主機的SCK脈沖將在數(shù)據(jù)線上傳輸主/從機的串行數(shù)據(jù)。主/從機的典型連接圖如圖(1)所示: 
           
                      圖(1)主/從機的連接圖

    串行外設(shè)接口SPI允許ATmega16和外設(shè)之間進(jìn)行高速的同步數(shù)據(jù)傳輸。ATmega16 SPI的特點如下:全雙工,3線同步數(shù)據(jù)傳輸,主/從機操作,LSB首先發(fā)送或MSB首先發(fā)送,7種可編程的比特率,傳送中斷結(jié)束,寫碰撞標(biāo)志檢測,可以從閑置模式喚醒,作為主機時具有雙速模式(CK/2)。

    如圖(2)所示,系統(tǒng)包括兩個移位寄存器和一個主時鐘發(fā)生器。通過將需要的從機的SS引腳拉低,主機啟動一次通信過程。主機和從機將需要的數(shù)據(jù)放到相應(yīng)的移位寄存器,主機在SCK引腳上產(chǎn)生時鐘脈沖以交換數(shù)據(jù)。主機的數(shù)據(jù)從MOSI移出,從從機MISO移入。從機的數(shù)據(jù)從MISO移出,從從機MOSI移入。主機通過將從機的SS拉高實現(xiàn)與從機的同步。 
      

             圖(2)SPI 主機 - 從機的互連

    下面將介紹SPI的幾個特殊寄存器:

1.1   SPI的控制寄存器—SPCR


    SPIE 為SPI 中斷使能,置位后,只要 SPSR 寄存器的 SPIF 和 SREG 寄存器的全局中斷使能位置位,就會引發(fā)SPI 中斷。SPE 置位將使能 SPI,DORD 置位時數(shù)據(jù)的 LSB首先發(fā)送;否則數(shù)據(jù)的 MSB首先發(fā)送。MSTR置位時選擇主機模式,否則為從機。CPOL置位表示空閑 SCK 為高電平;否則空閑時 SCK為低電平。CPHA決定數(shù)據(jù)是在 SCK的起始沿采樣還是在 SCK 的結(jié)束沿采樣。通過對SPR1、SPR0進(jìn)行設(shè)計,確定主機的 SCK 速率。

1.2 SPI的狀態(tài)寄存器—SPSR

    SPIF 為中斷標(biāo)志位,串行發(fā)送結(jié)束后,SPIF 置位。若此時寄存器 SPCR 的SPIE 和全局中斷使能位置位,SPI中斷即產(chǎn)生。進(jìn)入中斷例程后SPIF將自動清零。在發(fā)送當(dāng)中對SPI數(shù)據(jù)寄存器SPDR寫數(shù)據(jù)將置位WCOL,SPI2X置位后 SPI 的速度加倍。

1.3   SPI的數(shù)據(jù)寄存器—SPDR 

    SPDR 數(shù)據(jù)寄存器為讀/寫寄存器,用來在寄存器文件 SPI移位寄存器之間傳輸數(shù)據(jù)。寫寄存器將啟動數(shù)據(jù)傳輸,讀寄存器將讀取寄存器的接收緩沖器。SPI 系統(tǒng)的發(fā)送方向只有一個緩沖器,而在接收方向有兩個緩沖器。也就是說,在發(fā)送時一定要等到移位過程全部結(jié)束后才能對 SPI 數(shù)據(jù)寄存器執(zhí)行寫操作。而在接收數(shù)據(jù)時,需要在下一個字符移位過程結(jié)束之前通過訪問SPI 數(shù)據(jù)寄存器讀取當(dāng)前接收到的字符。否則第一個字節(jié)將丟失。

    在本設(shè)計中所使用的串行ADC芯片,選用了MAXIM公司MAX187。在AVR單片機SPI主機的控制下,完成對MAX187轉(zhuǎn)換后的數(shù)據(jù)讀操作。

2、  MAX187的介紹

    MAX187是美信公司推出的12位A/D轉(zhuǎn)換芯片,內(nèi)部含有采樣/保持電路,單5 V操作電源,轉(zhuǎn)換速度為8.5μs,具有片上4.096 V參考電壓,模擬量輸入范圍為0~VBEF。三線串行接口,兼容SPI,QSPI,MicroWire總線。

    MAX187用采樣/保持電路和逐位比較寄存器將輸入的模擬信號轉(zhuǎn)換為12位的數(shù)字信號,其采樣/保持電路不需要外接電容。MAX187有2種操作模式:正常模式和休眠模式,將置為低電平進(jìn)入休眠模式,這時的電流消耗降到10μA以下。置為高電平或懸空進(jìn)入正常操作模式。 

    完整的操作時序如圖(3)所示。使用內(nèi)參考時,在電源開啟后,經(jīng)過20 ms后參考引腳的4.7μF電容充電完成,可進(jìn)行正常的轉(zhuǎn)換操作。A/D轉(zhuǎn)換的工作過程是:當(dāng)為低電平時,在下降沿MAX187的T/H電路進(jìn)入保持狀態(tài),并開始轉(zhuǎn)換,8.5μs后DOUT輸出為高電平作為轉(zhuǎn)換完成標(biāo)志。這時可在SCLK端輸入一串脈沖將結(jié)果從DOUT端移出,讀入單片機中處理。數(shù)據(jù)讀取完成后將置為高電平。要注意的是:在置為低電平啟動A/D轉(zhuǎn)換后,檢測到DOUT有效(或者延時8.5μs以上),才能發(fā)SCLK移位脈沖讀數(shù)據(jù),SCLK至少為13個。發(fā)完脈沖后應(yīng)將置為高電平。


圖(3)SPI/Microwire 串行接口時序圖 (CPOL = CPHA = 0)

3、  串行ADC接口設(shè)計與實現(xiàn)

    MAX187電源需要加去耦合電容,常見的方法是用一個4.7μF電容和一個0.1μF電容并聯(lián)。為保證采樣精度,最好將MAX187與單片機分開供電。4腳為參考端接一個4.7μF的電容,這是使用內(nèi)部4.096 V參考電壓方式。輸入模擬信號的電壓范圍為0~4.096 V,如模擬輸入電壓不在這個范圍要外加電路進(jìn)行電壓范圍的變換。MAX187只有一路模擬輸入通道,如輸入為多路信號,要外加多路模擬開關(guān)。如圖(4)所示,Vinp為模擬信號的輸入端,經(jīng)過MAX187轉(zhuǎn)換后得到12的數(shù)據(jù),通過SCLK、CS、DOUT分別與AVR單片機SPI的SCK、SS、MISO相接,在單片機的控制下對數(shù)據(jù)進(jìn)行讀取。


圖(4)MAX187的硬件接線圖

程序設(shè)計:

     程序采用ATmega16編制,在ATmanAvr環(huán)境下調(diào)試通過。程序的基本思想是:定義PB7腳為時鐘SCLK,PB6為數(shù)據(jù)DOUT,PB4為片選。片選有效后延時8.5μs以上確保轉(zhuǎn)換完成,在時鐘SCLK的作用下從數(shù)據(jù)輸出端讀出轉(zhuǎn)換的數(shù)據(jù)后存入兩個無符號字符變量中,將這2個字符變量拼成一個16位無符號整形變量作用函數(shù)返回值返回,返回值的低12位有效。

#define   ss     4    //PB4

#define   mosi   5    //PB5

#define   miso   6    //PB6

#define   sck    7    //PB7

PORTB = 0x4f; DDRB = 0xb0;//對PB口的初始化

void spi_init(void)

{

       SPSR = 0x0;

       SPCR = 0x50;

}

unsigned int  ADC_MAX187(void)

{

 static uint temp,temp1;

 PORTB&=~(1<<sck);

 PORTB&=~(1<<ss);

 delay_nus(10);      //延時10uS

 while(!PORTB&(1<<miso));

 SPDR=0x00;

 while(!SPSR&(1<<SPIF));

 PORTB&=~(1<<sck);

 temp=SPDR;

 temp=(uint)temp<<8;

 SPSR=0x00;

 while(!SPSR&(1<<SPIF));

 temp1=SPDR;

 temp=(uint)((temp|temp1)&0x7fff)>>3;

PORTB|=(1<<ss);

 return (temp);

}

4、  總結(jié)

    本系統(tǒng)充分利用了AVR單片機的SPI模塊和MAX187是具有兼容SPI串行接口的A/D轉(zhuǎn)換器。本設(shè)計的串行ADC接口具有體積小、速度快、精度高等優(yōu)點。適用于儀器儀表、傳感器、工程檢測等方面。

參考文獻(xiàn)

1、Atmel corporation.ATmega16L Datasheet [DBOL]. http://www.atmel.com
2、馬潮. ATmega128原理與開發(fā)應(yīng)用指南上.北京:北京航空航天大學(xué)出版社.2004
3、http://www.ouravr.com
本站聲明: 本文章由作者或相關(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)意到認(rèn)證的所有需求的工具,可用于創(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ù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

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