18video性欧美19sex,欧美高清videosddfsexhd,性少妇videosexfreexxx片中国,激情五月激情综合五月看花,亚洲人成网77777色在线播放

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

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

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

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

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

掃碼添加小助手

加入工程師交流群

1. 說明

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

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

2. 任務的通常寫法

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

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

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

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

//2.waitsuccess,handle!
}
}

這種寫法中,在沒有事件發(fā)生的時候,任務會因為等待某個內(nèi)核對象而被掛起,讓出CPU不參與調(diào)度。

② 定時執(zhí)行

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

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

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

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

3. 一次性任務

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

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

//dosomething...

//exit?
}

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

4. 尋找答案

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

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

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

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

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

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

由于不同CPU架構的CPU寄存器組不同,所以初始化任務棧的代碼與架構強相關,在arch目錄下都有不同架構對應的實現(xiàn)。

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

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

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

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

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

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

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

__STATIC__voidtask_exit(void)
{
tos_task_destroy(K_NULL);
}

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

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

6. 總結

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

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

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

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

    關注

    31

    文章

    5503

    瀏覽量

    128263
  • API
    API
    +關注

    關注

    2

    文章

    1969

    瀏覽量

    65784
  • 函數(shù)
    +關注

    關注

    3

    文章

    4401

    瀏覽量

    66518
  • RTOS
    +關注

    關注

    24

    文章

    858

    瀏覽量

    122342

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

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

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

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

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

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

    詳解hal_entry入口函數(shù)

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

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

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

    揭秘LuatOS:實時操作系統(tǒng)RTOS核心庫的關鍵技術剖析!

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

    如何在Eclipse ThreadX RTOS中集成SystemView

    可以基于Systemview記錄ThreadX操作系統(tǒng)事件并執(zhí)行分析。我們基于SEGGER Embedded Studio開發(fā)環(huán)境描述如何在Eclipse ThreadX RTOS中集成SystemView。
    的頭像 發(fā)表于 05-06 17:11 ?1047次閱讀

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

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

    stm32cubemax為什么下載之后無法運行?

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

    RTOS中的本地存儲指針使用

    本地存儲指針是RTOS中的一個重要特性,增強了任務管理和數(shù)據(jù)處理能力。在RTOS上下文中,本地存儲是指存儲在本地的特定任務或對象的數(shù)據(jù)。通常與任務
    的頭像 發(fā)表于 02-28 16:33 ?1079次閱讀
    <b class='flag-5'>RTOS</b>中的本地存儲指針使用

    谷歌AI智能體執(zhí)行復雜任務能力大幅提升

    自然語言描述任務,隨后由AI智能體代替用戶執(zhí)行并最終完成任務,極大地提升工作效率和便捷性。 為了推進這一技術的實現(xiàn),谷歌正在積極開發(fā)兩個相關項目。其中備受矚目的是名為“Mariner”的瀏覽器擴展程序。通過該程序,AI智能體能夠
    的頭像 發(fā)表于 02-17 14:39 ?863次閱讀

    ADS1282發(fā)送SYNC命令之后無法發(fā)送RDATAC命令怎么處理?

    ADS1282發(fā)送SYNC命令之后無法發(fā)送RDATAC命令
    發(fā)表于 02-08 08:32

    使用任務通知提高RTOS應用的效率

    在實時嵌入式系統(tǒng)中,性能和資源效率是決定設計成敗的關鍵因素。傳統(tǒng)的實時操作系統(tǒng)(RTOS)提供了如隊列、信號量和事件組機制,實現(xiàn)任務之間的同步和通信。FreeRTOS/SAFERTOS還提供一種方法可以使這些過程更快、更輕量化,即任務
    的頭像 發(fā)表于 12-27 14:54 ?958次閱讀

    【RA-Eco-RA4E2-64PIN-V1.0開發(fā)板試用】MDK+點燈+流水燈

    的led引腳為P207\\\\P113P207引腳配置輸出高P113也是這樣當使用 RTOS 時,程序從 main 函數(shù)開始進行線程調(diào)度; 當沒有使用 RTOS 時,C語言程序的入口
    發(fā)表于 12-15 15:59

    如何獲取入口函數(shù)不是__iar_program_start的Program entry的stack使用情況

    問題 IAR中默認的入口函數(shù)是__iar_program_start,使能stack usage analysis之后: 生成的map文件中STACK USAGE章節(jié)里面會包含Program
    的頭像 發(fā)表于 11-25 16:23 ?1396次閱讀
    如何獲取<b class='flag-5'>入口</b><b class='flag-5'>函數(shù)</b>不是__iar_program_start的Program entry的stack使用情況

    MaXim96717 VPG功能啟用之后去哪里查看圖像

    MaXim96717 VPG功能啟用之后去哪里查看圖像
    發(fā)表于 11-01 10:42