在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

一個任務如何擁有自己的CPU

j4AI_wujianying ? 來源:單片機精講吳鑒鷹 ? 2020-05-14 15:01 ? 次閱讀

這個是在網上看到的一篇文檔,作者的目的是設計一個簡單的嵌入式操作系統,只實現一個基本任務調度器的功能。正如作者所說,雖然不能稱為操作系統,但已體現了小型嵌入式操作系統的精髓。對于我們來說是很好的學習資料,可以從中一窺操作系統的面目,今天分享給大家。

1、多任務機制

其實在單一CPU 的情況下,是不存在真正的多任務機制的,存在的只有不同的任務輪流使用CPU,所以本質上還是單任務的。但由于CPU執行速度非常快,加上任務切換十分頻繁并且切換的很快,所以我們感覺好像有很多任務同時在運行一樣。這就是所謂的多任務機制。

實時系統的特征是延時可預測,能夠在一個規定的時間內(通常是 ms 級別的)對某些信號做出反應。

2、任務的狀態


任務有下面的特性:任務并不是隨時都可以運行的,而一個已經運行的任務并不能保證一直占有 CPU 直到運行完。一般有就緒態,運行態,掛起態等。

運行態:一個運行態的任務是一個正在使用 CPU 的任務。任何時刻有且只有一個運行著的任務。

就緒態:一個就緒態任務是可運行的,等待占有 CPU 的任務釋放 CPU。

掛起態:某些條件不滿足而掛起不能運行的狀態。

3、如何轉化為就緒態

INT32U OSRdyTbl; /* 就緒任務表 */

上面定義一個 32 位變量,每一位代表一個任務,0 表示掛起狀態,1 表示就緒狀態。它記錄了各任務的就緒與否狀態,稱它為就緒表。OSRdyTbl 定義為 32 位變量,對應32 個任務。當然,定義為 64 位的話,便最多能支持 64 個任務。這樣,可以定義兩個宏,實現把任務的狀態變為就緒或掛起態。

/* 在就緒表中登記就緒任務 */

#define OSSetPrioRdy(prio) { OSRdyTbl |= 0x01<

/* 從就緒表中刪除任務 */

#define OSDelPrioRdy(prio) { OSRdyTbl &= ~(0x01<

任務之間互相獨立,不存在互相調用的關系。所有任務在邏輯上都是平等的。由于任務之間互相看不見,所以他們之間的信息傳輸就無法當面完成。這就需要各種通信機制如信號量,消息郵箱,隊列等來實現。

4、什么是搶占式調度?

調度的概念,通俗的說就是系統在多個任務中選擇合適的任務執行。系統如何知道何時該執行哪個任務?可以為每個任務安排一個唯一的優先級別,當同時有多個任務就緒時,優先運行優先級較高的任務。同時,任務的優先級也作為任務的唯一標識號。代碼中都是對標識號來完成對任務的操作的。

所謂“搶占式調度”是指:一旦就緒狀態中出現優先權更高的任務,便立即剝奪當前任務的運行權,把CPU分配給更高優先級的任務。這樣CPU 總是執行處于就緒條件下優先級最高的任務。

5、多任務系統的時間管理

與人一樣,多任務系統也需要一個“心跳”來維持其正常運行,這個心跳叫做時鐘節拍,通常由定時器產生一個固定周期的中斷來充當。

OSTimeDly 函數就是以時鐘節拍為基準來延時的(在時鐘的中斷服務函數中,依次對各個延時任務的延時節拍數減1。若發現某個任務的延時節拍數變為0,則把它從掛起態置為就緒態。)。這個函數完成功能很簡單,就是先掛起當起當前任務,設定其延時節拍數,然后進行任務切換,在指定的時鐘節拍數到來之后,將當前任務恢復為就緒狀態。任務必須通過OSTimeDly或 OSTaskSuspend 讓出CPU的使用權(延時或等待事件),使更低優先級任務有機會運行。

6、如何實現多任務?


