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

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

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

嵌入式系統(tǒng)低速接口SPI和UART的區(qū)別

云深之無跡 ? 來源:云深之無跡 ? 2023-08-14 11:44 ? 次閱讀

嵌入式系統(tǒng)低速接口-SPI

繼續(xù)說SPI,SPI來說就是沒有IIC那么固定。它就是設(shè)計(jì)了一種二進(jìn)制流的交互方式,所以這也是為什么它那么靈活的原因。它可以在任何兩個(gè)嵌入式的設(shè)備之間交換消息。

但是話又說回來了,SPI和UART都是串行的,那有啥區(qū)別呢?

SPI的優(yōu)點(diǎn):

速度快,可達(dá)數(shù)十Mbps

接口簡單,只需要三根線(SCLK、MOSI、MISO)

多設(shè)備支持簡單,通過CS線選擇從機(jī)

更好的實(shí)時(shí)控制能力

支持全雙工通信

推挽驅(qū)動(dòng)(跟漏極開路正相反)提供了比較好的信號(hào)完整性和較高的速度

比I2C或SMBus吞吐率更高

協(xié)議非常靈活支持“位”傳輸

不僅限于8-bit一個(gè)字節(jié)的傳輸

可任意選擇的信息大小、內(nèi)容、以及用途

異常簡單的硬件接口:

一般來講比I2C或SMBus需要的功耗更低,因?yàn)樾枰俚碾娐?包括上拉電阻)

沒有仲裁機(jī)制或相關(guān)的失效模式

“從設(shè)備”采用的是“主設(shè)備”的時(shí)鐘,不需要精確的晶振

“從設(shè)備”不需要一個(gè)單獨(dú)的地址 — 這點(diǎn)不像I2C或GPIB或SCSI

不需要收/發(fā)器

在一個(gè)IC上只用了4個(gè)管腳, 板上走線和布局連接都比并行接口簡單很多

每個(gè)設(shè)備最多只有一個(gè)單獨(dú)的總線信號(hào)(片選);其它的都是共享的

信號(hào)都是單方向的,非常容易進(jìn)行電流隔離

對(duì)于時(shí)鐘的速度沒有上限,有進(jìn)一步提高速度的潛力

SPI的缺點(diǎn):

通信距離短,不適合長距離通信

通常需要額外的片選信號(hào)增加從機(jī)數(shù)量

全雙工通信復(fù)雜度較高

相比于I2C總線需要更多的管腳, 即便是只用到3根線的情況下

沒有尋址機(jī)制,在共享的總線連接時(shí)需要通過片選信號(hào)支持多個(gè)設(shè)備的訪問

在從設(shè)備側(cè)沒有硬件流控機(jī)制(主設(shè)備一側(cè)可以通過延遲到下一個(gè)時(shí)鐘沿以降低傳輸?shù)乃俾?

從設(shè)備無法進(jìn)行硬件“應(yīng)答”(主設(shè)備傳送的信息無法確定傳遞到哪里,是否傳遞成功)

一般只支持一個(gè)主設(shè)備(取決于設(shè)備的硬件構(gòu)成)

沒有查錯(cuò)機(jī)制

沒有一個(gè)正式的標(biāo)準(zhǔn)規(guī)范,無法驗(yàn)證一致性

相對(duì)于RS-232, RS-485, 或CAN-總線,只能近距離傳輸

存在很多的變種,很難能夠找到開發(fā)工具(例如主適配卡)支持這所有的變種

SPI不支持熱交換(動(dòng)態(tài)地增加一個(gè)節(jié)點(diǎn)).

如果想使用“中斷”,只有通過SPI信號(hào)以外的其它信號(hào)線,或者采用類似USB1.1或2.0中的周期性查詢的欺騙方式

有一些變種比如多路I/O SPI和下面定義的三線串行總線都是半雙工的

UART的優(yōu)點(diǎn):

只需要兩根線(TX、RX),連接簡單

可支持較遠(yuǎn)距離的通信

更簡單的全雙工通信機(jī)制

已經(jīng)得到廣泛應(yīng)用,資料豐富

UART的缺點(diǎn):

速率較慢,通常在Mbps量級(jí)

單主機(jī)與單從機(jī)通信,擴(kuò)展難度大

對(duì)時(shí)序信號(hào)敏感,容易出現(xiàn)誤碼

