chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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)注

    147

    文章

    18388

    瀏覽量

    378944
  • AUTOSAR
    +關(guān)注

    關(guān)注

    10

    文章

    388

    瀏覽量

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

    關(guān)注

    14

    文章

    950

    瀏覽量

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

    關(guān)注

    0

    文章

    3

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    單片機運行一段時間死機,為什么?

    問題: 單片機運行一段時間死機,想通過在死機前異常時利用cmbacktrace捕捉log保存,讓系統(tǒng)重啟重啟后通過shell打印出死機時信息,用addr2line分析死機原因
    發(fā)表于 09-29 08:26

    如何驗證硬件冗余設(shè)計的有效性

    硬件冗余設(shè)計的核心目標是應(yīng)對單點故障、保障系統(tǒng)連續(xù)運行,其有效性驗證需圍繞 “故障發(fā)生時的切換能力、數(shù)據(jù)完整、業(yè)務(wù)連續(xù)” 三大核心指標展開,通過 “靜態(tài)配置檢查 + 動態(tài)故障模擬
    的頭像 發(fā)表于 09-18 16:36 ?471次閱讀
    如何<b class='flag-5'>驗證</b>硬件冗余設(shè)計的<b class='flag-5'>有效性</b>?

    AD7606BSTZ正常工作一段時間后,ad停止轉(zhuǎn)換是什么原因?qū)е碌模?/a>

    您好,我的控制板上采用AD7606BSTZ來采集逆變器的三相電流。在變流器沒有跑功率的時候,AD芯片可以直工作;跑功率時運行20min左右之后,AD轉(zhuǎn)換的數(shù)值開始發(fā)生錯誤,會出現(xiàn)較長時間結(jié)果為0;再過一段時間芯片就完全不工作了
    發(fā)表于 07-29 08:58

    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

    ADS1112的讀出的AD值就會保持不變,好長一段時間以后才會恢復(fù),為什么?

    輸入電壓每隔定的值,ADS1112的讀出的AD值就會保持不變,好長一段時間以后才會恢復(fù)。
    發(fā)表于 01-17 07:37

    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

    ADS1220運行一段時間后出現(xiàn)ADC = -1 的錯值,怎么解決?

    ADS1220可以轉(zhuǎn)換出數(shù)據(jù),但是經(jīng)常運行一段時間后出現(xiàn)ADC = -1 的錯值,并且復(fù)位單片機無法恢復(fù),只有把ADS1220斷電后才能恢復(fù)。 代碼是移植的github上適配Arduino的代碼。
    發(fā)表于 12-06 07:23

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

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

    CDCE72010運行一段時間后PLL_LOCK失鎖怎么解決?

    1、小批量試產(chǎn),有塊板卡CDCE72010開機一段時間后PLL失鎖,其他9片板卡均正常。不知道這個板子發(fā)生了什么問題,如下為原理圖、晶振、PLL參數(shù) 能幫忙看下,從那幾個方面入手分析下么,多謝了
    發(fā)表于 11-13 06:00

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

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