色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

電子通信的SPI詳解

傳感器技術 ? 來源:傳感器技術 ? 作者:傳感器技術 ? 2022-10-27 09:24 ? 次閱讀

微控制器連接到傳感器,顯示器或其他模塊時,您是否考慮過兩個設備之間如何通信?他們到底在說什么?他們如何能夠相互理解?

電子設備之間的通信就像人類之間的通信,雙方都需要說同一種語言。在電子學中,這些語言稱為通信協議。

SPI,I2CUART

我們先了解三種最常見協議的基礎知識:串行外設接口(SPI),內部集成電路(I2C)和通用異步接收器/發送器(UART)驅動通信。

SPI,I2C和UART比USB以太網藍牙和WiFi等協議慢得多,但它們更簡單,使用的硬件和系統資源也更少。SPI,I2C和UART非常適用于微控制器之間以及微控制器和傳感器之間的通信,在這些傳感器中不需要傳輸大量高速數據。

串行與并行通信

電子設備通過物理連接在設備之間的導線發送數據位來相互通信,有點像一個字母中的字母,除了26個字母(英文字母表中),一個位是二進制的,只能是1或0。通過電壓的快速變化,位從一個設備傳輸到另一個設備。在工作電壓為5V的系統中,0位作為0V的短脈沖通信,1位通過5V的短脈沖通信。 數據位可以并行或串行形式傳輸。在并行通信中,數據位是同時發送的,每個都通過單獨的線路。下圖顯示了二進制(01000011)中字母“C”的并行傳輸:

在串行通信中,通過單線逐個發送這些位。下圖顯示了二進制(01000011)中字母“C”的串行傳輸:

a0743370-5585-11ed-a3b6-dac502259ad0.png

SPI簡介

SPI,是英語Serial Peripheral interface的縮寫,顧名思義就是串行外圍設備接口。是Motorola首先在其MC68HCXX系列處理器上定義的。SPI接口主要應用在 EEPROM,FLASH,實時時鐘AD轉換器,還有數字信號處理器和數字信號解碼器之間。SPI,是一種高速的,全雙工,同步的通信總線,并且在芯片的管腳上只占用四根線,節約了芯片的管腳,同時為PCB的布局上節省空間,提供方便,正是出于這種簡單易用的特性,現在越來越多的芯片集成了這種通信協議。

1、SPI特點

(1)采用主-從模式(Master-Slave) 的控制方式

SPI 規定了兩個 SPI 設備之間通信必須由主設備 (Master) 來控制次設備 (Slave). 一個 Master 設備可以通過提供 Clock 以及對 Slave 設備進行片選 (Slave Select) 來控制多個 Slave 設備, SPI 協議還規定 Slave 設備的 Clock 由 Master 設備通過 SCK 管腳提供給 Slave 設備, Slave 設備本身不能產生或控制 Clock, 沒有 Clock 則 Slave 設備不能正常工作

(2)采用同步方式(Synchronous)傳輸數據

Master 設備會根據將要交換的數據來產生相應的時鐘脈沖(Clock Pulse), 時鐘脈沖組成了時鐘信號(Clock Signal) , 時鐘信號通過時鐘極性 (CPOL) 和 時鐘相位 (CPHA) 控制著兩個 SPI 設備間何時數據交換以及何時對接收到的數據進行采樣, 來保證數據在兩個設備之間是同步傳輸的.

a088a4a4-5585-11ed-a3b6-dac502259ad0.jpg

(3)數據交換(Data Exchanges)

SPI 設備間的數據傳輸之所以又被稱為數據交換, 是因為 SPI 協議規定一個 SPI 設備不能在數據通信過程中僅僅只充當一個 "發送者(Transmitter)" 或者 "接收者(Receiver)". 在每個 Clock 周期內, SPI 設備都會發送并接收一個 bit 大小的數據, 相當于該設備有一個 bit 大小的數據被交換了. 一個 Slave 設備要想能夠接收到 Master 發過來的控制信號, 必須在此之前能夠被 Master 設備進行訪問 (Access). 所以, Master 設備必須首先通過 SS/CS pin 對 Slave 設備進行片選, 把想要訪問的 Slave 設備選上. 在數據傳輸的過程中, 每次接收到的數據必須在下一次數據傳輸之前被采樣. 如果之前接收到的數據沒有被讀取, 那么這些已經接收完成的數據將有可能會被丟棄, 導致 SPI 物理模塊最終失效. 因此, 在程序中一般都會在 SPI 傳輸完數據后, 去讀取 SPI 設備里的數據, 即使這些數據(Dummy Data)在我們的程序里是無用的。

