娇小w搡bbbb搡bbb,《第一次の人妻》,中国成熟妇女毛茸茸,边啃奶头边躁狠狠躁视频免费观看

【GD32 MCU 入門教程】GD32 MCU 常見外設(shè)介紹(15)CAN 模塊介紹

發(fā)布者:科技創(chuàng)新實踐者最新更新時間:2024-11-04 來源: elecfans關(guān)鍵字:GD32  MCU  CAN  模塊 手機看文章 掃描二維碼
隨時隨地手機看文章

CAN是控制器局域網(wǎng)絡(luò)(Controller Area Network)的簡稱,它是由研發(fā)和生產(chǎn)汽車電子產(chǎn)品著稱的德國BOSCH公司開發(fā)的,并最終成為國際標(biāo)準(zhǔn)(ISO11519),是國際上應(yīng)用最廣泛的現(xiàn)場總線之一。


CAN總線協(xié)議已經(jīng)成為汽車計算機控制系統(tǒng)和嵌入式工業(yè)控制局域網(wǎng)的標(biāo)準(zhǔn)總線,并且擁有以CAN為底層協(xié)議專為大型貨車和重工機械車輛設(shè)計的J1939協(xié)議。近年來,它具有的高可靠性和良好的錯誤檢測能力受到重視,被廣泛應(yīng)用于汽車計算機控制系統(tǒng)和環(huán)境溫度惡劣、電磁輻射強及振動大的工業(yè)環(huán)境。


15.1.CAN 基礎(chǔ)知識

CAN 物理層

與I2C、SPI等具有時鐘信號的同步通訊方式不同,CAN通訊并不是以時鐘信號來進行同步的,它是一種異步通訊,只具有CAN_High和CAN_Low兩條信號線,共同構(gòu)成一組差分信號線,以差分信號的形式進行通訊。

閉環(huán)總線網(wǎng)絡(luò)

CAN物理層的形式主要有兩種,如下圖所示CAN閉環(huán)總線通訊網(wǎng)絡(luò)是一種遵循ISO11898標(biāo)準(zhǔn)的高速、短距離“閉環(huán)網(wǎng)絡(luò)”,它的總線最大長度為40m,通信速度最高為1Mbps,總線的兩端各要求有一個“120歐”的電阻。

輸入圖片說明

開環(huán)總線網(wǎng)絡(luò)

如下圖所示CAN開環(huán)總線通訊網(wǎng)絡(luò)是一種遵循ISO11519-2標(biāo)準(zhǔn)的低速、遠(yuǎn)距離“開環(huán)網(wǎng)絡(luò)”,它的最大傳輸距離為1km,最高通訊速率為125kbps,兩根總線是獨立的、不形成閉環(huán),要求每根總線上各串聯(lián)有一個“2.2千歐”的電阻。

輸入圖片說明

通訊節(jié)點

從CAN通訊網(wǎng)絡(luò)圖可了解到,CAN總線上可以掛載多個通訊節(jié)點,節(jié)點之間的信號經(jīng)過總線傳輸,實現(xiàn)節(jié)點間通訊。由于CAN通訊協(xié)議不對節(jié)點進行地址編碼,而是對數(shù)據(jù)內(nèi)容進行編碼的,所以網(wǎng)絡(luò)中的節(jié)點個數(shù)理論上不受限制,只要總線的負(fù)載足夠即可,可以通過中繼器增強負(fù)載。

CAN通訊節(jié)點由一個CAN控制器及CAN收發(fā)器組成,控制器與收發(fā)器之間通過CAN_Tx及CAN_Rx信號線相連,收發(fā)器與CAN總線之間使用CAN_High及CAN_Low信號線相連。其中CAN_Tx及CAN_Rx使用普通的類似TTL邏輯信號,而CAN_High及CAN_Low是一對差分信號線,使用比較特別的差分信號,下一小節(jié)再詳細(xì)說明。

當(dāng)CAN節(jié)點需要發(fā)送數(shù)據(jù)時,控制器把要發(fā)送的二進制編碼通過CAN_Tx線發(fā)送到收發(fā)器,然后由收發(fā)器把這個普通的邏輯電平信號轉(zhuǎn)化成差分信號,通過差分線CAN_High和CAN_Low線輸出到CAN總線網(wǎng)絡(luò)。而通過收發(fā)器接收總線上的數(shù)據(jù)到控制器時,則是相反的過程,收發(fā)器把總線上收到的CAN_High及CAN_Low信號轉(zhuǎn)化成普通的邏輯電平信號,通過CAN_Rx輸出到控制器中。

例如,GD32的CAN片上外設(shè)就是通訊節(jié)點中的控制器,為了構(gòu)成完整的節(jié)點,還要給它外接一個收發(fā)器,在GD32E103V-EVAL V1.0開發(fā)板上使用型號為SN65HVD230的芯片作為CAN收發(fā)器。

CAN控制器與CAN收發(fā)器的關(guān)系如同TTL串口與MAX3232電平轉(zhuǎn)換芯片的關(guān)系,MAX3232芯片把TTL電平的串口信號轉(zhuǎn)換成RS-232電平的串口信號,CAN收發(fā)器的作用則是把CAN控制器的TTL電平信號轉(zhuǎn)換成差分信號(或者相反)。

差分信號

差分信號又稱差模信號,與傳統(tǒng)使用單根信號線電壓表示邏輯的方式有區(qū)別,使用差分信號傳輸時,需要兩根信號線,這兩個信號線的振幅相等,相位相反,通過兩根信號線的電壓差值來表示 邏輯0和邏輯1。如下圖所示差分信號使用了V+與V-信號的差值表達(dá)出了圖下方的信號。

輸入圖片說明

相對于單信號線傳輸?shù)姆绞剑褂貌罘中盘杺鬏斁哂腥缦聝?yōu)點:

