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

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

3天內不再提示

AUTOSAR架構下的WdgDriver WdgIf WdgM模塊

Linux閱碼場 ? 來源:CSDN博客 ? 作者:ZhouArchie ? 2021-09-09 11:17 ? 次閱讀

本文主要介紹AUTOSAR 架構下的WdgDriver WdgIf WdgM 模塊,分析模塊之間的依賴關系以及運行原理以幫助快速理解。本文以MPC5746R為主控芯片,以FS6500為SBC,DaVinci Configurator 為AUTOSAR工具鏈。

01

模塊架構與依賴

1、模塊介紹AUTOSAR架構中的WDG 一共分為三個部分,Wdg Driver Wdg Interface Wdg Manager。其中Wdg Driver分為 External watchdog driver 與 Internal watch driver。其中外部驅動由SBC提供功能,內部驅動由SWT模塊提供功能。MPC5746R有三個SWT(Soft Watchdog Timer),SWT0 負責CPU0,SWT1負責CPU1,SWT2可以由CPU0 與CPU1訪問。Wdg Driver 提供底層喂狗與設置看門狗模式的驅動函數(shù),由WdgIf抽象成Wdg Device。WdgM獲取WdgIf的抽象數(shù)據(jù)得到底層的配置數(shù)據(jù)與驅動接口函數(shù)。WdgM一共支持三種形式的看門狗檢查方式。

1.AliveSpuervision

2.DeadlineSupervision

3. LogicalSupervision。AliveSpuervision提供一般的喂狗服務,即監(jiān)控周期性程序是否能正常執(zhí)行,保證程序處于Alive狀態(tài)。DeadlineSupervision提供監(jiān)督軟件在兩個狀態(tài)之間的轉換時間。LogicalSupervision提供監(jiān)督軟件執(zhí)行順序的正確性。

根據(jù)不同的檢查方式,WdgM可以抽象出不同的CheckPoint,Rte層可以通過函數(shù)WdgM_CheckpointReached()來通知WdgM程序正在正確運行。2、模塊交互與依賴看門狗模塊由WdgM統(tǒng)一管理后對外,這里只圍繞WdgM模塊分析與其他模塊的依賴性。

WdgIf模塊,WdgM通過WdgIf接口更改WdgDriver的驅動模式,同時通知看門狗觸發(fā)條件EcuM模塊,管理WdgM的Initializing 和DeInitializing狀態(tài),在Sleep模式下出發(fā)硬件看門狗Mcu模塊,在WdgM監(jiān)控程序失敗之后,可以通過Mcu的接口Mcu_PerformReset立即重新ECU單元Det模塊,診斷開發(fā)中的錯誤Dem模塊,WdgM 在偵測到錯誤之后,可以通過Dem模塊觸發(fā)EventSchM模塊,WdgM 調用SchM模塊接口WdgM_GlobalSuspendInterrupts進入臨界區(qū),WdgM_GlobalRestoreInterrupts退出臨界區(qū)Rte模塊,Rte通過WdgM_CheckpointReached()接口,監(jiān)控SWC是否按照設計運行BswM模塊,WdgM在監(jiān)控Spuervised Entity失敗后,可以通過BswM模塊重啟被監(jiān)控程序OS模塊

02

模塊配置

1、Wdg Wdg Driver提供三種喂狗模式給WdgM管理,WdgM可以通過Wdg_SetMode接口設置看門狗運行模式WdgSettingFast 快速喂狗WdgSettingOff 關閉看門狗WdgSettingSlow 慢速喂狗Wdg External Trigger Counter :外部定時器,定時調用Cbk函數(shù),檢測喂狗條件并喂狗2、Wdg_SbcWdgGptChannelParameterRef :關聯(lián)Gpt 模塊,利用Cbk函數(shù)喂狗執(zhí)行喂狗操作。Q :為何要用定時中斷喂狗?