(4)SPI有四種傳輸模式

上升沿、下降沿、前沿、后沿觸發。當然也有MSB和LSB傳輸方式.

a0a548c0-5585-11ed-a3b6-dac502259ad0.jpg

(5)SPI只有主模式和從模式之分。

沒有讀和寫的說法,因為實質上每次SPI是主從設備在交換數據。也就是說,你發一個數據必然會收到一個數據;你要收一個數據必須也要先發一個數據。

2、 工作機制

(1)概述

a0c086d0-5585-11ed-a3b6-dac502259ad0.jpg

上圖只是對 SPI 設備間通信的一個簡單的描述, 下面就來解釋一下圖中所示的幾個組件(Module):

SSPBUF,Synchronous Serial Port Buffer, 泛指 SPI 設備里面的內部緩沖區, 一般在物理上是以 FIFO 的形式, 保存傳輸過程中的臨時數據;

SSPSR, Synchronous Serial Port Register, 泛指 SPI 設備里面的移位寄存器(Shift Regitser), 它的作用是根據設置好的數據位寬(bit-width) 把數據移入或者移出 SSPBUF;

Controller, 泛指 SPI 設備里面的控制寄存器, 可以通過配置它們來設置 SPI 總線的傳輸模式。

通常情況下, 我們只需要對上圖所描述的四個管腳(pin) 進行編程即可控制整個 SPI 設備之間的數據通信:

SCK, Serial Clock, 主要的作用是 Master 設備往 Slave 設備傳輸時鐘信號, 控制數據交換的時機以及速率;

SS/CS, Slave Select/Chip Select, 用于 Master 設備片選 Slave 設備, 使被選中的 Slave 設備能夠被 Master 設備所訪問;

SDO/MOSI, Serial Data Output/Master Out Slave In, 在 Master 上面也被稱為 Tx-Channel, 作為數據的出口, 主要用于 SPI 設備發送數據;

SDI/MISO, Serial Data Input/Master In Slave Out, 在 Master 上面也被稱為 Rx-Channel, 作為數據的入口, 主要用于SPI 設備接收數據;

SPI 設備在進行通信的過程中, Master 設備和 Slave 設備之間會產生一個數據鏈路回環(Data Loop), 就像上圖所畫的那樣, 通過 SDO 和 SDI 管腳, SSPSR 控制數據移入移出 SSPBUF, Controller 確定 SPI 總線的通信模式, SCK 傳輸時鐘信號。

(2) Timing

a0c91bc4-5585-11ed-a3b6-dac502259ad0.jpg

上圖通過 Master 設備與 Slave 設備之間交換1 Byte 數據來說明 SPI 協議的工作機制.

首先, 在這里解釋一下相位和極性的概念

a, SPI相關的縮寫或說法

SPI的極性Polarity和相位Phase,最常見的寫法是CPOL和CPHA,不過也有一些其他寫法,簡單總結如下:

(1) CKPOL (Clock Polarity) = CPOL = POL = Polarity = (時鐘)極性

(2) CKPHA (Clock Phase) = CPHA = PHA = Phase = (時鐘)相位

(3) SCK=SCLK=SPI的時鐘

(4) Edge=邊沿,即時鐘電平變化的時刻,即上升沿(rising edge)或者下降沿(falling edge)

對于一個時鐘周期內,有兩個edge,分別稱為:

Leading edge=前一個邊沿=第一個邊沿,對于開始電壓是1,那么就是1變成0的時候,對于開始電壓是0,那么就是0變成1的時候;

Trailing edge=后一個邊沿=第二個邊沿,對于開始電壓是1,那么就是0變成1的時候(即在第一次1變成0之后,才可能有后面的0變成1),對于開始電壓是0,那么就是1變成0的時候;

b,SPI的相位和極性

CPOL和CPHA,分別都可以是0或時1,對應的四種組合就是:

Mode 0 CPOL=0, CPHA=0

Mode 1 CPOL=0, CPHA=1

Mode 2 CPOL=1, CPHA=0

Mode 3 CPOL=1, CPHA=1

a0ddaf3a-5585-11ed-a3b6-dac502259ad0.jpg

c,CPOL極性

先說什么是SCLK時鐘的空閑時刻,其就是當SCLK在數發送8個bit比特數據之前和之后的狀態,于此對應的,SCLK在發送數據的時候,就是正常的工作的時候,有效active的時刻了。

先說英文,其精簡解釋為:Clock Polarity = IDLE state of SCK。

再用中文詳解:

SPI的CPOL,表示當SCLK空閑idle的時候,其電平的值是低電平0還是高電平1:

