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

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

3天內不再提示

靈動MM32F0140:FlexCAN控制器介紹

海闊天空的專欄 ? 來源:靈動MM32MCU ? 作者:靈動MM32MCU ? 2022-05-13 16:42 ? 次閱讀

1 FlexCAN 簡介

FlexCAN 控制器局域網模塊是符合 ISO 11898-1 標準和 CAN 2.0B 規(guī)范的通信控制器,支持 CAN 總線協(xié)議。FlexCAN 模塊框圖如 圖1 所示。FlexCAN 模塊包括 CAN 收發(fā)器(CAN Transceiver)、協(xié)議引擎(Protocol Engine)、控制接口(Controller Host Interface)、總線接口單元(Bus Interface Unit),以及多個支持獨立收發(fā)功能的信息緩沖區(qū)(Message Buffer)。其中 CAN 收發(fā)器負責將收發(fā)引腳的 TTL 信號轉換為 CAN 總線的電平信號,協(xié)議引擎負責處理對信息緩沖區(qū)的讀寫請求,控制接口負責傳輸幀的發(fā)送仲裁以及接收匹配,總線接口單元處理 FlexCAN 和內部總線的交互,信息緩沖區(qū)用于存儲 FlexCAN 的傳輸幀。

poYBAGJ-FrGACB8FAAFWwN0WSBI965.png

MM32F0140 的 FlexCAN 模塊支持標準幀和擴展幀兩種幀格式,支持數據幀和遠程請求幀兩種幀類型,其中數據幀的最大有效數據長度可達8比特。FlexCAN 模塊支持最高可達 1Mps 的可編程比特率,支持對前 16 個信息緩沖區(qū)的中斷,支持局部和全局的接收幀過濾機制,支持可選擇的 FIFO 接收功能。

FlexCAN 模塊支持三種工作模式:回環(huán)模式、只聽模式和正常工作模式。因為在回環(huán)模式下,FlexCAN 的傳輸幀并不會通過其收發(fā)引腳發(fā)送到 CAN 總線,所以通常用于測試單塊芯片的 FlexCAN 模塊是否工作正常。只聽模式下,FlexCAN 模塊將只接收總線上的幀,而不能發(fā)送幀,并且也無法發(fā)送接收應答。正常工作模式下,FlexCAN 模塊既可發(fā)送幀,也可接收幀。

2 FlexCAN 幀格式

FlexCAN 幀傳輸過程

pYYBAGJ-FxGAYkl-AAA__4nyfxw255.png

圖2 是 CAN 幀的發(fā)送流程,首先是幀起始位 SOF,SOF 值規(guī)定為 1,標識此幀的開始。在 CAN 總線協(xié)議中約定,值 0 為顯性位,值 1 為隱性位。FlexCAN 采取多主機、基于優(yōu)先級的總線傳輸方式,總線幀的收發(fā)順序在 Arbitration field 仲裁段確定。仲裁成功的節(jié)點會繼續(xù)發(fā)送幀,仲裁失敗的節(jié)點會轉為接收狀態(tài)。如果不設置使用幀的優(yōu)先級進行仲裁,則使用幀的 ID 號進行仲裁比較,越小優(yōu)先級越高。結合 圖2 CAN 幀發(fā)送流程 和 圖3 CAN 標準數據幀格式可知,Arbitration field 仲裁段存放 CAN 報文的 ID 號以及 RTR 標識,RTR 用于表示幀類型,在下文講述 FlexCAN 使用信息緩沖區(qū)發(fā)送報文時,會進一步解釋其含義。Control filed 控制段在 MM32F0140 的 FlexCAN 中,主要涉及兩個部分,IDE 字段和 DLE 字段。IDE 字段用于標識幀格式,為數據幀還是遠程幀。DLC 字段用于標識此幀的有效字節(jié)數,DLC 字段值將影響后續(xù)的 Data field 字段長度。FDF 字段表示此幀是否為 CAN FD 幀,在MM32F0140 的 FlexCAN 模塊中暫時未使用到。Data field 有效傳輸數據負載段,如果此幀為遠程幀,將不攜帶任何數據,所以 DLC 字段對應為 0;如果此幀為數據幀,此段長度由 DLC 字段控制。CRC field 循環(huán)冗余碼段,用于在發(fā)送和接收流程中檢查此幀是否出現比特錯誤。CRC 后,為 ACK field 檢測段,發(fā)送方會發(fā)送隱性位 1,然后在此段期間回讀總線上信號。如果讀到為顯性位 0,則說明有其他 CAN 接收器接收到此幀,發(fā)送方發(fā)送成功。最后是 EOF 結束位,標識發(fā)送結束。

