一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

無MMU搶占式操作系統(tǒng)的搶占工作原理介紹

strongerHuang ? 來源: strongerHuang ? 作者: strongerHuang ? 2020-11-03 16:07 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

線程基礎(chǔ)原理

線程之間搶占

中斷搶占線程

中斷搶占中斷

strongerHuang

1

運(yùn)行多個線程

1.單核“單線程”

嚴(yán)格來說,單核處理器一次只能執(zhí)行一條指令,也就是說只能“單線程”。(當(dāng)然,多核處理器就不一樣)

為了在單核處理器上運(yùn)行多個線程,我們實(shí)際上需要定期在線程之間進(jìn)行快速切換,以便用戶感覺多個線程在并行運(yùn)行。

比如處理器執(zhí)行兩個線程,處理器實(shí)際在兩個線程之間來回切換,如下圖:

2.處理器在線程之間切換,它是如何做到的?

我們說的單核處理器是“單線程”的,它有一組寄存器,我們就叫這組寄存器屬于一個“線程”。

例如,計(jì)算兩個數(shù)字的總和時:

//假設(shè)我們有兩個整數(shù):a和bint c = a + b ;

實(shí)際發(fā)生的情況如下所示(當(dāng)然,它取決于的MCU類型,但總體思路是相同):

# MIPS反匯編: LW V0, -32744(GP) # "a" 的值從RAM加載到寄存器V0LW V1, -32740(GP) # 值"b" 從RAM加載到寄存器V1ADDU V0, V1, V0 # a、b值相加,結(jié)果保存到寄存器V0中SW V0, -32496(GP) # 寄存器V0的值存儲在RAM中(變量c所在的位置)

你會發(fā)現(xiàn)上面執(zhí)行了4個動作,但是搶占式操作系統(tǒng)可以在任何時候搶占另一個線程,包括在這4個動作之間。

假如在這過程中有其他線程搶占了,其他線程同樣搶占了當(dāng)前線程V0、 V1,如果不對V0、 V1進(jìn)行保存,那么下次回來執(zhí)行當(dāng)前線程,結(jié)果就會出錯。

所以,針對當(dāng)前這種問題,我們就需要在切換線程之前,對V0、 V1的數(shù)值進(jìn)行保存,當(dāng)下次切換到當(dāng)前線程,再恢復(fù)V0、 V1的數(shù)值,大致流程如下:

大概意思就是:當(dāng)我們需要從一個線程切換到另一個線程時,內(nèi)核獲得控制權(quán),執(zhí)行必要的內(nèi)務(wù)處理(至少要保存和恢復(fù)寄存器值),然后將控制權(quán)轉(zhuǎn)移到下一個線程以運(yùn)行。

strongerHuang

2

線程的堆棧

上面說的搶占位置,到底在哪里,每個線程保存在哪個寄存器值中?這就是線程的堆棧的內(nèi)容。 在有MMU的操作系統(tǒng)中,(用戶的)線程堆??梢园葱鑴討B(tài)增長:線程需要的堆??臻g越多,線程堆棧就越多(如果內(nèi)核允許)。 但是,我們一般的MCU卻沒有MMU這個“高端”的東西,所有RAM都靜態(tài)映射到地址空間。因此,每個線程都會有用于堆棧的RAM空間,如果線程使用的RAM超過堆棧的數(shù)量,則會導(dǎo)致內(nèi)存溢出或細(xì)微的錯誤。(實(shí)際上,每個線程的堆??臻g只是一連續(xù)數(shù)組空間)。 因此,當(dāng)我們決定為每個線程分配多少堆棧時,我們只是估計(jì)可能需要多少堆棧,但是具體多少可能不是很清楚。 比如,如果這是一個具有多層嵌套調(diào)用的GUI線程,則可能需要數(shù)個千字節(jié),但如果它是一個流水燈的小線程,則可能幾十字節(jié)就足夠了。 假設(shè)我們有三個線程,它們的堆棧消耗如下:

如上面所述,每個線程的寄存器值都保存在線程的堆棧中。線程的寄存器值集稱為線程的“上下文”。如下圖所示(線程A為在正在執(zhí)行的“活動線程”):

