SPI 傳輸機制
從圖可以看出,主機和從機都有一個串行移位寄存器,主機通過向它的 SPI 串行寄存器寫入一個字節(jié)來發(fā)起一次傳輸。寄存器通過 MOSI
信號線將字節(jié)傳送給從機,從機也將自己的移位寄存器中的內(nèi)容通過 MISO 信號線返回給主機。這樣,兩個移位寄存器中的內(nèi)容就被交換。
外設(shè)的寫操作和讀操作是同步完成的。如果只進行寫操作,主機只需忽略接收到的字節(jié);反之,若主機要讀取從機的一個字節(jié),就必須發(fā)送一個空字節(jié)來引發(fā)從機的傳輸。
雖然 SPI 四線制支持讀寫同時進行,但實際上我們很多時候并不需要又讀又寫,見以下兩種情況(參考 BMA223 數(shù)據(jù)手冊):
注意:如下三幅圖示均為 CPOL=1,CPHA=1
1、主機向從機寫數(shù)據(jù)
主機發(fā)送先發(fā)送 8 bits,第一個 bit 為 0 代表這次主機是想寫數(shù)據(jù)到從機,AD6~AD0
表示要寫的寄存器地址。然后,主機就會一直寫下去。在這期間 SDO 一直沒用,一直是高阻態(tài),算是一直讀到1。
2、主機從從機讀數(shù)據(jù)
這種情況下,主機先發(fā)送 8 bits,第一位為 1 代表這次是讀,然后 AD6 ~ AD0 是想要讀的寄存器地址,然后 SDO 開始返回數(shù)據(jù)。
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
相關(guān)推薦
當主機發(fā)送一個連續(xù)的數(shù)據(jù)流時,有些外設(shè)能夠進行多字節(jié)傳輸.多數(shù)具有SPI接口的存儲芯片就以這種方式工作.在這種傳輸方式下,從機的片選端必須在整個傳輸過程中保持低電平.
發(fā)表于 09-05 11:09
?1.5w次閱讀
= 0x0000; /*選擇DMA通道0外設(shè)地址寄存器SPI1*/ DMA0PAD = (volatile u16) &SPI1BUF; /*DMA0傳輸計數(shù)設(shè)置*/ DMA0CNT
發(fā)表于 09-25 16:23
現(xiàn)在淘寶上大多數(shù)藍牙模塊都是通過串口傳輸的,但是傳輸的速度太慢,本人想找個藍牙開發(fā)模塊,可以支持SPI傳輸的,求推薦一個比較合適的藍牙模塊,謝謝
發(fā)表于 03-08 21:09
一般情況下,SPI模塊的最大時鐘頻率為系統(tǒng)時鐘頻率的1/2。雖然SPI的傳輸速率主要受限于CPU處理SPI數(shù)據(jù)的能力,但在同另一個非常高速率的SPI
發(fā)表于 08-07 06:13
); spi_set_cs(SPI,F(xiàn)ALSE); SPI->主 - > unprepare_transfer_hardware(SPI->主);打破;在連續(xù)
發(fā)表于 04-29 06:24
目錄(?)[-]SPI簡介SPI特點1采用主-從模式Master-Slave 的控制方式2采用同步方式Synchronous傳輸數(shù)據(jù)3數(shù)據(jù)交換Data Exchanges4 SPI有四
發(fā)表于 08-05 08:15
SPI總線的傳輸速度比IIC速度快,故通常追求速度常常采用硬件SPI進行傳輸數(shù)據(jù)。下面記錄了利用stm32cubeMx配置硬件SPI1,外設(shè)
發(fā)表于 08-11 06:04
一、前言最近因為需要讀取傳感器數(shù)據(jù),需要單片機發(fā)送命令,傳感器返回24位數(shù)據(jù),因為使用SPI傳輸數(shù)據(jù),雖然命令只有8位,但是必須發(fā)送24位數(shù)據(jù)才能獲得傳感器的24位數(shù)據(jù)。關(guān)于SPI的知識可...
發(fā)表于 01-13 06:34
SPI總線是一種應(yīng)用廣泛的短距離串行同步通信協(xié)議,針對SPI 總線數(shù)據(jù)不能進行遠距離傳輸的問題,本文介紹了采用RS-422/RS-485 通信協(xié)議,利用MAX3045 和MAX3093 芯片構(gòu)成RS-422/RS-4
發(fā)表于 08-18 15:17
?78次下載
基于SPI總線的無線數(shù)據(jù)傳輸系統(tǒng)設(shè)計
摘要: 通過基于SPI總線的無線數(shù)據(jù)通信設(shè)備,利用無線數(shù)據(jù)收發(fā)芯片NRF905和51單片機STC89C52RC進行設(shè)計,給出了無線數(shù)據(jù)傳輸系
發(fā)表于 03-13 11:42
?3785次閱讀
SPI傳輸模擬資料匯總
發(fā)表于 11-17 15:39
?7次下載
目錄(?)[-]SPI簡介SPI特點1采用主-從模式Master-Slave 的控制方式2采用同步方式Synchronous傳輸數(shù)據(jù)3數(shù)據(jù)交換Data Exchanges4 SPI有四
發(fā)表于 12-22 19:14
?9次下載
數(shù)據(jù)傳輸 SPI 的英文全稱為 Serial Peripheral Interface,顧名思義為串行外設(shè)接口。 SPI 是一種同步串行通信接口規(guī)范,主要應(yīng)用于嵌入式系統(tǒng)中的短距離通信。該接口由
發(fā)表于 07-21 10:03
?8764次閱讀
1、前言 在之前的 JVM 分析系列之類加載 提到過 Java SPI 機制,主要是類加載器反雙親委派的實現(xiàn)(第三方包不在指定jdk路徑,一般類加載器無法加載,需要特殊
發(fā)表于 10-08 15:03
?1152次閱讀
探索SPI單線傳輸模式:時鐘線與數(shù)據(jù)傳輸的簡化之道 在當今的嵌入式系統(tǒng)和微控制器通信中,串行外設(shè)接口(SPI)因其高速、全雙工和同步的特點而廣受歡迎。然而,隨著設(shè)備尺寸和復(fù)雜性的不斷減
發(fā)表于 05-28 18:26
?1173次閱讀
評論