抗干擾能力強,當(dāng)外界存在噪聲干擾時,幾乎會同時耦合到兩條信號線上,而接收端只關(guān)心兩個信號的差值,所以外界的共模噪聲可以被完全抵消。

能有效抑制它對外部的電磁干擾,同樣的道理,由于兩根信號的極性相反,他們對外輻射的電磁場可以相互抵消,耦合的越緊密,泄放到外界的電磁能量越少。

時序定位精確,由于差分信號的開關(guān)變化是位于兩個信號的交點,而不像普通單端信號依靠高低兩個閾值電壓判斷,因而受工藝,溫度的影響小,能降低時序上的誤差,同時也更適合于低幅度信號的電路。

由于差分信號線具有這些優(yōu)點,所以在USB協(xié)議、485協(xié)議、以太網(wǎng)協(xié)議及CAN協(xié)議的物理層中,都使用了差分信號傳輸。

CAN 協(xié)議中的差分信號

CAN協(xié)議中對它使用的CAN_High及CAN_Low表示的差分信號做了規(guī)定,見下表CAN協(xié)議標(biāo)準(zhǔn)表示的信號邏輯及下圖CAN差分信號(高速)所示。以高速CAN協(xié)議為例,當(dāng)表示邏輯1時(隱性電平),CAN_High和CAN_Low線上的電壓均為2.5v,即它們的電壓差VH-VL=0V;而表示邏輯0時(顯性電平),CAN_High的電平為3.5V,CAN_Low線的電平為1.5V,即它們的電壓差為VHVL=2V。例如,當(dāng)CAN收發(fā)器從CAN_Tx線接收到來自CAN控制器的低電平信號時(邏輯0),它會使CAN_High輸出3.5V,同時CAN_Low輸出1.5V,從而輸出顯性電平表示邏輯0。

CAN協(xié)議標(biāo)準(zhǔn)表示的信號邏輯

輸入鏈接說明

CAN 差分信號(高速)

輸入圖片說明

在 CAN 總線中,必須使它處于隱性電平(邏輯 1)或顯性電平(邏輯 0)中的其中一個狀態(tài)。假如有兩個 CAN 通訊節(jié)點,在同一時間,一個輸出隱性電平,另一個輸出顯性電平,類似 I2C 總線的“線 與”特性將使它處于顯性電平狀態(tài),顯性電平的名字就是這樣來的,即可以認(rèn)為顯性具有優(yōu)先的意味。

由于 CAN 總線協(xié)議的物理層只有 1 對差分線,在一個時刻只能表示一個信號,所以對通訊節(jié)點來說,CAN 通訊是半雙工的,收發(fā)數(shù)據(jù)需要分時進行。在 CAN 的通訊網(wǎng)絡(luò)中,因為共用總線,在整個網(wǎng)絡(luò)中同一時刻只能有一個通訊節(jié)點發(fā)送信號,其余的節(jié)點在該時刻都只能接收。

CAN 協(xié)議層

以上是 CAN 的物理層標(biāo)準(zhǔn),約定了電氣特性,以下介紹的協(xié)議層則規(guī)定了通訊邏輯。

CAN 的波特率及位同步

由于CAN屬于異步通訊,沒有時鐘信號線,連接在同一個總線網(wǎng)絡(luò)中的各個節(jié)點會像串口異步通訊那樣,節(jié)點間使用約定好的波特率進行通訊,特別地,CAN還會使用“位同步”的方式來抗干擾、吸收誤差,實現(xiàn)對總線電平信號進行正確的采樣,確保通訊正常。

位時序分解

為了實現(xiàn)位同步,CAN 協(xié)議把每一個數(shù)據(jù)位的時序分解成如下圖 CAN 位時序分解圖所示的 SS段、PTS 段、PBS1 段、PBS2 段,這四段的長度加起來即為一個 CAN 數(shù)據(jù)位的長度。分解后最小的時間單位是 Tq,而一個完整的位由 8~25 個 Tq 組成。為方便表示,CAN 位時序分解圖中的高低電平直接代表信號邏輯 0 或邏輯 1(不是差分信號)。

輸入圖片說明

該圖中表示的 CAN 通訊信號每一個數(shù)據(jù)位的長度為 19Tq,其中 SS 段占 1Tq,PTS 段占 6Tq,PBS1 段占 5Tq,PBS2 段占 7Tq。信號的采樣點位于 PBS1 段與 PBS2 段之間,通過控制各段的長度,可以對采樣點的位置進行偏移,以便準(zhǔn)確地采樣。

各段的作用介紹如下:

SS段(SYNC SEG)

SS 譯為同步段,若通訊節(jié)點檢測到總線上信號的跳變沿被包含在 SS 段的范圍之內(nèi),則表示節(jié)點與總線的時序是同步的,當(dāng)節(jié)點與總線同步時,采樣點采集到的總線電平即可被確定為該位的電 平。SS 段的大小固定為 1Tq。

PTS段(PROP SEG)

PTS 譯為傳播時間段,這個時間段是用于補償網(wǎng)絡(luò)的物理延時時間。是總線上輸入比較器延時和輸出驅(qū)動器延時總和的兩倍。PTS 段的大小可以為 1~8Tq。

PBS1段(PHASE SEG1)

PBS1 譯為相位緩沖段,主要用來補償邊沿階段的誤差,它的時間長度在重新同步的時候可以加長。PBS1 段的初始大小可以為 1~8Tq。

PBS2段(PHASE SEG2)

PBS2 這是另一個相位緩沖段,也是用來補償邊沿階段誤差的,它的時間長度在重新同步時可以縮短。PBS2 段的初始大小可以為 2~8Tq。

通訊的波特率

總線上的各個通訊節(jié)點只要約定好1個Tq的時間長度以及每一個數(shù)據(jù)位占據(jù)多少個Tq,就可以確定CAN通訊的波特率。