不具備同步通信能力

總體來說,SPI更適合需要高速的數(shù)據(jù)交互和實(shí)時(shí)控制的場景;而UART更適合簡單的遠(yuǎn)距離串行通信。

SPI偏向大數(shù)據(jù)流,UART可以長距離的控制。

假如是自己的封裝的一個(gè)SPI的收發(fā)協(xié)議呢?

wKgaomTZoyyAE4wLAAEIokRUA6k556.png

用結(jié)構(gòu)體封裝一個(gè)這樣的東西,別問是啥?就這樣

wKgaomTZoyyAfcwZAAHwRDpYS8E725.png

發(fā)送

wKgaomTZoyyAMh-fAAG_4RyeljM571.png

接收

wKgZomTZoyyASu13AAEAtR4-kiA174.png

所以大概要實(shí)現(xiàn)的功能

wKgaomTZoyyALbojAACibAJ7atQ862.png

在應(yīng)用層的時(shí)候,這樣使用

以上這些函數(shù)就可以實(shí)現(xiàn),兩個(gè)MCU之間的自定義協(xié)議的通訊。

wKgZomTZoyyAcCPbAAHfyYHvKWM556.png

在數(shù)據(jù)在處理上面,還有一個(gè)小細(xì)節(jié),就是SPI和IIC的傳感器,有時(shí)候里面的data要使用二進(jìn)制的補(bǔ)碼。

wKgZomTZoy2AV9byAAIfMKVho-w573.png

就像這樣

使用二進(jìn)制補(bǔ)碼表示數(shù)據(jù)的好處主要有:

兼容有符號(hào)數(shù)據(jù)表示

二進(jìn)制補(bǔ)碼可以直接表示傳感器采集的有符號(hào)數(shù)據(jù)(負(fù)數(shù)),無需額外處理。比如溫度值可以直接用二進(jìn)制補(bǔ)碼形式表示正負(fù)溫度。

提高數(shù)據(jù)處理效率

如果使用純二進(jìn)制表示無符號(hào)數(shù)據(jù),CPU進(jìn)行有符號(hào)數(shù)的運(yùn)算和比較需要額外處理。使用補(bǔ)碼可以直接進(jìn)行算術(shù)運(yùn)算,提高效率。

節(jié)省通信帶寬

如果使用ASCII等編碼,數(shù)據(jù)存儲(chǔ)和傳輸會(huì)膨脹很多。二進(jìn)制補(bǔ)碼表示可以高效利用每一位。

簡化數(shù)據(jù)解析

補(bǔ)碼形式的數(shù)據(jù)可以直接作為int16、int32等有符號(hào)類型解析,無需復(fù)雜解碼。

減少出錯(cuò)概率

ASCII編碼需要進(jìn)行 num-to-ascii 和 ascii-to-num 的轉(zhuǎn)換,容易引入錯(cuò)誤。二進(jìn)制補(bǔ)碼可以避免這類問題。

統(tǒng)一不同設(shè)備的數(shù)據(jù)表示

采用標(biāo)準(zhǔn)補(bǔ)碼表示,使不同廠家的設(shè)備的數(shù)據(jù)可以統(tǒng)一被處理。

但需要注意,二進(jìn)制補(bǔ)碼需要處理符號(hào)位擴(kuò)展問題,左移時(shí)需要適當(dāng)維護(hù)符號(hào)位。并且 debug 和顯示需做轉(zhuǎn)換。使用二進(jìn)制補(bǔ)碼可以提高傳感器數(shù)據(jù)處理的效率與質(zhì)量。

那說了這么多,自己模擬一個(gè)協(xié)議可能是最好的,這里就用51單片機(jī)來搞這個(gè)。

wKgaomTZoy2Aau1cAAEjFECwJgg622.png

使用的引腳

wKgZomTZoy2ANNEhAAGFfpqFbRo949.png

遍歷需要發(fā)送的數(shù)據(jù)字節(jié)數(shù)組,一位一位寫入MOSI口。同時(shí)通過設(shè)置SCK為1和0來模擬SPI時(shí)鐘的上升沿和下降沿。

wKgaomTZoy2AAOx9AAFGYz_TNx8527.png