poYBAGJ-FzOAWP9lAACaeyaqaRY298.png

以下是 MM32F0140 FlexCAN 在上述 CAN 發(fā)送流程要求下,使用信息緩沖區(qū)寄存器進行 CAN 幀的收發(fā)的詳細操作流程。信息緩沖區(qū)寄存器的結構如圖 4 所示。

poYBAGJ-F0CAYlvlAADJ8lRZ9wo776.png

FlexCAN 發(fā)送幀

FlexCAN 發(fā)送幀時,首先將幀相關信息寫入預計使用的信息緩沖區(qū)寄存器中。如果此幀的 ID 號可用 11 個比特位進行表示,則將此幀的 ID 號填入 ID 段,并將 IDE 位置 0,標識為標準幀。如果此幀的 ID 號超過 11 位,則將剩余低位部分填入 ID(Extended) 段,并將 IDE 位置 1,標識為擴展幀。FlexCAN 的幀 ID 長度不能超過 29 位。

然后根據此幀的幀類型,如果是攜帶數據的數據幀,則將 SRR 替代遠程請求位和 RTR 遠程請求位都設置為 0,并將對應需要發(fā)送的數據寫入 DataByte 區(qū),將數據長度寫入 DLC 字段;如果是不攜帶數據的遠程請求幀,則將上述的 SRR 位和 RTR 位都設置為 1。

如果 MCR[LPRIOEN] 位被設置為 1,則在發(fā)送前還需要將此幀的優(yōu)先級寫入 PRIO 位,PRIO 位值越小,優(yōu)先級越高。

當上述各字段都填充完畢后,將 CODE 值 12 填入 CODE 區(qū),此 CODE 值表示將要發(fā)送此幀,發(fā)送完畢后 CODE 值變?yōu)?8,表示發(fā)送完畢?;刈x TIME STAMP 段,可以得到發(fā)送成功時的時間戳。

FlexCAN 接收幀

FlexCAN 接收幀前,需要設置此接收信息緩沖區(qū)的 ID 號、幀格式 IDE 和幀類型 SRR 和 RTR,參考上述發(fā)送過程的設置。然后將 CODE 區(qū)值設置為值 4,表示等待接收。如果需要幀過濾,還需要設置局部幀過濾器 RXIMR 和全局幀過濾器 RXMGMASK、RX14MASK和RX15MASK。當 CAN 總線上有其他 FlexCAN 模塊發(fā)送的幀時,信息緩沖區(qū)會將總線上的幀 ID 與自己的 ID 段以及掩碼值進行匹配,接收幀,此時 TIME STAMP 段的值為接收時的時間戳。

在傳輸中會常使用到的 CODE 值如下表 1 所示。

pYYBAGJ-F2WAINARAABLFAYkZnE971.png

FlexCAN 功能測試流程

首先使用 FlexCAN 的回環(huán)模式測試開發(fā)板上的 FlexCAN 是否工作正常?;丨h(huán)測試成功以后可以進行 FlexCAN 正常工作模式的測試。如果使用的是兩塊開發(fā)板或使用 CAN 分析儀進行測試,需要注意總線兩端必須連接 120Ω 終端電阻。在配置 FlexCAN 過程中,要保證收發(fā)方的波特率都配置成相同值。測試 FlexCAN 正常工作模式下收發(fā)的實驗過程中,要確保至少有一個接收節(jié)點是正常工作模式,而非只聽模式。

3 FlexCAN 配置

配置時鐘

首先需要使能 FlexCAN 時鐘,根據所使用的外設對 RCC 的 RCC_APB1ENR 寄存器進行賦值,將對應外設位置 1 即可使能時鐘,詳細外設如圖 5 所示。

pYYBAGJ-F5CAKHRbAAJUfOMwt10524.png

使能并初始化模塊

