在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

原來SPI并沒有想的那么簡單

璟琰乀 ? 來源:8號線攻城獅 ? 作者:8號線攻城獅 ? 2020-12-18 16:52 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

先說串口之前寫過一篇UART,通用串行異步通訊協議,感興趣可以參考一下《我打賭!你還不會UART》;因為UART沒有時鐘信號,無法控制何時發送數據,也無法保證雙發按照完全相同的速度接收數據。因此,雙方以不同的速度進行數據接收和發送,就會出現問題。

如果要解決這個問題,UART為每個字節添加額外的起始位和停止位,以幫助接收器在數據到達時進行同步;

雙方還必須事先就傳輸速度達成共識(設置相同的波特率,例如每秒9600位)。

傳輸速率如果有微小差異不是問題,因為接收器會在每個字節的開頭重新同步。相應的協議如下圖所示;

vqeU3a.png

串口傳輸的過程

如果您注意到上圖中的11001010不等于0x53,這是一個細節。串口協議通常會首先發送最低有效位,因此最小位在最左邊LSB。低四位字節實際上是0011 = 0x3,高四位字節是0101 = 0x5。

異步串行工作得很好,但是在每個字節發送的時候都需要額外的起始位和停止位以及在發送和接收數據所需的復雜硬件方面都有很多開銷。

不難發現,如果接收端和發送端設置的速度都不一致,那么接收到的數據將是垃圾(亂碼)。

下面開始講一下SPI協議,會有哪些優點。

SPI通訊協議于是我們想有沒有更好一點的串行通訊方式;相比較于UART,SPI的工作方式略有不同。

SPI是一個同步的數據總線,也就是說它是用單獨的數據線和一個單獨的時鐘信號來保證發送端和接收端的完美同步。

時鐘是一個振蕩信號,它告訴接收端在確切的時機對數據線上的信號進行采樣。

產生時鐘的一側稱為主機,另一側稱為從機。總是只有一個主機(一般來說可以是微控制器/MCU),但是可以有多個從機(后面詳細介紹);

數據的采集時機可能是時鐘信號的上升沿(從低到高)或下降沿(從高到低)。

具體要看對SPI的配置;

整體的傳輸大概可以分為以下幾個過程:

主機先將NSS信號拉低,這樣保證開始接收數據;

當接收端檢測到時鐘的邊沿信號時,它將立即讀取數據線上的信號,這樣就得到了一位數據(1bit);

由于時鐘是隨數據一起發送的,因此指定數據的傳輸速度并不重要,盡管設備將具有可以運行的最高速度(稍后我們將討論選擇合適的時鐘邊沿和速度)。

主機發送到從機時:主機產生相應的時鐘信號,然后數據一位一位地將從MOSI信號線上進行發送到從機;

主機接收從機數據:如果從機需要將數據發送回主機,則主機將繼續生成預定數量的時鐘信號,并且從機會將數據通過MISO信號線發送;

具體如下圖所示;

BjAr2i.png

SPI的時序

注意,SPI是“全雙工”(具有單獨的發送和接收線路),因此可以在同一時間發送和接收數據,另外SPI的接收硬件可以是一個簡單的移位寄存器。這比異步串行通信所需的完整UART要簡單得多,并且更加便宜;

SPI特性SPI總線包括4條邏輯線,定義如下:

MISO:Master input slave output 主機輸入,從機輸出(數據來自從機);

MOSI:Master output slave input 主機輸出,從機輸入(數據來自主機);

SCLK :Serial Clock 串行時鐘信號,由主機產生發送給從機;

SS:Slave Select 片選信號,由主機發送,以控制與哪個從機通信,通常是低電平有效信號。

其他制造商可能會遵循其他命名規則,但是最終他們指的相同的含義。以下是一些常用術語;

MISO也可以是SIMO,DOUT,DO,SDO或SO(在主機端);

MOSI也可以是SOMI,DIN,DI,SDI或SI(在主機端);

NSS也可以是CE,CS或SSEL;

SCLK也可以是SCK;

本文將按照以下命名進行講解[MISO, MOSI, SCK,NSS]

下圖顯示了單個主機和單個從機之間的典型SPI連接。

qmyYVf.png

主從連接

時鐘頻率SPI總線上的主機必須在通信開始時候配置并生成相應的時鐘信號。在每個SPI時鐘周期內,都會發生全雙工數據傳輸。

主機在MOSI線上發送一位數據,從機讀取它,而從機在MISO線上發送一位數據,主機讀取它。

