国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

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

揭秘RTOS任務(wù)入口函數(shù)執(zhí)行完之后去哪里了

strongerHuang ? 來(lái)源:Mculover666 ? 作者:mculover666 ? 2021-11-05 14:20 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1. 說(shuō)明

在工作過(guò)程中,我發(fā)現(xiàn)在實(shí)際使用RTOS完成項(xiàng)目時(shí),理解這些知識(shí)僅能達(dá)到會(huì)用RTOS的水平,要想用好RTOS,還需要了解一些比較細(xì)節(jié)的機(jī)制,否則容易掉坑進(jìn)去,花大量時(shí)間定位問(wèn)題。

本文結(jié)合TencentOS-Tiny實(shí)時(shí)操作系統(tǒng)給大家講述一下相關(guān)內(nèi)容。

2. 任務(wù)的通常寫法

遵循“不使用就讓出”的原則,任務(wù)通常有兩種寫法。

「阻塞等待」某個(gè)事件處理,等待到之后處理:

voidtask1_entry(void*arg)
{
//init...

while(1){
//1.waitsomekernelobject...
//eg.tos_sem_pend,tos_mutex_pend,tos_event_pend.

//2.waitsuccess,handle!
}
}

這種寫法中,在沒(méi)有事件發(fā)生的時(shí)候,任務(wù)會(huì)因?yàn)榈却硞€(gè)內(nèi)核對(duì)象而被掛起,讓出CPU不參與調(diào)度。

② 定時(shí)執(zhí)行

voidtask1_entry(void*arg)
{
//init...

while(1){
//1.dosomething...

//2.sleep!
//eg.tos_task_delay,tos_sleep_ms.
}
}

這種寫法中,任務(wù)在干完活之后,會(huì)主動(dòng)進(jìn)入睡眠狀態(tài),讓出CPU不參與調(diào)度。

3. 一次性任務(wù)

上面兩種寫法的共性是都有主循環(huán),不需要考慮任務(wù)入口函數(shù)退出的情況,但在一些場(chǎng)景中任務(wù)只需要執(zhí)行一次即可:

voidtask1_entry(void*arg)
{
//init...

//dosomething...

//exit?
}

「這個(gè)時(shí)候就要思考一個(gè)問(wèn)題:任務(wù)入口函數(shù)執(zhí)行完畢之后去了哪里?」

4. 尋找答案

首先,「任務(wù)入口函數(shù)本質(zhì)上是一個(gè)函數(shù)」,跳轉(zhuǎn)函數(shù)的指令是BL,CPU在執(zhí)行該指令跳轉(zhuǎn)到某個(gè)函數(shù)執(zhí)行時(shí),會(huì)將當(dāng)前PC地址作為函數(shù)返回地址、加載到LR寄存器中、保證函數(shù)執(zhí)行完可以返回到這兒繼續(xù)執(zhí)行,再將函數(shù)地址加載到PC寄存器、程序接著執(zhí)行就到了函數(shù)中。

6cdb8e6e-3dfd-11ec-82a9-dac502259ad0.png

那么,任務(wù)入口函數(shù)沒(méi)有被別的函數(shù)主動(dòng)調(diào)用,是如何被拉起來(lái)執(zhí)行的呢?

任務(wù)切換分為兩步:保存上文、切換下文。切換下文就是指將保存在任務(wù)棧中的CPU寄存器組的值、加載到CPU中。

「所以,當(dāng)任務(wù)棧中初始保存的CPU寄存器組的值中、PC寄存器值為該任務(wù)的任務(wù)入口函數(shù)地址時(shí),切換下文加載之后,由于PC指向任務(wù)入口函數(shù),所以CPU接著運(yùn)行就到了任務(wù)入口函數(shù)中,也就是該任務(wù)在運(yùn)行。」

同樣的道理,「任務(wù)棧中初始保存的CPU寄存器組的值中、LR寄存器的值決定了、任務(wù)入口函數(shù)退出時(shí)候返回到哪里。」

由于不同CPU架構(gòu)的CPU寄存器組不同,所以初始化任務(wù)棧的代碼與架構(gòu)強(qiáng)相關(guān),在arch目錄下都有不同架構(gòu)對(duì)應(yīng)的實(shí)現(xiàn)。

這里我們以ARM Cortex-M4為例(Arm-v7m)看看代碼如何實(shí)現(xiàn):

6d302d48-3dfd-11ec-82a9-dac502259ad0.png

從代碼里可以看到,TencentOS-Tiny默認(rèn)退出函數(shù)為exit參數(shù)指定的值,接下來(lái)我們看看退出函數(shù)~

5. 任務(wù)退出函數(shù)

在創(chuàng)建任務(wù)的API tos_task_create 中,初始化任務(wù)棧的過(guò)程中會(huì)指定退出函數(shù)為 task_exit

task->sp=cpu_task_stk_init((void*)entry,arg,(void*)task_exit,stk_base,stk_size);

task_exit 函數(shù)主要完成銷毀自身的工作,具體實(shí)現(xiàn)如下:

__STATIC__voidtask_exit(void)
{
tos_task_destroy(K_NULL);
}

