精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

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

3天內不再提示

USART波特率與SPI速率對比

黃工的嵌入式技術圈 ? 來源:黃工的嵌入式技術圈 ? 作者:黃工的嵌入式技術 ? 2020-01-15 16:37 ? 次閱讀

本文主要結合STM32,講述UART和SPI有關速率相關的知識。

1.串口和SPI內部時鐘 在回答上面問題之前,需要先了解STM32內部時鐘的概念,尤其是串口和SPI的內部時鐘。

STM32里包含有系統時鐘、AHB時鐘和APB時鐘。APB時鐘來源于AHB,AHB時鐘來源于系統時鐘。

從上圖中可以看出,時鐘就像流水一樣,從時鐘源匯聚到系統時鐘上,再從系統時鐘繼續分頻或者說是繼續分發到AHB、APB。

通常我們談論的MCU能跑到多少M、主頻多少M,其實所指的就是系統時鐘。

這些時鐘在不同的STM32系列中是不一樣的,我們以STM32F401為例,手冊上說它的APB1的最高時鐘是42MHz,APB2的最高時鐘是84MHz,不同的外設因為掛在不同的總線上,所以速度就不太相同了。比如USART1掛在APB2上,所以它的時鐘最高就是84MHz, USART2是掛在APB1上,它的總線時鐘最快就是42MHz。當我們配置串口的時候會發現,USART2的baudrate最高是2.625Mbit/s,但是同樣配置的USART1卻可以達到5.25Mbit/s,這就是因為所在的總線時鐘的不同而不同。

那我們怎么知道使用的USART1、USART2到底掛在哪條總線上呢?去從數據手冊里尋找,直接在手冊里搜索關鍵詞APB1或者APB2就可以快速找到列表。 2.串口的過采樣技術規范

比如說做數據的接收,我們可以看到串口是通過過采樣技術來實現對數據的接收,因為它沒有時鐘線,只能通過高于波特率的16倍或者8倍對總線上的數據一個一個地進行采集,根據最后采集到的情況來判斷信號的狀態。

舉個例子,當我們采集START信號的時候,實際上它要求采集到1110 x0x0x0 000這樣固定的序列的時候才認為是一個起始信號。START信號在串口里是一個bit的低電平信號,我們用16倍的速率進行采樣,首先它在前面會做一個下降沿檢測,這個檢測是要在前面的4個bit能檢測到1110,硬件會對總線上的數據根據采樣點一直進行檢測,這里的采樣點就是APB的時鐘,串口掛在不同的APB上用的時鐘不一樣。采樣的時候采集到1110就知道是一個下降沿,后面的x意思是任意的,后面的幾個位中至少需要檢測到三個0,而最后邊的三個位需要是連續的三個0,這樣才能被判定是一個起始位。其實只是判斷了3、5、7、8、9、10這六個點,只要是0,就可以確認了。這里我們是以START信號為例,其他信號也是這樣的。

可能有人會有疑問,x是任意的,不去檢測,如果0不滿足要求應該怎么辦呢?

如果3、5、7、8、9、10這六個點都是0,那就可以認為這是一個起始信號;如果在3、5、7和8、9、10這兩個階段都滿足至少有兩個bit是0的話,那就可以確認它是起始信號,確認的意思是說它里面的接收緩沖區非空,標志位就已經置上了,承認這個信號,但是還要給一個NE的標志位,因為雖然承認了這個信號,但里面是存在噪聲的。我們看串口的中斷標志位的時候就可以看到,在它的錯誤事件里就有一個NOISE FLAG,這個位就表示當串口在接收的時候,在總線上檢測到的電平并不是一個標準的、完整的高電平或者低電平,會有錯誤但不影響整個數據的接收,如果在接收的時候開啟了EIE位,錯誤可以產生一個中斷,讓MCU對總線上的情況有一個了解。

如果前三個bit滿足條件,而后三個bit沒有滿足的話,那就說明這個數據是錯誤的,就不會置標志位了,只要在3、5、7和8、9、10這兩個階段中有一個階段不滿足條件,就不會置位,并且還會有噪聲的說明。

當然了,這些都是在檢測下降沿沒有問題的情況下來說的,如果說在檢測下降沿1110都不完整或者是錯誤的,直接就會回到ideal狀態,重新等待下一個數據發送過來。

3.SPI的速度為什么這么快?

我們可以看一下SPI的時序圖,圖中上面兩根線是CLOCK線,它根據配置的不同而不同,在CPHA=0時,即在第一個時鐘沿進行采樣,CPOL表示的是時鐘的默認電平是高電平(CPOL=1)還是低電平(CPOL=0),這里看到的每個時鐘都可以傳輸一個bit。

4.SPI速率是不是應該和系統時鐘一樣? 其實不是,因為系統需要時間去獲取采集到的數據,所以SPI的時鐘分頻系數最小是二分之一的分頻,那么就是說SPI的速度是系統時鐘的一半了。

有人覺得同步傳輸明顯優于異步傳輸,因為有時鐘線,傳輸速率會更高。

但其實這種說法并不是完全正確的,因為每一種傳輸方式都有自己的優勢。比如串口有自動波特率的功能,就是說在接收的時候并不知道主機是按照什么樣的波特率進行傳輸的,那就只能等主機發一個特定字節的數據過來并且檢測數據的狀態,然后自己硬件去設置波特率的寄存器,這樣就可以在下一次傳輸的時候和主機使用相同的波特率。其次,在不同的溫度范圍內,內部的RC振蕩器是有溫漂的并且很大,最標準的校準方法是給它一個時鐘沿,但是很多時候并沒有這個時鐘沿,那我們就可以用自動波特率。每次通訊的時候都采用自動波特率,就是每次都先接收,接收之后BRR寄存器里面的值就會隨著溫度的變化發生改變,MCU就可以根據BRR的值來調節HSITRIM。這個方法的好處是不需要提供一個非常標準的時鐘,通過串口通訊這種異步的方式就可以把時鐘信息傳給單片機內部。

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

    關注

    2258

    文章

    10828

    瀏覽量

    352487
  • 波特率
    +關注

    關注

    2

    文章

    290

    瀏覽量

    33926
  • spi模式、spi速率

    關注

    0

    文章

    2

    瀏覽量

    2278