使能 FlexCAN 模塊,通過配置 FLEXCAN_MCR[MDIS] 為 0,可以使能 FlexCAN 模塊。使能后,FlexCAN 模塊會自動進入凍結模式。在凍結模式下,設置 FLEXCAN_MCR_SOFTRST 為 1,軟件重置 FlexCAN 模塊寄存器。然后將所有的信息緩沖區(qū)的獨立掩碼寄存器和全局掩碼寄存器的掩碼值都設置為 1,表示接收信息緩沖區(qū)將只接收 ID 號和緩沖區(qū)提前配置的 ID 號完全相同的報文,同時將每個信息緩沖區(qū)寄存器也全部清 0。

配置工作模式

如果 FlexCAN 需要進入正常工作模式,僅需在使能 FlexCAN、初始化信息緩沖區(qū)后退出凍結模式即可進入,即將 FLEXCAN_MCR[FRZ] 設置為 0。因為退出凍結模式需要一定時間,通過輪詢 FLEXCAN_MCR[FRZACK] 是否等于 1 判斷是否退出成功。如果 FlexCAN 需要配置為只讀模式,則需要將 FLEXCAN_CTRL1[LOM] 置為 1;如果 FlexCAN 需要配置為回環(huán)模式,則需要將 FLEXCAN_CTRL1[LPB] 設置為 1。值得注意的是,當配置為回環(huán)模式時,FlexCAN 的 FLEXCAN_MCR[SRXDIS] 不能被設置為 1,否則 FlexCAN 將無法收到回環(huán)報文。

配置波特率

首先通過設置 FLEXCAN_CTRL1[CLKSRC] 指定 FlexCAN 協(xié)議引擎的時鐘源,設置為 0 時使用振蕩器時鐘,設置為 1 時使用外設時鐘。可詳見圖 6 FlexCAN 模塊協(xié)議引擎時鐘框圖。

pYYBAGJ-F7uAYTu4AACjzMpbDNA117.png

對 FlexCAN 引擎時鐘頻率進行可編程分頻后得到 FlexCAN 串行時鐘頻率,FlexCAN 串行時鐘頻率的倒數被稱為時間份額Tq,用于衡量 FlexCAN 傳輸過程中各個階段所需的時間長度,詳見圖 7 1 bit time 下 FlexCAN 傳輸段。

poYBAGJ-F8yAG_qnAAEKwdp6RUU867.png

SYNC_SEG 表示使用 1 個時間份額用于同步;Time Segment 1 段包括 PROPSEG 段和 PSEG1 段,前者用于補償實際網絡傳輸延時,后者和 PSEG2 都將用于補償在 FlexCAN 傳輸過程中潛在的邊緣相位誤差。上述三項可以分別通過 FLEXCAN_CTRL1[PROPSEG]、FLEXCAN_CTRL1[PSEG1] 和 FLEXCAN_CTRL1[PSEG2] 進行設置。下圖 8 是 Bosch CAN 2.0B 標準中對于 PSEG1 和PSEG2 的設置表。

poYBAGJ-F_aAT_hUAABvwPbNUhs341.png

在上述定義下,假定此時引擎時鐘源的時鐘頻率為 ClockFreqHz,PROPSEG 中指定值為 PropSegLen,PSEG1 和PSEG2 中指定值分別為 PhaSegLen1 和 PhaSegLen2,所需波特率為 BaudRate 時,我們可以得到預期的分頻數值 Div 為:

pYYBAGJ-F_uAQn9dAAArRoH2sl0107.png

得到的 Div 值通過配置 FLEXCAN_CTRL1[PreDiv] 實現。這里尤其要注意各項和 ClockFreqHz 之間是否滿足整除關系。

配置發(fā)送幀

首先需要將發(fā)送幀的內容填入等待發(fā)送的 i 號信息緩沖區(qū)的寄存器 FLEXCAN_MB[i] 的 CS、ID、WORD0 和WORD1 寄存器。然后將發(fā)送 CODE 值 (12) 填入 FLEXCAN_MB[i].CS[CODE] 中,即可發(fā)送。此時,如果將 FLEXCAN_ IMASK1 中對應中斷位設置為 1,則發(fā)送成功后將會喚起中斷。

配置接收幀格式

接收匹配需要設置對應的 i 號信息緩沖區(qū) FLEXCAN_MB[i].CS[CODE] 值為 4,表示當前信息緩沖區(qū)接收為空,可以接收信息并安全存儲,配置 FLEXCAN_MB[i].ID 為預期接收的幀 ID 號。設置 FLEXCAN_MB[i].CS[IDE] 配置接收擴展幀或標準幀,接收擴展幀則配置為 1,接收標準幀則配置為 0。設置 FLEXCAN_MB[i].CS[RTR] 配置接收遠程幀或數據幀,接收遠程幀則此位配置為 1,否則配置為 0。

