RM新时代网站-首页

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

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

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

串行外圍設(shè)備接口如何使用

454398 ? 來(lái)源:wv ? 2019-09-27 09:41 ? 次閱讀

步驟1:總而言之,SPI是什么?

SPI是一種通信協(xié)議,最初是由Motorola開發(fā)的,在兩個(gè)電子設(shè)備之間傳輸信息。這是一種全雙工協(xié)議,這意味著兩個(gè)設(shè)備能夠同時(shí)彼此“交談”。

這兩個(gè)設(shè)備被指定為“主”設(shè)備和“從”設(shè)備。主設(shè)備是始終啟動(dòng)每個(gè)對(duì)話并控制對(duì)話進(jìn)行速度的芯片。從設(shè)備僅在主設(shè)備請(qǐng)求時(shí)才同時(shí)發(fā)送和接收信息。

步驟2:如何進(jìn)行SPI通信?

要使兩個(gè)設(shè)備之間的通信正常進(jìn)行,有四個(gè)使用的導(dǎo)線:通常標(biāo)記為CS或SS(用于從機(jī)選擇)的片選導(dǎo)線,主輸出從輸入數(shù)據(jù)線(MOSI),主輸入從輸出數(shù)據(jù)線(MISO)和串行時(shí)鐘線( SCK)。

主設(shè)備將CS線拉低,以與另一側(cè)的從設(shè)備指示它希望與其通信。因?yàn)檫@是一條單獨(dú)的電線,被賦予了“低”電壓信號(hào),所以這意味著主機(jī)可以通過(guò)將其特定電線驅(qū)動(dòng)為低電平來(lái)實(shí)際控制多個(gè)“從”設(shè)備。

MOSI和MISO數(shù)據(jù)行可以完成您可能已經(jīng)猜到的事情;這兩條線允許SPI為全雙工。數(shù)據(jù)位以高電壓或低電壓信號(hào)的形式在兩個(gè)設(shè)備之間沿一個(gè)方向或另一個(gè)方向傳輸,具體取決于我們正在查看的數(shù)據(jù)線。

SCK線控制速度傳輸MOSI和MISO線上的數(shù)據(jù)位。像CS線一樣,SCK線也由主機(jī)控制,并以高和低周期驅(qū)動(dòng)以創(chuàng)建“時(shí)鐘脈沖”,以控制何時(shí)在這些線上傳輸數(shù)據(jù)。可以將SPI配置為在時(shí)鐘變高或變低時(shí)傳輸數(shù)據(jù)。

第3步:您一直說(shuō)數(shù)據(jù)的“位”

實(shí)際上是。 SPI被設(shè)計(jì)(并且是真正成為SPI所必需的)以字節(jié)大小的通信塊工作,八位到一個(gè)字節(jié)。因此,對(duì)于每個(gè)數(shù)據(jù)傳輸,時(shí)鐘和兩條數(shù)據(jù)線上都會(huì)有8個(gè)時(shí)鐘脈沖和8個(gè)數(shù)據(jù)傳輸。

但是,有些器件,例如ADI公司AD5628芯片在Digilent的PmodDA4上,它使用串行外設(shè)接口,但表示它們傳輸12位數(shù)據(jù)而不是8位數(shù)據(jù)。雖然這似乎是不可能的,因?yàn)槟荒苁褂肧PI協(xié)議來(lái)傳輸8位數(shù)據(jù),然后僅傳輸4位數(shù)據(jù),但是當(dāng)我們深入研究該芯片的數(shù)據(jù)手冊(cè)時(shí),便找到了解決方案。滾動(dòng)一點(diǎn)后,我們可以看到DAC的移位寄存器實(shí)際上是32位長(zhǎng)(第22頁(yè))。可以很好地將其分為四個(gè)單獨(dú)的8位傳輸。

步驟4:我們?nèi)绾蝹鬏敶藬?shù)據(jù)?

與其他通信協(xié)議不同,SPI是它能夠以多種方式傳輸數(shù)據(jù),因此功能相當(dāng)廣泛。根據(jù)每個(gè)芯片想要接收數(shù)據(jù)的方式,可以先發(fā)送最高有效位(MSB)或先發(fā)送最低有效位(LSB)來(lái)發(fā)送信息。