就算只進行單向的數據傳輸,也要保持這樣的順序。這就意味著無論接收任何數據,必須實際發送一些東西!在這種情況下,我們稱其為虛擬數據;

從理論上講,只要實際可行,時鐘速率就可以是您想要的任何速率,當然這個速率受限于每個系統能提供多大的系統時鐘頻率,以及最大的SPI傳輸速率。

時鐘極性 CKP/Clock Polarity除了配置串行時鐘速率(頻率)外,SPI主設備還需要配置時鐘極性。

根據硬件制造商的命名規則不同,時鐘極性通常寫為CKP或CPOL。時鐘極性和相位共同決定讀取數據的方式,比如信號上升沿讀取數據還是信號下降沿讀取數據;

CKP可以配置為1或0。這意味著您可以根據需要將時鐘的默認狀態(IDLE)設置為高或低。極性反轉可以通過簡單的邏輯逆變器實現。您必須參考設備的數據手冊才能正確設置CKP和CKE。

CKP = 0:時鐘空閑 IDLE為低電平 0;

CKP = 1:時鐘空閑 IDLE為高電平 1;

時鐘相位 CKE /Clock Phase (Edge)除配置串行時鐘速率和極性外,SPI主設備還應配置時鐘相位(或邊沿)。根據硬件制造商的不同,時鐘相位通常寫為CKE或CPHA;

顧名思義,時鐘相位/邊沿,也就是采集數據時是在時鐘信號的具體相位或者邊沿;

CKE = 0:在時鐘信號 SCK的第一個跳變沿采樣;

CKE = 1:在時鐘信號 SCK的第二個跳變沿采樣;

時鐘配置總結綜上幾種情況,下圖總結了所有時鐘配置組合,并突出顯示了實際采樣數據的時刻;

其中黑色線為采樣數據的時刻;

藍色線為SCK時鐘信號;

具體如下圖所示;

qmmYNz.png

模式編號SPI的時鐘極性和相位的配置通常稱為 SPI模式,所有可能的模式都遵循以下約定;具體如下表所示;

SPI ModeCPOLCPHA

0 [00]00

1 [01]01

2 [10]10

3 [11]11

除此之外,我們還應該仔細檢查微控制器數據手冊中包含的模式表,以確保一切正常。

多從機模式前面說到SPI總線必須有一個主機,可以有多個從機,那么具體連接到SPI總線的方法有以下兩種:

第一種方法:多NSS

通常,每個從機都需要一條單獨的SS線。

如果要和特定的從機進行通訊,可以將相應的 NSS信號線拉低,并保持其他 NSS信號線的狀態為高電平;如果同時將兩個 NSS信號線拉低,則可能會出現亂碼,因為從機可能都試圖在同一條 MISO線上傳輸數據,最終導致接收數據亂碼。

具體連接方式如下圖所示;

f6n2yu.png

多NSS連接

第二種方法:菊花鏈

在數字通信世界中,在設備信號(總線信號或中斷信號)以串行的方式從一 個設備依次傳到下一個設備,不斷循環直到數據到達目標設備的方式被稱為菊花鏈。

菊花鏈的最大缺點是因為是信號串行傳輸,所以一旦數據鏈路中的某設備發生故障的時候,它下面優先級較低的設備就不可能得到服務了;

另一方面,距離主機越遠的從機,獲得服務的優先級越低,所以需要安排好從機的優先級,并且設置總線檢測器,如果某個從機超時,則對該從機進行短路,防止單個從機損壞造成整個鏈路崩潰的情況;

具體的連接如下圖所示;

菊花鏈連接

其中紅線加粗為數據的流向;

所以最終的數據流向圖可以表示為:

z6ZFNv.png

數據流圖

SCK為時鐘信號,8clks表示8個邊沿信號;

其中D為數據,X為無效數據;

所以不難發現,菊花鏈模式充分使用了SPI其移位寄存器的功能,整個鏈充當通信移位寄存器,每個從機在下一個時鐘周期將輸入數據復制到輸出。

優缺點SPI通訊的優勢使SPI作為串行通信接口脫穎而出的原因很多;

全雙工串行通信;

高速數據傳輸速率。

簡單的軟件配置;

極其靈活的數據傳輸,不限于8位,它可以是任意大小的字;

非常簡單的硬件結構。從站不需要唯一地址(與I2C不同)。從機使用主機時鐘,不需要精密時鐘振蕩器/晶振(與UART不同)。不需要收發器(與CAN不同)。

SPI的缺點沒有硬件從機應答信號(主機可能在不知情的情況下無處發送);

通常僅支持一個主設備;

需要更多的引腳(與I2C不同);

