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

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

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

3天內不再提示

需要把握住的SPI通信知識點

痞子衡嵌入式 ? 來源:最后一個bug ? 作者:bug菌 ? 2022-06-17 17:03 ? 次閱讀

SPI通信嵌入式領域是非常常用的一種通信方式了,相比串口、IIC等等,SPI通信是一種高速、高效率的串行接口技術

然而最近在新項目開發中使用SPI通信卻遇到了不少問題,過程中還是有挺多技術細節和知識點需要把握住的,那么今天bug菌就結合最近的使用情況和一直以來在SPI通信上踩過的坑進行總結和記錄,一起避坑。 本文為基礎鞏固篇:

1通信形式

SPI是一種全雙工、同步串行的通信方式,全雙工、半雙工等,表示某一時刻,數據的流動形式,全雙工即可雙向同時收發,而半雙工則在一個時刻只能收或者發,通常全雙工具有兩條獨立通信線路,而半雙工則共用同一條線路。

af95fd88-ed5d-11ec-ba43-dac502259ad0.png

從SPI通信接線圖可以看出,MOSI用于主機數據輸出,從機數據輸入,MISO引腳的數據流則剛好與之相反,所以數據流收發是走的兩條獨立的線路,從而可實現全雙工通信模式,當然你也可以用于只用于單向數據傳輸,比如省略掉MISO僅主機傳輸從機數據等。

SPI通信有一個SCLK時鐘線作為通信的同步信號,用來標定數據在MOSI和MISO引腳上的傳輸情況,SCLK是由主機來控制提供,從機檢測識別,從而同步完成數據傳輸。

片選信號CS引腳,還記得有一次面試問片選信號CS英文是什么?英文直譯即可--Chip Select。

片選信號在大部分數字芯片都有存在,外界給該引腳相應的電平即可選中,相當于一個"總開關",大部分從設備都是低電平被選中(電路圖中通常在CS上劃線標識),如果一直被選中則直接接地即可;當然也有少部分高電平選中則可直接接到VCC,切記不可懸空,以免異常。

這樣看SPI的通信線路非常簡單,沒有繁雜的線路硬件也省了不少事,但很多朋友包括bug菌曾經因為把主機的MOSI接到從機的MISO而折騰得不輕,都是慣性思維惹的禍,一定要記住是對應引腳相連。

afa70146-ed5d-11ec-ba43-dac502259ad0.png

2通信線路

SPI是一種主從通信方式,在SPI通信總線上通常只有一個主機,一切通信的開始都是以主機發起,那如果在一條總線上與多個從設備通信呢?下面以兩個從機為例,更多的從機也是類似的。

afb31620-ed5d-11ec-ba43-dac502259ad0.png

通過不同的片選引腳來選中不同的從設備,從而完成一對多的通信過程。通常多從機的情況都會采用多余的IO口連接從設備的片選引腳,以便分時控制從設備,達到一主多從機的主從控制方式。

當然如果獨立的IO口引腳有限,可以采用IO口擴展芯片進行選中,也是比較方便的。

3通信數據

SPI通信是一種交換數據的形式,主機根據SCLK時鐘把數據從MOSI引腳按bit位發送的同時,從機也以相同的速率把數據從MISO引腳傳輸,其傳輸數據形式如下:

afbdc3ae-ed5d-11ec-ba43-dac502259ad0.png

從SPI通信數據流圖可以看出其發送與接收形成了一個封閉的環,所要傳輸的數據像水在一根管道內循環流動,所以其硬件線路上并沒有像I2C那樣有所謂的應答機制,通信效率上提高不少,但數據可靠性也會有一定的減弱。

前面bug也談到SPI是一種主從通信機制,那么使得“管子”內數據流涌動的源泉一方面需要SPI的SCLK時鐘保持好節奏,另一方面就是需要主機來推動,所以如果master只是想獲取slave的數據,也需要發送空數據來使得整個數據流動起來,從而獲得從機的數據。

細心的朋友應該注意到上圖中MSB和LSB方向了,通常SPI通信都是以MSB來進行發送,但像stm32芯片這樣的芯片可以設置是LSB先發送還是MSB先發送。

所以在分析SPI通信數據的時候這些數據都是需要提前了解的。

4通信電平?

SPI比較麻煩點的就是時鐘極性和時鐘相位的確定了,但再怎么麻煩也就確定了4種模式。

如下是4種模式的時序圖,其中CPOL(Clock Polarity)表示時鐘極性,CPHA(Clock Phase)表示時鐘相位。