但是真正的多功能性來(lái)自四種不同的SPI時(shí)鐘模式,可供選擇。這些模式可以調(diào)整時(shí)鐘信號(hào)是從高電壓值開始還是從低電壓值開始,以及數(shù)據(jù)的位是隨著時(shí)鐘信號(hào)轉(zhuǎn)變?yōu)楦唠娖綘顟B(tài)而傳輸還是隨著時(shí)鐘轉(zhuǎn)變?yōu)榈蛻B(tài)狀態(tài)而傳輸。上表概述了每種時(shí)鐘模式的配置。同樣,根據(jù)設(shè)備期望接收信息的方式來(lái)選擇每種模式。

因此,如果我們希望兩個(gè)設(shè)備通過(guò)SPI互相發(fā)送210值,則最高位首先,在時(shí)鐘下降沿傳輸數(shù)據(jù),首先讓主機(jī)將芯片選擇線拉低,然后使時(shí)鐘信號(hào)拉高,讓每個(gè)設(shè)備將適當(dāng)?shù)奈弧凹虞d”到數(shù)據(jù)線上,然后讓主機(jī)將時(shí)鐘信號(hào)拉低,以便兩個(gè)設(shè)備“收集”在線上的數(shù)據(jù)位。重復(fù)該過(guò)程,直到所有位均已傳輸,然后主機(jī)最終再次將芯片選擇線拉高以結(jié)束通信。

步驟5:接收數(shù)據(jù)如何?

要正確接收數(shù)據(jù)所需執(zhí)行的操作取決于接收數(shù)據(jù)的組件類型。如果您擁有主設(shè)備(通常是某種形式的微控制器),則將信息發(fā)送到另一設(shè)備,該設(shè)備不是微控制器,而只是一個(gè)只做一件事并且永遠(yuǎn)不會(huì)回應(yīng)您的小芯片(例如在這種情況下產(chǎn)生模擬電壓信號(hào)) (Analog Devices AD5628),那么作為用戶創(chuàng)建電路的用戶通常不需要執(zhí)行任何操作。只需確保您以設(shè)備想要接收的格式將信息發(fā)送到設(shè)備即可。

如果您希望從設(shè)備接收反饋(或者正在將信息發(fā)送到所需的其他微控制器)進(jìn)行編程以正確接收和解釋傳入的信息),您可能需要做兩件事。如果您使用的SPI庫(kù)支持全部接收(并返回)8位數(shù)據(jù),例如chipKIT/Arduino的SPI庫(kù),那么您可以簡(jiǎn)單地將所有信息接收并存儲(chǔ)到一個(gè)變量中

如果不使用SPI庫(kù),則必須收集各個(gè)信息位,然后將它們“網(wǎng)狀”在一起。 (可能)最容易通過(guò)接收數(shù)組中的信息位來(lái)完成。

步驟6:需要考慮的其他事項(xiàng)

盡管看起來(lái)SPI是通過(guò)某種方式完成的并且可以始終如一地工作,但情況并非總是如此。嘗試使用主設(shè)備與其從芯片進(jìn)行通信時(shí),線路的另一端可能沒(méi)有從設(shè)備。作為主設(shè)備的電子芯片無(wú)法物理地知道它是否通過(guò)電線連接到其他芯片。

此外,SPI中可能使用的許多代碼僅用于SPI庫(kù)。一些配置(例如,是否應(yīng)首先發(fā)送最高或最低有效位或何時(shí)應(yīng)在時(shí)鐘周期發(fā)送)僅由庫(kù)處理。但是,也可以“手動(dòng)”執(zhí)行SPI協(xié)議。畢竟,SPI使用的所有信號(hào)就是這樣。高低壓信號(hào)。因此,只要將主機(jī)用于發(fā)送電壓信號(hào)的引腳連接到“從”設(shè)備上的正確引腳,就可以通過(guò)“ SPI”完成通信,而無(wú)需實(shí)際使用指定的SPI引腳。

自然地,使用SPI庫(kù)可能會(huì)更快(無(wú)論是鍵入速度還是實(shí)際速度),但是很高興知道所有通信(無(wú)論是SPI還是其他方式)實(shí)際上都是電壓信號(hào)。/p》

第7步:運(yùn)行SPI:沒(méi)有庫(kù)