CPOL=0,時鐘空閑idle時候的電平是低電平,所以當SCLK有效的時候,就是高電平,就是所謂的active-high;

CPOL=1,時鐘空閑idle時候的電平是高電平,所以當SCLK有效的時候,就是低電平,就是所謂的active-low;

d,CPHA相位

首先說明一點,capture strobe = latch = read = sample,都是表示數據采樣,數據有效的時刻。相位,對應著數據采樣是在第幾個邊沿(edge),是第一個邊沿還是第二個邊沿,0對應著第一個邊沿,1對應著第二個邊沿。

對于:

CPHA=0,表示第一個邊沿:

對于CPOL=0,idle時候的是低電平,第一個邊沿就是從低變到高,所以是上升沿;

對于CPOL=1,idle時候的是高電平,第一個邊沿就是從高變到低,所以是下降沿;

CPHA=1,表示第二個邊沿:

對于CPOL=0,idle時候的是低電平,第二個邊沿就是從高變到低,所以是下降沿;

對于CPOL=1,idle時候的是高電平,第一個邊沿就是從低變到高,所以是上升沿;

還是上圖大家更容易看懂

a0eacf9e-5585-11ed-a3b6-dac502259ad0.jpg

e,軟件中如何設置SPI的極性和相位

SPI分主設備和從設備,兩者通過SPI協議通訊。

而設置SPI的模式,是從設備的模式,決定了主設備的模式。

所以要先去搞懂從設備的SPI是何種模式,然后再將主設備的SPI的模式,設置和從設備相同的模式,即可正常通訊。

對于從設備的SPI是什么模式,有兩種:

固定的,有SPI從設備硬件決定的

SPI從設備,具體是什么模式,相關的datasheet中會有描述,需要自己去datasheet中找到相關的描述,即:

關于SPI從設備,在空閑的時候,是高電平還是低電平,即決定了CPOL是0還是1;

然后再找到關于設備是在上升沿還是下降沿去采樣數據,這樣就是,在定了CPOL的值的前提下,對應著可以推算出CPHA是0還是1了。

可配置的,由軟件自己設定

從設備也是一個SPI控制器,4種模式都支持,此時只要自己設置為某種模式即可。

然后知道了從設備的模式后,再去將SPI主設備的模式,設置為和從設備模式一樣,即可。

對于如何配置SPI的CPOL和CPHA的話,不多細說,多數都是直接去寫對應的SPI控制器中對應寄存器中的CPOL和CPHA那兩位,寫0或寫1即可。

(3)SSPSR

a100772c-5585-11ed-a3b6-dac502259ad0.jpg

SSPSR 是 SPI 設備內部的移位寄存器(Shift Register). 它的主要作用是根據 SPI 時鐘信號狀態, 往 SSPBUF 里移入或者移出數據, 每次移動的數據大小由 Bus-Width 以及 Channel-Width 所決定。

Bus-Width 的作用是指定地址總線到 Master 設備之間數據傳輸的單位.

例如, 我們想要往 Master 設備里面的 SSPBUF 寫入 16 Byte 大小的數據: 首先, 給 Master 設備的配置寄存器設置 Bus-Width 為 Byte; 然后往 Master 設備的 Tx-Data 移位寄存器在地址總線的入口寫入數據, 每次寫入 1 Byte 大小的數據(使用 writeb 函數); 寫完 1 Byte 數據之后, Master 設備里面的 Tx-Data 移位寄存器會自動把從地址總線傳來的1 Byte 數據移入 SSPBUF 里; 上述動作一共需要重復執行 16 次.

Channel-Width 的作用是指定 Master 設備與 Slave 設備之間數據傳輸的單位. 與 Bus-Width 相似, Master 設備內部的移位寄存器會依據 Channel-Width 自動地把數據從 Master-SSPBUF 里通過 Master-SDO 管腳搬運到 Slave 設備里的 Slave-SDI 引腳, Slave-SSPSR 再把每次接收的數據移入 Slave-SSPBUF里.通常情況下, Bus-Width 總是會大于或等于 Channel-Width, 這樣能保證不會出現因 Master 與 Slave 之間數據交換的頻率比地址總線與 Master 之間的數據交換頻率要快, 導致 SSPBUF 里面存放的數據為無效數據這樣的情況.

(4) SSPBUF

a10b88b0-5585-11ed-a3b6-dac502259ad0.jpg

我們知道, 在每個時鐘周期內, Master 與 Slave 之間交換的數據其實都是 SPI 內部移位寄存器從 SSPBUF 里面拷貝的. 我們可以通過往 SSPBUF 對應的寄存器 (Tx-Data / Rx-Data register) 里讀寫數據, 間接地操控 SPI 設備內部的 SSPBUF.