該銷毀函數(shù)傳入的參數(shù)為NULL表示銷毀自身,如果是靜態(tài)任務(wù)則按以下步驟銷毀(動(dòng)態(tài)任務(wù)銷毀值得用一篇文章去講述):

  • 將任務(wù)從就緒列表移除
  • 將任務(wù)從等待列表移除
  • 將任務(wù)從統(tǒng)計(jì)列表移除
  • 任務(wù)狀態(tài)置為K_TASK_STATE_DELETED

6. 總結(jié)

本文講述了任務(wù)的兩種常規(guī)寫法,以及任務(wù)函數(shù)執(zhí)行完畢之后去了哪里?

當(dāng)任務(wù)函數(shù)執(zhí)行完畢退出時(shí),會(huì)執(zhí)行到哪里由任務(wù)棧初始化時(shí)LR寄存器的值決定,RTOS內(nèi)核都會(huì)提供一個(gè)默認(rèn)退出函數(shù),TencentOS-Tiny提供的任務(wù)退出函數(shù)中,會(huì)自動(dòng)銷毀任務(wù)自身。

所以在編寫一次性任務(wù)時(shí),就不需要主動(dòng)調(diào)用銷毀API銷毀自身啦~

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

    關(guān)注

    31

    文章

    5608

    瀏覽量

    130001
  • API
    API
    +關(guān)注

    關(guān)注

    2

    文章

    2372

    瀏覽量

    66790
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4417

    瀏覽量

    67521
  • RTOS
    +關(guān)注

    關(guān)注

    25

    文章

    866

    瀏覽量

    123011

原文標(biāo)題:RTOS 任務(wù)入口函數(shù)執(zhí)行完之后去哪里了?

