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

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

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

AUTOSAR架構(gòu)下的WdgDriver WdgIf WdgM模塊

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

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

01

模塊架構(gòu)與依賴

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

1.AliveSpuervision

2.DeadlineSupervision

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

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

WdgIf模塊,WdgM通過WdgIf接口更改WdgDriver的驅(qū)動模式,同時(shí)通知看門狗觸發(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 調(diào)用SchM模塊接口WdgM_GlobalSuspendInterrupts進(jìn)入臨界區(qū),WdgM_GlobalRestoreInterrupts退出臨界區(qū)Rte模塊,Rte通過WdgM_CheckpointReached()接口,監(jiān)控SWC是否按照設(shè)計(jì)運(yùn)行BswM模塊,WdgM在監(jiān)控Spuervised Entity失敗后,可以通過BswM模塊重啟被監(jiān)控程序OS模塊

02

模塊配置

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

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

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

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

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

3、關(guān)聯(lián)Core

3

源碼分析

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

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

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

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

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

04

多核的WdgM管理

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

2. 更新WdgM節(jié)拍數(shù) WdgM提供三種更新節(jié)拍數(shù)的方式 1. WDGM_INTERNAL_SOFTWARE_TICK , 通過MainFunction調(diào)度跟新節(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)喂狗

責(zé)任編輯:haq

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

    關(guān)注

    452

    文章

    49994

    瀏覽量

    419675
  • 模塊
    +關(guān)注

    關(guān)注

    7

    文章

    2628

    瀏覽量

    47216
  • 看門狗
    +關(guān)注

    關(guān)注

    10

    文章

    557

    瀏覽量

    70672

原文標(biāo)題:AUTOSAR 架構(gòu)下看門狗的理解

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

收藏 人收藏

    評論

    相關(guān)推薦

    AUTOSAR架構(gòu),持續(xù)集成CI的最佳實(shí)踐

    集成(CI)流程。今天,我們就來探討一基于AUTOSAR架構(gòu)的CI流程實(shí)踐,并通過對流程的詳細(xì)講解,展示其在實(shí)際開發(fā)中的重要性和優(yōu)勢。什么是AUTOSAR
    的頭像 發(fā)表于 10-24 08:06 ?73次閱讀
    <b class='flag-5'>AUTOSAR</b><b class='flag-5'>架構(gòu)</b><b class='flag-5'>下</b>,持續(xù)集成CI的最佳實(shí)踐

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

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

    AUTOSAR架構(gòu)中復(fù)雜驅(qū)動設(shè)計(jì)

    復(fù)雜驅(qū)動(Complex Driver,CDD)是一種不受 AUTOSAR 標(biāo)準(zhǔn)化約束的軟件實(shí)體,它可以通過 AUTOSAR 接口和/或基礎(chǔ)軟件模塊 API 進(jìn)行訪問 AUTOSAR
    的頭像 發(fā)表于 12-21 10:13 ?3758次閱讀
    <b class='flag-5'>AUTOSAR</b><b class='flag-5'>架構(gòu)</b>中復(fù)雜驅(qū)動設(shè)計(jì)

    分析Autosar架構(gòu)的NVM源碼

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

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

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

    AUTOSAR架構(gòu)的多核通信介紹

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

    AUTOSAR CAN時(shí)鐘同步問題

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

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

    隨著軟件日益復(fù)雜,并且車載系統(tǒng)和傳感器數(shù)量穩(wěn)步增加,車內(nèi)系統(tǒng)的通訊成幾何增長,必須加強(qiáng)密碼保護(hù)。這種保護(hù)可以通過經(jīng)典的實(shí)時(shí)汽車開放系統(tǒng)架構(gòu)AUTOSAR) 來實(shí)現(xiàn)。即便在資源稀缺的情況,安裝合適固件的硬件安全
    發(fā)表于 10-30 10:15 ?992次閱讀
    <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架構(gòu)中的一個(gè)組件,
    的頭像 發(fā)表于 10-27 16:55 ?1980次閱讀

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

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

    AUTOSAR CP的復(fù)雜驅(qū)動是什么

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

    AUTOSAR架構(gòu)MCAL、服務(wù)層、ECU抽象層介紹

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

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

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

    AUTOSAR架構(gòu)自適應(yīng)平臺

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

    解讀AUTOSAR模式管理BswM配置

    模式管理是AUTOSAR中的一個(gè)難點(diǎn),也可以說是最龐雜的一塊。因?yàn)槟J焦芾碡灤┱麄€(gè)CP Autosar流程,幾乎所有模塊都跟BSWM發(fā)生著聯(lián)系。
    的頭像 發(fā)表于 10-26 16:55 ?1986次閱讀
    解讀<b class='flag-5'>AUTOSAR</b>模式管理BswM配置