例如,假設(shè)圖5-53中的1Tq=1us,而每個數(shù)據(jù)位由19個Tq組成,則傳輸一位數(shù)據(jù)需要時間T1bit =19us,從而每秒可以傳輸?shù)臄?shù)據(jù)位個數(shù)為:

1x106/19 = 52631.6 (bps)

這個每秒可傳輸?shù)臄?shù)據(jù)位的個數(shù)即為通訊中的波特率。

同步過程分析

波特率只是約定了每個數(shù)據(jù)位的長度,數(shù)據(jù)同步還涉及到相位的細(xì)節(jié),這個時候就需要用到數(shù)據(jù)位內(nèi)的SS、PTS、PBS1及PBS2段了。

根據(jù)對段的應(yīng)用方式差異,CAN 的數(shù)據(jù)同步分為硬同步和重新同步。其中硬同步只是當(dāng)存在“幀起始信號”時起作用,無法確保后續(xù)一連串的位時序都是同步的,而重新同步方式可解決該問題,這 兩種方式具體介紹如下:

(1)硬同步

若某個 CAN 節(jié)點通過總線發(fā)送數(shù)據(jù)時,它會發(fā)送一個表示通訊起始的信號(即下一小節(jié)介紹的幀起始信號),該信號是一個由高變低的下降沿。而掛載到 CAN 總線上的通訊節(jié)點在不發(fā)送數(shù)據(jù)時, 會時刻檢測總線上的信號。

下圖硬同步過程圖所示,可以看到當(dāng)總線出現(xiàn)幀起始信號時,某節(jié)點檢測到總線的幀起始信號不在節(jié)點內(nèi)部時序的 SS 段范圍,所以判斷它自己的內(nèi)部時序與總線不同步,因而這個狀態(tài)的采樣點采集得的數(shù)據(jù)是不正確的。所以節(jié)點以硬同步的方式調(diào)整,把自己的位時序中的 SS 段平移至總線出現(xiàn)下降沿的部分,獲得同步,同步后采樣點就可以采集得正確數(shù)據(jù)了。

輸入圖片說明

(2)重新同步

前面的硬同步只是當(dāng)存在幀起始信號時才起作用,如果在一幀很長的數(shù)據(jù)內(nèi),節(jié)點信號與總線信號相位有偏移時,這種同步方式就無能為力了。因而需要引入重新同步方式,它利用普通數(shù)據(jù)位的高至低電平的跳變沿來同步(幀起始信號是特殊的跳變沿)。重新同步與硬同步方式相似的地方是它們都使用 SS 段來進行檢測,同步的目的都是使節(jié)點內(nèi)的 SS 段把跳變沿包含起來。

重新同步的方式分為超前和滯后兩種情況,以總線跳變沿與 SS 段的相對位置進行區(qū)分。第一種相位超前的情況如下圖所示,相位超前時的重新同步,節(jié)點從總線的邊沿跳變中,檢測到它內(nèi)部的時序比總線的時序相對超前2Tq,這時控制器在下一個位時序中的PBS1段增加2Tq的時間長度,使得節(jié)點與總線時序重新同步。

相位超前時的重新同步

輸入圖片說明

第二種相位滯后的情況如下圖所示,相位滯后時的重新同步,節(jié)點從總線的邊沿跳變中,檢測到它的時序比總線的時序相對滯后2Tq,這時控制器在前一個位時序中的 PBS2 段減少 2Tq 的時間長 度,獲得同步。

相位滯后時的重新同步

輸入圖片說明

在重新同步的時候,PBS1 和 PBS2 中增加或減少的這段時間長度被定義為“重新同步補償寬度SJW (reSynchronization Jump Width)”。一般來說 CAN 控制器會限定 SJW 的最大值,如限定了 最大 SJW=3Tq 時,單次同步調(diào)整的時候不能增加或減少超過 3Tq 的時間長度,若有需要,控制器會通過多次小幅度調(diào)整來實現(xiàn)同步。當(dāng)控制器設(shè)置的 SJW 極限值較大時,可以吸收的誤差加大,但通訊的速度會下降。

CAN 的報文種類及結(jié)構(gòu)

在 SPI 通訊中,片選、時鐘信號、數(shù)據(jù)輸入及數(shù)據(jù)輸出這 4 個信號都有單獨的信號線,I2C 協(xié)議包含有時鐘信號及數(shù)據(jù)信號 2 條信號線,異步串口包含接收與發(fā)送 2 條信號線,這些協(xié)議包含的 信號都比 CAN 協(xié)議要豐富,它們能輕易進行數(shù)據(jù)同步或區(qū)分?jǐn)?shù)據(jù)傳輸方向。而 CAN 使用的是兩條差分信號線,只能表達(dá)一個信號,簡潔的物理層決定了 CAN 必然要配上一套更復(fù)雜的協(xié)議,如 何用一個信號通道實現(xiàn)同樣、甚至更強大的功能呢?CAN 協(xié)議給出的解決方案是對數(shù)據(jù)、操作命令(如讀/寫)以及同步信號進行打包,打包后的這些內(nèi)容稱為報文。

在原始數(shù)據(jù)段的前面加上傳輸起始標(biāo)簽、片選(識別)標(biāo)簽和控制標(biāo)簽,在數(shù)據(jù)的尾段加上 CRC 校驗標(biāo)簽、應(yīng)答標(biāo)簽和傳輸結(jié)束標(biāo)簽,把這些內(nèi)容按特定的格式打包好,就可以用一個通道表達(dá)各種信號了,各種各樣的標(biāo)簽就如同 SPI 中各種通道上的信號,起到了協(xié)同傳輸?shù)淖饔谩.?dāng)整個數(shù)據(jù)包被傳輸?shù)狡渌O(shè)備時,只要這些設(shè)備按格式去解讀,就能還原出原始數(shù)據(jù),這樣的報文就被稱為 CAN 的“數(shù)據(jù)幀”。