只有一個CPU,如何在同一時間實現多個獨立程序的運行?要實現多任務,條件是每個任務互相獨立。人如何才能獨立,有自己的私有財產。任務也一樣,如果一個任務有自己的CPU,堆棧,程序代碼,數據存儲區,那這個任務就是一個獨立的任務。(CPU是通過多任務機制獲得的,其他的需要你分配)

TIPS:

如果一個任務正在運行某個公共函數時(如Printf), 被另一個高優先級的任務搶占,那么當這個高優先級的任務也調用同一個公共函數時,極有可能破壞原任務的數據。因為兩個任務可能共用一套數據。為了防止這種情況發生,常采用兩種措施:可重入設計和互斥調用。

可重入函數中所有的變量均為局部變量,局部變量在調用時臨時分配空間,所以不同的任務在不同的時刻調用該函數時,它們的同一個局部變量所分配的存儲空間并不相同(任務私有棧中),互不干擾。另外,如果可重入函數調用了其他函數,則這些被調用的函數也必須是可重入函數。

實現互斥(獨占)訪問的方法有關中斷,關調度,互斥信號量,計數信號量等。

6.1 一個任務如何擁有自己的程序代碼

對于如何實現多任務,首先是程序代碼,每個任務的程序代碼與函數一樣,與51 的裸奔程序一樣,每個任務都是一個大循環。然后是數據存儲區,由于全局變量是系統共用的,各個任務共享,不是任務私有,所以這里的數據存儲區是指任務的私有變量,如何變成私有?局部變量也。編譯器是把局部變量保存在棧里的,所以好辦,只要任務有個私有的棧就行。

TIPS:

臨界資源是一次僅允許一個任務使用的共享資源。每個任務中訪問臨界資源的那段程序稱為臨界區。

在多任務系統中,為保障數據的可靠性和完整性,共享資源要互斥(獨占)訪問,所以全局變量(只讀的除外)不能同時有多個任務訪問,即一個任務訪問的時候不能被其他任務打斷。共享資源是一種臨界資源。

6.2 一個任務如何擁有自己的堆棧、數據存儲區

私有棧的作用是存放局部變量,函數的參數,它是一個線性的空間,所以可以申請一個靜態數組,把棧頂指針SP指向棧的數組的首元素(遞增棧)或最后一個元素(遞減棧)。即可打造一個人工的棧出來。每個任務還要有記錄自己棧頂指針的變量,保存在任務控制塊(TCB)中。

什么是任務控制塊?

系統中的每個任務具有一個任務控制塊,任務控制塊記錄任務執行的環境,這里的任務控制塊比較簡單,只包含了任務的堆棧指針和任務延時節拍數。任務控制塊是任務的身份證。它把任務的程序與數據聯系起來,找到它就可以得到任務的所有資源。

6.3 一個任務如何擁有自己的CPU

最后來看看任務是如何“擁有”自己的CPU 的。只有一個 CPU,各個任務共享,輪流使用。如何才能實現?我們先來看看中斷的過程,當中斷來臨時,CPU 把當前程序的運行地址,寄存器等現場數據保存起來(一般保存在棧里),然后跳到中斷服務程序執行。待執行完畢,再把先前保存的數據裝回CPU 又回到原來的程序執行。這樣就實現了兩個不同程序的交叉運行。

借鑒這種思想不就能實現多任務了嗎!模仿中斷的過程就可以實現任務切換運行。任務切換時,把當前任務的現場數據保存在自己的任務棧里面,再把待運行的任務的數據從自己的任務棧裝載到CPU中,改變 CPU 的 PC,SP,寄存器等。可以說,任務的切換是任務運行環境的切換。而任務的運行環境保存在任務棧中,也就是說,任務切換的關鍵是把任務的私有堆棧指針賦予處理器的堆棧指針SP。

創建一個任務。它接收三個參數,分別是任務的入口地址,任務堆棧的首地址和任務的優先級。調用本函數后,系統會根據用戶給出的參數初始化任務棧,并把棧頂指針保存到任務控制塊中,在任務就緒表標記該任務為就緒狀態。最后返回,這樣一個任務就創建成功了。

