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

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

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

CAN發(fā)送的底層邏輯:CANwrite函數(shù)機制介紹

冬至子 ? 來源:汽車電子過山車 ? 作者:歡樂皮皮峰 ? 2023-07-17 15:47 ? 次閱讀

1.前言:AUTOSAR通信系列介紹

這個系列是全新的系列,整個系列會通過實際操作,調(diào)試實際的代碼,以CAN為例,完整的解析AUTOSAR的從底層MCAL 到COM等上層模塊的通信鏈路層。重點講述數(shù)據(jù)的流向,以及各個模塊的作用,配置方法。

通過這個系列,將會以代碼的視角,了解如IPDU LPDU SDU HOH HTH HRH MB等AUTOSAR抽象概念的實際實現(xiàn)及其數(shù)據(jù)結(jié)構(gòu),以及在真實的AUTOSAR 架構(gòu)軟件中,CAN CANIF PDUR COM CANTP 等模塊中數(shù)據(jù)的傳輸,配置參數(shù),函數(shù)的調(diào)用等各個方面。讓我們在使用AUTOSAR配置通信的同時,不被其架空,不當只會配置的工具人。

系列將會從MCAL自底向上,一步步分析各個模塊,搞清楚整個通信的發(fā)送機制,和通信的接收機制。

2.Can_write函數(shù)介紹,以及HOH抽象的實施 MessgeBuffer介紹

整個的CAN發(fā)送,實際上是由Can模塊里面的Can_write實現(xiàn)的。我們先以S32K14x MCAL代碼為實例,介紹Can_write函數(shù)的發(fā)送機制,以對L_PDU HOH HTH Message Buffer這些抽象建立起基本的概念。

ECU執(zhí)行完必要的初始化函數(shù)和設置controller模式后,我們就可以調(diào)用Can_Write函數(shù)來發(fā)送報文了。

Can_Write函數(shù)的傳入?yún)?shù)有兩個:

  1. hth:hardware transmit handle 硬件傳輸句柄。這個的詳細講解在后面。
  2. PduInfo(此即LPDU Data link Layer protocol)結(jié)構(gòu)體成員如下:
    id:CAN報文ID
    swPduHandle:LPDU 句柄,此句柄在Canif層定義。每個句柄表示的是1個LPDU.用來在發(fā)送的最后時刻觸發(fā)PDU的tx_confirmation.
    length:LPDU數(shù)據(jù)長度,即報文的長度。
    sdu:LPDU的數(shù)據(jù)指針。

實例:Can_write函數(shù)介紹,以及HOH抽象的實施 MessgeBuffer介紹

我們以一個簡單的例子說明:

如下是代碼:

圖片

如下是報文:

圖片

這個例子介紹了AUTOSAR發(fā)送報文的最底層接口的使用方法,可以先建立一個直觀的印象。

can_write的第一個參數(shù)hth是AUTOSAR標準里面的一個概念,接下來的內(nèi)容的講解目的是為了透徹的理解hth。

AUTOSAR從MCAL開始 就對CAN進行抽象了,抽象出HOH Hardware object handle 硬件處理對象,HOH以發(fā)送和接收的不同,分為了HTH,HRH,這倆可以統(tǒng)稱為HOH。

HOH對象包括很多屬性,如