為了更有效地控制通訊,CAN 一共規(guī)定了 5 種類型的幀,它們的類型及用途說明如下表幀的種類及其用途所示。

輸入圖片說明

數(shù)據(jù)幀的結(jié)構(gòu)

數(shù)據(jù)幀是在 CAN 通訊中最主要、最復(fù)雜的報文,我們來了解它的結(jié)構(gòu),如下圖數(shù)據(jù)幀的結(jié)構(gòu)所示。

輸入圖片說明

數(shù)據(jù)幀以一個顯性位(邏輯 0)開始,以 7 個連續(xù)的隱性位(邏輯 1)結(jié)束,在它們之間,分別有仲裁段、控制段、數(shù)據(jù)段、CRC 段和 ACK 段。

幀起始

SOF 段(Start Of Frame),譯為幀起始,幀起始信號只有一個數(shù)據(jù)位,是一個顯性電平,它用于通知各個節(jié)點將有數(shù)據(jù)傳輸,其它節(jié)點通過幀起始信號的電平跳變沿來進行硬同步。

仲裁段

當(dāng)同時有兩個報文被發(fā)送時,總線會根據(jù)仲裁段的內(nèi)容決定哪個數(shù)據(jù)包能被傳輸,這也是它名稱的由來。

仲裁段的內(nèi)容主要為本數(shù)據(jù)幀的 ID 信息(標(biāo)識符),數(shù)據(jù)幀具有標(biāo)準(zhǔn)格式和擴展格式兩種,區(qū)別就在于 ID 信息的長度,標(biāo)準(zhǔn)格式的 ID 為 11 位,擴展格式的 ID 為 29 位,它在標(biāo)準(zhǔn) ID 的基礎(chǔ)上多 出 18 位。在 CAN 協(xié)議中,ID 起著重要的作用,它決定著數(shù)據(jù)幀發(fā)送的優(yōu)先級,也決定著其它節(jié)點是否會接收這個數(shù)據(jù)幀。CAN 協(xié)議不對掛載在它之上的節(jié)點分配優(yōu)先級和地址,對總線的占有權(quán)是由信息的重要性決定的,即對于重要的信息,我們會給它打包上一個優(yōu)先級高的 ID,使它能夠及時地發(fā)送出去。也正因為它這樣的優(yōu)先級分配原則,使得 CAN 的擴展性大大加強,在總線上增加或減少節(jié)點并不影響其它設(shè)備。

報文的優(yōu)先級,是通過對 ID 的仲裁來確定的。根據(jù)前面對物理層的分析我們知道如果總線上同時出現(xiàn)顯性電平和隱性電平,總線的狀態(tài)會被置為顯性電平,CAN 正是利用這個特性進行仲裁。

若兩個節(jié)點同時競爭CAN總線的占有權(quán),當(dāng)它們發(fā)送報文時,若首先出現(xiàn)隱性電平,則會失去對總線的占有權(quán),進入接收狀態(tài)。如下圖過程所示,在開始階段,兩個設(shè)備發(fā)送的電平一樣,所以它們一直繼續(xù)發(fā)送數(shù)據(jù)。到了圖中箭頭所指的時序處,節(jié)點單元1發(fā)送的為隱性電平,而此時節(jié)點單元2發(fā)送的為顯性電平,由于總線的“線與”特性使它表達(dá)出顯示電平,因此單元2競爭總線成功,這個報文得以被繼續(xù)發(fā)送出去。

輸入圖片說明

仲裁段 ID 的優(yōu)先級也影響著接收設(shè)備對報文的反應(yīng)。因為在 CAN 總線上數(shù)據(jù)是以廣播的形式發(fā)送的,所有連接在 CAN 總線的節(jié)點都會收到所有其它節(jié)點發(fā)出的有效數(shù)據(jù),因而我們的 CAN 控制器大多具有根據(jù) ID 過濾報文的功能,它可以控制自己只接收某些 ID 的報文。

回看數(shù)據(jù)幀的結(jié)構(gòu)圖中的數(shù)據(jù)幀格式,可看到仲裁段除了報文 ID 外,還有 RTR、IDE 和SRR 位。

(1) RTR 位(Remote Transmission Request Bit),譯作遠(yuǎn)程傳輸請求位,它是用于區(qū)分?jǐn)?shù)據(jù)幀和遙控幀的,當(dāng)它為顯性電平時表示數(shù)據(jù)幀,隱性電平時表示遙控幀。

(2) IDE 位(Identifier Extension Bit),譯作標(biāo)識符擴展位,它是用于區(qū)分標(biāo)準(zhǔn)格式與擴展格式,當(dāng)它為顯性電平時表示標(biāo)準(zhǔn)格式,隱性電平時表示擴展格式。

(3) SRR 位(Substitute Remote Request Bit),只存在于擴展格式,它用于替代標(biāo)準(zhǔn)格式中的 RTR位。由于擴展幀中的 SRR 位為隱性位,RTR 在數(shù)據(jù)幀為顯性位,所以在兩個 ID 相同的標(biāo)準(zhǔn)格式 報文與擴展格式報文中,標(biāo)準(zhǔn)格式的優(yōu)先級較高。

控制段

在控制段中的 r1 和 r0 為保留位,默認(rèn)設(shè)置為顯性位。它最主要的是 DLC 段(Data Length Code),譯為數(shù)據(jù)長度碼,它由 4 個數(shù)據(jù)位組成,用于表示本報文中的數(shù)據(jù)段含有多少個字節(jié),DLC 段表 示的數(shù)字為 0~8。

數(shù)據(jù)段

數(shù)據(jù)段為數(shù)據(jù)幀的核心內(nèi)容,它是節(jié)點要發(fā)送的原始信息,由 0~8 個字節(jié)組成,MSB 先行。

CRC 段