當一個任務將要運行時,便通過取得它的堆棧指針(保存在任務控制塊中)將這些寄存器出棧裝入CPU 相應的位置即可。

6.4 如何實現搶占式調度?

基于任務優先級的搶占式調度,也就是最高優先級的任務一旦處于就緒狀態,則立即搶占正在運行的低優先級任務的處理器資源。為了保證CPU 總是執行處于就緒條件下優先級最高的任務,每當任務狀態改變后,即判斷當前運行的任務是否是就緒任務中優先級最高的,否則進行任務切換。

任務狀態會在什么時候發生改變呢?有下面兩種情況:

1、高優先級的任務因為需要某種資源或延時,主動請求掛起,讓出處理器,此時將調度就緒狀態的低優先級任務獲得執行,這種調度稱為任務級的切換。如任務執行OSTimeDly()或OSTaskSuspend()把自身掛起就屬于這種。

2、高優先級的任務因為時鐘節拍到來,或在中斷處理結束后,內核發現更高優先級任務獲得了執行條件(如延時的時鐘到時)則在中斷后直接切換到更高優先級任務執行。這種調度也稱為中斷級的切換。

6.5 掛起/恢復任務

1. 掛起任務

通過 OSTaskSuspend()可以主動掛起一個任務。OSTaskSuspend()會把任務從任務就緒表中移出,最后重新啟動系統調度。這個函數可以掛起任務本身也可以掛起其他任務。

2 .恢復任務(OSTaskResume())

可以讓被 OSTaskSuspend 或 OSTimeDly 掛起的任務恢復就緒態,然后進行任務調度。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 嵌入式
    +關注

    關注

    5086

    文章

    19141

    瀏覽量

    305971
  • cpu
    cpu
    +關注

    關注

    68

    文章

    10873

    瀏覽量

    212093

原文標題:一個小型嵌入式操作系統設計:精髓都有了!