雖然理論很不錯(cuò),但我個(gè)人也看到了有關(guān)某物的實(shí)際示例時(shí),它會(huì)更有用看起來(lái)像在代碼中。這將不需要使用預(yù)定義的SPI庫(kù),因?yàn)槲艺J(rèn)為查看SPI協(xié)議的各個(gè)部分何時(shí)發(fā)生會(huì)更有幫助。代碼本身(在下面的文本文件中提供)基于Digilent的uC32,這是一個(gè)功能強(qiáng)大的Arduino兼容微控制器。

步驟8:運(yùn)行SPI:使用庫(kù)

您還可以將SPI與適當(dāng)?shù)膸?kù)一起使用。這種方法(毫不奇怪)大大減少了您作為用戶需要鍵入的代碼量,但同時(shí)從本質(zhì)上來(lái)說(shuō)還是抽象的。除非您已經(jīng)知道每個(gè)命令在內(nèi)部執(zhí)行的操作,否則沒(méi)有簡(jiǎn)單的方法只能通過(guò)查看它們來(lái)弄清楚發(fā)生了什么。

步驟9:一些最終想法

正如我之前提到的,SPI是電子領(lǐng)域中使用最廣泛的通信協(xié)議之一,但并沒(méi)有給人以為使用 協(xié)議的印象。 ; I2CUART,USB等許多其他協(xié)議,甚至簡(jiǎn)單的通用輸入/輸出(GPIO)引腳在通訊方面都有其優(yōu)點(diǎn)和缺點(diǎn)。

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

    關(guān)注

    17

    文章

    1706

    瀏覽量

    91502
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    KeyStone架構(gòu)串行外設(shè)接口(SPI)手冊(cè)

    SPI(Serial Peripheral Interface)是一種高速、全雙工、同步的串行通信協(xié)議,它允許微控制器與一個(gè)或多個(gè)外圍設(shè)備進(jìn)行通信。SPI通信通常使用四根線:SCK(時(shí)鐘線
    發(fā)表于 12-16 10:33 ?0次下載

    單片機(jī)語(yǔ)音芯片中的SPI Flash探秘及其分類詳解

    在單片機(jī)語(yǔ)音芯片的領(lǐng)域中,SPIflash,即串行外圍設(shè)備接口閃存,扮演著舉足輕重的角色。它是一種時(shí)鐘同步的串行通訊接口,如單片機(jī)語(yǔ)音芯片與
    的頭像 發(fā)表于 12-03 01:01 ?180次閱讀
    單片機(jī)語(yǔ)音芯片中的SPI Flash探秘及其分類詳解

    通信協(xié)議之SPI總線硬件篇

    SPI:Serial Peripheral Interface,串行外圍設(shè)備接口。 是由摩托羅拉在20世紀(jì)80年代中期開發(fā)的同步串行總線接口
    的頭像 發(fā)表于 11-25 17:56 ?392次閱讀
    通信協(xié)議之SPI總線硬件篇

    SPI接口靜電放電防護(hù)方案

    SPI(Serial Peripheral Interface,串行外圍設(shè)備接口),是Motorola公司提出的一種同步串行接口技術(shù),是一種
    的頭像 發(fā)表于 09-20 15:31 ?375次閱讀
    SPI<b class='flag-5'>接口</b>靜電放電防護(hù)方案

    SPI通信協(xié)議的基本概念和工作模式

    SPI(Serial Peripheral Interface)通信協(xié)議,即串行外圍設(shè)備接口,是一種高速、全雙工、同步通信總線,由摩托羅拉公司提出并廣泛應(yīng)用。SPI以其高效的數(shù)據(jù)傳輸能力和簡(jiǎn)單的硬件
    的頭像 發(fā)表于 09-09 17:04 ?1338次閱讀

    SPI總線的定義和特點(diǎn)

    SPI總線(Serial Peripheral Interface),全稱為串行外圍設(shè)備接口,是由Motorola公司提出并定義的一種同步、串行、高速的通信總線。SPI總線以其獨(dú)特的優(yōu)
    的頭像 發(fā)表于 09-03 14:05 ?776次閱讀

    串行接口與并行接口的區(qū)別

    串行接口(Serial Interface)與并行接口(Parallel Interface)是計(jì)算機(jī)與外部設(shè)備之間進(jìn)行數(shù)據(jù)傳輸?shù)膬煞N基本方式,它們?cè)诙鄠€(gè)方面存在顯著差異。以下將從數(shù)據(jù)
    的頭像 發(fā)表于 08-25 17:08 ?3633次閱讀

    串行接口的工作原理和結(jié)構(gòu)

    串行接口(Serial Interface)的工作原理和結(jié)構(gòu)是理解其在計(jì)算機(jī)與外部設(shè)備之間數(shù)據(jù)傳輸方式的重要基礎(chǔ)。以下將詳細(xì)闡述串行接口的工
    的頭像 發(fā)表于 08-25 17:01 ?1664次閱讀

    使用GMSL隧穿對(duì)遠(yuǎn)程汽車外設(shè)進(jìn)行身份驗(yàn)證

    外圍設(shè)備是經(jīng)過(guò)授權(quán)的高質(zhì)量組件非常重要。千兆多媒體串行鏈路(GMSL)串行-反序列化器(SerDes)對(duì)與DS28C40的結(jié)合是一種解決方案,用于連接嵌入在外圍設(shè)備
    的頭像 發(fā)表于 03-05 08:23 ?1212次閱讀
    使用GMSL隧穿對(duì)遠(yuǎn)程汽車外設(shè)進(jìn)行身份驗(yàn)證

    是否有可能使用CYSPP配置文件連接到外圍設(shè)備

    我們的現(xiàn)有系統(tǒng)使用中央和外圍設(shè)備,使用基于 Microchip RN4020 的中央和外圍設(shè)備。 由于供應(yīng)限制的原因,我們希望將英飛凌 CYBT-483056 SoC 用于 BLE central。 我們想知道是否有可能使用CYSPP配置文件連接到
    發(fā)表于 03-01 06:54

    用PSOC6 BLE當(dāng)外圍設(shè)備,兩者傳輸數(shù)據(jù)時(shí),psoc6概率性出現(xiàn)藍(lán)牙掛死的原因?

    我們用PSOC6 BLE當(dāng)外圍設(shè)備,手機(jī)當(dāng)中心設(shè)備, 兩者傳輸數(shù)據(jù)時(shí),psoc6概率性(1%的概率)出現(xiàn)藍(lán)牙掛死。具體現(xiàn)象是 斷開手機(jī)藍(lán)牙后,無(wú)法收到ble廣播,硬件上查到ble的晶振一直處于起振
    發(fā)表于 02-21 06:54

    什么是I2C接口?什么是I3C接口?I2C與I3C的區(qū)別

    I2C接口是一種串行通信協(xié)議,全稱為Inter-Integrated Circuit,即集成電路間總線。它是一種雙向、兩線制(SCL和SDA)的串行通信接口,主要用于連接微控制器和其他
    的頭像 發(fā)表于 02-17 14:39 ?6240次閱讀
    什么是I2C<b class='flag-5'>接口</b>?什么是I3C<b class='flag-5'>接口</b>?I2C與I3C的區(qū)別

    usb-c接口是什么意思 pd接口和usb接口哪個(gè)更好

    以通過(guò)USB-C接口提供更高的功率輸出,以滿足各種設(shè)備的充電需求。 USB接口是一種通用的串行總線標(biāo)準(zhǔn),它早期版本主要用于連接計(jì)算機(jī)與外圍設(shè)備
    的頭像 發(fā)表于 01-31 17:01 ?8131次閱讀

    PSOC6如何通過(guò)I2C與外圍設(shè)備通信?

    PSOC6 如何通過(guò) I2C 與外圍設(shè)備通信? 我不太明白這一系列芯片 CAN 如何向上或向下拉動(dòng)?我根據(jù)例程編寫了一個(gè)與I2C通信的外圍設(shè)備,但它 CAN不起作用, ADXL345模塊
    發(fā)表于 01-31 06:08

    TC39x如何在用戶模式下訪問(wèn)外圍設(shè)備?

    你好, 我已經(jīng)在 TC39x 中啟用了用戶模式 1,并希望在用戶模式下允許訪問(wèn)一些外圍設(shè)備和功能。 我主要想在用戶模式下使用 cpu endinit(在啟用和禁用看門狗的上下文中)。
    發(fā)表于 01-22 06:52
    RM新时代网站-首页