0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

一文講透SPI總線和IIC總線通信2

jf_78858299 ? 來源:金沙灘工作室 ? 作者:宋雪松 ? 2023-02-13 10:40 ? 次閱讀

66.6 邏輯分析儀測試UART和IIC

在實際開發(fā)過程中,大多數(shù)情況下程序代碼并不是一寫出來就可以正常運行,通常需要查找問題,調(diào)試功能。在單片機內(nèi)部運行的變量和寄存器參數(shù)可以通過在線仿真的方法查看,而單片機外部引腳的運行就要使用示波器或邏輯分析儀來查看了。在分析數(shù)字信號以及標(biāo)準(zhǔn)協(xié)議信號方面,邏輯分析儀的分析功能比示波器更優(yōu)一些,下面就采用Kingst LA5016邏輯分析儀,針對6.5節(jié)的程序,將UART和I2C信號進行抓取分析。

UART數(shù)據(jù)抓取和解析解碼的界面如圖6-6所示,從圖上可以看出,單個脈沖T1到T2之間的時間差是104us,時間差的倒數(shù)就是波特率,也就是9600。當(dāng)沒有信號的時候,通道處于高電平,產(chǎn)生第1個低電平就是起始位,而后是8位數(shù)據(jù)位,最后是停止位,其中數(shù)據(jù)位的位置軟件都加了白點。最終,軟件根據(jù)協(xié)議設(shè)置選項將數(shù)據(jù)解析出來是0x31,0x32......。

圖片

圖6-6 Kingst LA5016邏輯分析儀解析UART數(shù)據(jù)

當(dāng)串口助手發(fā)送讀數(shù)據(jù)指令,讀到的數(shù)據(jù)不正確的時候,首先我們要判斷一下是單片機發(fā)送錯了,還是電腦接收錯了,這個時候可以通過分析儀測量一下UART串口通信波形以及解析的數(shù)據(jù)來判斷。如果分析儀抓到的都正確,那就說明發(fā)送正確,接收方出現(xiàn)問題。

如果分析儀抓取分析的數(shù)據(jù),不是單片機想發(fā)送的數(shù)據(jù),那說明發(fā)送錯了。既然發(fā)送錯了,要么是程序問題,要么是從EEPROM讀取的數(shù)據(jù)錯了。這個時候需要抓一下從EEPROM讀到的數(shù)據(jù)。采集分析完從EEPROM讀到的數(shù)據(jù),如果數(shù)據(jù)正確,那問題可能就出在了讀數(shù)據(jù)后轉(zhuǎn)成UART發(fā)送給電腦的程序過程中;如果數(shù)據(jù)是錯誤的,那要么是存入EEPROM本來就是錯誤的,要么是存入正確,讀取EEPROM的程序是錯誤的,如圖6-7所示。

圖片

圖6-7 Kingst LA5016邏輯分析儀解析IIC數(shù)據(jù)

在圖6-7當(dāng)中,其中通道0是SCL,通道1是SDA。圖中可以看出讀寫時序圖,并且可以將讀寫的數(shù)據(jù)解析出來,用來判斷出從EEPROM讀取的數(shù)據(jù)是否有錯。

76.7 初識SPI總線協(xié)議

SPI(Serial Peripheral Interface)是一種高速的、全雙工、同步通信總線,常用于單片機和EEPROM、FLASH、實時時鐘、數(shù)字信號處理器等器件的通信。由于其簡單實用,數(shù)據(jù)傳輸速率較高,被廣泛應(yīng)用于外設(shè)控制領(lǐng)域。標(biāo)準(zhǔn)的SPI接口一般使用4條線:串行時鐘線(SCK)、主機輸入/從機輸出數(shù)據(jù)線(MISO)、主機輸出/從機輸入數(shù)據(jù)線(MOSI)和從機選擇線(CS,也被稱作SSEL或NSS)。SPI總線允許一對一或一對多通信,無論哪種方式,通信線路中只允許有一個主機。一對多通信要求從機共用SCK、MISO、MOSI,通過片選CS(NSS)選擇使能從機設(shè)備。從微觀角度上看主機一次只能與一個從機通信,比如主機先與從機1通信,然后再與從機2通信,如此循環(huán),在宏觀角度上看就相當(dāng)于一個主機與兩個從機實現(xiàn)通信,如圖6-8所示。

