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

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

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

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

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

j4AI_wujianying ? 來源:單片機精講吳鑒鷹 ? 2020-05-14 15:01 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

1、多任務機制

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

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

2、任務的狀態(tài)


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

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

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

掛起態(tài):某些條件不滿足而掛起不能運行的狀態(tài)。

3、如何轉(zhuǎn)化為就緒態(tài)

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

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

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

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

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

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

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

4、什么是搶占式調(diào)度?

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

所謂“搶占式調(diào)度”是指:一旦就緒狀態(tài)中出現(xiàn)優(yōu)先權(quán)更高的任務,便立即剝奪當前任務的運行權(quán),把CPU分配給更高優(yōu)先級的任務。這樣CPU 總是執(zhí)行處于就緒條件下優(yōu)先級最高的任務。

5、多任務系統(tǒng)的時間管理

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

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

6、如何實現(xiàn)多任務?


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

TIPS:

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

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

實現(xiàn)互斥(獨占)訪問的方法有關(guān)中斷,關(guān)調(diào)度,互斥信號量,計數(shù)信號量等。

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

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

TIPS:

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

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

6.2 一個任務如何擁有自己的堆棧、數(shù)據(jù)存儲區(qū)

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

什么是任務控制塊?

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

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

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

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

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

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

6.4 如何實現(xiàn)搶占式調(diào)度?

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

任務狀態(tài)會在什么時候發(fā)生改變呢?有下面兩種情況:

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

2、高優(yōu)先級的任務因為時鐘節(jié)拍到來,或在中斷處理結(jié)束后,內(nèi)核發(fā)現(xiàn)更高優(yōu)先級任務獲得了執(zhí)行條件(如延時的時鐘到時)則在中斷后直接切換到更高優(yōu)先級任務執(zhí)行。這種調(diào)度也稱為中斷級的切換。

6.5 掛起/恢復任務

1. 掛起任務

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

2 .恢復任務(OSTaskResume())

可以讓被 OSTaskSuspend 或 OSTimeDly 掛起的任務恢復就緒態(tài),然后進行任務調(diào)度。

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

    關(guān)注

    5175

    文章

    19982

    瀏覽量

    324456
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    11187

    瀏覽量

    221304

原文標題:一個小型嵌入式操作系統(tǒng)設(shè)計:精髓都有了!

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

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

掃碼添加小助手