沒有定義硬件級別的錯誤檢查協議;

RS-232和CAN總線相比,只能支持非常短的距離;

編程實現下面是通過STM32的cubemx自動生成的HAL庫代碼,比較簡單,截取了其中一部分,具體如下;

static void MX_SPI1_Init(void){ hspi1.Instance = SPI1; hspi1.Init.Mode = SPI_MODE_MASTER; //主機模式 hspi1.Init.Direction = SPI_DIRECTION_2LINES; //全雙工 hspi1.Init.DataSize = SPI_DATASIZE_8BIT; //數據位為8位 hspi1.Init.CLKPolarity = SPI_POLARITY_LOW; //CPOL=0 hspi1.Init.CLKPhase = SPI_PHASE_1EDGE; //CPHA為數據線的第一個變化沿 hspi1.Init.NSS = SPI_NSS_SOFT; //軟件控制NSS hspi1.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_2;//2分頻,32M/2=16MHz hspi1.Init.FirstBit = SPI_FIRSTBIT_MSB; //最高位先發送 hspi1.Init.TIMode = SPI_TIMODE_DISABLE; //TIMODE模式關閉 hspi1.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;//CRC關閉 hspi1.Init.CRCPolynomial = 10; //默認值,無效 if (HAL_SPI_Init(&hspi1) != HAL_OK) //初始化 { _Error_Handler(__FILE__, __LINE__); }} //發送數據HAL_StatusTypeDef HAL_SPI_Transmit(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size, uint32_t Timeout);//接收數據HAL_StatusTypeDef HAL_SPI_Receive(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size, uint32_t Timeout);

責任編輯:haq

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

    關注

    18

    文章

    6187

    瀏覽量

    137517
  • SPI
    SPI
    +關注

    關注

    17

    文章

    1789

    瀏覽量

    95114
  • 串行通信
    +關注

    關注

    4

    文章

    587

    瀏覽量

    36087
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    客戶改了一個電阻就炸機?原因并沒有那么簡單

    客戶改了一個電阻就炸機?原因并沒有那么簡單【樣機芯片介紹】本次調試的樣機主控IC為思睿達主推的成都啟臣微的CR6853B,該IC為副邊控制IC,該IC是一款高集成度,低功耗的電流模PWM控制芯片,該
    的頭像 發表于 05-08 09:59 ?198次閱讀
    客戶改了一個電阻就炸機?原因<b class='flag-5'>并沒有</b><b class='flag-5'>那么</b><b class='flag-5'>簡單</b>

    看完這篇,SPI其實也很簡單嘛(可下載)

    首先我們來簡單介紹一下SPISPI是串行外設接口(SerialPeripheralInterface)簡單來講就是它一種高速的,全雙工,同步的通信總線被各種總線搞的暈頭轉向的人來說就
    發表于 03-26 14:29 ?2次下載

    在TIDA-00570提供的參考設計中,并沒有100歐姆的端接電阻,請問怎么處理?

    請問,APP-FPGA和DLPC910之間的A、B、C、D四組LVDS信號,DLPC910手冊上寫明需要外接100歐姆端接電阻,但是在TIDA-00570提供的參考設計中,并沒有100歐姆的端接電阻,請問怎么處理?
    發表于 02-24 06:34

    ADS1198 DRDY并沒有自動變成高電平,而是一直維持在低電平,為什么?

    手冊上說DRDY會在SCLK的下降沿自動變成高電平(DRDY s pulled high at the falling edge of SCLK),但為什么我做了幾次后發現DRDY并沒有自動變成高電平,而是一直維持在低電平。
    發表于 02-06 07:14

    請問有沒有ADS1293的SPI的各個寄存器的介紹?

    請問有沒有ADS1293的SPI的各個寄存器的介紹,數據手冊中并沒有詳細介紹,TI給的官方歷程中涉及到很多與開發板相關的引腳,所以不太理解給出的例程。
    發表于 01-15 07:05

    ADS58B18通過SPI控制將其test pattern寄存器設置為001或010,為什么輸出并沒有全為0或1而是變化的?

    ADS58B18通過SPI控制將其 test pattern 寄存器設置為001或010,但其輸出并沒有全為 0或1,而是變化的。我通過SPI讀該寄存器,ovr_sdout輸出顯示該寄存器已經
    發表于 01-15 07:04

    DAC5687沒有設置差分,采用的等效單端,那么內部PLL可以工作嗎?

    時鐘模式采用PLL模式,datasheet要求輸入時鐘采用差分,但是我并沒有設置差分,而是采用的等效單端,那么內部PLL可以工作嗎? 如今情況是可以測到滿偏電流,但是輸出端一直是高電平,有個小波動,這是為什么啊?
    發表于 01-09 08:17

    編寫好ADS1148讀寫數據的驅動時候,發現SPI總線上的數據并沒有被讀回來,是什么原因呢?

    在編寫好ADS1148 讀寫數據的驅動時候,發現SPI總線上的數據并沒有被讀回來,從示波器上,可以發現SPI的read命令是沒有問題的,可是SDO上面沒數據,后來進一步查看是ADS11
    發表于 12-06 07:13

    進行ads1299短接噪聲測試時,增益更改后短接噪聲并沒有發生變化,為什么?

    在進行ads1299短接噪聲測試時,ads1299的增益更改,短接噪聲并沒有發生變化,而且在使用內部方波測試時,方波不對成,在增益為1時,短接噪聲為0.35mV左右,這是為什么呢
    發表于 11-14 07:46

    TPA2005為什么實際測量輸出波形根輸入一樣,并沒有放大阿?

    我選用的TPA2005D1芯片,輸入電容3300pF,輸入電阻150K。輸出33uH(160mA)電感,1uF電容。 為什么實際測量輸出波形根輸入一樣,并沒有放大阿? 輸入波形:1k,1V的音頻信號。
    發表于 10-12 08:46

    THS7530增益控制電壓加到0.9V并沒有放大到40多dB,為什么?

    按照數據手冊上FIG.21的接法,輸入100mV VPP以下的信號,增益控制電壓加到0.9V并沒有放大到40多dB,只放大到700mV VPP;下圖是TINA里面的仿真模型,為什么增益控制電壓
    發表于 09-06 08:18

    為什么INA188的GBW并沒有1Mhz?

    請問下,為什么INA188的GBW并沒有1Mhz, 但是在官方推薦的應用(TIDA-01063)中卻可以適用于20Mhz的傳感器的檢測?
    發表于 08-02 10:39

    單獨使用AFE031芯片并沒有任何輸出怎么解決?

    你好,在使用AFE031芯片與非C2000系列芯片連接時,按照C2000Ware中boostxl_afe031_f28379d_dacmode示例中初始化完成后,使用SPI任意向AFE031芯片發送一個數據,示波器中并沒有數據變化,請問這種情況怎么解決呢?
    發表于 07-30 06:48

    編譯運行ESP8266_RTOS_SDK-master,發現程序并沒有正確執行,為什么?

    ,eagle.irom0text.bin---->0x20000燒寫到相應地址,程序運行后,發現并沒有正確執行,請問是否燒寫地址錯誤,或者是配置FLASH錯誤
    發表于 07-12 08:21

    靜態庫中定義的INIT_DEVICE_EXPORT函數并沒有被系統調用,為什么?

    1,將一段代碼編譯成靜態庫 2,主工程鏈接這個靜態庫 3,靜態庫里的函數并沒有被主工程調用 4,靜態庫中定義了一些 INIT_DEVICE_EXPORT 函數 問題: 靜態庫中定義的 INIT_DEVICE_EXPORT 函數并沒有被系統調用,百思不得其解,求各位大佬指
    發表于 07-04 06:49
    主站蜘蛛池模板: 日本一区高清视频 | 日本特黄特黄刺激大片免费 | 天天摸天天操天天干 | 一级一片免费视频播放 | 色综合久久98天天综合 | 爽好舒服快给老师 | 三级成人影院 | 你懂的在线免费 | 奇米欧美 | 国产美女精品久久久久久久免费 | 天堂视频免费在线观看 | 日韩毛片免费视频一级特黄 | 国产精品美女一区二区三区 | 美女张开大腿让男人捅 | 97色综合 | 色com| 色综合亚洲天天综合网站 | 狠狠的操 | 91精品久久久久含羞草 | 亚洲成人一级片 | 天天看毛片 | 天天天天色 | 天天色成人网 | 天天操网站 | 亚洲免费成人在线 | 亚洲综合色吧 | 国产综合色在线视频区色吧图片 | 国产激烈床戏无遮挡在线观看 | 操碰视频在线 | 免费亚洲视频在线观看 | 成人a一级毛片免费看 | 国产成人在线网址 | julia一区二区三区中文字幕 | 精品你懂的 | 成人性色生活片免费看爆迷你毛片 | 国产自在自线午夜精品视频在 | 午夜影院404 | 狠狠干干干 | 人人插人人爽 | 日本精品一卡二卡≡卡四卡 | 欧美性狂猛xxxxxbbbbb |