圖片

圖6-8 SPI接口連接示意圖

6.7.1 SPI通信原理

SPI總線與前面講的IIC總線類似,都屬于同步通信,即通信雙方時必須使用相同的時鐘信號;都屬于一主多從結(jié)構(gòu),即總線上只有一個主機,可以掛載多個從機。不同之處在于,IIC屬于單工通信,同一時刻只能收或者發(fā),而SPI可以全雙工通信,同一時刻既能收又能發(fā),因此SPI的通信速率遠(yuǎn)遠(yuǎn)超過IIC,可以達(dá)到幾十Mbps。此外IIC通信可以由主從設(shè)備的任意一方發(fā)起,而SPI通信只能由主機發(fā)起,從機不能主動與主機通信,因為從機不產(chǎn)生同步時鐘信號。

SPI通信本質(zhì)上是一個串行移位過程。SPI主從設(shè)備構(gòu)成一個環(huán)形總線結(jié)構(gòu),SPI通信的主機一般是單片機,首先主機拉低CS(NSS)信號使能片選,告訴從機開始通信,然后主機開始輸出同步時鐘信號SCK,主機的移位寄存器通過MOSI移出1位數(shù)據(jù),從機的移位寄存器通過該線移入這1位數(shù)據(jù);同時從機的移位寄存器又通過MISO線移出1位數(shù)據(jù),主機的移位寄存器通過該線移入這1位數(shù)據(jù),因此在1個時鐘周期內(nèi),主從設(shè)備的雙向移位寄存器通過MOSI和MISO數(shù)據(jù)線實現(xiàn)了1 bit數(shù)據(jù)的交換,即雙方都發(fā)出并接收到1 bit數(shù)據(jù)。

6.7.2 SPI通信模式

I^2^C總線只有一種通信模式,即當(dāng)SCL在低電平的時候,向SDA輸出數(shù)據(jù),當(dāng)SCL在高電平的時候,對SDA上的數(shù)據(jù)進行采樣。與I^2^C不同的是,SPI總線有四種通信模式,要了解這四種模式,首先我們得學(xué)習(xí)以下兩個名詞。

CPOL: Clock Polarity,就是時鐘的極性。時鐘的極性是什么概念呢?通信的整個過程分為空閑時刻和通信時刻,如果CPOL=1,那么SCLK在數(shù)據(jù)發(fā)送之前和之后的空閑狀態(tài)是高電平,如果CPOL=0,那么SCK煩人空閑狀態(tài)就是低電平。

CPHA: Clock Phase,意思是時鐘的相位,就是指數(shù)據(jù)采樣發(fā)生在第幾個時鐘邊沿, CPHA =0對應(yīng)著第一個時鐘邊沿,CPHA =1對應(yīng)著第二個時鐘邊沿。

主機和從機要交換數(shù)據(jù),就牽涉到一個問題,即主機在什么時刻輸出數(shù)據(jù)到MOSI上而從機在什么時刻采樣這個數(shù)據(jù),或者從機在什么時刻輸出數(shù)據(jù)到MISO上而主機什么時刻采樣這個數(shù)據(jù)。同步通信的一個特點就是所有數(shù)據(jù)的變化和采樣都是伴隨著時鐘沿進行的,也就是說數(shù)據(jù)總是在時鐘的邊沿附近輸出或被采樣。而一個時鐘周期必定包含了一個上升沿和一個下降沿,這是周期的定義所決定的,只是這兩個沿的先后并無規(guī)定。又因為數(shù)據(jù)從產(chǎn)生的時刻到其穩(wěn)定是需要一定時間的,那么,如果主機在上升沿輸出數(shù)據(jù)到MOSI上,從機就只能在下降沿去采樣這個數(shù)據(jù)了。反之如果一方在下降沿輸出數(shù)據(jù),那么另一方就必須在上升沿采樣這個數(shù)據(jù)。