加入工程師交流群

    評論

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

    【人臉+手勢AI識別模組】100元自己一個數(shù)碼相機

    以下作品由安信可社區(qū)用戶 dzy7455339 制作 原貼地址 【電子DIY作品】BW21數(shù)碼相機+BW21-CBV-KIT 直想自己DIY相機,但是奈何筆者個人水平有限,雖然有
    的頭像 發(fā)表于 09-16 16:06 ?239次閱讀
    【人臉+手勢AI識別模組】100元<b class='flag-5'>自己</b>做<b class='flag-5'>一個</b>數(shù)碼相機

    如何打造屬于自己的手勢識別應用

    期小編給大家介紹了和MediaPipe的相遇之路,本期小編將帶著大家起來動手,如何打造屬于自己的手勢識別應用。
    的頭像 發(fā)表于 07-29 10:12 ?656次閱讀
    如何打造<b class='flag-5'>一</b><b class='flag-5'>個</b>屬于<b class='flag-5'>自己</b>的手勢識別應用

    單核CPU網(wǎng)關(guān)和雙核CPU網(wǎng)關(guān)有什么區(qū)別

    單核CPU網(wǎng)關(guān)與雙核CPU網(wǎng)關(guān)的核心區(qū)別在于處理能力、多任務效率、性能表現(xiàn)及適用場景,雙核CPU網(wǎng)關(guān)在多任務處理、復雜計算和響應速度上具有顯
    的頭像 發(fā)表于 07-05 14:37 ?567次閱讀

    CPU密集型任務開發(fā)指導

    密集型任務可以提高CPU利用率,提升應用程序響應速度。 當任務不需要長時間(3分鐘)占據(jù)后臺線程,而是一個個獨立的任務時,推薦使用TaskP
    發(fā)表于 06-19 06:05

    片主板可以有多少路CPU?

    CPU是計算機的中央處理器,可以直接影響到服務器的并行處理能力。CPU路數(shù)越多,服務器可以同時處理的任務數(shù)量就越多,從而提高了整體的處理效率和性能,特別是在處理大量并發(fā)任務時,多路服務
    的頭像 發(fā)表于 06-13 09:14 ?422次閱讀
    <b class='flag-5'>一</b>片主板可以有多少路<b class='flag-5'>CPU</b>?

    主板和CPU東西嗎?有什么區(qū)別?

    在數(shù)字化浪潮席卷的時代,電腦早已成為現(xiàn)代生活的核心樞紐。而在計算機硬件體系中,主板與CPU堪稱兩大支柱,共同構(gòu)筑了整臺機器的運算中樞。雖然主板和CPU在功能定位上不同,但它們的協(xié)同運作,卻如同精密齒輪的咬合,直接決定了電腦性能的上限。
    的頭像 發(fā)表于 06-11 09:19 ?1740次閱讀

    CPU的各種指令和執(zhí)行流程

    在集成電路設(shè)計中,CPU的指令是指計算機中央處理單元(CPU)用來執(zhí)行計算任務的基本操作指令集。這些指令是CPU能夠理解并執(zhí)行的二進制代碼,它們在計算機內(nèi)部由硬件控制并按順序執(zhí)行,從而
    的頭像 發(fā)表于 04-18 11:24 ?1499次閱讀

    Linux計劃任務cron詳解

    cron是linux下用來周期性的執(zhí)行某種任務或等待處理某些事件的守護進程,與windows下的計劃任務類似,當安裝完成操作系統(tǒng)后,默認會安裝此服務 工具,并且會自動啟動crond
    的頭像 發(fā)表于 02-07 15:31 ?1376次閱讀
    Linux計劃<b class='flag-5'>任務</b>cron詳解

    自己搭建達龍云電腦,自己搭建達龍云電腦的詳細操作步驟

    云電腦并非易事,因為達龍云電腦是復雜的系統(tǒng),涉及到強大的硬件配置、專業(yè)的軟件支持以及多平臺的適配和優(yōu)化。達龍云電腦面向的是游戲玩家,因此必須具備高性能的硬件配置,如E52650v4CPU、16G內(nèi)存、英偉達特斯拉顯卡等,這
    的頭像 發(fā)表于 01-16 10:42 ?871次閱讀
    <b class='flag-5'>自己</b>搭建達龍云電腦,<b class='flag-5'>自己</b>搭建達龍云電腦的詳細操作步驟

    自己動手做一個好玩的POV顯示設(shè)備

    “ 讀大學的時候就很喜歡這些開腦洞的小玩意兒??吹?b class='flag-5'>一印度小哥用ESP32 做了高分辨率的 POV,而且開源了全部的硬件和代碼,忍不住想分享給大家?!?/div>
    的頭像 發(fā)表于 12-25 15:15 ?2133次閱讀
    <b class='flag-5'>自己</b>動手做<b class='flag-5'>一個</b>好玩的POV顯示設(shè)備

    Linux之CPU調(diào)度策略和CPU親和性

    、調(diào)度策略 調(diào)度進程 單個 CPU次只能執(zhí)行進程,雖然 Linux 系統(tǒng)通過使用多任務
    的頭像 發(fā)表于 12-05 16:38 ?1520次閱讀
    Linux之<b class='flag-5'>CPU</b>調(diào)度策略和<b class='flag-5'>CPU</b>親和性

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

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

    如何訓練自己的LLM模型

    訓練自己的大型語言模型(LLM)是復雜且資源密集的過程,涉及到大量的數(shù)據(jù)、計算資源和專業(yè)知識。以下是訓練LLM模型的般步驟,以及些關(guān)
    的頭像 發(fā)表于 11-08 09:30 ?1868次閱讀

    如何訓練自己的AI大模型

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

    CPU占用率過高的常見原因

    排查系統(tǒng)問題時,CPU 飆升是常見的問題。
    的頭像 發(fā)表于 10-23 09:33 ?4353次閱讀