為了保證報文的正確傳輸,CAN 的報文包含了一段 15 位的 CRC 校驗碼,一旦接收節(jié)點算出的CRC 碼跟接收到的 CRC 碼不同,則它會向發(fā)送節(jié)點反饋出錯信息,利用錯誤幀請求它重新發(fā)送。CRC 部分的計算一般由 CAN 控制器硬件完成,出錯時的處理則由軟件控制最大重發(fā)數(shù)。

在 CRC 校驗碼之后,有一個 CRC 界定符,它為隱性位,主要作用是把 CRC 校驗碼與后面的 ACK 段間隔起來。

ACK 段

ACK 段包括一個 ACK 槽位,和 ACK 界定符位。類似 I2C 總線,在 ACK 槽位中,發(fā)送節(jié)點發(fā)送的是隱性位,而接收節(jié)點則在這一位中發(fā)送顯性位以示應(yīng)答。在 ACK 槽和幀結(jié)束之間由 ACK 界定符間隔開。

幀結(jié)束

EOF 段(End Of Frame),譯為幀結(jié)束,幀結(jié)束段由發(fā)送節(jié)點發(fā)送的 7 個隱性位表示結(jié)束。

其它報文的結(jié)構(gòu)

關(guān)于其它的 CAN 報文結(jié)構(gòu),不再展開講解,其主要內(nèi)容見下圖 各種 CAN 報文的結(jié)構(gòu)。

輸入圖片說明

15.2.GD32 CAN 外設(shè)原理簡介

因篇幅有限,本文無法詳細(xì)介紹GD32所有系列CAN外設(shè)接口,下面以GD32E103為例,著重介紹下GD32E103的CAN外設(shè)簡介和結(jié)構(gòu)框圖,后介紹下各個系列的差異。

GD32 CAN 主要特性

? 支持CAN總線協(xié)議2.0A和2.0B;

? 支持CAN-FD幀(ISO11898-1和CAN-FD規(guī)范V1.0);

? 常規(guī)幀:通信波特率最大為1Mbit/s;

? CAN-FD幀:通信最大波特率為6Mbit/s;

? 支持傳輸延遲補償;

? 支持時間觸發(fā)通信(Time-triggered communication);

? 中斷使能和清除;

發(fā)送功能

? 3個發(fā)送郵箱;

? 支持發(fā)送優(yōu)先級;

? 支持發(fā)送時間戳。

接收功能

? 2個深度為3的接收FIFO;

? 具有28個標(biāo)識符過濾器;

? FIFO鎖定功能。

時間觸發(fā)通信

? 在時間觸發(fā)通信模式下禁用自動重傳;

? 16位定時器;

? 接收時間戳;

? 發(fā)送時間戳。

CAN 結(jié)構(gòu)框圖介紹

CAN 模塊結(jié)構(gòu)框圖

輸入圖片說明

GD32E103一共有兩個CAN控制器,分別為CAN0和CAN1。每個CAN控制器有3個發(fā)送郵箱,2個深度為3的接收FIFO。

CAN控制器包含多個寄存器,下面主要講解其中的控制寄存CAN_CTL和位時序寄存器CAN_BT。

控制寄存器 CAN_CTL

控制寄存器CAN_CTL負(fù)責(zé)管理CAN的工作模式,它使用以下寄存器位實現(xiàn)控制。

(1) DFZ調(diào)試凍結(jié)功能

DFZ(Debug freeze)調(diào)試凍結(jié),使用它可設(shè)置CAN處于工作狀態(tài)或禁止收發(fā)的狀態(tài),禁止收發(fā)時仍可訪問接收FIFO中的數(shù)據(jù)。這兩種狀態(tài)是當(dāng)STM32芯片處于程序調(diào)試模式時才使用的,平時使用 并不影響。

(2) TTC時間觸發(fā)通信

TTC(Time triggered communication)時間觸發(fā)通信,它用于配置CAN的時間觸發(fā)通信模式,在此模式下,CAN使用它內(nèi)部定時器產(chǎn)生時間戳,并把它保存在CAN_TMxP、CAN_RFIFOMPx寄存器中。內(nèi)部定時器在每個CAN位時間累加,在接收和發(fā)送的幀起始位被采樣,并生成時間戳。利用它可以實現(xiàn)ISO 11898-4 CAN標(biāo)準(zhǔn)的分時同步通信功能。

(3) ABOR自動離線恢復(fù)

ABOR(Automatic bus-off recovery) 自動離線恢復(fù),它用于設(shè)置是否使用自動離線管理功能。當(dāng)節(jié)點檢測到它發(fā)送錯誤或接收錯誤超過一定值時,會自動進入離線狀態(tài),在離線狀態(tài)中,CAN不能接收或發(fā)送報文。處于離線狀態(tài)的時候,可以軟件控制恢復(fù)或者直接使用這個自動離線管理功能,它會在適當(dāng)?shù)臅r候自動恢復(fù)。

(4) AWU自動喚醒

AWU(Automatic wakeup),自動喚醒功能,CAN外設(shè)可以使用軟件進入低功耗的睡眠模式,如果使能了這個自動喚醒功能,當(dāng)CAN檢測到總線活動的時候,會自動喚醒。

(5) AR自動重傳

AR(Automatic retransmission)報文自動重傳功能,設(shè)置這個功能后,當(dāng)報文發(fā)送失敗時會自動重傳至成功為止。若不使用這個功能,無論發(fā)送結(jié)果如何,消息只發(fā)送一次。

(6) RFO接收FIFO覆蓋

RFO (Receive FIFO overwrite)接收FIFO覆蓋,該功能用于鎖定接收FIFO。鎖定后,當(dāng)接收FIFO溢出時,會丟棄下一個接收的報文。若不鎖定,則下一個接收到的報文會覆蓋原報文。

(7) TFO發(fā)送FIFO順序