afc7bbe8-ed5d-11ec-ba43-dac502259ad0.png

afd2a5da-ed5d-11ec-ba43-dac502259ad0.png

從圖中我們可以分析得到:

1、CPOL和CPHA共同決定數據的采集方式。

2、CPOL決定了SCLK默認狀態,當CPOL=0,時鐘空閑時是低電平;當CPOL=1,時鐘空閑時為高電平。

3、CPHA決定了數據在第幾個跳變沿采集,當CPHA=0,在SCLK第一個跳變沿采集穩定數據;當CPHA=1,在SCLK第二個跳變沿采集穩定數據。

每個bit的數據交換,都是在電平穩定的時候進行數據電平采集,在電平變化的時候進行數據發送,一般從設備像高精度ADC等等,出廠就已經是固定了某種模式,我們需要做的就是通過配置可編程的主機SPI外設在相同的一種頻率和模式下通信,否則就是造成數據錯亂。

現在比較流行庫開發,很多外設使用案例直接可以拿過來用,或者嘗試著調整幾個參數就可以了,似乎不需要懂太多的原理,但這樣的學習終究只是把芯片玩起來了,要做到一通百通還是得從最原始的理論出發,只有把握住這些重點才能在項目開發的過程中直面問題并搞定它。

下一篇進階避坑篇,我們再更加深入聊聊SPI。

原文標題:大話SPI通信--基礎鞏固篇

文章出處:【微信公眾號:痞子衡嵌入式】歡迎添加關注!文章轉載請注明出處。

審核編輯:湯梓紅

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

    關注

    10

    文章

    2878

    瀏覽量

    88051
  • SPI通信
    +關注

    關注

    0

    文章

    35

    瀏覽量

    11358
  • MOSI
    +關注

    關注

    0

    文章

    5

    瀏覽量

    3984

原文標題:大話SPI通信--基礎鞏固篇