請注意,在正在執(zhí)行的線程A的上下文沒有保存在堆棧中,堆棧指針指向線程A用戶數(shù)據(jù)的頂部,并且當(dāng)前處理器的寄存器專用于線程A。 當(dāng)內(nèi)核決定將控制權(quán)切換到線程B時,它將執(zhí)行以下操作:

將所有寄存器值保存到堆棧中(保存到線程A堆棧的頂部);

將堆棧指針切換到線程B的堆棧頂部;

從堆棧(從線程B的堆棧頂部)恢復(fù)所有寄存器值;

此時,你會看到:

strongerHuang

3

中斷(ISR)搶占

上面在執(zhí)行過程中,或進(jìn)行上下文切換時,還可能會涉及到一個非常重要的內(nèi)容:中斷。 MCU通常具有外設(shè):TIM、UART、 SPI、 CAN等,它們隨時都能發(fā)生重要事件以觸發(fā)中斷。 中斷條件是當(dāng)當(dāng)前正在執(zhí)行的線程暫停時,處理器在一段時間內(nèi)執(zhí)行其他操作(Handles Interrupt),然后返回。中斷可能隨時觸發(fā),我們應(yīng)該做好處理的準(zhǔn)備。 中斷處理程序稱為ISR(中斷服務(wù)程序):中斷可能具有不同的優(yōu)先級,例如,如果觸發(fā)了一些低優(yōu)先級的中斷,則當(dāng)前正在執(zhí)行的線程將暫停,并且ISR會獲得控制權(quán)。然后,如果觸發(fā)了某個高優(yōu)先級中斷,則當(dāng)前正在執(zhí)行的ISR將再次暫停,并為該高優(yōu)先級中斷運(yùn)行一個新的ISR。 這樣一來,完成后,控制權(quán)將返回到第一個ISR,并且在完成時,也會恢復(fù)被中斷的線程。 重要的關(guān)鍵代碼:在線程活躍過程中,如果有重要的事情“關(guān)鍵的代碼”,在這過程中如果中斷發(fā)生,很容易導(dǎo)致意想不到的結(jié)果。 這部分關(guān)鍵的代碼,我們需要要保護(hù)起來,通常我們的做法就是:在之前“關(guān)鍵代碼”之前禁用全局中斷,執(zhí)行完之后,開始全局中斷。 有點(diǎn)需要注意:關(guān)閉全局中斷,此時就不會相應(yīng)中斷,所以,“關(guān)鍵代碼”不能太長。

strongerHuang

3

中斷堆棧

在上面說到一點(diǎn),高優(yōu)先級中斷搶占低優(yōu)先中斷,就會出現(xiàn)一個問題:低優(yōu)先級的代碼需要和線程一樣,用于保存數(shù)據(jù)的堆棧。 一般有兩種方法:

使用被中斷的線程堆棧;

為中斷使用單獨(dú)的堆??臻g;

1.使用被中斷的線程堆棧如果使用被中斷的線程堆棧,就類似如下圖:

這種情況存在你一個嚴(yán)重的問題,你知道是什么嗎? 頻繁中斷,或者中斷較多,線程自身的堆??臻g就會很快被使用完。 每個線程的堆棧都應(yīng)該包含以下內(nèi)容:

線程自己的數(shù)據(jù);

線程的上下文;

用于執(zhí)行最壞情況的ISR的數(shù)據(jù)。

因此,我們就需要換一種方法,為為所有ISR中斷開辟單獨(dú)的堆??臻g。 2.為中斷使用單獨(dú)的堆??臻g

為中斷使用單獨(dú)的堆??臻g大致如上圖所示。 好了,本文講述了上面幾種關(guān)于搶占,以及相關(guān)的內(nèi)容,你學(xué)會了幾點(diǎn),又有幾點(diǎn)沒懂,歡迎留言討論。

責(zé)任編輯:xj

原文標(biāo)題:無MMU搶占式操作系統(tǒng)的搶占工作原理

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

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

    關(guān)注

    37

    文章

    7138

    瀏覽量

    125477
  • 線程
    +關(guān)注

    關(guān)注

    0

    文章

    508

    瀏覽量

    20187
  • MMU
    MMU
    +關(guān)注

    關(guān)注

    0

    文章

    92

    瀏覽量

    18731