FTO(Tx FIFO order)報文發(fā)送順序的判定方法,當(dāng)CAN外設(shè)的發(fā)送郵箱中有多個待發(fā)送報文時,本功能可以控制它是根據(jù)報文的ID優(yōu)先級還是報文存進郵箱的順序來發(fā)送。

位時序寄存器(CAN_BT)及波特率

CAN外設(shè)中的位時序寄存器CAN_BT用于配置測試模式、波特率以及各種位內(nèi)的段參數(shù)。

(1) 測試模式

為方便調(diào)試,GD32的CAN提供了測試模式,配置位時序寄存器CAN_BT的SCMOD及LCMOD位可以控制使用正常模式、靜默模式、回環(huán)模式及靜默回環(huán)模式,見下圖四種通訊模式

輸入圖片說明

各個通訊模式介紹如下:

正常模式

正常模式下就是一個正常的CAN節(jié)點,可以向總線發(fā)送數(shù)據(jù)和接收數(shù)據(jù)。

靜默模式

靜默模式下,它自己的輸出端的邏輯0數(shù)據(jù)會直接傳輸?shù)剿约旱妮斎攵耍壿?可以被發(fā)送到總線,所以它不能向總線發(fā)送顯性位(邏輯0),只能發(fā)送隱性位(邏輯1)。輸入端可以從總線接收內(nèi)容。 由于它只可發(fā)送的隱性位不會強制影響總線的狀態(tài),所以把它稱為靜默模式。這種模式一般用于監(jiān)測,它可以用于分析總線上的流量,但又不會因為發(fā)送顯性位而影響總線。

回環(huán)模式

回環(huán)模式下,它自己的輸出端的所有內(nèi)容都直接傳輸?shù)阶约旱妮斎攵耍敵龆说膬?nèi)容同時也會被傳輸?shù)娇偩€上,即也可使用總線監(jiān)測它的發(fā)送內(nèi)容。輸入端只接收自己發(fā)送端的內(nèi)容,不接收來自總線上的內(nèi)容。使用回環(huán)模式可以進行自檢。

回環(huán)靜默模式

回環(huán)靜默模式是以上兩種模式的結(jié)合,自己的輸出端的所有內(nèi)容都直接傳輸?shù)阶约旱妮斎攵耍⑶也粫蚩偩€發(fā)送顯性位影響總線,不能通過總線監(jiān)測它的發(fā)送內(nèi)容。輸入端只接收自己發(fā)送端的內(nèi)容,不接收來自總線上的內(nèi)容。這種方式可以在“熱自檢”時使用,即自我檢查的時候,不會干擾總線。

以上說的各個模式,是不需要修改硬件接線的,如當(dāng)輸出直連輸入時,它是在GD32芯片內(nèi)部連接的,傳輸路徑不經(jīng)過STM32的CAN_Tx/Rx引腳,更不經(jīng)過外部連接的CAN收發(fā)器,只有輸出數(shù)據(jù) 到總線或從總線接收的情況下才會經(jīng)過CAN_Tx/Rx引腳和收發(fā)器。

(2)位時序及波特率

GD32外設(shè)定義的位時序與我們前面解釋的CAN標(biāo)準(zhǔn)時序有一點區(qū)別,見下圖GD32中的位時序。

輸入圖片說明

GD32的CAN外設(shè)位時序中只包含3段,分別是同步段SYNC_SEG、位段BS1及位段BS2,采樣點位于BS1及BS2段的交界處。其中SYNC_SEG段固定長度為1Tq,而BS1及BS2段可以在位時序寄存器CAN_BT設(shè)置它們的時間長度,它們可以在重新同步期間增長或縮短,該長度DSJW也可在位時序寄存器中配置。

理解GD32的CAN外設(shè)的位時序時,可以把它的BS1段理解為是由前面介紹的CAN標(biāo)準(zhǔn)協(xié)議中PTS段與PBS1段合在一起的,而BS2段就相當(dāng)于PBS2段。

了解位時序后,我們就可以配置波特率了。通過配置位時序寄存器CAN_BT的BS1[6:0]及BS2[4:0]寄存器位設(shè)定BS1及BS2段的長度后,我們就可以確定每個CAN數(shù)據(jù)位的時間:

BS1段時間: TS1=Tq x (BS1[6:0] + 1)

BS2段時間: TS2= Tq x (BS2[4:0] + 1)

一個數(shù)據(jù)位的時間: T1bit =1Tq+TS1+TS2 =1+ (BS1[6:0] + 1)+ (BS2[4:0] + 1)= N Tq

其中單個時間片的長度Tq與CAN外設(shè)的所掛載的時鐘總線及分頻器配置有關(guān)。

CAN0和CAN1外設(shè)都是掛載在APB1總線上的,而位時序寄存器CAN_BT中的BAUDPSC[9:0]位可以設(shè)置CAN外設(shè)時鐘的分頻值 ,所以:

Tq = (BAUDPSC[9:0]) x TPCLK

其中的PCLK指APB1時鐘,默認(rèn)值為60MHz。

最終可以計算出CAN通訊的波特率:

BaudRate = 1/N Tq

例如下表一種配置波特率為1Mbps的方式說明了如何配置波特率為1Mbps。

[1] [2]
關(guān)鍵字:GD32  MCU  CAN  模塊 引用地址:【GD32 MCU 入門教程】GD32 MCU 常見外設(shè)介紹(15)CAN 模塊介紹

上一篇:【GD32 MCU 入門教程】GD32 MCU 常見外設(shè)介紹(1)RCU 時鐘介紹
下一篇:【GD32 MCU 入門教程】GD32 MCU 常見外設(shè)介紹(3)NVIC 介紹

推薦閱讀最新更新時間:2025-04-24 10:12