如果需要對幀進行過濾接收,則需額外考慮配置全局幀過濾器或局部幀過濾器。配置 FLEXCAN_MCR[IRMQ] 為 1 則采用局部幀過濾,配置為 0 則采用全局幀過濾。當使用局部幀過濾方法時,掩碼需要通過 FLEXCAN_RXIMRN[i] 寄存器配置,全局則通過 FLEXCAN_RXMGMASK、FLEXCAN_RX14MASK 和FLEXCAN_RX15MASK 寄存器進行配置。

4 FlexCAN 實驗

SDK 中已有支持的 pokt-f0140 開發(fā)板上,在 driver example 下的 flexcan_loopback 樣例中,使用 FlexCAN 模塊進行回環(huán)測試,演示 FlexCAN 的初始化設置、接收和發(fā)送設置以及中斷處理。

初始化外設時鐘

FlexCAN 模塊在 APB1 總線上,因此對 RCC_ APB1ENR 寄存器的 FLEXCAN 對應位設置為 1。

RCC_EnableAPB1Periphs(RCC_APB1_PERIPH_FLEXCAN, true);

初始化FlexCAN

使用外設時鐘作為 FlexCAN 的時鐘源,則 FlexCAN 的時鐘頻率為 pokt-f0140 上 APB1 總線時鐘頻率,為48MHz。此時將傳輸階段的時鐘配置 PhaseSegLen1,PhaseSegLen2,PropSegLen 分別配置為 2, 1, 1;將波特率APP_FLEXCAN_XFER_BAUDRATE 設置為 1MHz。則根據先前所述的波特率計算公式,可以滿足整除關系。在實際調整波特率,需要考慮傳輸段的時鐘設置是否滿足整除關系。

pYYBAGJ-GEmAVXL4AAEE5TOO24g735.png

配置接收信息緩沖區(qū)

配置接收 MB 的接收幀類型為標準數據幀,ID 為 APP_FLEXCAN_XFER_ID。通過配置接收 MB 的 CODE 區(qū),將其配置為接收為空的狀態(tài)。

poYBAGJ-GKaAKi1YAABegCJj0ZU951.png

配置發(fā)送信息緩沖區(qū)

將發(fā)送 MB 的寄存器清空。通過設置該 MB 的 CODE 區(qū),將該 MB 設置為發(fā)送空閑。

pYYBAGJ-GM-AYj0bAAAiDQ4OiH0561.png

配置接收中斷

使能 FlexCAN 的接收中斷,設置 NVIC。

/* Enable intterupts for rx mb. */FLEXCAN_EnableMbInterrupts(BOARD_FLEXCAN_PORT, BOARD_FLEXCAN_RX_MB_INT, true);NVIC_EnableIRQ(BOARD_FLEXCAN_IRQn);

中斷處理函數

中斷處理函數檢查接收中斷,設置接收全局標志位為真。

poYBAGJ-GNSAMOXIAABVM7-o-E4673.png

發(fā)送數據

設置標準數據幀的 ID 號,幀類型和幀格式以及優(yōu)先級;然后填入數據;設置數據長度。將上述配置寫入 MB 相關寄存器,然后修改 MB 的 CODE 區(qū)進行發(fā)送。

pYYBAGJ-GP2AJa9lAAC3Y7MwqF8084.png

讀取數據

讀取對應的 MB 寄存器,將幀數據段內容解析出來。

poYBAGJ-GQSABVSTAABsdr7EKtA565.png

main() 函數

主函數會在鍵入之后,準備好數據并通過發(fā)送 MB 發(fā)送;等待中斷處理函數將全局標志位設置為真后,解析接收MB 收到的幀,并打印。然后再等待下一次鍵入。

pYYBAGJ-GSuAXFKZAADU9hpsCjM098.png

實驗結果

poYBAGJ-GTGATFTKAAEdyCSaj_c929.png

來源: 靈動MM32MCU

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

    關注

    112

    文章

    16415

    瀏覽量

    178746
  • 靈動微電子
    +關注

    關注

    7

    文章

    122

    瀏覽量

    19658
  • MM32
    +關注

    關注

    1

    文章

    106

    瀏覽量

    789