Can Implementation Type(FULL/BASIC

Can ID Message Type(STANDARD/MIXED/EXTEND)

Can Controller Reference (使用哪個can controler)

Number of Hw objects used to implement one HOH

等等屬性。

當我們用其中的一個HOH作為對象來發(fā)送報文時,這個報文的發(fā)送屬性會繼承這個HOH對象的所有屬性。

舉例說明:

EB(S32K148)中配置了如下幾個HOH:

圖片

這里的配置實際會影響的是Can_PBcfg中的MessgeBuffer的配置結(jié)構(gòu)體,MessgeBuffer結(jié)構(gòu)體數(shù)組是HOH的具體實施,它的含義下文詳細描述。Can Object ID即為HOH的ID。

在Can_write例子中我們傳入HTH的是4,即利用HOH_3_EcuTestNode_CanCluster這個HOH作為對象,進行發(fā)送。

深入Can_write中,調(diào)用的是Can_FlexCan_Write的這個函數(shù):

圖片

他會先搜索Messge Buffer配置結(jié)構(gòu)體中u32HWObjID為hth,即為4的這個配置。

Messge Buffer的配置結(jié)構(gòu)體的部分成員:

static CONST(Can_MBConfigObjectType, CAN_CONST) MessageBufferConfigs0_PB[CAN_MAXMBCOUNT_PB] =
{
    /* HOH_0_EcuTestNode_CanCluster Message Buffer of Can Controller ID = 0U*/
    {
        (Can_HwHandleType)0x0U, /* uIdMaskIndex */
        (uint8)0U, /* ControllerId  - based on the order from CanController list */
        (CanIdType)CAN_STANDARD, /* ID type: EXTENDED, STANDARD, MIXED */
        (Can_ObjType)CAN_RECEIVE, /* Receive/Transmit MB configuration */
        (Can_IdType)0x0U, /* MessageId */
        (uint8)0x0U, /* Local priority bits used for arbitration */
        (Can_HwHandleType)0x0U, /* Hardware Object ID */
        #if (CAN_FD_MODE_ENABLE == STD_ON)
        (uint8)0U,
        #endif
        /* Read/Write period reference used when POLLING mode is selected for the controller */
        (uint8)0U, /* HOH configured for INTERRUPT mode, reference not used */

        (uint16)0x0080U,       /* Address of Message Buffer  */
        (uint8)8U,    /* Payload lenth of Message Buffer */
        (uint8)0U    /* The index of MB in message buffer memory */
        #if (CAN_TRIGGER_TRANSMIT_EN == STD_ON)
        /* The parameter is used to detect the MB which run with trigger transmit feature */
        ,(boolean)FALSE
        #endif
    },


    /* HOH_3_UDSTX_Node Message Buffer of Can Controller ID = 0U*/
    {
        (Can_HwHandleType)CAN_MAXMASKCOUNT, /* uIdMaskIndex */
        (uint8)0U, /* ControllerId  - based on the order from CanController list */
        (CanIdType)CAN_STANDARD, /* ID type: EXTENDED, STANDARD, MIXED */
        (Can_ObjType)CAN_TRANSMIT, /* Receive/Transmit MB configuration */
        (Can_IdType)0x7eaU, /* MessageId */
        (uint8)0x0U, /* Local priority bits used for arbitration */
        (Can_HwHandleType)0x1U, /* Hardware Object ID */
        #if (CAN_FD_MODE_ENABLE == STD_ON)
        (uint8)0U,
        #endif
        /* Read/Write period reference used when POLLING mode is selected for the controller */
        (uint8)0U,   /* HOH configured for INTERRUPT mode, reference not used */

        (uint16)0x0180U,       /* Address of Message Buffer  */
        (uint8)8U,    /* Payload lenth of Message Buffer */
        (uint8)16U    /* The index of MB in message buffer memory */
        #if (CAN_TRIGGER_TRANSMIT_EN == STD_ON)
        /* The parameter is used to detect the MB which run with trigger transmit feature */
        ,(uint8)FALSE
        #endif
    },


    /* HOH_3_NMTX_Node Message Buffer of Can Controller ID = 0U*/
    {
        (Can_HwHandleType)CAN_MAXMASKCOUNT, /* uIdMaskIndex */
        (uint8)0U, /* ControllerId  - based on the order from CanController list */
        (CanIdType)CAN_STANDARD, /* ID type: EXTENDED, STANDARD, MIXED */
        (Can_ObjType)CAN_TRANSMIT, /* Receive/Transmit MB configuration */
        (Can_IdType)0x424U, /* MessageId */
        (uint8)0x0U, /* Local priority bits used for arbitration */
        (Can_HwHandleType)0x2U, /* Hardware Object ID */
        #if (CAN_FD_MODE_ENABLE == STD_ON)
        (uint8)0U,
        #endif
        /* Read/Write period reference used when POLLING mode is selected for the controller */
        (uint8)0U,   /* HOH configured for INTERRUPT mode, reference not used */

        (uint16)0x0190U,       /* Address of Message Buffer  */
        (uint8)8U,    /* Payload lenth of Message Buffer */
        (uint8)17U    /* The index of MB in message buffer memory */
        #if (CAN_TRIGGER_TRANSMIT_EN == STD_ON)
        /* The parameter is used to detect the MB which run with trigger transmit feature */
        ,(uint8)FALSE
        #endif
    },


    /* HOH_3_XCPTX_Node Message Buffer of Can Controller ID = 0U*/
    {
        (Can_HwHandleType)CAN_MAXMASKCOUNT, /* uIdMaskIndex */
        (uint8)0U, /* ControllerId  - based on the order from CanController list */
        (CanIdType)CAN_STANDARD, /* ID type: EXTENDED, STANDARD, MIXED */
        (Can_ObjType)CAN_TRANSMIT, /* Receive/Transmit MB configuration */
        (Can_IdType)0x667U, /* MessageId */
        (uint8)0x0U, /* Local priority bits used for arbitration */
        (Can_HwHandleType)0x3U, /* Hardware Object ID */
        #if (CAN_FD_MODE_ENABLE == STD_ON)
        (uint8)0U,
        #endif
        /* Read/Write period reference used when POLLING mode is selected for the controller */
        (uint8)0U,   /* HOH configured for INTERRUPT mode, reference not used */

        (uint16)0x01a0U,       /* Address of Message Buffer  */
        (uint8)8U,    /* Payload lenth of Message Buffer */
        (uint8)18U    /* The index of MB in message buffer memory */
        #if (CAN_TRIGGER_TRANSMIT_EN == STD_ON)
        /* The parameter is used to detect the MB which run with trigger transmit feature */
        ,(uint8)FALSE
        #endif
    },


    /* HOH_3_EcuTestNode_CanCluster Message Buffer of Can Controller ID = 0U*/
    {
        (Can_HwHandleType)CAN_MAXMASKCOUNT, /* uIdMaskIndex */
        (uint8)0U, /* ControllerId  - based on the order from CanController list */
        (CanIdType)CAN_STANDARD, /* ID type: EXTENDED, STANDARD, MIXED */
        (Can_ObjType)CAN_TRANSMIT, /* Receive/Transmit MB configuration */
        (Can_IdType)0x110U, /* MessageId */
        (uint8)0x0U, /* Local priority bits used for arbitration */
        (Can_HwHandleType)0x4U, /* Hardware Object ID */
        #if (CAN_FD_MODE_ENABLE == STD_ON)
        (uint8)0U,
        #endif
        /* Read/Write period reference used when POLLING mode is selected for the controller */
        (uint8)0U,   /* HOH configured for INTERRUPT mode, reference not used */

        (uint16)0x01b0U,       /* Address of Message Buffer  */
        (uint8)8U,    /* Payload lenth of Message Buffer */
        (uint8)19U    /* The index of MB in message buffer memory */
        #if (CAN_TRIGGER_TRANSMIT_EN == STD_ON)
        /* The parameter is used to detect the MB which run with trigger transmit feature */
        ,(uint8)FALSE
        #endif
    },
    /* HOH_3_EcuTestNode_CanCluster Message Buffer of Can Controller ID = 0U*/
    {
        (Can_HwHandleType)CAN_MAXMASKCOUNT, /* uIdMaskIndex */
        (uint8)0U, /* ControllerId  - based on the order from CanController list */
        (CanIdType)CAN_STANDARD, /* ID type: EXTENDED, STANDARD, MIXED */
        (Can_ObjType)CAN_TRANSMIT, /* Receive/Transmit MB configuration */
        (Can_IdType)0x110U, /* MessageId */
        (uint8)0x0U, /* Local priority bits used for arbitration */
        (Can_HwHandleType)0x4U, /* Hardware Object ID */
        #if (CAN_FD_MODE_ENABLE == STD_ON)
        (uint8)0U,
        #endif
        /* Read/Write period reference used when POLLING mode is selected for the controller */
        (uint8)0U,   /* HOH configured for INTERRUPT mode, reference not used */

        (uint16)0x01c0U,       /* Address of Message Buffer  */
        (uint8)8U,    /* Payload lenth of Message Buffer */
        (uint8)20U    /* The index of MB in message buffer memory */
        #if (CAN_TRIGGER_TRANSMIT_EN == STD_ON)
        /* The parameter is used to detect the MB which run with trigger transmit feature */
        ,(uint8)FALSE
        #endif
    },........

所以上文函數(shù)搜索到的第一個結(jié)構(gòu)體成員一定是第一個Hardware Object ID為4的這個MB 結(jié)構(gòu)體:

/* HOH_3_EcuTestNode_CanCluster Message Buffer of Can Controller ID = 0U*/
    {
        (Can_HwHandleType)CAN_MAXMASKCOUNT, /* uIdMaskIndex */
        (uint8)0U, /* ControllerId  - based on the order from CanController list */
        (CanIdType)CAN_STANDARD, /* ID type: EXTENDED, STANDARD, MIXED */
        (Can_ObjType)CAN_TRANSMIT, /* Receive/Transmit MB configuration */
        (Can_IdType)0x110U, /* MessageId */
        (uint8)0x0U, /* Local priority bits used for arbitration */
        (Can_HwHandleType)0x4U, /* Hardware Object ID */
        #if (CAN_FD_MODE_ENABLE == STD_ON)
        (uint8)0U,
        #endif
        /* Read/Write period reference used when POLLING mode is selected for the controller */
        (uint8)0U,   /* HOH configured for INTERRUPT mode, reference not used */

        (uint16)0x01b0U,       /* Address of Message Buffer  */
        (uint8)8U,    /* Payload lenth of Message Buffer */
        (uint8)19U    /* The index of MB in message buffer memory */
        #if (CAN_TRIGGER_TRANSMIT_EN == STD_ON)
        /* The parameter is used to detect the MB which run with trigger transmit feature */
        ,(uint8)FALSE
        #endif
    },

以這個成員的配置去改變對應的寄存器,從而讓發(fā)送的報文繼承這里面的屬性。

我們現(xiàn)在需要搞明白的就剩這個MessgeBuffer配置結(jié)構(gòu)體。

結(jié)構(gòu)體里面的屬性的含義,這些看EB的CAN模塊的配置手冊可以搞明白,我想介紹的是MessgeBuffer這個機制。這是S32K Flex CAN的機制

圖片

這是 Flex CAN的報文緩沖。報文緩沖有很多,配置好相關寄存器,最后將報文數(shù)據(jù)寫入報文緩沖,可完成發(fā)送。

我們注意到MessageBufferConfigs0_PB中的每個結(jié)構(gòu)體成員都有表示Address of Message Buffer的屬性和表示The index of MB in message buffer memory的屬性。這屬性各個成員全不同并且是序號,地址按順序遞增的現(xiàn)象。所以這些結(jié)構(gòu)體成員就是一個一個不同的Messagebuffer。再注意到之前提到的Can_Write中傳入的Hth即是這里的Hardware Object ID。最后兩個結(jié)構(gòu)體,你發(fā)現(xiàn)他們雖然Message Buffer的地址不同,但是共用一個Hth號4.實際上完整的Messagebuffer的定義,有十個結(jié)構(gòu)體成員都是共用4號Hth.

這是由EB配置項Number of Hw objects used to implement one HOH配為10決定的。這里 Hw objects即不同的MessageBuffer。但是他們關聯(lián)了同個Hth。換言之1個Hth中可以包括多個MessageBuffer。即HTH是比MessageBuffer是更高層的抽象,例子中向Can_Write傳入這個ID為4的hth,可以有10個MessageBuffer供選擇寫入數(shù)據(jù),一個MessgeBuffer被占了我再找下個MessageBuffer。這樣的配置作用就是使用這個HTH,可以在極短時間同時支持最多10個報文的發(fā)送。

以上例子Can_write函數(shù)的底層實現(xiàn)的邏輯簡化說明如下:
1.輪詢Messge Buffer配置結(jié)構(gòu)體中u32HWObjID為hth是4的MB結(jié)構(gòu)體成員。

2找到第一個hth為4的MessageBuffer。傳入LPDU數(shù)據(jù),嘗試更新MessageBuffer發(fā)送,再判斷是否是CAN_BUSY狀態(tài)。假如是,找下一個Hth為4的MB繼續(xù)嘗試發(fā)送,直到成功發(fā)送出去一次,返回CAN_OK。

這期的介紹就到這里,本期我們可以搞清楚什么是LPDU,什么是HOH和HTH。從HOH的實際實施可以看出,所謂的AUTOSAR抽象,即將某個對象的所有配置,用結(jié)構(gòu)體數(shù)組打包在一起,然后給他們編號。這個編號和各個對象的配置一一對應。后面需要使用這個對象的時候即使用編號去索引對應的結(jié)構(gòu)體數(shù)組即可。這個思路會貫穿整個的AUTOSAR實現(xiàn)。

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

    關注

    31

    文章

    5343

    瀏覽量

    120443
  • CAN通信
    +關注

    關注

    5

    文章

    93

    瀏覽量

    17870
  • 緩沖器
    +關注

    關注

    6

    文章

    1922

    瀏覽量

    45503
  • AUTOSAR
    +關注

    關注

    10

    文章

    362

    瀏覽量

    21607
  • PDU
    PDU
    +關注

    關注

    0

    文章

    94

    瀏覽量

    16990
收藏 人收藏

    評論

    相關推薦

    邏輯函數(shù)邏輯問題的介紹

    本帖最后由 gk320830 于 2015-3-9 22:17 編輯 邏輯函數(shù)邏輯問題的描述  在討論了與、或、非三種基本邏輯運算后,下面將從工程實際出發(fā),提出
    發(fā)表于 04-06 23:57

    ESM6802 Android版支持雙CAN通信

    libCanControl.so文件的C/C++源碼做參考。這樣,對于Android應用開發(fā)的客戶來說,只需要專注于Java層的應用邏輯開發(fā)?! anControl類的四個native函數(shù)簡單介紹如下
    發(fā)表于 10-20 11:32

    請問CAN接收中斷DSP底層會怎么樣?

    請教:正常流程:CAN設置成中斷接收方式,通過CAN調(diào)試助手,發(fā)送一幀數(shù)據(jù),產(chǎn)生一個CAN接收中斷,并進行數(shù)據(jù)處理;異常流程:如果我發(fā)送
    發(fā)表于 10-17 14:37

    EPP邏輯接口WinDriver底層驅(qū)動的可視化

    取自外部CAN總線系統(tǒng)的+5V電源;發(fā)光二極管用做電源和主、備節(jié)點的收發(fā)指示。2 EPP和SJAl000之間的接口邏輯設計 在EPP接口和SJAl000之間加入適當?shù)?b class='flag-5'>邏輯接口,可以避免傳統(tǒng)設計中對EPP
    發(fā)表于 11-29 14:51

    iTOP-iMX6開發(fā)板-Android-can測試例程介紹

    Java_can_hardware_hardwareControl_canWrite這是 can發(fā)送接口。JNIEXPORT jobject JNICALL
    發(fā)表于 03-11 10:24

    can底層驅(qū)動配置好的前提下,向DSP發(fā)送任何數(shù)據(jù),can就能接收到數(shù)據(jù)嗎

    我想問下在can底層驅(qū)動配置好的前提下,我向DSP發(fā)送任何數(shù)據(jù),can就能接收到數(shù)據(jù)嗎,然后將RMP=1即ECanaShadow.CANRMP.bit.RMP1 = 1;還是說必須
    發(fā)表于 07-08 15:39

    邏輯代數(shù)與邏輯函數(shù)

    邏輯代數(shù)與邏輯函數(shù):本章主要討論分析和設計數(shù)字邏輯功能的數(shù)學。首先介紹邏輯代數(shù)中的基本運算、基本
    發(fā)表于 09-01 09:11 ?0次下載

    邏輯函數(shù)邏輯問題的描述

    邏輯函數(shù)邏輯問題的描述   在討論了與、或、非三種基本邏輯運算后,下面將從工程實際出發(fā),提出邏輯命題,然后用真值表加以描述,從真值表可以
    發(fā)表于 04-06 23:56 ?1381次閱讀
    <b class='flag-5'>邏輯</b><b class='flag-5'>函數(shù)</b>與<b class='flag-5'>邏輯</b>問題的描述

    STM32_CAN發(fā)送和接收過濾原理

    STM32_CAN發(fā)送和接收過濾原理介紹。
    發(fā)表于 07-22 17:04 ?9次下載

    CAN為什么會發(fā)送失敗

    CAN總線調(diào)試過程中出現(xiàn)報文發(fā)送失敗,很多工程師都對此只知其一不知其二,這里就CAN報文發(fā)送失敗的問題我們來做一次探討。在了解CAN報文為什
    發(fā)表于 07-19 18:47 ?1.9w次閱讀
    <b class='flag-5'>CAN</b>為什么會<b class='flag-5'>發(fā)送</b>失敗

    03 底層函數(shù)

    03 底層函數(shù)
    發(fā)表于 10-11 09:29 ?7次下載
    03 <b class='flag-5'>底層</b>庫<b class='flag-5'>函數(shù)</b>

    邏輯NOT函數(shù)功能介紹

    邏輯NOT函數(shù)輸出在其單個輸入為false時為true,在單個輸入為true時為false邏輯NOT函數(shù)僅為單個輸入反相器將邏輯電平“1”的
    的頭像 發(fā)表于 06-23 05:48 ?9156次閱讀
    <b class='flag-5'>邏輯</b>NOT<b class='flag-5'>函數(shù)</b>功能<b class='flag-5'>介紹</b>

    CAN底層驅(qū)動數(shù)據(jù)的傳輸需要注意什么

    ,但經(jīng)典CAN還是使用最多和最頻繁的,在底層驅(qū)動中,我們要注意數(shù)據(jù)的傳輸。 如我們在讀取CAN數(shù)據(jù)幀的時候需要做調(diào)整,我們以NXP的 Kinetis系列為例子, 同樣在發(fā)送傳輸?shù)臅r候,
    的頭像 發(fā)表于 06-04 14:49 ?1926次閱讀
    <b class='flag-5'>CAN</b><b class='flag-5'>底層</b>驅(qū)動數(shù)據(jù)的傳輸需要注意什么

    IGBT驅(qū)動優(yōu)化的底層邏輯是什么

    ——驅(qū)動優(yōu)化的底層邏輯是什么?
    的頭像 發(fā)表于 04-29 16:15 ?2915次閱讀

    PduR模塊的發(fā)送機制 PduR這個模塊對什么進行了抽象呢?

    前兩期,我們講了CAN模塊的發(fā)送邏輯,Canif模塊的發(fā)送邏輯發(fā)送確認
    的頭像 發(fā)表于 07-17 15:54 ?3219次閱讀
    PduR模塊的<b class='flag-5'>發(fā)送機制</b> PduR這個模塊對什么進行了抽象呢?