文章出處:【微信號(hào):strongerHuang,微信公眾號(hào):strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    【瑞薩FPB-RA6E2試用】【瑞薩FPB-RA6E2】RTOS(Real-Time Operating System,實(shí)時(shí)操作系統(tǒng))《線程》個(gè)人理解及項(xiàng)目實(shí)現(xiàn)

    System,實(shí)時(shí)操作系統(tǒng))線程含義 在 RTOS(Real-Time Operating System,實(shí)時(shí)操作系統(tǒng)) 中,線程(Thread) 是任務(wù)調(diào)度和并發(fā)執(zhí)行的基本單位。不同 RT
    發(fā)表于 01-14 11:50

    如何在Zephyr RTOS中實(shí)現(xiàn)延時(shí)和計(jì)時(shí)函數(shù)

    在實(shí)時(shí)操作系統(tǒng)(RTOS)中,時(shí)間管理是核心功能之一。無(wú)論是任務(wù)調(diào)度、超時(shí)控制,還是周期性事件,延時(shí)和計(jì)時(shí)機(jī)制都扮演著至關(guān)重要的角色。Zephyr RTOS作為一個(gè)輕量級(jí)、模塊化的開源系統(tǒng),提供
    的頭像 發(fā)表于 12-26 10:32 ?5480次閱讀
    如何在Zephyr <b class='flag-5'>RTOS</b>中實(shí)現(xiàn)延時(shí)和計(jì)時(shí)<b class='flag-5'>函數(shù)</b>

    RTOS在嵌入式開發(fā)中的作用

    中,不依賴其它任務(wù)或調(diào)度器。 高峰負(fù)載管理 RTOS提供為管理系統(tǒng)高峰活動(dòng)提供一個(gè)有效的方法。更高的優(yōu)先級(jí)分配給執(zhí)行峰值負(fù)載活動(dòng)的
    發(fā)表于 12-26 07:53

    使用RTOS時(shí)需要注意的幾點(diǎn)內(nèi)容分享

    是為一個(gè)外設(shè)指定一個(gè)核。所以,在等待事件發(fā)生期間,使該核空閑起來(lái)是有意義的。 其結(jié)果是,優(yōu)先式、中斷驅(qū)動(dòng)的RTOS架構(gòu)占據(jù)業(yè)已部署的大部分平臺(tái)。雖然借助硬件手段(多個(gè)寄存器組合、硬件調(diào)度、任務(wù)切換
    發(fā)表于 12-23 06:34

    選擇RTOS的要點(diǎn)

    補(bǔ)充Linux,因?yàn)樗鼈兛商峁┯矊?shí)時(shí)級(jí)別的QoS。 要指出的很重要一點(diǎn)是:這類補(bǔ)充常常是在原始OS上集成一個(gè)RTOS編程環(huán)境。與傳統(tǒng)臺(tái)式或服務(wù)器OS相比,RTOS通常要小很多。RTOS
    發(fā)表于 12-12 08:00

    RTOS Crash 問(wèn)題全維度分析與解決指南

    →TaskB”),識(shí)別死鎖(長(zhǎng)時(shí)間無(wú)切換)、優(yōu)先級(jí)反轉(zhuǎn); 中斷時(shí)長(zhǎng)檢測(cè) :在ISR入口/出口記錄時(shí)間戳(如SysTick值),排查ISR執(zhí)行超時(shí)(超過(guò)RTOS調(diào)度周期); 壓力測(cè)試 :模擬極限場(chǎng)景(如
    發(fā)表于 12-08 03:56

    FreeRTOS 空閑任務(wù)

    幾乎所有的小型 RTOS 中都會(huì)有一個(gè)空閑任務(wù),空閑任務(wù)屬于系統(tǒng)任務(wù),是必須要執(zhí)行的,用戶程序不能將其關(guān)閉。不光小型系統(tǒng)中有空閑
    發(fā)表于 12-04 07:35

    RTOS 必學(xué)概念:任務(wù)、信號(hào)量、隊(duì)列一次搞懂

    如果你剛接觸RTOS(實(shí)時(shí)操作系統(tǒng)),很可能會(huì)有這樣的困惑:“RTOS和裸機(jī)程序到底有什么區(qū)別?”“任務(wù)是線程嗎?為什么要分任務(wù)?”“信號(hào)量和互斥鎖有什么區(qū)別,不都是同步手段嗎?”“隊(duì)
    的頭像 發(fā)表于 11-17 10:53 ?474次閱讀
    <b class='flag-5'>RTOS</b> 必學(xué)概念:<b class='flag-5'>任務(wù)</b>、信號(hào)量、隊(duì)列一次搞懂

    Task任務(wù):LuatOS實(shí)現(xiàn)“任務(wù)級(jí)并發(fā)”的核心引擎

    Task任務(wù)通過(guò)其強(qiáng)大的并發(fā)處理能力,使LuatOS能夠在單線程環(huán)境中模擬多線程執(zhí)行,通過(guò)協(xié)程的掛起與恢復(fù)機(jī)制,實(shí)現(xiàn)任務(wù)級(jí)的并行操作,顯著提升系統(tǒng)效能。 sys核心庫(kù)是LuatOS運(yùn)行框架庫(kù),也是
    的頭像 發(fā)表于 08-28 13:49 ?515次閱讀
    Task<b class='flag-5'>任務(wù)</b>:LuatOS實(shí)現(xiàn)“<b class='flag-5'>任務(wù)</b>級(jí)并發(fā)”的核心引擎

    揭秘LuatOS Task:多任務(wù)管理的“智能中樞”

    ,也是LuatOS應(yīng)用程序運(yùn)行的核心大腦——所有LuatOS應(yīng)用項(xiàng)目都會(huì)使用到sys核心庫(kù)。 ? ?sys核心庫(kù)提供四大類功能: Task任務(wù) Message消息 Timer定時(shí)器 Run調(diào)度器 本文將
    的頭像 發(fā)表于 08-28 13:48 ?648次閱讀
    <b class='flag-5'>揭秘</b>LuatOS Task:多<b class='flag-5'>任務(wù)</b>管理的“智能中樞”

    詳解hal_entry入口函數(shù)

    當(dāng)使用RTOS時(shí),程序從main函數(shù)開始進(jìn)行線程調(diào)度;當(dāng)沒(méi)有使用RTOS時(shí),C語(yǔ)言程序的入口函數(shù)main
    的頭像 發(fā)表于 07-25 15:34 ?1997次閱讀

    【RA4L1-SENSOR】05 按鍵實(shí)現(xiàn)RTOS任務(wù)切換

    與計(jì)數(shù)功能的切換,為之后的多任務(wù)切換做個(gè)鋪墊。 2. 軟件部分 將上次的實(shí)驗(yàn)工程復(fù)制一份,重命名為05_Button_Switch_Task 2.1 綁定按鍵IO &&
    發(fā)表于 06-16 22:38

    揭秘LuatOS:實(shí)時(shí)操作系統(tǒng)RTOS核心庫(kù)的關(guān)鍵技術(shù)剖析!

    電機(jī)控制、傳感器采集等實(shí)時(shí)數(shù)據(jù)處理場(chǎng)景。 在LuatOS開發(fā)中, 用于實(shí)時(shí)操作系統(tǒng)(RTOS)相關(guān)功能的核心庫(kù) ——提供定時(shí)器管理、系統(tǒng)控制、內(nèi)存監(jiān)控、路徑配置等底層操作接口,為物聯(lián)網(wǎng)設(shè)備提供可靠的實(shí)時(shí)系統(tǒng)基礎(chǔ)支撐。 ? 本文以A
    的頭像 發(fā)表于 05-21 16:02 ?668次閱讀
    <b class='flag-5'>揭秘</b>LuatOS:實(shí)時(shí)操作系統(tǒng)<b class='flag-5'>RTOS</b>核心庫(kù)的關(guān)鍵技術(shù)剖析!

    詳解RTOS中的Hook函數(shù)

    Hook函數(shù)RTOS中的一個(gè)關(guān)鍵特性,通過(guò)該函數(shù),用戶可以增強(qiáng)對(duì)任務(wù)管理的控制,定義系統(tǒng)行為。
    的頭像 發(fā)表于 03-24 16:14 ?1083次閱讀

    stm32cubemax為什么下載之后無(wú)法運(yùn)行?

    我本來(lái)想上傳代碼的,完全完全無(wú)法理解為什么下載之后無(wú)法運(yùn)行
    發(fā)表于 03-12 06:06