在一個(gè)8位循環(huán)內(nèi),讀取MOSI的每一位數(shù)據(jù),在SCK上升沿時(shí)采樣,并寫入data變量。SCK下降沿準(zhǔn)備采樣下一位。

wKgZomTZoy2AV5dsAADUslD_Hr8770.png

傳感器具有能在SCK輸入信號(hào)為有效高電平或低電平時(shí)工作的能力。當(dāng) CE 信號(hào)變成高電平時(shí),檢測到 SCK 的 無效狀態(tài),而時(shí)鐘輸入 (CP)的極性決定數(shù)據(jù)是在系統(tǒng)時(shí)鐘的上升沿或下降沿移入或移出,

wKgZomTZoy2AcSsKAACXqh2WrAc168.png

看眼引腳

wKgaomTZoy2AT4ztAAGZm0hEEcg415.png

這個(gè)圖給出了用于傳送數(shù)據(jù)到寄存器和從寄存器移出數(shù)據(jù)的相應(yīng)時(shí)鐘邊沿。 每個(gè)時(shí)鐘脈沖傳送一位數(shù)據(jù) ,數(shù)據(jù)位以 8 位為一組傳送。

A是地址,D是數(shù)據(jù)。先發(fā)送地址字節(jié),隨后為數(shù)據(jù)。

wKgaomTZoy2AGzleAAJNfsbtUyA764.png

數(shù)據(jù)可以采用單字節(jié)或多字節(jié)包的方式進(jìn)行傳送,在 3 字節(jié)包中,數(shù)據(jù)序列包括溫度數(shù)據(jù)的 MSb、溫度數(shù)據(jù)的 LSb 和緊接著的控制寄存器數(shù)據(jù)。通過向寄存器寫入所需數(shù)據(jù)包的最高地址來啟動(dòng)多字節(jié)讀功能。

串行輸出: SCLK : SCK, CLK.

主輸出 –> 從輸入: MOSI : SIMO, SDI(對(duì)于“從”設(shè)備), DI, DIN, SI, MTST.

主輸入 ←- 從輸出: –> MISO : SOMI, SDO (對(duì)于“從”設(shè)備), DO, DOUT, SO, MRSR.

從選擇: SS : nCS, CS, CSB, CSN, EN, nSS, STE, SYNC.

多數(shù)從設(shè)備的輸出是三態(tài)的,當(dāng)該從設(shè)備沒有被選中的時(shí)候它們的MISO信號(hào)就為高阻(邏輯上斷開連接)。不具有三態(tài)輸出的器件是不能同其它器件共享SPI總線部分的,只能是一個(gè)從設(shè)備跟主設(shè)備相連。

單片機(jī)GPIO引腳的三態(tài)(Tri-state)是指該引腳可以處于三種狀態(tài):

1.推挽輸出: 引腳被配置為輸出,可以被置高電平(1)或者低電平(0)。

2.開漏輸出: 引腳被配置為開漏輸出,可以被置低電平(0),或處于高阻抗?fàn)顟B(tài)(Z)。

3.高阻輸入: 引腳被配置為輸入,此時(shí)處于高阻抗?fàn)顟B(tài)(Z),可以檢測外部信號(hào)的高低電平。

文章的最后解惑一下。

wKgZomTZoy2AQWb_AAIcNciz0xA041.png

這里以最常見的SPI3模式說下時(shí)序圖怎么看。

當(dāng)數(shù)據(jù)未發(fā)送時(shí)以及發(fā)送完畢后,SCK都是高電平,因此CPOL=1??醋钋懊?。

在SCK第一個(gè)沿(下降沿)的時(shí)候,MOSI和MISO會(huì)發(fā)生變化。同時(shí)SCK第二個(gè)沿(上升沿)的時(shí)候,數(shù)據(jù)是穩(wěn)定的,此刻采樣數(shù)據(jù)是合適的,也就是上升沿即一個(gè)時(shí)鐘周期的后沿鎖存讀取數(shù)據(jù),即CPHA=1。

當(dāng)CPHA=0、CPOL=0時(shí)SPI總線工作在方式0,如下圖。簡化起見把MOSI和MISO合在一起了。

wKgaomTZoy2AJvBVAAIGeGj1IOU158.png

SPI0通信時(shí)序圖

SPI1和SPI2

當(dāng)CPHA=0、CPOL=1時(shí)SPI總線工作在SPI1