例如, 在發送數據之前, 我們應該先往 Master 的 Tx-Data 寄存器寫入將要發送出去的數據, 這些數據會被 Master-SSPSR 移位寄存器根據 Bus-Width 自動移入 Master-SSPBUF 里, 然后這些數據又會被 Master-SSPSR 根據 Channel-Width 從 Master-SSPBUF 中移出, 通過 Master-SDO 管腳傳給 Slave-SDI 管腳, Slave-SSPSR 則把從 Slave-SDI 接收到的數據移入 Slave-SSPBUF 里. 與此同時, Slave-SSPBUF 里面的數據根據每次接收數據的大小(Channel-Width), 通過 Slave-SDO 發往 Master-SDI, Master-SSPSR 再把從 Master-SDI 接收的數據移入 Master-SSPBUF.在單次數據傳輸完成之后, 用戶程序可以通過從 Master 設備的 Rx-Data 寄存器讀取 Master 設備數據交換得到的數據.

(5) Controller

Master 設備里面的 Controller 主要通過時鐘信號(Clock Signal)以及片選信號(Slave Select Signal)來控制 Slave 設備. Slave 設備會一直等待, 直到接收到 Master 設備發過來的片選信號, 然后根據時鐘信號來工作.

Master 設備的片選操作必須由程序所實現. 例如: 由程序把 SS/CS 管腳的時鐘信號拉低電平, 完成 SPI 設備數據通信的前期工作; 當程序想讓 SPI 設備結束數據通信時, 再把 SS/CS 管腳上的時鐘信號拉高電平.

SPI的優點和缺點

使用SPI有一些優點和缺點,如果在不同的通信協議之間進行選擇,您應該根據項目的要求知道何時使用SPI: 優點沒有啟動和停止位,因此數據可以連續流式傳輸而不會中斷沒有復雜的從機尋址系統,如I2C比I2C更高的數據傳輸速率(幾乎快兩倍)單獨的MISO和MOSI線,因此可以同時發送和接收數據 缺點使用四根線(I2C和UART使用兩根)無法確認數據已成功接收(I2C已執行此操作)沒有錯誤檢查,如UART中的奇偶校驗位僅允許單個主機

審核編輯:湯梓紅

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 通信協議
    +關注

    關注

    28

    文章

    887

    瀏覽量

    40317
  • SPI
    SPI
    +關注

    關注

    17

    文章

    1707

    瀏覽量

    91675
  • I2C
    I2C
    +關注

    關注

    28

    文章

    1489

    瀏覽量

    123897
  • uart
    +關注

    關注

    22

    文章

    1237

    瀏覽量

    101446

原文標題:電子通信的SPI詳解