CPHA=0,就表示數(shù)據(jù)的采樣是在一個時鐘周期的第一個沿上,至于這個沿是上升沿還是下降沿,這要視CPOL的值而定,CPOL=1那就是下降沿,反之就是上升沿。那么數(shù)據(jù)的采樣自然就是在第二個沿上了。

CPHA=1,就表示數(shù)據(jù)的采樣是在一個時鐘周期的第二個沿上,同樣它是什么沿由CPOL決定。CPOL=1那就是上升沿,反之就是下降沿。

以CPOL=1/CPHA=1,高位在前為例,把時序圖畫出來給大家看一下,如圖6-9所示。

圖片

圖6-9 SPI通信時序圖(一)

如圖6-10所示,當(dāng)數(shù)據(jù)未發(fā)送時以及發(fā)送完畢后,由于CPOL=1,因此SCK都是高電平??梢钥闯觯赟CK第一個沿的時候,MOSI和MISO會發(fā)生變化,同時SCK第二個沿的時候,數(shù)據(jù)是穩(wěn)定的,此刻采樣數(shù)據(jù)是合適的,即一個時鐘周期的后沿鎖存并讀取數(shù)據(jù),即CPHA=1。

注意最后最隱蔽的SSEL片選,這個引腳通常用來決定主機是和哪個從機進行通信。剩余的三種模式,直接把圖畫出來,簡化起見把MOSI和MISO合在一起了,可以通過仔細(xì)對比加深對SPI通信的理解,SPI剩余三種模式時序如圖6-8所示。

需要解釋一下CPHA=0時的兩種模式時序圖,圖中數(shù)據(jù)采樣發(fā)生在數(shù)據(jù)輸出之前,可能會存在疑問,主機和從機還未輸出數(shù)據(jù)就進行采樣?圖中所示的數(shù)據(jù)輸出指的是輸出第二位數(shù)據(jù),即圖中所示bit 6 位的數(shù)據(jù)。那么被采樣的數(shù)據(jù)位是什么時候輸出的?其實早在SCK信號由空閑狀態(tài)轉(zhuǎn)變?yōu)橛行顟B(tài)之前,即在SCK的第一個時鐘邊沿還要早半個時鐘周期時,SPI主機就已經(jīng)開始輸出數(shù)據(jù)了,但是SPI從機卻是在片選SSEL置低后開始輸出數(shù)據(jù),總之SPI設(shè)備輸出數(shù)據(jù)要早于SCK,這也是為什么SPI通信時要先使能片選。

圖片

圖6-10 SPI通信時序圖(二)

86.8 配置STM32的SPI外設(shè)

STM32單片機的SPI接口允許芯片與外部設(shè)備以半/全雙工、同步、串行方式通信。此接口可以被配置成主模式或從模式,當(dāng)被配置為主模式時,可以為外部從設(shè)備提供通信時鐘信號(SCK)。SPI接口擁有8個主模式波特率預(yù)分頻系數(shù)(最大為f PCLK /2,fPCL~~K為掛載SPI外設(shè)的APBx的時鐘頻率)。需要說明的一點,由于APB1的最高頻率是36Mhz,APB2的最高頻率是72Mhz,SPI波特率預(yù)分頻系數(shù)為2時,位于APB2上的SPI外設(shè)理論上最大速率是36MHz,但是實際上由于STM32F103的硬件限制,SPI的最大速率只能達(dá)到18Mhz(選型手冊也有介紹)。此外,SPI接口還支持硬件的CRC校驗,保證通信的可靠性。