文章出處:【微信號:pzh_mcu,微信公眾號:痞子衡嵌入式】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    spi master接口的fpga實現

    前言 當你器件的引腳賊少的時候,需要主機和從機通信spi就派上了用場,它可以一對多,但只是片選到的從機能和主機通信,其他的掛機。 spi
    的頭像 發表于 11-16 10:35 ?349次閱讀
    <b class='flag-5'>spi</b> master接口的fpga實現

    接口測試理論、疑問收錄與擴展相關知識點

    本文章使用王者榮耀游戲接口、企業微信接口的展示結合理論知識,講解什么是接口測試、接口測試理論、疑問收錄與擴展相關知識點知識學院,快來一起看看吧~
    的頭像 發表于 11-15 09:12 ?308次閱讀
    接口測試理論、疑問收錄與擴展相關<b class='flag-5'>知識點</b>

    移為通信閃耀亮相2024中國摩博會,攜手錢江摩托共創智能騎行新未來

    隨著新國標政策的逐步落地執行,以及消費者對高品質智能車輛需求的日益增加,兩輪車市場正在加速向智能化轉型。移為通信敏銳地把握住這一發展趨勢,憑借深厚的技術積累和廣泛的市場布局,幫助國內外兩輪車廠商在智能化升級中實現技術與成本的平衡。
    的頭像 發表于 09-20 16:32 ?391次閱讀
    移為<b class='flag-5'>通信</b>閃耀亮相2024中國摩博會,攜手錢江摩托共創智能騎行新未來

    單片機SPI通信實現

    在深入探討單片機(如基于STM32、AVR、PIC等)如何通過SPI(Serial Peripheral Interface)進行通信之前,我們先概述SPI通信的基本原理,隨后以STM
    的頭像 發表于 09-09 17:00 ?496次閱讀

    模擬電子技術知識點問題總結概覽

    給大家分享模擬電子技術知識點問題總結。
    的頭像 發表于 05-08 15:16 ?1149次閱讀
    模擬電子技術<b class='flag-5'>知識點</b>問題總結概覽

    PCB主板對三防漆的選擇具體要求在哪里?需要哪些測試?

    很多PCBA工廠在使用 三防漆 時對于產品本身特性有所認知,但在不同使用環境、溫度、濕度變化時卻沒有去把握住三防漆特性變化。在使用的過程中沒有好的防護措施,會對人造成一定的傷害,所以使用三防漆一定
    的頭像 發表于 04-17 16:57 ?942次閱讀

    一篇搞定DCS系統相關知識點

    目標。DCS系統廣泛應用于各個行業,如化工、電力、制藥等。在這些行業中,DCS系統可以實現對生產過程的集中監控和分散控制,提高生產效率和產品質量,降低能耗和減少環境污染,從而保證產品質量,并確保生產過程的安全可靠。 二.DCS系統知識點
    的頭像 發表于 03-26 18:40 ?884次閱讀
    一篇搞定DCS系統相關<b class='flag-5'>知識點</b>

    使用myir開發板進行spi通信的疑問求解

    spi1的a7節,開啟(或不開啟)m4_spi1的節點依然無法進行通信。 問題:兩個spi
    發表于 03-26 07:39

    光纖通信應對高流量高標準挑戰與光纖鏈路運維要點解析

    面對如此高流量高標準的增長趨勢,作為通信網骨干的光纖通信承受著巨大的升級壓力,相應地,關于光纖鏈路運維的知識點及注意事項也逐漸受到人們的重視。
    發表于 03-22 11:30 ?538次閱讀
    光纖<b class='flag-5'>通信</b>應對高流量高標準挑戰與光纖鏈路運維要點解析

    【量子計算機重構未來 | 閱讀體驗】第二章關鍵知識點

    本帖最后由 oxlm_1 于 2024-3-6 23:20 編輯 之所以將第二章單獨拿出來,是因為在閱讀過程中,發現第二章知識點較多,理解起來比較耗時間。 第二章的主要知識點: 量子
    發表于 03-06 23:17

    企業在實施MES時要把握什么

    電子發燒友網站提供《企業在實施MES時要把握什么.docx》資料免費下載
    發表于 02-22 15:01 ?1次下載

    鴻蒙知識點

    install package File ? 這里列舉的幾個命令是不是很熟悉?一看名字就知道和安卓中的adb是對應關系。不需要去記憶,在需要使用到的時候去官網查一下就行: hdc使用指導 2、Mac系統配置hdc 環境變量 3、項目中的
    的頭像 發表于 01-31 17:40 ?935次閱讀
    鴻蒙<b class='flag-5'>知識點</b>

    電路隔離的基礎知識點匯總

    隔離 什么是隔離?為什么需要隔離? 隔離是一種防止電流在兩個通信之間流動的手段。一般在兩種情況下需使用隔離:第一種是可能會出現導致設備受損或人員傷害的浪涌電流;第二種是互連涉及到不同的地電
    發表于 01-03 08:19

    詳解SystemVue中AtoD模型的help文件

    看懂軟件中ADC模型的help文件,需要懂的知識點也是不少的哈!
    的頭像 發表于 12-26 17:06 ?640次閱讀
    詳解SystemVue中AtoD模型的help文件

    淺談初級電工必備知識點

    對于初學電工的朋友來說,掌握一些基礎且實用的知識點是非常重要的。本文旨在分享初級電工應該掌握的核心知識,幫助新手電工更好地入門和提升技能。
    的頭像 發表于 12-26 10:44 ?1093次閱讀
    主站蜘蛛池模板: 国产极品美女视频福利| 亚洲中文 字幕 国产 综合| 亚洲国产精品一区二区动图| 伊人久久综合成人亚洲| 不戴套挺进人妻怀孕| 韩国甜性涩爱| 欧美日韩在线亚洲一| 亚洲成年男人的天堂网| 99亚偷拍自图区亚洲| 国模沟沟一区二区三区| 欧美午夜精品A片一区二区HD| 鸭子玩富婆流白浆视频| 99热只有这里有精品| 国内精品免费久久影院| 欧美高清视频www夜色资源网| 亚洲精品成人无码区一在线观看| 99热久这里都是精品小草| 国产综合在线视频| 青青青久久| 欧美色偷偷亚洲天堂bt| 亚洲精品AV中文字幕在线| 成年人视频免费在线观看| 久久午夜夜伦痒痒想咳嗽P| 同桌上课把奶露出来给我玩| 99RE6这里只有精品国产AV| 好男人好资源在线播放| 日韩美一区二区| 91综合精品网站久久| 精品国产在线观看福利| 涩涩涩涩爱网站| 99热在线观看精品| 久久秋霞理伦片| 亚洲国产日韩欧美高清片a| 东京热百度影音| 嫩草影院在线观看精品| 一边喂奶一边做边爱| 国产精品色欲AV亚洲三区软件| 欧美最猛12teevideos欧美| 国产精品人妻系列21P| 妻子+免费观看完整| 2012中文字幕手机在线|