A : 一般理解,不在定時中斷函數(shù)中喂狗是為了方式在主函數(shù)異常的情況,中斷服務函數(shù)還能正常執(zhí)行,這樣喂狗起不到真正的作用。在AUTOSAR中為何在SBC 外部看門狗采用這種方式,因為 Wdg_30_Sbc_SetTriggerCondition 函數(shù)只是負責根據(jù)配置調整看門狗喂狗的時機,然后Gpt的Cbk函數(shù)會在這個時間到達的同時執(zhí)行喂狗操作。如果,MainFunction沒有及時的設置看門狗觸發(fā)條件,Cbk會因為提前喂狗導致看門狗出錯。截取Gpt回調函數(shù)如下:

3、WdgIf關聯(lián)Wdg Driver驅動函數(shù),與WdgM直接通過函數(shù)接口關聯(lián),因此WdgIf沒有Lcfg文件。關聯(lián)的關鍵函數(shù)如下

4、WdgMWdgMDemEventParameterRefs :關聯(lián)Dem模塊,在WdgM模塊出錯時可以Event的方式記錄下來。WdgMMode :1)WdgMAliveSupervision :激活監(jiān)控模式2 ) WdgMDeadlineSupervision :截止監(jiān)控模式3)WdgMLocalStatusParams :邏輯監(jiān)控模式4)WdgMSupervisedEntity :監(jiān)控實體WdgMWatchdog ::管理的Wdg Device,需要關聯(lián)WdgIf 的Device,通過配置的WdgM_ConfigSet關聯(lián)不同的Device,可以實現(xiàn)不同的Wdg Device關聯(lián)不同的Core。1.、關聯(lián)WdgIf Device

2、關聯(lián)Trigger 的Device

3、關聯(lián)Core

3

源碼分析

WdgIf 有兩個對外接口:Std_ReturnType WdgIf_SetMode(uint8 DeviceIndex, WdgIf_ModeType WdgMode ) void WdgIf_SetTriggerCondition( uint8 DeviceIndex, uint16 Timeout )都是通過DeviceIndex 來確定所屬的驅動列表,WdgM模塊會通過所管理的Device數(shù)量來輪詢調用接口截取一段WdgM_Init的代碼說明:

1、內部狗與外部狗的區(qū)別WdgM對外部狗與內部狗的管理方式相同,都是通過SetTriggerCondition的方式設置,在通過關聯(lián)的Gpt模塊的Ckb函數(shù)來實現(xiàn)喂狗。但是兩者在內部實現(xiàn)方式不一致。內部狗通過定時器完成計數(shù),每次觸發(fā)中斷都會關閉定時器,需要SetMode重新開啟然后繼續(xù)計數(shù),最后在Cbk中完成喂狗。設置運行模式,開啟定時器

設置觸發(fā)條件,寫入計數(shù)值

Gpt 回調函數(shù)檢測喂狗條件,并喂狗

2、CheckpointWdgM 提供了三種對SupervisedEntity的方式1. Alive 2. Deadline 3. ProgrameFlowWdgM通過接口函數(shù)WdgM_CheckpointReached 來表示SpuervisedEntityes的Checkpoint到達,函數(shù)接口的詳細描述如下。Std_ReturnType WdgM_CheckpointReached( WdgM_SupervisedEntityIdType SEID, WdgM_CheckpointIdType CheckpointID );

04

多核的WdgM管理

WdgM支持多核,每個內核互不干擾,每個Core下面都關聯(lián)了單獨的SupervisedEntityes, 每個Core都需要單獨單獨調用WdgM_MainFunction。1.獲取CoreId,根據(jù)CoreId獲取配置指針

2. 更新WdgM節(jié)拍數(shù) WdgM提供三種更新節(jié)拍數(shù)的方式 1. WDGM_INTERNAL_SOFTWARE_TICK , 通過MainFunction調度跟新節(jié)拍 2. WDGM_OS_COUNTER ,根據(jù)OS節(jié)拍數(shù)跟新WdgM節(jié)拍 3. WDGM_EXTERNAL_TICK ,根據(jù)接口WdgM_UpdateTickCounter更新節(jié)拍