收藏 人收藏

    評論

    相關推薦

    串口通信中的波特率你真的了解嗎?差距竟如此重要!

    波特率在串口通信中的作用在串口通信中,波特率起著至關重要的作用。因為在傳輸數據時,發送方和接收方需要以相同的波特率進行通信。如果兩端的波特率不同,那么就會出現數據丟失、傳輸錯誤等問題,
    的頭像 發表于 08-27 11:46 ?553次閱讀
    串口通信中的<b class='flag-5'>波特率</b>你真的了解嗎?差距竟如此重要!

    關于比特波特率的定義與區別介紹

    比特波特率都是衡量數字通信中數據傳輸速率的重要參數。比特率直接表示了單位時間內傳輸的數據量(以比特為單位),而波特率則表示了信號變化的速率
    的頭像 發表于 08-05 14:31 ?208次閱讀

    如何使用示波器測量串口波特率

    在通信和電子測量領域,串口波特率是一個至關重要的參數,它決定了數據在串行通信線上的傳輸速率。使用示波器來測量串口波特率是一種常見且有效的方法,尤其是在沒有專業串口調試工具或需要更精確測量時。本文將
    的頭像 發表于 05-27 16:25 ?2960次閱讀

    芯海應用筆記:通用 MCU USART 自動波特率檢測

    本文檔介紹和說明芯??萍计煜?CS32 系列 MCU 的自動波特率檢測功能,并為不具備硬件自動波特率檢測的 MCU 產品提供替代軟件方法 。*附件:應用筆記:芯海通用MCU USART自動波特
    發表于 05-16 11:42

    波特率有什么危害尼?又該如何避免?

    深入探討了波特率過高可能帶來的危害,并提供了一些實用建議來保護設備不受影響。在通信領域,波特率是決定數據傳輸速度的重要參數。然而,波特率設置不當可能會對設備造成嚴重的影響。本文旨在揭示波特率
    的頭像 發表于 04-03 16:45 ?939次閱讀

    請問STM32F407 SPI如何設置不同的波特率

    請教下大家F407 SPI1(Master)的波特率,因為讀取TI ADS1274,需要將SPI波特率設置成某些特殊值,比如 51200 * 256 = 13107200,請問是否能做
    發表于 03-13 08:23

    為啥要轉換波特率 波特率和傳輸速率的關系

    對于串行多主 CAN 總線,如果波特率被稱為“500000波特”,則 CAN 上的該端口每秒最多可傳輸500000位。
    的頭像 發表于 03-06 17:38 ?3534次閱讀
    為啥要轉換<b class='flag-5'>波特率</b> <b class='flag-5'>波特率</b>和傳輸<b class='flag-5'>速率</b>的關系

    波特率發生器使用哪個定時器 波特率發生器的時鐘來源是什么

    波特率發生器是一種用于控制串行數據通信速率的設備,它可以生成特定波特率的時鐘信號。在嵌入式系統、通信設備和計算機硬件中,波特率發生器的使用十分常見。
    的頭像 發表于 01-24 09:56 ?1423次閱讀

    什么是串口波特率?串口通信為什么要設置波特率?

    什么是串口波特率?串口通信為什么要設置波特率波特率與比特的關系 如何選擇串口波特率?? 串口波特率
    的頭像 發表于 01-22 16:10 ?1548次閱讀

    以太網CAN轉換器波特率的設置步驟是怎樣的?

    確定CAN總線的波特率:首先,需要確定所連接的CAN總線的波特率。CAN總線的波特率通常以位/秒(bps)為單位,用于確定數據傳輸速度。
    的頭像 發表于 01-17 09:24 ?765次閱讀

    單片機的各個通信協議的波特率

    下面是一些常見的波特率數值,這些波特率通常被用于串口通信,SPI、I2C、CAN等接口的實際波特率可能有所不同:USART:110bps30
    的頭像 發表于 12-09 08:00 ?2236次閱讀
    單片機的各個通信協議的<b class='flag-5'>波特率</b>

    什么是串口波特率?串口通信為什么要設置波特率

    。串口通信為什么要設置波特率?今天,我們就來認識波特率。什么是串口波特率?我們需要先了解一下什么是波特率。波特率(BaudRate)是衡量數
    的頭像 發表于 11-03 08:21 ?3786次閱讀
    什么是串口<b class='flag-5'>波特率</b>?串口通信為什么要設置<b class='flag-5'>波特率</b>?

    SJA1000波特率計算

    電子發燒友網站提供《SJA1000波特率計算.zip》資料免費下載
    發表于 10-13 11:43 ?6次下載
    SJA1000<b class='flag-5'>波特率</b>計算

    CAN通信波特率不對會怎樣?

    ,該波特率是處理器要進行通信所需的數據傳輸速率。波特率不正確將導致通信失敗,并可能導致危險的結果,因此正確的波特率設置是至關重要的。 CAN通信協議的
    的頭像 發表于 10-11 17:19 ?2088次閱讀

    STM32 USART自動波特率檢測

    電子發燒友網站提供《STM32 USART自動波特率檢測.pdf》資料免費下載
    發表于 09-25 15:09 ?8次下載
    STM32 <b class='flag-5'>USART</b>自動<b class='flag-5'>波特率</b>檢測