文章出處:【微信號:WW_CGQJS,微信公眾號:傳感器技術】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    單片機spi通信原理詳解

    單片機是一個可編程的微控制器,和spi通信其實是兩個獨立的東西。只不過我們用單片機可以去實現spi通信而已,但是實現spi
    的頭像 發表于 12-22 14:03 ?4156次閱讀
    單片機<b class='flag-5'>spi</b><b class='flag-5'>通信</b>原理<b class='flag-5'>詳解</b>

    通用電子SPI通信嗅探器PCB

    描述通用電子紙嗅探器通用電子SPI 通信嗅探器 PCB該 PCB 將幫助您非常簡單地分析未知電子紙顯示器與庫存微控制器之間的
    發表于 06-21 07:18

    關于STM32的SPI通信

    STM32的SPI通信調試經驗
    發表于 02-07 15:53 ?24次下載

    SPI通信原理 SPI的接線實例

    SPI,是英語 Serial Peripheral interface 的縮寫,中文全稱是串行外圍設備接口。是 Motorola 所研發的一種串行通信協議。SPI接口主要應用在 EEPROM
    的頭像 發表于 12-01 14:04 ?1.8w次閱讀

    SPI通信

    SPI簡介SPI是一種串行外圍設備通信接口,高速全雙工通信總線,主要用于通信速率較高的場合。SPI
    發表于 11-24 15:06 ?50次下載
    <b class='flag-5'>SPI</b><b class='flag-5'>通信</b>

    基于SPI通信方式的OLED顯示

    本文目的是通過SPI通信方式進行OLED的顯示,同時與之前學的I2C通信方式進行對比,在實踐中學習SPI通信。目錄(一)
    發表于 12-08 09:06 ?39次下載
    基于<b class='flag-5'>SPI</b><b class='flag-5'>通信</b>方式的OLED顯示

    SPI通信分析

    SPI通信分析許久不更,想你們了。SPI 模式的配置SPI通信配置STM官方的芯片手冊中對于SPI
    發表于 12-22 19:12 ?2次下載
    <b class='flag-5'>SPI</b><b class='flag-5'>通信</b>分析

    SPI通信

    SPI簡介SPI是一種串行外圍設備通信接口,高速全雙工通信總線,主要用于通信速率較高的場合。SPI
    發表于 12-22 19:13 ?3次下載
    <b class='flag-5'>SPI</b><b class='flag-5'>通信</b>

    SPI通信協議講解

    SPI通信協議講解SPI通信概念SPI通信SPI
    發表于 12-22 19:19 ?26次下載
    <b class='flag-5'>SPI</b><b class='flag-5'>通信</b>協議講解

    [SPI].SPI協議詳解

    轉自:http://www.sohu.com/a/211324861_4686261、 SPI簡介SPI,是英語Serial Peripheral interface的縮寫,顧名思義就是串行外圍設備
    發表于 12-22 19:19 ?43次下載
    [<b class='flag-5'>SPI</b>].<b class='flag-5'>SPI</b>協議<b class='flag-5'>詳解</b>

    通信協議:SPI

    STM32模擬SPI通信協議SPI的簡介:SPI是串行外設接口的縮寫,是一種高速的,全雙工、同步的串行通信總線;
    發表于 12-22 19:20 ?22次下載
    <b class='flag-5'>通信</b>協議:<b class='flag-5'>SPI</b>

    通信協議(SPI

    一、SPI簡介SPI(Serial Peripheral Interface)是串行外設接口的縮寫,SPI是高速的,**全雙工**、**同步**的串行通信總線;
    發表于 12-22 19:33 ?6次下載
    <b class='flag-5'>通信</b>協議(<b class='flag-5'>SPI</b>)

    通用電子SPI通信嗅探器PCB

    該 PCB 將幫助您非常簡單地分析未知電子紙顯示器與庫存微控制器之間的 SPI 通信
    發表于 07-01 15:09 ?1次下載
    通用<b class='flag-5'>電子</b>紙<b class='flag-5'>SPI</b><b class='flag-5'>通信</b>嗅探器PCB

    超全面!SPI通信協議詳解,一篇就夠

    什么是SPISPI的英文全稱為SerialPeripheralInterface,顧名思義為串行外設接口。SPI是一種同步串行通信接口規范,主要應用于嵌入式系統中的短距離
    的頭像 發表于 09-30 10:18 ?3955次閱讀
    超全面!<b class='flag-5'>SPI</b><b class='flag-5'>通信</b>協議<b class='flag-5'>詳解</b>,一篇就夠

    超全面!SPI通信協議詳解

    什么是SPISPI的英文全稱為SerialPeripheralInterface,顧名思義為串行外設接口。SPI是一種同步串行通信接口規范,主要應用于嵌入式系統中的短距離
    的頭像 發表于 08-14 10:06 ?4214次閱讀
    超全面!<b class='flag-5'>SPI</b><b class='flag-5'>通信</b>協議<b class='flag-5'>詳解</b>
    主站蜘蛛池模板: 亚洲一区在线播放| 国产又湿又黄又硬又刺激视频| 中文字幕在线不卡精品视频99| 日本少妇内射视频播放舔| 果冻传媒在线观看完整版免费| 国产色欲一区二区精品久久呦| 又紧又大又爽精品一区二区| 80岁色老头69av| 菠萝菠萝蜜高清观看在线| 国产毛片女人高潮叫声| 色婷婷国产精品视频一区二区三区| 午夜免费小视频| 在线亚洲中文字幕36页| 成人国产一区| 久久99国产精品一区二区| 欧美日本韩国一二区视频| 亚洲h视频在线观看| 538prom国产在线视频一区| 久久视频在线视频| 日本激情网址| 大屁股国产白浆一二区| 亚洲第一成年网站视频| 嘿嘿视频在线观看 成人| 日韩一区二区天海翼| 亚洲综合日韩在线2019| 成人在线视频免费| 色www.亚洲免费视频| 99久久综合精品免费| 国产亚洲日韩另类在线播放| 亚洲精品m在线观看| 公和熄洗澡三级中文字幕 | 亚洲欧美在无码片一区二区| 白丝美女被狂躁免费漫画| 久久精品成人免费看| 午夜向日葵视频在线观看| 国产亚洲精品a在线观看app| 日韩精品卡1卡2三卡四卡乱码| 闺蜜扒开我尿口使劲揉| 亚洲1区2区3区精华液| 国产AV亚洲精品久久久久软件| 午夜福到在线4国产|