6.8.1 SPI引腳

在配置STM32的SPI模塊為主機模式時,MOSI引腳是數(shù)據(jù)輸出,而MISO引腳是數(shù)據(jù)輸入。當(dāng)被配置為從機模式時 MOSI引腳則是數(shù)據(jù)輸入,MISO引腳是數(shù)據(jù)輸出。因此通信時主從設(shè)備的MOSI兩兩相連,MISO兩兩相連,此外還需要連接SCK和CS(NSS)引腳。

圖片

注意:SPI3模塊部分引腳與 JTAG引腳共用,這些引腳不受IO控制器控制,它們(復(fù)位后)被默認(rèn)保留為JTAG用途。如果想把引腳配置給SPI3,必須在初始化引腳時關(guān)閉JTAG并切換SWD接口,代碼為:

GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable, ENABLE);

// JTAG-DP 失能 + SW-DP 使能指令。

NSS:從設(shè)備選擇。作為“片選引腳”,這是一個可選的引腳,使得主設(shè)備可以單獨地與特定從設(shè)備通訊,避免數(shù)據(jù)線上的沖突。從設(shè)備的NSS引腳可以由主設(shè)備的一個標(biāo)準(zhǔn)I/O引腳來驅(qū)動,不一定非要SPI外設(shè)的NSS引腳,采用普通IO口作為NSS引腳時需要設(shè)置NSS引腳模式為軟件NSS模式。Kingst-32F1開發(fā)板SPI2接口與多路設(shè)備通信,其從機的NSS引腳就是STM32的幾個普通I/O口,后續(xù)用到再詳細(xì)介紹。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 單片機
    +關(guān)注

    關(guān)注

    6040

    文章

    44594

    瀏覽量

    636941
  • SPI
    SPI
    +關(guān)注

    關(guān)注

    17

    文章

    1717

    瀏覽量

    91852
  • EEPROM
    +關(guān)注

    關(guān)注

    9

    文章

    1027

    瀏覽量

    81783
  • IIC
    IIC
    +關(guān)注

    關(guān)注

    11

    文章

    302

    瀏覽量

    38407
  • uart
    +關(guān)注

    關(guān)注

    22

    文章

    1242

    瀏覽量

    101547