AT90CANCAN通信模塊驅(qū)動設(shè)計及C編程
  CAN 總線 通信較之一般的通信總線而言,其數(shù)據(jù)通信具有突出的可靠性、實時性和靈活性,應(yīng)用范圍也早已不再局限于汽車行業(yè),而是擴展到了機器人、數(shù)控機床、家用電器等領(lǐng)域。CAN控制器用來實現(xiàn)統(tǒng)一的CAN通信協(xié)議。CAN控制器分為兩種: 一種是獨立的控制 芯片 ,如SJA1100;另一種是將其集成在 微控制器 內(nèi)部,例如 Atmel 公司最新推出的AT90CAN系列 單片機 。與使用獨立的CAN控制器相比,自身集成了CAN 接口 的微控制器在簡化硬件 電路 設(shè)計的同時,提高了軟件開發(fā)的效率。   1 AT90CAN單片機CAN控制器特性   AT90CAN單片機的CAN控制器能夠兼容CAN2.0A和CAN2.0B通信協(xié)議,內(nèi)部設(shè)
[單片機]
AT90<font color='red'>CAN</font>的<font color='red'>CAN</font>通信<font color='red'>模塊</font>驅(qū)動設(shè)計及C編程
GD32與STM32兼容嗎?
GD32與STM32是兩個不同的微控制器系列,是由兩個不同的公司設(shè)計和生產(chǎn)的。GD32系列是由國內(nèi)的長沙國芯微電子設(shè)計和生產(chǎn)的,而STM32系列則是由歐洲的STMicroelectronics公司設(shè)計和生產(chǎn)的。 雖然GD32與STM32都是基于ARM Cortex-M內(nèi)核的微控制器,但是它們并不完全兼容。由于兩個公司的設(shè)計和生產(chǎn)流程不同,GD32系列和STM32系列的外設(shè)具有不同的寄存器映射和不同的寄存器位域。因此,任何在STM32上編寫的應(yīng)用程序不能直接在GD32上運行,需要對代碼進行適當(dāng)?shù)男薷摹?在進行移植時,需要仔細(xì)研究兩者之間的差異性,例如GPIO、串口、定時器等外設(shè)的差異,以及使用的庫函數(shù)的不同。同時也需要檢查時鐘、中斷
[單片機]
MCUCAN總線中繼器設(shè)計
引 言 CAN總線以其開發(fā)維護成本低、總線利用率高、傳輸距離遠(yuǎn)(最遠(yuǎn)可達(dá)10 km)、傳輸速率高(最高可達(dá)1 Mbps)使用戶能組建穩(wěn)定、高效的現(xiàn)場總線網(wǎng)絡(luò)。CAN總線已被廣泛應(yīng)用到各個自動化控制系統(tǒng)中,例如汽車電子、自動控制、智能大廈、電力系統(tǒng)、安防監(jiān)控等領(lǐng)域。隨著CAN總線網(wǎng)絡(luò)區(qū)域的擴大,2個節(jié)點之間的直接數(shù)據(jù)傳輸將難以滿足遠(yuǎn)距離通信要求。CAN中繼器是延長CAN總線通信距離的中轉(zhuǎn)站,其通信效率和通信可靠性直接影響CAN總線的通信能力。傳統(tǒng)的基于單MCU的CAN中繼器難以滿足大量數(shù)據(jù)的中轉(zhuǎn)要求,本文基于雙MCU設(shè)計高性能的CAN總線中繼器。 1 系統(tǒng)總體設(shè)計 CY7C136是2 KB高速CMOS靜態(tài)RAM。同一片RAM
[單片機]
雙<font color='red'>MCU</font>的<font color='red'>CAN</font>總線中繼器設(shè)計
基于單片機μPD780822的客車CAN總線燈光節(jié)點的設(shè)計及實現(xiàn)
1 引言 CAN(Controller Area Network)是德國Bosch公司最先提出的,是目前汽車控制器局域網(wǎng)中最流行、最常用的總線。它的主要特點是:CAN總線為多主站總線,各節(jié)點均可在任意時刻主動向網(wǎng)絡(luò)上的其他節(jié)點發(fā)送信息,不分主從,通信靈活;CAN總線采用獨特的非破壞性總線仲裁技術(shù),優(yōu)先級高的節(jié)點先傳送數(shù)據(jù),能滿足實時性要求;CAN總線具有點對點、一點對多點及全局廣播傳送數(shù)據(jù)的功能;CAN總線上每幀有效字節(jié)數(shù)最多為8個,并有CRC及其他校驗措施,數(shù)據(jù)出錯率極低,某個節(jié)點出現(xiàn)嚴(yán)重錯誤,可自動脫離總線,總線上的其他操作不受影響;CAN總線只有2條導(dǎo)線,系統(tǒng)擴充時可直接將新節(jié)點掛在總線上,因此走線少,系
[單片機]
基于<font color='red'>單片機</font>μPD780822的客車<font color='red'>CAN</font>總線燈光節(jié)點的設(shè)計及實現(xiàn)
基于CAN總線和PIC單片機的汽車開關(guān)電器盒設(shè)計
   0 引 言   隨著現(xiàn)代汽車工業(yè)技術(shù)的不斷發(fā)展進步,車上安裝的電子設(shè)備在不斷增加,從而使汽車綜合控制系統(tǒng)中,有大量控制信號需要進行實時交換。CAN 總線作為一種可靠的汽車計算機網(wǎng)絡(luò)總線,已經(jīng)被廣泛地推廣到汽車控制系統(tǒng)的各個應(yīng)用領(lǐng)域。將CAN 總線技術(shù)應(yīng)用到汽車開關(guān)電器盒中,可使得各汽車計算機控制單元能夠通過CAN 總線得到開關(guān)電器盒中的工作數(shù)據(jù),又能對開關(guān)電器盒的各個繼電器進行精準(zhǔn)的控制,從而達(dá)到減少汽車線束、提高通信可靠性、降低系統(tǒng)成本、避免系統(tǒng)功能重復(fù)、提高系統(tǒng)工作效率的目的。    1 汽車開關(guān)電器盒設(shè)計方案   本開關(guān)電器盒采用的是基于Microchip 公司生產(chǎn)的PIC18F45K80 芯片作為主芯片的設(shè)計方