3. 更新SpuervisedEntityes的狀態(tài)

4. 根據(jù)Global Spuervised Entityes的狀態(tài)喂狗

責任編輯:haq

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

    關注

    450

    文章

    49636

    瀏覽量

    417144
  • 模塊
    +關注

    關注

    7

    文章

    2613

    瀏覽量

    47010
  • 看門狗
    +關注

    關注

    10

    文章

    554

    瀏覽量

    70572

原文標題:AUTOSAR 架構下看門狗的理解

文章出處:【微信號:LinuxDev,微信公眾號:Linux閱碼場】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    TC334使能內部看門狗為SLOW mode,離線跑無法啟動的原因?

    芯片:TC334 平臺: Autosar 詳細描述: 在Configurator里配置好后,使能內部看門狗為SLOW mode。編譯刷寫進板子,debug的時候是正常的,不會復位。并且在
    發(fā)表于 05-22 06:46

    AUTOSAR架構中復雜驅動設計

    復雜驅動(Complex Driver,CDD)是一種不受 AUTOSAR 標準化約束的軟件實體,它可以通過 AUTOSAR 接口和/或基礎軟件模塊 API 進行訪問 AUTOSAR
    的頭像 發(fā)表于 12-21 10:13 ?3326次閱讀
    <b class='flag-5'>AUTOSAR</b><b class='flag-5'>架構</b>中復雜驅動設計

    分析Autosar架構的NVM源碼

    Autosar(Automotive Open System Architecture)是一種用于汽車電子系統(tǒng)開發(fā)的開放式架構標準,旨在提供一種用于構建可靠、安全的分布式系統(tǒng)的框架。其中,NVM
    的頭像 發(fā)表于 12-08 13:56 ?1143次閱讀

    復雜驅動如何將現(xiàn)有的或新的概念引入AUTOSAR軟件架構中的?

    復雜驅動(Complex Driver,CDD)是一種不受 AUTOSAR 標準化約束的軟件實體,它可以通過 AUTOSAR 接口和/或基礎軟件模塊 API 進行訪問 AUTOSAR
    的頭像 發(fā)表于 11-22 10:57 ?1204次閱讀
    復雜驅動如何將現(xiàn)有的或新的概念引入<b class='flag-5'>AUTOSAR</b>軟件<b class='flag-5'>架構</b>中的?

    AUTOSAR架構的多核通信介紹

    隨著汽車ECU迅速的往域控制器方向發(fā)展,ECU要處理的任務越來越多,單核CPU的負載越來越大,多核ECU勢在必行。AUTOSAR架構OS支持多核處理,本系列文章將詳細介紹AUTOSAR
    的頭像 發(fā)表于 11-13 09:24 ?1674次閱讀
    <b class='flag-5'>AUTOSAR</b><b class='flag-5'>架構</b><b class='flag-5'>下</b>的多核通信介紹

    AUTOSAR CAN時鐘同步問題

    請問有沒有AUTOSAR CAN時鐘同步的能運行的代碼,或者有沒有能做這一塊的大佬,主要是CanTsyn和STBM這兩個模塊的。有償,價格都好商量,急需。
    發(fā)表于 11-09 00:00

    Autosar硬件安全模塊HSM的使用分析

    隨著軟件日益復雜,并且車載系統(tǒng)和傳感器數(shù)量穩(wěn)步增加,車內系統(tǒng)的通訊成幾何增長,必須加強密碼保護。這種保護可以通過經(jīng)典的實時汽車開放系統(tǒng)架構AUTOSAR) 來實現(xiàn)。即便在資源稀缺的情況,安裝合適固件的硬件安全
    發(fā)表于 10-30 10:15 ?862次閱讀
    <b class='flag-5'>Autosar</b>硬件安全<b class='flag-5'>模塊</b>HSM的使用分析

    AUTOSAR OS操作系統(tǒng)功能特性

    AUTOSAR OS AUTOSAR OS(AUTomotive Open System ARchitecture Operating System)是AUTOSAR架構中的一個組件,
    的頭像 發(fā)表于 10-27 16:55 ?1851次閱讀

    AUTOSAR軟件開發(fā)流程簡介

    AUTOSAR軟件開發(fā)流程簡介 AUTOSAR軟件開發(fā)流程是指在AUTOSAR架構進行軟件開發(fā)的一系列步驟和方法。它包括以下幾個主要階段:
    的頭像 發(fā)表于 10-27 15:55 ?2724次閱讀
    <b class='flag-5'>AUTOSAR</b>軟件開發(fā)流程簡介

    AUTOSAR CP的復雜驅動是什么

    、ASIC等,以滿足特殊的功能和時序要求。此外,CDD還可以用于實現(xiàn)增強的服務/協(xié)議或封裝非AUTOSAR系統(tǒng)的傳統(tǒng)功能。CDD的實現(xiàn)可能與應用、微控制器和ECU有關。最后,CDD可以作為引入現(xiàn)有或新概念到AUTOSAR軟件架構
    的頭像 發(fā)表于 10-27 15:39 ?1819次閱讀
    <b class='flag-5'>AUTOSAR</b> CP的復雜驅動是什么

    AUTOSAR架構MCAL、服務層、ECU抽象層介紹

    1 微控制器抽象層(MCAL) AUTOSAR CP的微控制器抽象層(MCAL)是AUTOSAR軟件架構中的一個重要組成部分,它提供了對底層硬件的抽象和訪問接口,以實現(xiàn)軟件與硬件之間的解耦和可移植性
    的頭像 發(fā)表于 10-27 15:36 ?5554次閱讀

    AUTOSAR經(jīng)典平臺介紹

    經(jīng)典平臺(AUTOSAR CP) AUTOSAR經(jīng)典平臺(AUTOSAR CP)是AUTOSAR軟件架構的一種實現(xiàn),旨在提供一種標準化的方法
    的頭像 發(fā)表于 10-27 15:30 ?1226次閱讀
    <b class='flag-5'>AUTOSAR</b>經(jīng)典平臺介紹

    AUTOSAR架構自適應平臺

    。AUTOSAR架構的目標是實現(xiàn)汽車電子系統(tǒng)的模塊化、可重用和可擴展,以提高開發(fā)效率和系統(tǒng)的可靠性。 AUTOSAR架構由三個主要的層次組成
    的頭像 發(fā)表于 10-27 15:23 ?1107次閱讀
    <b class='flag-5'>AUTOSAR</b><b class='flag-5'>架構</b>自適應平臺

    解讀AUTOSAR模式管理BswM配置

    模式管理是AUTOSAR中的一個難點,也可以說是最龐雜的一塊。因為模式管理貫穿整個CP Autosar流程,幾乎所有模塊都跟BSWM發(fā)生著聯(lián)系。
    的頭像 發(fā)表于 10-26 16:55 ?1770次閱讀
    解讀<b class='flag-5'>AUTOSAR</b>模式管理BswM配置

    基于Tricore芯片的AUTOSAR架構的多核啟動

    隨著汽車ECU迅速的往域控制器方向發(fā)展,ECU要出來任務越來越多,單核CPU的負載越來越大,多核ECU勢在必行。AUTOSAR架構OS支持多核處理,本系列文章將詳細介紹AUTOSAR
    的頭像 發(fā)表于 10-23 10:15 ?2576次閱讀
    基于Tricore芯片的<b class='flag-5'>AUTOSAR</b><b class='flag-5'>架構</b><b class='flag-5'>下</b>的多核啟動