資料介紹
SPI,是英語(yǔ)Serial Peripheral Interface的縮寫(xiě),顧名思義就是串行外圍設(shè)備接口。SPI,是一種高速的,全雙工,同步的通信總線(xiàn),并且在芯片的管腳上只占用四根線(xiàn),節(jié)約了芯片的管腳,同時(shí)為PCB的布局上節(jié)省空間,提供方便,正是出于這種簡(jiǎn)單易用的特性,現(xiàn)在越來(lái)越多的芯片集成了這種通信協(xié)議。
SPI是一個(gè)環(huán)形總線(xiàn)結(jié)構(gòu),由ss(cs)、sck、sdi、sdo構(gòu)成,其時(shí)序其實(shí)很簡(jiǎn)單,主要是在sck的控制下,兩個(gè)雙向移位寄存器進(jìn)行數(shù)據(jù)交換。
下面為一種情況例舉:
上升沿發(fā)送、下降沿接收、高位先發(fā)送。
上升沿到來(lái)的時(shí)候,sdo上的電平將被發(fā)送到從設(shè)備的寄存器中。
下降沿到來(lái)的時(shí)候,sdi上的電平將被接收到主設(shè)備的寄存器中。
假設(shè)主機(jī)和從機(jī)初始化就緒:并且主機(jī)的sbuff=0xaa (10101010),從機(jī)的sbuff=0x55 (01010101),下面將分步對(duì)spi的8個(gè)時(shí)鐘周期的數(shù)據(jù)情況演示一遍(假設(shè)上升沿發(fā)送數(shù)據(jù))。
這樣就完成了兩個(gè)寄存器8位的交換,上面的0--1表示上升沿、1--0表示下降沿,sdi、 sdo相對(duì)于主機(jī)而言的。根據(jù)以上分析,一個(gè)完整的傳送周期是16位,即兩個(gè)字節(jié),因?yàn)?,首先主機(jī)要發(fā)送命令過(guò)去,然后從機(jī)根據(jù)主機(jī)的名準(zhǔn)備數(shù)據(jù),主機(jī)在 下一個(gè)8位時(shí)鐘周期才把數(shù)據(jù)讀回來(lái)。
SPI總線(xiàn)是Motorola公司推出的三線(xiàn)同步接口,同步串行3線(xiàn)方式進(jìn)行通信:一條時(shí)鐘線(xiàn)SCK,一條數(shù)據(jù)輸入線(xiàn)MOSI,一條數(shù)據(jù)輸出線(xiàn)MISO; 用于 CPU與各種外圍器件進(jìn)行全雙工、同步串行通訊。SPI主要特點(diǎn)有:可以同時(shí)發(fā)出和接收串行數(shù)據(jù);可以當(dāng)作主機(jī)或從機(jī)工作;提供頻率可編程時(shí)鐘;發(fā)送結(jié)束 中斷標(biāo)志;寫(xiě)沖突保護(hù);總線(xiàn)競(jìng)爭(zhēng)保護(hù)等。
SPI總線(xiàn)有四種工作方式(SP0, SP1, SP2, SP3),其中使用的最為廣泛的是SPI0和SPI3方式。
SPI模塊為了和外設(shè)進(jìn)行數(shù)據(jù)交換,根據(jù)外設(shè)工作要求,其輸出串行同步時(shí)鐘極性和相位可以進(jìn)行配置,時(shí)鐘極性(CPOL)對(duì)傳輸協(xié)議沒(méi)有重大的影響。如果 CPOL=0,串行同步時(shí)鐘的空閑狀態(tài)為低電平;如果CPOL=1,串行同步時(shí)鐘的空閑狀態(tài)為高電平。時(shí)鐘相位(CPHA)能夠配置用于選擇兩種不同的傳 輸協(xié)議之一進(jìn)行數(shù)據(jù)傳輸。如果 CPHA=0,在串行同步時(shí)鐘的第一個(gè)跳變沿(上升或下降)數(shù)據(jù)被采樣;如果CPHA=1,在串行同步時(shí)鐘的第二個(gè)跳變沿(上升或下降)數(shù)據(jù)被采樣。 SPI主模塊和與之通信的外設(shè)音時(shí)鐘相位和極性應(yīng)該一致。
SPI接口在模式0下輸出第一位數(shù)據(jù)的時(shí)刻
SPI接口有四種不同的數(shù)據(jù)傳輸時(shí)序,取決于CPOL和CPHL這兩位的組合。圖1中表現(xiàn)了這四種時(shí)序,時(shí)序與CPOL、CPHL的關(guān)系也可以從圖中看出。
圖1
CPOL是用來(lái)決定SCK時(shí)鐘信號(hào)空閑時(shí)的電平,CPOL=0,空閑電平為低電平,CPOL=1時(shí),空閑電平為高電平。CPHA是用來(lái)決定采樣時(shí)刻的,CPHA=0,在每個(gè)周期的第一個(gè)時(shí)鐘沿采樣,CPHA=1,在每個(gè)周期的第二個(gè)時(shí)鐘沿采樣。
由于我使用的器件工作在模式0這種時(shí)序(CPOL=0,CPHA=0),所以將圖1簡(jiǎn)化為圖2,只關(guān)注模式0的時(shí)序。
圖2
我們來(lái)關(guān)注SCK的第一個(gè)時(shí)鐘周期,在時(shí)鐘的前沿采樣數(shù)據(jù)(上升沿,第一個(gè)時(shí)鐘沿),在時(shí)鐘的后沿輸出數(shù)據(jù)(下降沿,第二個(gè)時(shí)鐘沿)。首先來(lái)看主器件,主器件的輸出口(MOSI)輸出的數(shù)據(jù)bit1,在時(shí)鐘的前沿被從器件采樣,那主器件是在何時(shí)刻輸出bit1的呢?bit1的輸出時(shí)刻實(shí)際上在SCK信號(hào)有效以前,比 SCK的上升沿還要早半個(gè)時(shí)鐘周期。bit1的輸出時(shí)刻與SSEL信號(hào)沒(méi)有關(guān)系。再來(lái)看從器件,主器件的輸入口MISO同樣是在時(shí)鐘的前沿采樣從器件輸出的bit1的,那從器件又是在何時(shí)刻輸出bit1的呢。從器件是在SSEL信號(hào)有效后,立即輸出bit1,盡管此時(shí)SCK信號(hào)還沒(méi)有起效。關(guān)于上面的主器件和從器件輸出bit1位的時(shí)刻,可以從圖3、4中得到驗(yàn)證。
圖3
注意圖3中,CS信號(hào)有效后(低電平有效,注意CS下降沿后發(fā)生的情況),故意用延時(shí)程序延時(shí)了一段時(shí)間,之后再向數(shù)據(jù)寄存器寫(xiě)入了要發(fā)送的數(shù)據(jù),來(lái)觀察主器件輸出bit1的情況(MOSI)。
可以看出,bit1(值為1)是在SCK信號(hào)有效之前的半個(gè)時(shí)鐘周期的時(shí)刻開(kāi)始輸出的(與CS信號(hào)無(wú)關(guān)),到了SCK的第一個(gè)時(shí)鐘周期的上升沿正好被從器件采樣。
圖4
圖4中,注意看CS和MISO信號(hào)。我們可以看出,CS信號(hào)有效后,從器件立刻輸出了bit1(值為1)。
通常我們進(jìn)行的spi操作都是16位的。圖5記錄了第一個(gè)字節(jié)和第二個(gè)字節(jié)間的相互銜接的過(guò)程。
第一個(gè)字節(jié)的最后一位在SCK的上升沿被采樣,隨后的SCK下降沿,從器件就輸出了第二個(gè)字節(jié)的第一位。
SPI總線(xiàn)協(xié)議介紹(接口定義,傳輸時(shí)序)
一、技術(shù)性能
SPI接口是Motorola 首先提出的全雙工三線(xiàn)同步串行外圍接口,采用主從模式(Master Slave)架構(gòu);支持多slave模式應(yīng)用,一般僅支持單Master。
時(shí)鐘由Master控制,在時(shí)鐘移位脈沖下,數(shù)據(jù)按位傳輸,高位在前,低位在后(MSB first);SPI接口有2根單向數(shù)據(jù)線(xiàn),為全雙工通信,目前應(yīng)用中的數(shù)據(jù)速率可達(dá)幾Mbps的水平。
二、接口定義
SPI接口共有4根信號(hào)線(xiàn),分別是:設(shè)備選擇線(xiàn)、時(shí)鐘線(xiàn)、串行輸出數(shù)據(jù)線(xiàn)、串行輸入數(shù)據(jù)線(xiàn)。
(1)MOSI:主器件數(shù)據(jù)輸出,從器件數(shù)據(jù)輸入
(2)MISO:主器件數(shù)據(jù)輸入,從器件數(shù)據(jù)輸出
(3)SCLK :時(shí)鐘信號(hào),由主器件產(chǎn)生
(4)/SS:從器件使能信號(hào),由主器件控制
三、內(nèi)部結(jié)構(gòu)
四、傳輸時(shí)序
SPI接口在內(nèi)部硬件實(shí)際上是兩個(gè)簡(jiǎn)單的移位寄存器,傳輸?shù)臄?shù)據(jù)為8位,在主器件產(chǎn)生的從器件使能信號(hào)和移位脈沖下,按位傳輸,高位在前,低位在后。如下圖所示,在SCLK的下降沿上數(shù)據(jù)改變,上升沿一位數(shù)據(jù)被存入移位寄存器。
SPI接口沒(méi)有指定的流控制,沒(méi)有應(yīng)答機(jī)制確認(rèn)是否接收到數(shù)據(jù)。
本文轉(zhuǎn)載自:
聲明:本文為轉(zhuǎn)載文章,轉(zhuǎn)載此文目的在于傳遞更多信息,版權(quán)歸原作者所有,如涉及侵權(quán),請(qǐng)聯(lián)系小編郵箱: 進(jìn)行處理。
(mbbeetchina)
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- SPI總線(xiàn)協(xié)議及SPI時(shí)序圖詳解
- spi協(xié)議介紹
- 基于FPGA與MCU通信的SPI協(xié)議設(shè)計(jì)
- 各種USB接口類(lèi)型傳輸協(xié)議匯總資料下載
- 基于SPI協(xié)議的SD卡讀寫(xiě)說(shuō)明 49次下載
- MDB接口總線(xiàn)通訊協(xié)議中文版資料免費(fèi)下載 0次下載
- 如何使用單片機(jī)模擬SPI時(shí)序代碼免費(fèi)下載
- SPI總線(xiàn)協(xié)議的詳細(xì)資料介紹和程序免費(fèi)下載
- SPI總線(xiàn)協(xié)議和SPI時(shí)序圖的詳細(xì)資料講解 46次下載
- SPI總線(xiàn)接口實(shí)現(xiàn)數(shù)據(jù)傳輸的實(shí)現(xiàn)方法 8次下載
- SPI總線(xiàn)協(xié)議介紹 17次下載
- SPI總線(xiàn)簡(jiǎn)介與參考實(shí)例 55次下載
- 用SPI總線(xiàn)實(shí)現(xiàn)DSP和MCU之間的高速通信
- SPI總線(xiàn)數(shù)據(jù)遠(yuǎn)距離傳輸實(shí)現(xiàn)
- 基于PC/104 總線(xiàn)與CPLD 的SPI 接口設(shè)計(jì)
- UART通信協(xié)議介紹和數(shù)據(jù)傳輸工作流程 883次閱讀
- 淺談SPI總線(xiàn)通信接口及其協(xié)議 1851次閱讀
- 一文介紹SPI串行總線(xiàn) 3003次閱讀
- 多種SPI總線(xiàn)隔離設(shè)計(jì)方案 1.3w次閱讀
- 詳解SPI總線(xiàn)協(xié)議與時(shí)序圖 1.4w次閱讀
- AXI總線(xiàn)協(xié)議的幾種時(shí)序介紹 1.1w次閱讀
- 嵌入式硬件通信接口協(xié)議中的串行通信接口-SPI 1654次閱讀
- 串行外設(shè)接口SPI通信協(xié)議的應(yīng)用 1900次閱讀
- SPI接口之間數(shù)據(jù)傳輸中故障分析 9197次閱讀
- spi與i2c總線(xiàn)有什么區(qū)別 4.1w次閱讀
- 面向接口的編程——SPI總線(xiàn)和IIC總線(xiàn) 8692次閱讀
- SPI、I2C、UART三種串行總線(xiàn)協(xié)議的區(qū)別和SPI接口介紹,以及SPI接口詳解 7.2w次閱讀
- 《振南電子STM32視頻教程》第十一講:SPI總線(xiàn) 1448次閱讀
- 帶你詳細(xì)解析串行外設(shè)接口(SPI)總線(xiàn)時(shí)序 7350次閱讀
- 支持單線(xiàn)SPI接口的燒錄技術(shù)實(shí)現(xiàn) 5142次閱讀
下載排行
本周
- 1TC358743XBG評(píng)估板參考手冊(cè)
- 1.36 MB | 330次下載 | 免費(fèi)
- 2開(kāi)關(guān)電源基礎(chǔ)知識(shí)
- 5.73 MB | 11次下載 | 免費(fèi)
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設(shè)計(jì)
- 0.60 MB | 3次下載 | 免費(fèi)
- 5DIY動(dòng)手組裝LED電子顯示屏
- 0.98 MB | 3次下載 | 免費(fèi)
- 6基于FPGA的C8051F單片機(jī)開(kāi)發(fā)板設(shè)計(jì)
- 0.70 MB | 2次下載 | 免費(fèi)
- 751單片機(jī)PM2.5檢測(cè)系統(tǒng)程序
- 0.83 MB | 2次下載 | 免費(fèi)
- 8基于51單片機(jī)的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33566次下載 | 免費(fèi)
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費(fèi)
- 4開(kāi)關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21549次下載 | 免費(fèi)
- 5電氣工程師手冊(cè)免費(fèi)下載(新編第二版pdf電子書(shū))
- 0.00 MB | 15349次下載 | 免費(fèi)
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費(fèi)
- 7電子制作實(shí)例集錦 下載
- 未知 | 8113次下載 | 免費(fèi)
- 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德?tīng)栔?/a>
- 0.00 MB | 6656次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537797次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420027次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191186次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183279次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138040次下載 | 免費(fèi)
評(píng)論