99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

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

喚醒事件(也稱喚醒源)有效性驗證為什么要設(shè)置一段時間?

冬至配餃子 ? 來源:開心果 Need Car ? 作者:開心果 Need Car ? 2022-08-23 11:25 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前言

上一篇中講只有Transceiver、Controller處于正常工作模式以后才能有效的收發(fā)報文,進而才能識別報文的類型(NM Message、XCPMessage、Diagnostic Message、APPMessage)。但識別出這些報文需要一個前提:ECU上電同時整個主程序運行起來,且需要一定的時間去識別報文類型。

項目中,喚醒事件(也稱喚醒源)有效性驗證為什么要設(shè)置一段時間?ECU上電,整個主程序如何運行起來?

本篇就上述問題進行分析。

喚醒事件有效性驗證時間分析

在實際的網(wǎng)絡(luò)管理項目中,大家可能會遇到這樣的需求:收到有效喚醒事件(如:網(wǎng)絡(luò)管理報文),網(wǎng)絡(luò)激活,報文正常收發(fā);如果收到的報文是非網(wǎng)絡(luò)管理報文,ECU需要保持一定時間后休眠(如:ECU保持5s,即5s內(nèi)ECU處于供電狀態(tài))。注意后者網(wǎng)絡(luò)仍然在BSM(BusSleepMode),只能此時間內(nèi)接收報文,不能發(fā)送報文。如果ECU在該時間內(nèi)收到有效喚醒事件(多數(shù)是網(wǎng)絡(luò)管理報文,也可能是有效的Power ON信號報文),網(wǎng)絡(luò)將激活,進而進行正常的報文收發(fā)。

注意:ECU喚醒是網(wǎng)絡(luò)喚醒的前提條件,ECU喚醒并不一定網(wǎng)絡(luò)喚醒,如果網(wǎng)絡(luò)激活(進入NormalMode)則ECU一定喚醒(RUN模式)。

為什么要ECU保持一段時間呢?這里說一下個人理解,ECU自身并不知道喚醒事件是不是有效,ECU只要被供電就從啟動文件指定的位置開始執(zhí)行程序。如果要識別該喚醒事件是不是有效需要上層模塊(EcuM)識別,而EcuM從開始驗證到確認該事件的有效性需要調(diào)用底層模塊確認(如:Controller或者Transceiver),這需要時間,且EcuM的驗證和確認一般是異步執(zhí)行,這也需要時間。上述時間其實并不長,項目不同執(zhí)行的時間不等(每個項目初始化模塊數(shù)量和讀NVM時間不同),但多數(shù)在幾十毫秒內(nèi)執(zhí)行完,但又為什么會要求1s或者5s或者更長呢?個人理解:ECU被喚醒,整個冷啟動(可以理解為與電壓相關(guān)的啟動)花費了“較長”的時間,廢了這么大勁立馬Shutdown有點“過分”,如果ECU下電又被干擾起來還需要重頭再來(各個模塊、外設(shè)初始化、讀NVM等),既然這樣還不如等待一段時間確定沒有有效喚醒事件以后,ECU再走Shutdown流程,進而避免ECU頻繁的喚醒->休眠->喚醒,注意是ECU,不是網(wǎng)絡(luò)被喚醒->休眠->喚醒,網(wǎng)絡(luò)只有有效喚醒源才能激活。

ECU上電,程序運行過程分析

ECU如果要正常的運行程序,則需要供電,之后程序開始執(zhí)行:啟動文件->BootLoader->Application,進入“main”函數(shù),也就是我們熟知的用戶代碼程序。用戶代碼程序包含ASWC的runnable以及各個模塊的mainhandler(如:CanTrcv_30_Tja1145_MainFunction),這些程序在OS的調(diào)度下周期性或者事件觸發(fā)執(zhí)行,這也是上層模塊可以收到消息和處理消息的基礎(chǔ)。

這里主要分析EcuM管理的上電到程序運行過程。AUTOSAR中,EcuM分為Flexible和Fixed兩種類型,因為Fixed并不支持多核且不靈活,本文主要討論Flexible類型的EcuM。