原文標(biāo)題:無MMU搶占式操作系統(tǒng)的搶占工作原理

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

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

掃碼添加小助手

加入工程師交流群

    評論

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

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

    為滿足實(shí)時控制場景的嚴(yán)苛需求,LuatOS核心庫采用搶占調(diào)度策略,確保高優(yōu)先級任務(wù)即時響應(yīng)。通過靜態(tài)內(nèi)存分配和零拷貝通信機(jī)制,系統(tǒng)不僅避免了動態(tài)內(nèi)存碎片問題,還大幅提升了任務(wù)間數(shù)據(jù)交換效率,適用于
    的頭像 發(fā)表于 05-21 16:02 ?194次閱讀
    揭秘LuatOS:實(shí)時<b class='flag-5'>操作系統(tǒng)</b>RTOS核心庫的關(guān)鍵技術(shù)剖析!

    國產(chǎn)銀河麒麟操作系統(tǒng)V10和星光麒麟V1.0操作系統(tǒng)如何選擇?

    國產(chǎn)銀河麒麟操作系統(tǒng)和星光麒麟操作系統(tǒng)都是由中國電子旗下科技企業(yè)麒麟軟件有限公司(簡稱“麒麟軟件”)開發(fā)的國產(chǎn)自主可控的操作系統(tǒng)。麒麟軟件介紹:麒麟軟件以安全可信
    的頭像 發(fā)表于 01-24 09:14 ?2159次閱讀
    國產(chǎn)銀河麒麟<b class='flag-5'>操作系統(tǒng)</b>V10和星光麒麟V1.0<b class='flag-5'>操作系統(tǒng)</b>如何選擇?

    鴻道Intewell操作系統(tǒng)的Windows實(shí)時拓展方案

    鴻道Intewell操作系統(tǒng)的Windows實(shí)時拓展方案,即鴻道Intewell-Win構(gòu)型,是一款專為工業(yè)控制領(lǐng)域設(shè)計(jì)的國產(chǎn)操作系統(tǒng),支持Windows實(shí)時擴(kuò)展,具備以下特點(diǎn)和優(yōu)勢:多業(yè)務(wù)融合:鴻
    的頭像 發(fā)表于 12-24 17:40 ?543次閱讀
    鴻道Intewell<b class='flag-5'>操作系統(tǒng)</b>的Windows實(shí)時拓展方案

    deepin操作系統(tǒng)介紹

    希望從自己的能力和對桌面操作系統(tǒng)的理解,能給 Linux 的用戶與開發(fā)者更多的選擇。我們也相信 deepin 能夠得到更多用戶的認(rèn)可與喜愛,成為開源世界的最佳選擇。? 一、 deepin 操作系統(tǒng) 先說 Linux 操作系統(tǒng),它
    的頭像 發(fā)表于 12-23 09:08 ?2308次閱讀
    deepin<b class='flag-5'>操作系統(tǒng)</b><b class='flag-5'>介紹</b>

    什么是嵌入操作系統(tǒng)?

    機(jī)器人的大腦。它告訴機(jī)器人怎么工作,什么時候做什么事,怎么和它身體上的各種傳感器和部件溝通,EOS是為嵌入系統(tǒng)設(shè)計(jì)的專用操作系統(tǒng)。 那它到底有什么特別的呢? 1.超快反應(yīng):EOS得像
    發(fā)表于 11-08 15:07

    ARM開發(fā)板上的實(shí)時操作系統(tǒng)介紹

    在現(xiàn)代電子設(shè)備中,嵌入系統(tǒng)扮演著越來越重要的角色。ARM處理器因其低功耗、高性能的特點(diǎn),成為了許多嵌入系統(tǒng)的首選平臺。 一、實(shí)時操作系統(tǒng)
    的頭像 發(fā)表于 11-05 11:34 ?1095次閱讀

    橋PFC工作原理和電路結(jié)構(gòu)

    橋PFC(Power Factor Correction,功率因數(shù)校正)技術(shù)是一種廣泛應(yīng)用于電源電路的技術(shù),旨在提高電源的功率因數(shù),從而改善電源的有效使用效率。本文將詳細(xì)介紹橋PFC的工作
    的頭像 發(fā)表于 10-29 17:25 ?4410次閱讀

    rtthread是搶占的rtos,那么線程的timeout參數(shù)具體的作用是什么呢?

    查閱相關(guān)說明,rtthread是搶占的rtos,那么線程的timeout參數(shù)具體的作用是什么呢, 假如線程A,B的優(yōu)先級分別是1和2,timeout是10ms。當(dāng)線程B 在運(yùn)行中,還未到timeout,此刻掛起的線程A被觸發(fā),是直接
    發(fā)表于 09-27 08:39

    開啟全新AI時代 智能嵌入系統(tǒng)快速發(fā)展——“第六屆國產(chǎn)嵌入操作系統(tǒng)技術(shù)與產(chǎn)業(yè)發(fā)展論壇”圓滿結(jié)束

    航空計(jì)算技術(shù)研究所研究員崔西寧做了“AI時代的機(jī)載嵌入操作系統(tǒng)”專題報告。 崔西寧回顧了機(jī)載軟件技術(shù)發(fā)展歷程,介紹機(jī)載智能計(jì)算的演進(jìn)之路,分享了天脈操作系統(tǒng)現(xiàn)狀和發(fā)展計(jì)劃。 圖3
    發(fā)表于 08-30 17:24

    簡單認(rèn)識RTOS實(shí)時操作系統(tǒng)

    RTOS(Real Time Operating System,實(shí)時操作系統(tǒng))是一種專門設(shè)計(jì)用于在嚴(yán)格時間限制內(nèi)處理任務(wù)的操作系統(tǒng)。它以其高實(shí)時性、多任務(wù)處理能力和資源管理能力在工業(yè)自動化、醫(yī)療設(shè)備、航空航天、汽車電子等眾多領(lǐng)域得到廣泛應(yīng)用。以下是對RTOS實(shí)時
    的頭像 發(fā)表于 08-20 11:20 ?5175次閱讀

    源蜂鳴器的工作原理是什么

    源蜂鳴器是一種常見的電子元件,廣泛應(yīng)用于各種電子設(shè)備中,如鬧鐘、電話、電腦、汽車等。它通過將電能轉(zhuǎn)換為聲音信號,實(shí)現(xiàn)聲音的輸出。 一、源蜂鳴器的工作原理 1.1 基本工作原理
    的頭像 發(fā)表于 08-09 09:46 ?3881次閱讀

    Windows操作系統(tǒng)中的常用命令

    這些命令不僅能提高工作效率,還能幫助用戶解決許多復(fù)雜的問題。本系列文章將詳細(xì)介紹Windows操作系統(tǒng)中的常用命令,幫助你成為Windows極客!
    的頭像 發(fā)表于 08-07 15:40 ?1153次閱讀
    Windows<b class='flag-5'>操作系統(tǒng)</b>中的常用命令

    第六屆國產(chǎn)嵌入操作系統(tǒng)技術(shù)與產(chǎn)業(yè)發(fā)展論壇議程發(fā)布

    每年一度的國產(chǎn)嵌入操作系統(tǒng)論壇即將在杭州濱江舉辦,今年是第六屆了,又是中國嵌入系統(tǒng)新朋老友相聚的時刻。大模型催生AI走人千家萬戶、喚醒端側(cè)AI的需求爆發(fā)。以機(jī)器人、無人駕駛和智能制
    發(fā)表于 07-26 10:54

    3568F-麒麟KylinOS國產(chǎn)操作系統(tǒng)演示案例

    :支持輕量級AI框架,功能域完成邊緣智能計(jì)算。 (5)工業(yè)穩(wěn)定:工業(yè)級系統(tǒng)穩(wěn)定性,支持操作系統(tǒng)長時間值守工作。 (6)泛在連接:集成主流工業(yè)通信協(xié)議、物聯(lián)網(wǎng)協(xié)議,實(shí)現(xiàn)云邊端協(xié)同連接。
    發(fā)表于 07-25 15:55

    3568F-翼輝SylixOS國產(chǎn)操作系統(tǒng)演示案例

    、VxWorks操作系統(tǒng)的應(yīng)用程序可方便快捷地移植到SylxOS 系統(tǒng)上運(yùn)行。 SylixOS作為搶占多任務(wù)硬實(shí)時操作系統(tǒng),具有如下功能特
    發(fā)表于 07-25 15:52