收藏 人收藏

    評論

    相關推薦

    基于MM32F0140系列MCU實現UDS Bootloader的設計

    1、使用MM32F0140系列MCU實現UDS Bootloader  MM32F0140 使用高性能的 Arm?Cortex-M0 內核的 32 位微控制器,最高工作頻率可達 72MHz,內置
    發(fā)表于 09-15 16:35

    上海靈動微電子M0內核32位單片機MM32F0140

    上海靈動微電子MM32F0140系列使用高性能的Arm?Cortex?-M0為內核的32位微控制器,工作頻率高可達72兆赫茲,內置高速64KBFlash和8KBSRAM存儲,具有豐富
    發(fā)表于 11-09 17:53 ?883次閱讀

    靈動MM32F0140可替換瑞薩單片機LPC11C14

    FlexCAN接口。MM32F0140系列MCU適用于各類汽車,工業(yè)和消費市場,其典型應用包括電池管理、電梯外呼板、斷路、消防、車載診斷儀、照明等。 ? MM32F0140該系列3
    發(fā)表于 01-12 15:18 ?742次閱讀

    AN0052從MM32F0130移植到MM32F0140(英文版)

    AN0052 從MM32F0130移植到MM32F0140(英文版)
    發(fā)表于 02-22 18:43 ?0次下載
    AN0052從<b class='flag-5'>MM32F</b>0130移植到<b class='flag-5'>MM32F0140</b>(英文版)

    MM32F0140 產品手冊(中文版)

    MM32F0140 產品手冊(中文版)
    發(fā)表于 02-22 18:45 ?0次下載
    <b class='flag-5'>MM32F0140</b> 產品手冊(中文版)

    MM32F0140 用戶手冊(英文版)

    MM32F0140 用戶手冊(英文版)
    發(fā)表于 02-22 18:46 ?0次下載
    <b class='flag-5'>MM32F0140</b> 用戶手冊(英文版)

    MM32F0140 勘誤表(英文版)

    MM32F0140 勘誤表(英文版)
    發(fā)表于 02-22 18:48 ?0次下載
    <b class='flag-5'>MM32F0140</b> 勘誤表(英文版)

    MM32F0140學習筆記——CRC

    MM32F0140學習筆記——CRC
    的頭像 發(fā)表于 11-10 18:27 ?652次閱讀
    <b class='flag-5'>MM32F0140</b>學習筆記——CRC

    MM32F0140 FlexCAN一致性測試 (2)

    MM32F0140 FlexCAN一致性測試 (2)
    的頭像 發(fā)表于 11-10 18:23 ?711次閱讀
    <b class='flag-5'>MM32F0140</b> <b class='flag-5'>FlexCAN</b>一致性測試 (2)

    MM32F0140 FlexCAN一致性測試(1)

    MM32F0140 FlexCAN一致性測試 (1)
    的頭像 發(fā)表于 11-10 17:50 ?655次閱讀
    <b class='flag-5'>MM32F0140</b> <b class='flag-5'>FlexCAN</b>一致性測試(1)

    MM32F0140學習筆記——FlexCAN 控制器局域網

    MM32F0140學習筆記——FlexCAN 控制器局域網
    的頭像 發(fā)表于 10-27 09:25 ?1501次閱讀
    <b class='flag-5'>MM32F0140</b>學習筆記——<b class='flag-5'>FlexCAN</b> <b class='flag-5'>控制器</b>局域網

    MM32F0140 SPI學習筆記

    MM32F0140 SPI學習筆記
    的頭像 發(fā)表于 09-26 16:51 ?622次閱讀
    <b class='flag-5'>MM32F0140</b> SPI學習筆記

    MM32F0140 DMA學習筆記

    MM32F0140 DMA 學習筆記
    的頭像 發(fā)表于 09-18 16:57 ?732次閱讀
    <b class='flag-5'>MM32F0140</b> DMA學習筆記

    MM32F0140 UART學習筆記

    MM32F0140 UART學習筆記
    的頭像 發(fā)表于 09-26 16:45 ?780次閱讀
    <b class='flag-5'>MM32F0140</b> UART學習筆記

    MM32F0140 GPIO學習筆記

    MM32F0140 GPIO學習筆記
    的頭像 發(fā)表于 09-26 16:42 ?578次閱讀
    <b class='flag-5'>MM32F0140</b> GPIO學習筆記