文章出處:【微信號:wujianying_danpianji,微信公眾號:單片機精講吳鑒鷹】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    從零到:搭建屬于自己的海外IP代理池

    從零到搭建屬于自己的海外IP代理池是復雜但具有挑戰性的任務,它涉及多個步驟和考慮因素。
    的頭像 發表于 11-15 08:15 ?437次閱讀

    如何訓練自己的AI大模型

    訓練自己的AI大模型是復雜且耗時的過程,涉及多個關鍵步驟。以下是詳細的訓練流程: 、明
    的頭像 發表于 10-23 15:07 ?1842次閱讀

    服務器cpu和臺式機cpu區別

    服務器CPU和臺式機CPU的區別是復雜的話題,涉及到多個方面,包括設計、性能、功耗、可靠性、成本等。 服務器CPU和臺式機
    的頭像 發表于 10-10 15:12 ?1267次閱讀

    雙核cpu和單核cpu的區別

    理器核心連接起來,從而提高計算能力。這種設計使得處理器能夠同時執行多個任務,提高計算效率和性能。 單核CPU :只有處理器核心,所有的計算任務
    的頭像 發表于 09-24 16:17 ?3180次閱讀

    freertos最多支持多少任務

    FreeRTOS是輕量級的實時操作系統(RTOS),其設計初衷就是為了提供簡單、可靠且高效的實時任務管理。關于FreeRTOS最多支持多少任務
    的頭像 發表于 09-02 14:21 ?965次閱讀

    如何使用freeRTOS在兩任務之間傳輸任務數據?

    的問題是不知道如何將傳感器的數據從任務傳輸到另一個任務。 或許這根本就不是好主意,應該在
    發表于 07-03 07:55

    請問下FREERTOS只能創建4任務,修改哪個宏定義可以增加創建任務的數量?

    請問下FREERTOS只能創建4任務,修改哪個宏定義可以增加創建任務的數量?解決方法:增加FREERTOS的堆。
    發表于 05-13 06:44

    freertos任務創建,每一個任務分配的內存是多大才好,怎么計算呢?

    小白剛剛接觸freertos,想問下就創建任務而言,每一個任務分配的內存是多大才好,怎么計算呢? 另外,每個任務的執行周期怎么確定?在
    發表于 04-23 06:39

    鴻蒙OS開發實例:【ArkTS類庫多線程CPU密集型任務TaskPool】

    CPU密集型任務是指需要占用系統資源處理大量計算能力的任務,需要長時間運行,這段時間會阻塞線程其它事件的處理,不適宜放在主線程進行。例如圖像處理、視頻編碼、數據分析等。 基于多線程并發機制處理
    的頭像 發表于 04-01 22:25 ?857次閱讀
    鴻蒙OS開發實例:【ArkTS類庫多線程<b class='flag-5'>CPU</b>密集型<b class='flag-5'>任務</b>TaskPool】

    文詳解GPU硬件與CUDA開發工具

    CPU 和 GPU 的顯著區別是:典型的 CPU 擁有少數幾個快速的計算核心,而
    的頭像 發表于 03-21 10:15 ?1222次閱讀
    <b class='flag-5'>一</b>文詳解GPU硬件與CUDA開發工具

    服務器中的CPU核心和線程到底是什么?

    CPU核心作為CPU(中央處理單元)的主要處理單元。該組件從計算機內存中讀取并執行指令。每個核心次只能運行任務,因此具有多個核心的
    的頭像 發表于 03-04 17:09 ?1401次閱讀

    HarmonyOS CPU與I/O密集型任務開發指導

    。 基于多線程并發機制處理CPU密集型任務可以提高CPU利用率,提升應用程序響應速度。 當進行系列同步任務時,推薦使用Worker;而進行
    的頭像 發表于 02-18 10:17 ?982次閱讀
    HarmonyOS <b class='flag-5'>CPU</b>與I/O密集型<b class='flag-5'>任務</b>開發指導

    為什么GPU比CPU更快?

    GPU比CPU更快的原因并行處理能力:GPU可以同時處理多個任務和數據,而CPU通常只能次處理任務
    的頭像 發表于 01-26 08:30 ?2436次閱讀
    為什么GPU比<b class='flag-5'>CPU</b>更快?

    處理器和cpu東西嗎 cpu和主板的區別

    處理器和CPU東西,CPU是指中央處理器(Central Processing Unit)的簡稱,是計算機的核心部件,負責執行各種計算任務
    的頭像 發表于 01-19 09:52 ?2w次閱讀

    鴻蒙原生應用/元服務開發-延遲任務說明(

    WorkSchedulerExtensionAbility,并給WorkSchedulerExtensionAbility定的活動周期,開發者可以在對應回調方法中實現自己任務邏輯。 三、約束與限制 數量限制:
    發表于 01-16 14:57
    主站蜘蛛池模板: 天堂自拍| 天天天天做夜夜夜夜| 色婷婷综合久久久久中文一区二区| 亚洲三级网| 婷婷午夜影院| 色偷偷成人| 欧美在线免费| 女人特黄大aaaaaa大片| 国内一国产农村妇女一级毛片| 国产三级黄色录像| 一级黄色片a| 免费观看在线永久免费xx视频| 国产精品久久1024| 欧美成人激情在线| 交在线观看网站视频| 性做久久久久久久免费看 | 奇米影视一区| 在线视频黄色| 热久久国产| www.日本黄色| 222www免费观看| 免费 视频| 欧美性操| 综合色99| 日本大片黄色| 波多野结衣在线网址| 天天草天天射| www.夜夜骑| 久久精品国产免费高清| 四虎永久免费在线| 精品三级视频| 天天综合天天做| 五月婷婷欧美| 永久网站色视频在线观看免费| 色多网站免费视频| 国产91小视频在线观看| 欧美黄色大片免费| 双性强迫开宫灌满h| 四虎传媒| 国产高清色视频免费看的网址| 日本片巨大的乳456线观看|