當(dāng)CPHA=1、CPOL=0時(shí)SPI總線工作在SPI2。

wKgaomTZoy2AL75PAAPC8EQ-sdQ517.png

SPI1和SPI2通信時(shí)序圖

要點(diǎn),看發(fā)送前的時(shí)鐘,然后看兩個(gè)邊沿對(duì)應(yīng)的數(shù)據(jù)線,判斷什么時(shí)候是保持邊沿的。適合采樣的。

審核編輯:湯梓紅

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

    關(guān)注

    41

    文章

    3610

    瀏覽量

    129603
  • 接口
    +關(guān)注

    關(guān)注

    33

    文章

    8668

    瀏覽量

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

    關(guān)注

    17

    文章

    1717

    瀏覽量

    91842
  • uart
    +關(guān)注

    關(guān)注

    22

    文章

    1242

    瀏覽量

    101540

原文標(biāo)題:?嵌入式系統(tǒng)低速接口-SPI(完結(jié))

文章出處:【微信號(hào):TT1827652464,微信公眾號(hào):云深之無跡】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    調(diào)試嵌入式系統(tǒng)設(shè)計(jì)中的低速串行總線

    調(diào)試嵌入式系統(tǒng)設(shè)計(jì)中的低速串行總線今天,嵌入式系統(tǒng)幾乎遍布在人類社會(huì)的每個(gè)角落。嵌入式
    發(fā)表于 11-26 09:33

    調(diào)試嵌入式系統(tǒng)設(shè)計(jì)中的低速串行總線(二)

    調(diào)試嵌入式系統(tǒng)設(shè)計(jì)中的低速串行總線(二)SPI背景知識(shí)串行外設(shè)接口總線(SPI)最初是摩托羅拉在
    發(fā)表于 11-26 21:39 ?1209次閱讀
    調(diào)試<b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>設(shè)計(jì)中的<b class='flag-5'>低速</b>串行總線(二)

    DSP嵌入式系統(tǒng)人機(jī)接口設(shè)計(jì)

    DSP嵌入式系統(tǒng)人機(jī)接口設(shè)計(jì)  1 引言   人機(jī)接口嵌入式控制系統(tǒng)的重要組成部分,用于
    發(fā)表于 12-24 16:34 ?984次閱讀
    DSP<b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>人機(jī)<b class='flag-5'>接口</b>設(shè)計(jì)

    基于嵌入式系統(tǒng)的Internet接口開發(fā)

    基于嵌入式系統(tǒng)的Internet接口開發(fā)
    發(fā)表于 02-07 17:25 ?11次下載

    低速數(shù)據(jù)采集系統(tǒng)設(shè)計(jì),DSP嵌入式系統(tǒng)開發(fā)典型案例

    低速數(shù)據(jù)采集系統(tǒng)設(shè)計(jì),DSP嵌入式系統(tǒng)開發(fā)典型案例
    發(fā)表于 10-19 10:28 ?17次下載
    中<b class='flag-5'>低速</b>數(shù)據(jù)采集<b class='flag-5'>系統(tǒng)</b>設(shè)計(jì),DSP<b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>開發(fā)典型案例

    嵌入式硬件通信接口協(xié)議中的串行通信接口-SPI

    本節(jié)繼續(xù)講嵌入式硬件通信接口協(xié)議中的另外一個(gè)串行通信接口-SPI。相比于UART串口協(xié)議,SPI
    發(fā)表于 02-05 11:35 ?1654次閱讀
    <b class='flag-5'>嵌入式</b>硬件通信<b class='flag-5'>接口</b>協(xié)議中的串行通信<b class='flag-5'>接口</b>-<b class='flag-5'>SPI</b>

    嵌入式系統(tǒng)教程之嵌入式系統(tǒng)的IO模塊詳細(xì)資料說明

    本文檔的主要內(nèi)容詳細(xì)介紹的是嵌入式系統(tǒng)教程之嵌入式系統(tǒng)的IO模塊詳細(xì)資料說明包括了:1 復(fù)位電路,2 時(shí)鐘,3 I/O模塊,4 譯碼器,5 定時(shí)器/計(jì)數(shù)器
    發(fā)表于 06-14 17:14 ?8次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>教程之<b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>的IO模塊詳細(xì)資料說明

    嵌入式常見的通信接口/協(xié)議

    0 引言??嵌入式開發(fā)中,常見的通信接口/協(xié)議有SPI,I2C,UART三種,本文先分三個(gè)部分對(duì)SPI,I2C,
    發(fā)表于 10-19 18:33 ?16次下載
    <b class='flag-5'>嵌入式</b>常見的通信<b class='flag-5'>接口</b>/協(xié)議

    嵌入式軟件接口怎么測試,嵌入式系統(tǒng)接口測試策略.doc

    嵌入式系統(tǒng)接口測試策略嵌入式系統(tǒng)接口測試策略摘要:在日益廣泛應(yīng)用的
    發(fā)表于 10-20 19:06 ?16次下載
    <b class='flag-5'>嵌入式</b>軟件<b class='flag-5'>接口</b>怎么測試,<b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b><b class='flag-5'>接口</b>測試策略.doc

    嵌入式Linux UART

    文章目錄前言串口連接串口測試C代碼微信公眾號(hào)前言這是前篇:嵌入式Linux i.MX開發(fā)板嵌入式Linux NFS嵌入式Linux 交叉編譯工具鏈嵌入式Linux LED GPIO
    發(fā)表于 11-01 16:26 ?8次下載
    <b class='flag-5'>嵌入式</b>Linux <b class='flag-5'>UART</b>

    嵌入式linux系統(tǒng)嵌入式android系統(tǒng)區(qū)別和聯(lián)系

    目錄區(qū)別與聯(lián)系嵌入式系統(tǒng)在物聯(lián)網(wǎng)行業(yè)中的應(yīng)用物聯(lián)網(wǎng)嵌入式系統(tǒng)的特征區(qū)別與聯(lián)系這個(gè)問題很多人問,尤
    發(fā)表于 11-01 17:05 ?5次下載
    <b class='flag-5'>嵌入式</b>linux<b class='flag-5'>系統(tǒng)</b>和<b class='flag-5'>嵌入式</b>android<b class='flag-5'>系統(tǒng)</b>的<b class='flag-5'>區(qū)別</b>和聯(lián)系

    嵌入式硬件通信接口協(xié)議-SPI(二)分層架構(gòu)設(shè)計(jì)模擬接口

    嵌入式硬件通信接口協(xié)議-SPI(二)分層架構(gòu)設(shè)計(jì)模擬接口
    發(fā)表于 12-09 12:36 ?19次下載
    <b class='flag-5'>嵌入式</b>硬件通信<b class='flag-5'>接口</b>協(xié)議-<b class='flag-5'>SPI</b>(二)分層架構(gòu)設(shè)計(jì)模擬<b class='flag-5'>接口</b>

    嵌入式硬件通信接口協(xié)議-SPI(一)協(xié)議基礎(chǔ)

    /hDUK43s8naybJLvoE2UsoA?本節(jié)繼續(xù)講嵌入式硬件通信接口協(xié)議中的另外一個(gè)串行通信接口-SPI。相比于UART串口協(xié)議,
    發(fā)表于 01-12 17:48 ?10次下載
    <b class='flag-5'>嵌入式</b>硬件通信<b class='flag-5'>接口</b>協(xié)議-<b class='flag-5'>SPI</b>(一)協(xié)議基礎(chǔ)

    嵌入式系統(tǒng)串口UART接口為啥沒有數(shù)據(jù)輸出

    大家常說嵌入式里面的串口,一般是指UART(Universal Asynchronous Receiver Transmitter:通用異步收發(fā)器)。雷卯電子工程師了解到嵌入系統(tǒng)
    的頭像 發(fā)表于 08-15 10:24 ?999次閱讀
    <b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>串口<b class='flag-5'>UART</b><b class='flag-5'>接口</b>為啥沒有數(shù)據(jù)輸出

    嵌入式系統(tǒng)串口UART接口為啥沒有數(shù)據(jù)輸出

    點(diǎn)擊關(guān)注,電磁兼容不迷路。1.簡單解釋SOC的串口UART接口做啥用雷卯大家常說嵌入式里面的串口,一般是指UART(UniversalAsynchronousReceiverTrans
    的頭像 發(fā)表于 08-16 11:47 ?1219次閱讀
    <b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>串口<b class='flag-5'>UART</b><b class='flag-5'>接口</b>為啥沒有數(shù)據(jù)輸出