SPI (Serial Peripheral interface),顧名思義就是串行外圍設備接口。SPI是一種高速的,全雙工,同步的通信總線,并且在芯片的管腳上只占用四根線,節(jié)約了芯片的管腳,同時為PCB的布局上節(jié)省空間,提供方便,主要應用在 EEPROM,F(xiàn)LASH,實時時鐘,AD轉(zhuǎn)換器,還有數(shù)字信號處理器和數(shù)字信號解碼器之間。
SPI內(nèi)部簡明結構圖
關于SPI傳輸過程(下面由靈魂畫家作圖)
SPI包含四根線:
1、SS(Slave Select):片選信號線,當有多個SPI設備與MCU相連時,每個設備的這個片選信號線是與MCU單獨的引腳相連的,而其他SCK,MOSI,MISO線則為多個設備并聯(lián)到相同的SPI總線上,當SS信號線為低電平時,片選有效,開始SPI通信
2、SCK(Serial Clock):時鐘信號線,由主通信設備產(chǎn)生,不同的設備支持的時鐘頻率不一樣。
3、MOSI(Master Output,Slave Input):主設備輸出、從設備輸入引腳
4、MISO(Master Input,Slave Output):主設備輸入、從設備輸出引腳
關于SPI模式
根據(jù)SPI時鐘極性(CPOL)和時鐘相位(CPHA)配置的不同可分為4種模式
時鐘極性是指SPI通信設備處于空閑狀態(tài)時(或SPI通信開始時,即SS為低電平時),SCK的電平信號CPOL=0時,SCK空閑狀態(tài)為低電平,CPOL=1時則相反。
時鐘相位是指數(shù)據(jù)采樣的時刻,當CPHA=0時,MOSI或MISO數(shù)據(jù)線會在時鐘線第一個邊沿開始采樣(奇數(shù)邊沿)
當CPHA=1時,MOSI或MISO數(shù)據(jù)線會在時鐘線第二個邊沿開始采樣(偶數(shù)邊沿)
步驟分析:SS片選信號線拉低-->根據(jù)CPOL和CPHA進行數(shù)據(jù)采樣
stm32 SPI接口框圖
stm32 SPI配置過程
1、配置相關引腳的復用功能,使能SPIx時鐘
void GPIO_Init(GPIO_TypeDef* GPIOx, GPIO_InitTypeDef* GPIO_InitStruct);
2、初始化SPIx,設置SPIx工作模式
void SPI_Init(SPI_TypeDef* SPIx, SPI_InitTypeDef* SPI_InitStruct);
3、使能SPIx
void SPI_Cmd(SPI_TypeDef* SPIx, FunctionalState NewState);
4、SPI傳輸數(shù)據(jù)
void SPI_I2S_SendData(SPI_TypeDef* SPIx, uint16_t Data);
uint16_t SPI_I2S_ReceiveData(SPI_TypeDef* SPIx);
5、查看SPI傳輸狀態(tài)
FlagStatus SPI_I2S_GetFlagStatus(SPI_TypeDef* SPIx, uint16_t SPI_I2S_FLAG);
-
pcb
+關注
關注
4368文章
23492瀏覽量
409765 -
SPI
+關注
關注
17文章
1804瀏覽量
96010 -
AD轉(zhuǎn)換器
+關注
關注
4文章
250瀏覽量
42243
原文標題:stm32之SPI通信協(xié)議
文章出處:【微信號:mcugeek,微信公眾號:MCU開發(fā)加油站】歡迎添加關注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
STM32 SPI從機用DMA方式實現(xiàn)全雙工,數(shù)據(jù)在傳輸過程中就會CRC校驗失敗,為什么?
請問stm32 SPI DMA傳輸過程該如何操作?
STM32F103和STM32F030 SPI-miso配置不同點

STM32F1x HAL庫學習筆記(12)硬件 SPI 的配置

SPI的基本知識(偏向STM32中的SPI)

STM32 SPI配置及深入解析

關于STM32的SPI外設時鐘分頻對應的SCK速率

評論