[單片機]
基于<font color='red'>CAN</font>總線和PIC<font color='red'>單片機</font>的汽車開關(guān)電器盒設(shè)計
基于PIC單片機的嵌入式CAN智能節(jié)點及其與PC的通信
引言 CAN總線是一種串行數(shù)據(jù)通信協(xié)議,其通信接口中集成了CAN協(xié)議的物理層和數(shù)據(jù)鏈路層功能,可完成對數(shù)據(jù)的成幀處理。CAN協(xié)議的一個最大特點是廢除了傳統(tǒng)的站地址編碼,而代之以對通信數(shù)據(jù)塊編碼,采用這種方法可使網(wǎng)絡(luò)內(nèi)節(jié)點個數(shù)在理論上不受限制,還可使不同的節(jié)點同時收到相同的數(shù)據(jù)。 本文介紹了嵌入式CAN智能節(jié)點,并且應(yīng)用PC和嵌入式CAN智能節(jié)點組成了CAN通信系統(tǒng),完成了電壓。電流。溫度等信號的實時采集。可靠傳輸和實時顯示,實現(xiàn)了PC端對嵌入式CAN智能節(jié)點PWM波輸出的脈沖寬度的控制。 基于PIC單片機的嵌入式CAN智能節(jié)點的設(shè)計 嵌入式CAN智能節(jié)點以PIC16F874單片機作為嵌入式微控制器,以MCP25
[單片機]
Microchip推出搭載硬件安全模塊的PIC32CK 32位單片機, 輕松實現(xiàn)嵌入式安全功能
這款全新的中端MCU系列為設(shè)計人員提供了更高水平的安全性和靈活性 自2024年生效的新法律法規(guī)對從消費物聯(lián)網(wǎng)設(shè)備到關(guān)鍵基礎(chǔ)設(shè)施的網(wǎng)絡(luò)安全提出了更嚴(yán)格的要求。從產(chǎn)品和供應(yīng)鏈的角度來看,滿足這些新的安全合規(guī)要求可能非常復(fù)雜、昂貴且耗時。為了向開發(fā)人員提供嵌入式安全解決方案,使他們能夠設(shè)計出符合法規(guī)要求的應(yīng)用,Microchip Technology(微芯科技公司)今日宣布推出新型PIC32CK 32位單片機(MCU)系列。 該系列集成了硬件安全模塊(HSM)子系統(tǒng)和采用TrustZone?技術(shù)的Arm?Cortex?-M33內(nèi)核,可幫助隔離并確保設(shè)備安全。 PIC32CK SG是市場上首款將HSM的強大安全性與基于硬件的安全
[單片機]
Microchip推出搭載硬件安全<font color='red'>模塊</font>的PIC32CK 32位<font color='red'>單片機</font>,  輕松實現(xiàn)嵌入式安全功能
基于GSM模塊Q2403A和8051單片機實現(xiàn)短消息收發(fā)系統(tǒng)的應(yīng)用方案
基于GSM短消息的業(yè)務(wù)不需要建立撥號連接,只需把待發(fā)的消息加上目的地址發(fā)送至短消息中心,再由短消息中心轉(zhuǎn)發(fā)到最終目標(biāo)。GSM 短消息業(yè)務(wù)以其連接簡單、費用低廉、覆蓋范圍廣、實現(xiàn)方便等優(yōu)點得到了廣泛的應(yīng)用。運用 GSM 短消息實現(xiàn)遠(yuǎn)程測控的可靠性較高、信號傳播距離遠(yuǎn)、覆蓋面積廣,并且可以節(jié)省建網(wǎng)初期的巨額投資。 本文對基于GSM短消息收發(fā)系統(tǒng)的設(shè)計與實現(xiàn)作了具體描述,給出了系統(tǒng)的軟硬件設(shè)計方案,對主要硬件,即GSM模塊Q2403A 和8051單片機作了重點介紹。給出了系統(tǒng)的軟件設(shè)計,包括PC與單片機通信部分和短消息收發(fā)部分。最后實現(xiàn)系統(tǒng)監(jiān)控功能。 系統(tǒng)硬件實現(xiàn) 總體系統(tǒng)結(jié)構(gòu) 該系統(tǒng)硬件主要由8051單片機擴展電路、Q2403
[單片機]
基于GSM<font color='red'>模塊</font>Q2403A和8051<font color='red'>單片機</font>實現(xiàn)短消息收發(fā)系統(tǒng)的應(yīng)用方案
小廣播
設(shè)計資源 培訓(xùn) 開發(fā)板 精華推薦

最新單片機文章

 
EEWorld訂閱號

 
EEWorld服務(wù)號

 
汽車開發(fā)圈

 
機器人開發(fā)圈

電子工程世界版權(quán)所有 京ICP證060456號 京ICP備10001474號-1 電信業(yè)務(wù)審批[2006]字第258號函 京公網(wǎng)安備 11010802033920號 Copyright ? 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
主站蜘蛛池模板: 开封县| 宁德市| 墨竹工卡县| 邵阳县| 黄石市| 祥云县| 武鸣县| 长丰县| 张家口市| 哈巴河县| 台中县| 蕲春县| 天镇县| 綦江县| 沁源县| 鄂伦春自治旗| 莱西市| 油尖旺区| 宜黄县| 佛冈县| 天气| 仙居县| 益阳市| 兴安县| 九龙坡区| 成安县| 缙云县| 方正县| 兰溪市| 建阳市| 广饶县| 五寨县| 巴彦县| 无极县| 额济纳旗| 乳山市| 鄂州市| 汉源县| 蒲城县| 独山县| 三台县|