收藏 人收藏

    評論

    相關(guān)推薦

    詳解IIC總線

    IIC(Inter-Integrated Circuit)集成電路總線,它是種兩線式串行通信總線,又叫I
    發(fā)表于 06-07 15:38 ?9953次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>詳解<b class='flag-5'>IIC</b><b class='flag-5'>總線</b>

    詳解IIC總線

    IIC(Inter-Integrated Circuit)是個多主從的串行總線,又叫I2C,是由飛利浦公司發(fā)明的通訊總線,屬于半雙工同步傳
    發(fā)表于 09-12 11:15 ?2316次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>詳解<b class='flag-5'>IIC</b><b class='flag-5'>總線</b>

    SPI總線學(xué)習(xí)筆記

    SPI種全雙工的串行通信總線,最早由Motorola提出,雖然應(yīng)用廣泛,但沒有個統(tǒng)
    發(fā)表于 09-20 15:17 ?1137次閱讀
    <b class='flag-5'>SPI</b><b class='flag-5'>總線</b>學(xué)習(xí)筆記

    IIC總線SPI總線的比較

    現(xiàn)今,在低端數(shù)字通信應(yīng)用領(lǐng)域,我們隨處可見IIC (Inter-Integrated Circuit) 和 SPI (Serial Peripheral Interface)的身影。原因是這兩種
    發(fā)表于 09-26 09:30 ?2676次閱讀
    <b class='flag-5'>IIC</b><b class='flag-5'>總線</b>和<b class='flag-5'>SPI</b><b class='flag-5'>總線</b>的比較

    IIC總線SPI總線通信詳解

    IIC總線SPI總線通信介紹
    發(fā)表于 12-23 07:02

    串行通信中的IIC總線工作原理是什么

    串行通信中的IIC總線工作原理51本身不帶IIC總線 ,使用程序模擬IIC
    發(fā)表于 12-08 07:52

    iic總線通信程序

    iic總線通信,要的人速度下載看看哦。
    發(fā)表于 03-21 13:50 ?30次下載

    解讀IIC總線的FPGA實現(xiàn)原理及過程

    本文首先介紹了IIC總線概念和IIC總線硬件結(jié)構(gòu),其次介紹了IIC總線典型應(yīng)用,最后詳細(xì)介紹了
    發(fā)表于 05-31 10:56 ?6749次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>解讀<b class='flag-5'>IIC</b><b class='flag-5'>總線</b>的FPGA實現(xiàn)原理及過程

    STC89C52的IIC總線寫EEPROM

    串行通信中的IIC總線工作原理51本身不帶IIC總線 ,使用程序模擬IIC
    發(fā)表于 11-25 15:51 ?11次下載
    STC89C52的<b class='flag-5'>IIC</b><b class='flag-5'>總線</b>寫EEPROM

    IIC通信總線尋址

    IIC的使用IIC總線簡介IIC通信時序IIC總線
    發(fā)表于 12-04 16:06 ?14次下載
    <b class='flag-5'>IIC</b><b class='flag-5'>通信</b><b class='flag-5'>總線</b>尋址

    IIC總線學(xué)習(xí)筆記

    3.3、字節(jié)傳送與應(yīng)答3.3、讀寫操作四、應(yīng)用實例、I2C總線背景? IIC(Inter-Integrated Circuit) 是IICBus簡稱,中文叫集成電路
    發(fā)表于 01-17 13:33 ?6次下載
    <b class='flag-5'>IIC</b><b class='flag-5'>總線</b>學(xué)習(xí)筆記

    SPI總線IIC總線通信1

    從應(yīng)用上來講,UART通信多用于板間通信,比如單片機和計算機,這個設(shè)備和另外個設(shè)備之間的通信。而IIC
    的頭像 發(fā)表于 02-13 10:39 ?2698次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>講</b><b class='flag-5'>透</b><b class='flag-5'>SPI</b><b class='flag-5'>總線</b>和<b class='flag-5'>IIC</b><b class='flag-5'>總線</b><b class='flag-5'>通信</b>1

    SPI總線IIC總線通信3

    從應(yīng)用上來講,UART通信多用于板間通信,比如單片機和計算機,這個設(shè)備和另外個設(shè)備之間的通信。而IIC
    的頭像 發(fā)表于 02-13 10:41 ?1598次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>講</b><b class='flag-5'>透</b><b class='flag-5'>SPI</b><b class='flag-5'>總線</b>和<b class='flag-5'>IIC</b><b class='flag-5'>總線</b><b class='flag-5'>通信</b>3

    SPI總線IIC總線通信4

    從應(yīng)用上來講,UART通信多用于板間通信,比如單片機和計算機,這個設(shè)備和另外個設(shè)備之間的通信。而IIC
    的頭像 發(fā)表于 02-13 10:41 ?1802次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>講</b><b class='flag-5'>透</b><b class='flag-5'>SPI</b><b class='flag-5'>總線</b>和<b class='flag-5'>IIC</b><b class='flag-5'>總線</b><b class='flag-5'>通信</b>4

    淺談SPI總線通信接口及其協(xié)議

    上篇內(nèi)容我們介紹了IIC總線通信接口及其協(xié)議,這篇文章我們介紹另種項目開發(fā)中非常常見的通信
    的頭像 發(fā)表于 03-22 16:11 ?1848次閱讀
    淺談<b class='flag-5'>SPI</b><b class='flag-5'>總線</b><b class='flag-5'>通信</b>接口及其協(xié)議