pYYBAGMESDyAX8xwAACoYJ2kfXY991.png

如上圖(1)所示,CInitCode一般是應(yīng)用程序的main函數(shù),即EcuM_Init在應(yīng)用程序的main函數(shù)被調(diào)用,EcuM將控制ECU的啟動流程,EcuM調(diào)用StartOS,讓Os完成Task的激活。

EcuM_Init并不能完成MCU所有的初始化動作,在StartPreOS Sequence階段主要完成DET模塊(最先完成初始化,以便其它模塊可以上報開發(fā)錯誤)以及一些硬件外設(shè)的初始化,如MCU、Port、Internal Watchdog等(主要根據(jù)項目需求設(shè)置要初始化的外設(shè)模塊)。

poYBAGMESFKAP1JDAADR9R37i-A697.png

如上圖,EcuM_StartupTwo將完成SchM(Os),BSW模塊的初始化,其中各個模塊的初始化(Can_Init、CanIf_Init等)在BswM中完成。程序所需的所有外設(shè)、模塊初始化之后,啟動Scheduler 定時,即周期性的執(zhí)行BSW/SWCs任務(wù),至此Application程序得以運行。



審核編輯:劉清

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

    關(guān)注

    146

    文章

    17985

    瀏覽量

    367314
  • AUTOSAR
    +關(guān)注

    關(guān)注

    10

    文章

    380

    瀏覽量

    22700
  • ecu
    ecu
    +關(guān)注

    關(guān)注

    14

    文章

    935

    瀏覽量

    55841
  • DET
    DET
    +關(guān)注

    關(guān)注

    0

    文章

    3

    瀏覽量

    8708
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    FX3的FLAGA信號,在運行一段時間后,無法拉高怎么解決?

    Thread0所在的緩存,上傳上位機。同時,F(xiàn)PGA檢測Thread2中是否有數(shù)據(jù)需要讀取,若有,則將Thread2中的數(shù)據(jù)讀取到FPGA中進行解析。 如下圖,在正常運行一段時間后,F(xiàn)LAGA信號會拉低,并且無法恢復(fù)為高電平,導(dǎo)致FPGA無法繼續(xù)寫數(shù)據(jù)至Thread0。 請問我該如何解決這個問題?
    發(fā)表于 05-08 07:38

    LSM6DSR工作一段時間后就算靜止不動會出現(xiàn)Y軸數(shù)據(jù)偏移,是什么原因?qū)е碌模?/a>

    LSM6DSR工作一段時間后就算靜止不動會出現(xiàn)Y軸數(shù)據(jù)偏移,請問下是什么原因可能會導(dǎo)致出現(xiàn)這個異常?
    發(fā)表于 03-11 07:52

    ADS1278上電后運行一段時間后DRDY信號就沒有了,為什么?

    我們用 ADS1278 做了個樣板,直有 DRDY 引號,數(shù)據(jù)可以采集到。但前幾天,上電后運行一段時間后 DRDY 信號就沒有了,再斷電、上電,還是運行
    發(fā)表于 01-09 07:55

    使用STM32單片機可以進行SPI通訊,一段時間可以正常工作,一段時間沒有數(shù)值,這是什么問題?

    我使用STM32單片機,可以進行SPI通訊。。一段時間可以正常工作,一段時間沒有數(shù)值,寄存器0x20顯示0xf0.。。。請問您這是什么問題?
    發(fā)表于 01-09 07:52

    使用stm32的spi讀取ads1256數(shù)據(jù),ads1256正常輸出數(shù)據(jù)一段時間后總會出現(xiàn)異常默認設(shè)置,為什么?

    使用stm32的spi讀取ads1256數(shù)據(jù),發(fā)現(xiàn)ads1256在正常輸出數(shù)據(jù)一段時間(不確定多少時間,有時候幾秒有時候一兩分鐘)之后,總會出現(xiàn)異常默認設(shè)置,表現(xiàn)為數(shù)據(jù)輸出頻率(DRDY引腳脈沖
    發(fā)表于 01-07 08:23

    使用LTC3780EG工作一段時間后無輸出是什么原因?qū)е碌模?/a>

    使用LTC3780EG,汽車電瓶輸入,12V輸出,剛開機的時候正常,工作一段時間后(小時內(nèi)),輸出12V沒了,發(fā)現(xiàn)INTVCC的6V輸出沒了,RUN引腳的電壓是3V,請問般是什么原因?qū)е碌倪@個內(nèi)部穩(wěn)壓輸出損壞
    發(fā)表于 12-19 09:18

    ADS1013采集運放輸出數(shù)據(jù),一段時間后變的很低是為什么?

    我用ADS1013采集AD8237運放輸出直流數(shù)據(jù),開始采集得到的原始數(shù)據(jù)為683,對應(yīng)1.3v。一段時間后大概5-9分鐘,ads1013讀出來的數(shù)據(jù)變成11,對應(yīng)0.02v,然后不再發(fā)生變化。需要系統(tǒng)復(fù)位ADS1013采集的數(shù)據(jù)才會變成683,但過了一段時間還是會出現(xiàn)
    發(fā)表于 12-17 07:09

    TLV5633IPW使用一段時間就壞了,為什么?

    最近使用TLV5633IPW芯片,使用一段時間就壞了,跟C8051F530A單片機搭配使用,DA輸出過大,請大佬出來指點一二,謝謝
    發(fā)表于 11-26 08:18

    文搞懂Linux進程的睡眠和喚醒

    : 使用 sleep() 函數(shù)讓進程暫停執(zhí)行一段時間 使用 usleep() 函數(shù),使進程睡眠0.5秒,精確度更高 使用 nanosleep(),使進程睡眠1.5秒,可以精細控制時間 2.
    發(fā)表于 11-04 15:15

    TAS5825正常播放一段時間后,進入Sleep模式喇叭沒有聲音,為什么?怎么解決?

    TAS5825正常輸出音頻信號一段時間后,芯片進入sleep模式,喇叭沒有聲音。 讀取相關(guān)寄存器發(fā)現(xiàn)DEVICE_CTRL2 寄存器設(shè)置為0x03,上電之后STATE_RPT 寄存器值為0x03
    發(fā)表于 10-15 08:19

    風(fēng)機運行一段時間跳閘的原因

    風(fēng)機在運行一段時間后跳閘,可能的原因有多種,以下是些常見的因素及其解決方法: 、電氣因素 起動電流過大 : 對于大功率容量的風(fēng)機,建議采用降壓起動方式以減少起動電流。 檢查電氣系統(tǒng),確保電氣元件
    的頭像 發(fā)表于 09-30 10:11 ?4633次閱讀

    CYW89820怎么關(guān)閉HIDOFF下GPIO作為喚醒?

    HIDOFF, 因為我計劃在HIDOFF下周期喚醒,但設(shè)置喚醒時間到后,查看wake up reason,會顯示GPIO,通過
    發(fā)表于 09-26 06:56

    求助,有沒有上升沿和下降沿觸發(fā)后保持一段時間可以恢復(fù)的芯片?

    電源輸出 然后在板子上電時SN74LVC1G80-Q1的Q pin就直接輸出了高電平,并不能停止輸出 我想咨詢有沒有上升沿和下降沿觸發(fā)后保持一段時間可以恢復(fù)的芯片
    發(fā)表于 09-23 07:16

    使用labview調(diào)用python運行一段時間后,報錯

    使用labview調(diào)用python運行一段時間后,報錯。 labview版本:2018*64; python:3.6x64 怎么解決~
    發(fā)表于 08-26 10:16

    如何讓蜂鳴器響一段時間停止

    蜂鳴器是種常見的電子元件,廣泛應(yīng)用于各種電子設(shè)備中,如鬧鐘、電話、電子玩具等。蜂鳴器的工作原理是通過電磁線圈產(chǎn)生磁場,使蜂鳴片振動產(chǎn)生聲音。本文將介紹如何讓蜂鳴器響一段時間停止,包括硬件連接、軟件
    的頭像 發(fā)表于 08-09 10:06 ?2224次閱讀