新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > SPI、IIC、UART、can區別

        SPI、IIC、UART、can區別

        作者: 時間:2016-11-28 來源:網絡 收藏
        第一個區別當然是名字:

        SPI(Serial Peripheral Interface:串行外設接口);
        I2C(INTER IC BUS)
        UART(Universal Asynchronous Receiver Transmitter:通用異步收發器)

        第二,區別在電氣信號線上:
        SPI總線由三條信號線組成:串行時鐘(SCLK)、串行數據輸出(SDO)、串行數據輸入(SDI)。SPI總線可以實現 多個SPI設備互相連接。提供SPI串行時鐘的SPI設備為SPI主機或主設備(Master),其他設備為SPI從機或從設備(Slave)。主從設備間可以實現全雙工通信,當有多個從設備時,還可以增加一條從設備選擇線。
        如果用通用IO口模擬SPI總線,必須要有一個輸出口(SDO),一個輸入口(SDI),另一個口則視實現的設備類型而定,如果要實現主從設備,則需輸入輸出口,若只實現主設備,則需輸出口即可,若只實現從設備,則只需輸入口即可。

        I2C總線是雙向、兩線(SCL、SDA)、串行、多主控(multi-master)接口標準,具有總線仲裁機制,非常適合在器件之間進行近距離、非經常性的數據通信。在它的協議體系中,傳輸數據時都會帶上目的設備的設備地址,因此可以實現設備組網。
        如果用通用IO口模擬I2C總線,并實現雙向傳輸,則需一個輸入輸出口(SDA),另外還需一個輸出口(SCL)。(注:I2C資料了解得比較少,這里的描述可能很不完備)

        UART總線是異步串口,因此一般比前兩種同步串口的結構要復雜很多,一般由波特率產生器(產生的波特率等于傳輸波特率的16倍)、UART接收器、UART發送器組成,硬件上由兩根線,一根用于發送,一根用于接收。
        顯然,如果用通用IO口模擬UART總線,則需一個輸入口,一個輸出口。

        第三,從第二點明顯可以看出,SPI和UART可以實現全雙工,但I2C不行;

        第四,看看牛人們的意見吧!
        wudanyu:I2C線更少,我覺得比UART、SPI更為強大,但是技術上也更加麻煩些,因為I2C需要有雙向IO的支持,而且使用上拉電阻,我覺得抗干擾能力較弱,一般用于同一板卡上芯片之間的通信,較少用于遠距離通信。SPI實現要簡單一些,UART需要固定的波特率,就是說兩位數據的間隔要相等,而SPI則無所謂,因為它是有時鐘的協議。
        quickmouse:I2C的速度比SPI慢一點,協議比SPI復雜一點,但是連線也比標準的SPI要少。

        本文引用地址:http://www.104case.com/article/201611/322756.htm
        posted @2009-02-22 23:00陳廣強 閱讀(185) |評論(0)| 編輯
        SPI總線
        SPI總線簡介

        同步外設接口(SPI)是由摩托羅拉公司開發的全雙工同步串行總線,該總線大量用在與EEPROM、ADC、FRAM和顯示驅動器之類的慢速外設器件通信。

        SPI(Serial Peripheral Interface)是一種串行同步通訊協議,由一個主設備和一個或多個從設備組成,主設備啟動一個與從設備的同步通訊,從而完成數據的交換。SPI 接口由SDI(串行數據輸入),SDO(串行數據輸出),SCK(串行移位時鐘),CS(從使能信號)四種信號構成,CS 決定了唯一的與主設備通信的從設備,如沒有CS 信號,則只能存在一個從設備,主設備通過產生移位時鐘來發起通訊。通訊時,數據由SDO 輸出,SDI 輸入,數據在時鐘的上升或下降沿由SDO 輸出,在緊接著的下降或上升沿由SDI 讀入,這樣經過8/16 次時鐘的改變,完成8/16 位數據的傳輸。

        SPI通信

        該總線通信基于主-從配置。它有以下4個信號:

        MOSI:主出/從入

        MISO:主入/從出

        SCK:串行時鐘

        SS:從屬選擇

        芯片上“從屬選擇”(slave-select)的引腳數決定了可連到總線上的器件數量。

        在SPI傳輸中,數據是同步進行發送和接收的。數據傳輸的時鐘基于來自主處理器的時鐘脈沖,摩托羅拉沒有定義任何通用SPI的時鐘規范。然而,最常用的時鐘設置基于時鐘極性(CPOL)和時鐘相位(CPHA)兩個參數,CPOL定義SPI串行時鐘的活動狀態,而CPHA定義相對于SO-數據位的時鐘相位。CPOL和CPHA的設置決定了數據取樣的時鐘沿。

        數據方向和通信速度

        SPI傳輸串行數據時首先傳輸最高位。波特率可以高達5Mbps,具體速度大小取決于SPI硬件。例如,Xicor公司的SPI串行器件傳輸速度能達到5MHz。

        SPI總線接口及時序

        SPI總線包括1根串行同步時鐘信號線以及2根數據線。

        SPI模塊為了和外設進行數據交換,根據外設工作要求,其輸出串行同步時鐘極性和相位可以進行配置,時鐘極性(CPOL)對傳輸協議沒有重大的影響。如果CPOL=0,串行同步時鐘的空閑狀態為低電平;如果CPOL=1,串行同步時鐘的空閑狀態為高電平。時鐘相位(CPHA)能夠配置用于選擇兩種不同的傳輸協議之一進行數據傳輸。如果CPHA=0,在串行同步時鐘的第一個跳變沿(上升或下降)數據被采樣;如果CPHA=1,在串行同步時鐘的第二個跳變沿(上升或下降)數據被采樣。SPI主模塊和與之通信的外設備時鐘相位和極性應該一致。SPI主模塊和與之通信的外設備時鐘相位和極性應該一致。個人理解這句話有2層意思:其一,主設備SPI時鐘和極性的配置應該由外設來決定;其二,二者的配置應該保持一致,即主設備的SDO同從設備的SDO配置一致,主設備的SDI同從設備的SDI配置一致。因為主從設備是在SCLK的控制下,同時發送和接收數據,并通過2個雙向移位寄存器來交換數據。SPI接口時序如圖3、圖4所示。

        SPI是一個環形總線結構,由ss(cs)、sck、sdi、sdo構成,其時序其實很簡單,主要是在sck的控制下,兩個雙向移位寄存器進行數據交換。
        假設下面的8位寄存器裝的是待發送的數據10101010,上升沿發送、下降沿接收、高位先發送。
        那么第一個上升沿來的時候數據將會是sdo=1;寄存器=0101010x。下降沿到來的時候,sdi上的電平將所存到寄存器中去,那么這時寄存器=0101010sdi,這樣在8個時鐘脈沖以后,兩個寄存器的內容互相交換一次。這樣就完成里一個spi時序。


        上一頁 1 2 3 4 下一頁

        關鍵詞: SPIIICUARTca

        評論


        技術專區

        主站蜘蛛池模板: 申扎县| 上蔡县| 仁布县| 哈尔滨市| 绥棱县| 台东市| 扎赉特旗| 沙洋县| 青龙| 福安市| 昌邑市| 娄底市| 麻江县| 德令哈市| 武邑县| 富蕴县| 黎城县| 沽源县| 和田县| 镇远县| 定结县| 资阳市| 宣武区| 玛纳斯县| 镇康县| 沅陵县| 阜平县| 丁青县| 清丰县| 广灵县| 开远市| 上高县| 平乡县| 丹巴县| 扬州市| 平昌县| 新和县| 南平市| 汕尾市| 沐川县| 鲜城|
        <blockquote id="aueyq"><tfoot id="aueyq"></tfoot></blockquote><ul id="aueyq"></ul>
        <ul id="aueyq"></ul>
        <strike id="aueyq"></strike>
        <samp id="aueyq"></samp>