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

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

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

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

嵌入式軟件優(yōu)先級的重要性

strongerHuang ? 來源:博客園 ? 作者:博客園 ? 2020-09-04 15:29 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

嵌入式軟件開發(fā)中,我們不可避免的需要接觸優(yōu)先級的概念,掌握優(yōu)先級的概念對于設(shè)計(jì)一個(gè)好的軟件系統(tǒng)尤為重要。

本篇筆記的主要內(nèi)容有以下幾個(gè)方面:

1、中斷優(yōu)先級

2、操作系統(tǒng)中的任務(wù)優(yōu)先級

3、同等優(yōu)先級處理

4、中斷嵌套

今天借助大家熟悉的 STM32F103 平臺(tái)和各位聊聊其中的密事。

首先,我們從一個(gè)裸機(jī)系統(tǒng)的變量自加開始說起。

這里有三個(gè)變量,A、B、C,其中 B 變量除了在 main 函數(shù)中自加外,還會(huì)在中斷處理函數(shù)中進(jìn)行自加。

這里面考慮了B的兩種情況,一是先執(zhí)行 main 中的自加再執(zhí)行中斷的自加,二是先執(zhí)行中斷的自加再進(jìn)行 main 的自加。

不管發(fā)生哪種情況,當(dāng)程序執(zhí)行到 C 位置時(shí),B 的值都是一樣的。

當(dāng)然,以上分析是從 C 語言的角度進(jìn)行分析的,如果以匯編的視角進(jìn)行分析(自加操作在匯編中分為三個(gè)步驟),你會(huì)發(fā)現(xiàn),這里面其實(shí)還有第三種情況:

這里面的 B’ 可以認(rèn)為是寄存器,即變量的 B 的副本。

正因?yàn)楦北镜拇嬖?,在main 函數(shù)的寫入過程中導(dǎo)致丟失了中斷中 B 的自加操作。

對于程序而言,就好像根本沒有進(jìn)入中斷一樣!

這就是全局變量的使用隱患。

但是善于分析的道友可能會(huì)提出這樣一個(gè)疑問,為什么上面只考慮了main 函數(shù)中的B++被打斷的可能,卻沒有考慮中斷(橙色部分)的B++被打斷的可能,是魚鷹忽略了嗎?

不不,其實(shí)這里面就涉及到了今天的主題,優(yōu)先級。

在裸機(jī)系統(tǒng)中,中斷優(yōu)先級高于main函數(shù)的處理,也就是說,一且中斷來臨, 不管main函數(shù)執(zhí)行到哪個(gè)位置,都會(huì)優(yōu)先處理中斷程序,只有中斷程序執(zhí)行完成后,才會(huì)繼續(xù)執(zhí)行main函數(shù),所以中斷的 B++ 不可能被main 函數(shù)打斷!

這里插兩個(gè)問題:

怎么進(jìn)入中斷函數(shù)的?

當(dāng)中斷請求(中斷請求可以認(rèn)為是種電平信號(hào),在寄存器中就表現(xiàn)為某一位的標(biāo)志位)來臨時(shí),硬件負(fù)責(zé)把部分寄存器存儲(chǔ)到棧(一種特殊的數(shù)據(jù)結(jié)構(gòu))中,這里面就包含了PC寄存器(用于指示下一條指令執(zhí)行的位置),之后從向量表中找到中斷處理函數(shù)的入口地址,開始進(jìn)入中斷處理函數(shù)中執(zhí)行。

怎么回到原來的位置?

因?yàn)樵谶M(jìn)入中斷前已經(jīng)保存了PC等其他寄存器的值,所以只要在執(zhí)行完中斷處理函數(shù)后,將之前的保存到棧中的值恢復(fù)回來,那么CPU就可以繼續(xù)從被打斷的指令開始繼續(xù)執(zhí)行。

更多相關(guān)的中斷行為請查看《權(quán)威指南》,魚鷹不再細(xì)說。

回到剛才的優(yōu)先級話題,正因?yàn)橹袛嗟膱?zhí)行優(yōu)先級比main高,所以中斷中的 B++ 不會(huì)被打斷,這也是為什么有些時(shí)候,我們不需要對中斷中的變量進(jìn)行臨界保護(hù)的原因所在。

在 Cortex-M3 內(nèi)核中,中斷分為可屏蔽和不可屏蔽中斷,同時(shí)又有可編程優(yōu)先級和不可編程優(yōu)先級之分。

所謂可屏蔽,就是說這個(gè)中斷是可以屏蔽掉的,即使發(fā)生了中斷,也不會(huì)讓CPU執(zhí)行中斷里面的程序。

比如我們的定時(shí)器中斷,如果我們沒有開啟相應(yīng)的中斷的話,即使定時(shí)器溢出中斷來了,那也不會(huì)進(jìn)入中斷處理函數(shù)處理的。

而不可屏蔽,就是說這個(gè)中斷是不可以屏蔽的,比如復(fù)位中斷(是不是不可思議,代碼執(zhí)行的第一條指令竟然是中斷處理函數(shù)里面的),如果復(fù)位中斷都被屏蔽了,那么系統(tǒng)也就別想運(yùn)行了。

可編程,意味著這個(gè)中斷的優(yōu)先級可以由軟件修改(不可編程,即優(yōu)先級固定死了,不能修改)。

中斷的優(yōu)先級在設(shè)置時(shí)又有搶占式優(yōu)先級和非搶占式優(yōu)先級兩種設(shè)置(根據(jù)單片機(jī)不同,搶占式和非搶占式可設(shè)置的位數(shù)不同,并且可以分配各自的位數(shù),即所謂的中斷分組,如STM32F103 共有四位,通過設(shè)置中斷分組來決定搶占式和非搶占的位數(shù))。

搶占優(yōu)先級,即如果中斷 1 的優(yōu)先級比中斷 2 的搶占優(yōu)先級高的話,一旦中斷1發(fā)出中斷請求,即使已經(jīng)在中斷 2 執(zhí)行了,也會(huì)強(qiáng)制進(jìn)入中斷 1 執(zhí)行,這個(gè)類似于 main 函數(shù)與中斷的關(guān)系,只不過這里兩個(gè)都是中斷而已。

在搶占優(yōu)先級相同情況下,非搶占優(yōu)先級就會(huì)開始起作用了。

如果中斷 1 和中斷 2 的搶占優(yōu)先級設(shè)置成一樣,而非搶占優(yōu)先級不一樣,此時(shí)如果兩個(gè)中斷同時(shí)發(fā)出請求,那么優(yōu)先處理非搶占優(yōu)先級高的中斷。

但是如果不是同時(shí)發(fā)生呢?那么就會(huì)依次處理中斷請求,在其中一個(gè)中斷處理過程中,是不可以被另一個(gè)中斷打斷的,同時(shí)如果本中斷再來一個(gè)請求,也不會(huì)重新進(jìn)入中斷函數(shù)處理。

即中斷本身不可打斷自身的處理,換句話說中斷不會(huì)執(zhí)行到一半時(shí)又因?yàn)樽陨硇碌闹袛嗾埱髞砼R而重新再次進(jìn)入本中斷處理函數(shù)執(zhí)行。

如果搶占優(yōu)先級和非搶占優(yōu)先級都設(shè)置成一樣呢,此時(shí)如果兩個(gè)中斷同時(shí)發(fā)生,又該選擇哪個(gè)先執(zhí)行,隨機(jī)嗎?

這里就涉及到硬件優(yōu)先級了。

在上圖中,每一個(gè)中斷其實(shí)都是有固定的默認(rèn)優(yōu)先級的,這個(gè)優(yōu)先級肯定不同,所以當(dāng)搶占優(yōu)先級和非搶占優(yōu)先級一樣的情況下,在中斷同時(shí)發(fā)生時(shí),先執(zhí)行默認(rèn)優(yōu)先級高的。

看圖:

講到了中斷,就不可不說如何禁止中斷的問題了。

在常規(guī)操作中,我們會(huì)使用禁止全局中斷來禁止中斷的處理,一旦禁止了全局中斷,那么除了不可屏蔽中斷外,所有的中斷都會(huì)被屏蔽掉,即如果在禁止中斷后發(fā)生了中斷,也不會(huì)再執(zhí)行。

但是一旦中斷打開了,那么之前被屏蔽的中斷就會(huì)立刻開始執(zhí)行(有一個(gè)中斷掛起位,代表中斷的發(fā)生,只有CPU執(zhí)行了中斷處理函數(shù),并清零相應(yīng)標(biāo)志位,該掛起位才會(huì)清除)。

如果在關(guān)閉中斷的過程中發(fā)送了兩次中斷,比如外部中斷發(fā)生了兩次,那么在開啟中斷后,也只會(huì)響應(yīng)一次中斷,因?yàn)閽炱鹞痪椭挥心敲匆晃唬ú幌耜?duì)列一樣可以保留多個(gè)標(biāo)志位)。

對于一般功能而言,禁止全局中斷確實(shí)有用,對于保護(hù)全局變量也非常有效,但是對于整個(gè)系統(tǒng)而言會(huì)有一定的影響。

如果禁止中斷的時(shí)間很短,那么確實(shí)無關(guān)緊要,但是一旦需要禁止較長的時(shí)間(毫秒級別),對于那些需要及時(shí)處理的中斷而言,就是一個(gè)不可忽視的延遲。

而在操作系統(tǒng)中,為了保護(hù)那些全局變量,禁止中斷的操作時(shí)有發(fā)生,那么是否有一種方法可以屏蔽部分中斷,而讓高優(yōu)先級的中斷不被屏蔽呢?

有的,在 Cortex-M3 內(nèi)核中,有一個(gè)寄存器專門干這事,即 BASEPRI。

當(dāng)設(shè)置該寄存器時(shí),將屏蔽所有優(yōu)先級不高于某個(gè)具體值的中斷。

比如設(shè)置該寄存器為 3,那么優(yōu)先級0~ 2的中斷不會(huì)被屏蔽。

所以在操作系統(tǒng)中,我們可以修改禁止中斷的代碼,使其不會(huì)屏蔽高優(yōu)先級的中斷,對于高優(yōu)先級中斷來說,可增加實(shí)時(shí)性。

uCOS II 中默認(rèn)是直接全局禁止中斷的(可以修改它),但是 FreeRTOS 是可以禁止部分中斷的,使用的就是上述寄存器,當(dāng)然這個(gè)功能需要單片機(jī)本身支持才行。

以上就是中斷優(yōu)先級的內(nèi)容,如果只會(huì)裸機(jī)的話,那么以上內(nèi)容就差不多了,但是如果是操作系統(tǒng),那么需要再增加一個(gè)任務(wù)優(yōu)先級的概念。

所謂任務(wù),你也可以認(rèn)為是一種中斷,只不過,這種特殊的中斷優(yōu)先級低于所有的硬件觸發(fā)的中斷。

中斷的優(yōu)先級凌駕于所有任務(wù)之上。

也就是說,一旦中斷來臨,不管CPU正在執(zhí)行哪個(gè)任務(wù),在全局中斷開啟的情況下,都會(huì)立刻執(zhí)行中斷里的程序。

在中斷中,可以進(jìn)行中斷嵌套,所謂的中斷嵌套即當(dāng)前中斷被另一個(gè)更高優(yōu)先級的中斷所打斷(即搶占),被打斷的中斷必須在高優(yōu)先級任務(wù)執(zhí)行完成后才會(huì)繼續(xù)執(zhí)行。而在嵌入式實(shí)時(shí)操作系統(tǒng)中,為了更好的處理實(shí)時(shí)任務(wù),一般而言也會(huì)設(shè)置成可搶占的任務(wù)(亦稱可剝奪)。

中斷的優(yōu)先級處理是由內(nèi)核進(jìn)行管理的,這里的內(nèi)核是指單片機(jī)內(nèi)核,比如STM32F103的內(nèi)核是Cortex-M3(更準(zhǔn)確的說是由 NVIC 管理)。

一旦設(shè)置好相應(yīng)的寄存器之后,只要中斷來了,那么就會(huì)自動(dòng)處理中斷程序,這些工作由硬件完成,它會(huì)在多個(gè)中斷同時(shí)來臨時(shí)選擇最高的優(yōu)先處理;也會(huì)在中斷執(zhí)行時(shí),如果有一個(gè)更高優(yōu)先級的中斷來臨時(shí),打斷當(dāng)前中斷的執(zhí)行而先執(zhí)行更高優(yōu)先級的中斷。

但是操作系統(tǒng)是純軟件行為,那么操作系統(tǒng)的任務(wù)優(yōu)先級又是誰管理的?又是如何管理的呢?

答案就在Systick中斷。

既然要管理所有任務(wù)的優(yōu)先級,即在合適時(shí)選擇運(yùn)行優(yōu)先級最高的任務(wù),那么操作系統(tǒng)本身必然需要有能剝奪所有任務(wù)執(zhí)行的能力,而中斷是凌駕于任務(wù)之上的,可以在任何時(shí)候剝奪任務(wù)的執(zhí)行,從而獲得CPU的使用權(quán),所以選擇中斷作為操作系統(tǒng)的核心是合適的。

但是中斷那么多,選擇什么中斷比較合適呢?沒有比 Systick 中斷更合適的了,因?yàn)樗褪菫榇硕摹?/p>

Systick說白了就是一個(gè)定時(shí)器,但是和普通定時(shí)器不同的是,功能比較單一,就是一個(gè)計(jì)數(shù)器而已,所以使用它管理任務(wù)是合適的,不會(huì)占用其他定時(shí)器。

那么Systick又是如何管理任務(wù)的呢?

一般而言,Systick 會(huì)設(shè)置成幾毫秒中斷一次,在每次中斷時(shí),Systick處理程序(即操作系統(tǒng)內(nèi)核)都會(huì)從所有的任務(wù)中選擇最高優(yōu)先級的任務(wù)執(zhí)行,也就是說,系統(tǒng)總是運(yùn)行最高的任務(wù)。

而這個(gè)特性也就導(dǎo)致你的高優(yōu)先級任務(wù)不可以無限執(zhí)行而不主動(dòng)釋放CPU,因?yàn)橐坏└邇?yōu)先級任務(wù)無限執(zhí)行了,那么低優(yōu)先級任務(wù)將永遠(yuǎn)得不到執(zhí)行機(jī)會(huì),這就給人一種死機(jī)的假象。

可能有道友會(huì)疑惑,為什么空閑任務(wù)不需要調(diào)用系統(tǒng)延時(shí)函數(shù)去主動(dòng)釋放CPU的使用權(quán)呢?

那是因?yàn)榭臻e任務(wù)本身優(yōu)先級就是所有任務(wù)中最低的,如果它主動(dòng)釋放 CPU 了,而其他任務(wù)都處于掛起狀態(tài),那么操作系統(tǒng)又該讓誰去執(zhí)行呢?

所以,空閑任務(wù)需要永遠(yuǎn)處于運(yùn)行狀態(tài)。

從這個(gè)角度來說,操作系統(tǒng)主要的功能就是定時(shí)從所有任務(wù)中尋找最高優(yōu)先級的任務(wù),然后讓該任務(wù)得到運(yùn)行機(jī)會(huì)(使用PendSV 中斷切換到任務(wù)中,模擬中斷切換過程),功能類似于中斷管理器。

而正因?yàn)椴僮飨到y(tǒng)只會(huì)尋找最高優(yōu)先級的任務(wù)來執(zhí)行(對于實(shí)時(shí)操作系統(tǒng)是這樣,有些操作系統(tǒng)可能先來先處理的策略),所以任務(wù)本身主動(dòng)釋放 CPU 就顯得尤為重要了。

最常用的主動(dòng)釋放 CPU 的函數(shù)就是系統(tǒng)延時(shí)函數(shù)了,調(diào)用這個(gè)函數(shù)后,任務(wù)將延時(shí)一段時(shí)候才回來繼續(xù)執(zhí)行,而在延時(shí)過程中,操作系統(tǒng)就可以調(diào)用其他任務(wù)執(zhí)行了,正因?yàn)槿绱?,操作系統(tǒng)才顯得高效。

雖然操作系統(tǒng)需要中斷來剝奪所有任務(wù)的執(zhí)行,從而擁有 CPU 的控制權(quán),但是一般而言,它的優(yōu)先級卻是所有中斷中最低的,因?yàn)樗膬?yōu)先級只需要高于任務(wù)即可,如果設(shè)置的更高,那么就會(huì)影響到真正需要高優(yōu)先處理的中斷,因?yàn)镾ystick中斷的處理還是比較頻繁和繁重的,如果設(shè)置的太高,那么在Systick處理時(shí),更低優(yōu)先級的中斷將無法處理,這可不是我們想看到的結(jié)果。

而如果設(shè)置成中斷優(yōu)先級最低的話,既可以剝奪任務(wù)的執(zhí)行,又可以在高優(yōu)先級中斷來臨時(shí)及時(shí)處理中斷,讓系統(tǒng)的實(shí)時(shí)得到提高。

與 Systick 配套的中斷,還有一個(gè) PendSV 中斷,這個(gè)優(yōu)先級一般和 Systick 設(shè)置成一樣,一般而言該中斷的觸發(fā)是由操作系統(tǒng)內(nèi)核主動(dòng)觸發(fā)的(在切換任務(wù)時(shí)軟件觸發(fā)該中斷),而不像 Systick 一樣,定時(shí)被動(dòng)觸發(fā),關(guān)于兩個(gè)中斷更具體描述可參考《Cortex-M3 權(quán)威指南》。

既然中斷可以設(shè)置成優(yōu)先級一樣的,那么任務(wù)應(yīng)該也可以才對,確實(shí)一般的操作系統(tǒng)都可以設(shè)置相同優(yōu)先級的任務(wù)(uCOS II 不可以, uCOS III 和 FreeRTOS 、RT-Thread可以),那么操作系統(tǒng)又是如何處理同等優(yōu)先級的任務(wù)?

一般而言,在任務(wù)初始化時(shí),會(huì)設(shè)置任務(wù)的時(shí)間片,這個(gè)時(shí)間片就是在任務(wù)優(yōu)先級相同的情況下才會(huì)發(fā)生作用。

比如,任務(wù) 1 設(shè)置 5 個(gè)時(shí)間片(即Systick中斷時(shí)間),任務(wù) 2 設(shè)置 10 個(gè)時(shí)間片,如果兩個(gè)任務(wù)的優(yōu)先級一樣,那么在 15 個(gè)時(shí)間片內(nèi),任務(wù) 1 將執(zhí)行 5 個(gè)時(shí)間片,之后切換到任務(wù) 2 執(zhí)行10個(gè)時(shí)間片,來回往復(fù)。

那么比任務(wù)1 和任務(wù) 2 優(yōu)先級更高的任務(wù)該什么時(shí)候執(zhí)行呢?答案是隨時(shí),即只要高優(yōu)先級任務(wù)有需要,那么不管任務(wù) 1 和 任務(wù) 2 是否主動(dòng)釋放 CPU,都會(huì)被操作系統(tǒng)強(qiáng)制切換到高優(yōu)先級任務(wù)中執(zhí)行(由 Systick完成,所以可能會(huì)有一點(diǎn)延時(shí))。

那么優(yōu)先級比它們低的任務(wù)呢?這個(gè)就靠它們的自覺了,如果它們自覺的主動(dòng)釋放CPU(比如調(diào)用系統(tǒng)延時(shí)函數(shù)),那么低優(yōu)先級任務(wù)就有執(zhí)行機(jī)會(huì),否則,低優(yōu)先級任務(wù)將不會(huì)執(zhí)行!

該用一張圖來說明整個(gè)系統(tǒng)的優(yōu)先級關(guān)系了:

最后魚鷹再聊聊該如何設(shè)置任務(wù)優(yōu)先級。

很多人設(shè)計(jì)任務(wù)優(yōu)先級時(shí)都會(huì)從 0、1、2、3 這樣的順序來設(shè)置,實(shí)際上,這種設(shè)置是不合理的,因?yàn)橐坏┖竺嫘枨笞兓耍獜闹屑尤胍粋€(gè)中間的優(yōu)先級,那么很可能在加入后程序出現(xiàn)問題了。

其實(shí)我們可以從 Cortex-M3 的中斷優(yōu)先級得到啟發(fā),即空開部分優(yōu)先級不使用,留待后面擴(kuò)展用,比如設(shè)計(jì)優(yōu)先級時(shí)可以設(shè)置成 3、5、7、9、11,留出最高的0~2用于可能的高優(yōu)先級任務(wù),中間空出一個(gè)或兩個(gè)優(yōu)先級用于擴(kuò)展,這樣一旦后面需要增加其他優(yōu)先級的任務(wù),會(huì)顯得異常簡單(可能會(huì)有額外的一點(diǎn)內(nèi)存損耗,但卻是值得的)。

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

    關(guān)注

    5186

    文章

    20149

    瀏覽量

    328856
  • 嵌入式系統(tǒng)
    +關(guān)注

    關(guān)注

    41

    文章

    3716

    瀏覽量

    133106

原文標(biāo)題:嵌入式系統(tǒng)優(yōu)先級詳解

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

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

掃碼添加小助手

加入工程師交流群

    評論

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

    搶占優(yōu)先級和子優(yōu)先級

    關(guān)于搶占優(yōu)先級和子優(yōu)先級: 1)具有高搶占優(yōu)先級的中斷可以在具有低搶占優(yōu)先級的中斷服務(wù)程序執(zhí)
    發(fā)表于 12-03 07:11

    嵌入式實(shí)時(shí)操作系統(tǒng)的特點(diǎn)

    的時(shí)間限制內(nèi)完成,而軟實(shí)時(shí)任務(wù)對時(shí)間限制更靈活。 任務(wù)調(diào)度和優(yōu)先級:實(shí)時(shí)嵌入式操作系統(tǒng)通過任務(wù)調(diào)度器來管理和分配任務(wù),通常采用優(yōu)先級調(diào)度算法,確保高優(yōu)先級的實(shí)時(shí)任務(wù)得到及時(shí)處理。 中斷
    發(fā)表于 11-13 06:30

    電能質(zhì)量在線監(jiān)測裝置的暫態(tài)數(shù)據(jù)補(bǔ)傳的優(yōu)先級如何在實(shí)際應(yīng)用中進(jìn)行動(dòng)態(tài)調(diào)整?

    電能質(zhì)量在線監(jiān)測裝置的暫態(tài)數(shù)據(jù)補(bǔ)傳優(yōu)先級在實(shí)際應(yīng)用中通過 事件驅(qū)動(dòng)、主站指令、資源狀態(tài)感知和動(dòng)態(tài)策略調(diào)整 等多層機(jī)制實(shí)現(xiàn)靈活調(diào)控,確保關(guān)鍵數(shù)據(jù)的實(shí)時(shí)與可靠。以下是具體實(shí)現(xiàn)方式和典型場景的動(dòng)態(tài)調(diào)整
    的頭像 發(fā)表于 11-06 14:10 ?96次閱讀

    電能質(zhì)量在線監(jiān)測裝置的暫態(tài)數(shù)據(jù)補(bǔ)傳的優(yōu)先級是怎樣的?

    電能質(zhì)量在線監(jiān)測裝置的暫態(tài)數(shù)據(jù)補(bǔ)傳優(yōu)先級設(shè)計(jì)遵循 事件驅(qū)動(dòng)、主站指令優(yōu)先、資源動(dòng)態(tài)分配 的原則,結(jié)合行業(yè)標(biāo)準(zhǔn)和設(shè)備機(jī)制,形成以下多層級優(yōu)先級體系: 一、最高優(yōu)先級:緊急事件驅(qū)動(dòng)補(bǔ)傳 1
    的頭像 發(fā)表于 11-06 14:02 ?94次閱讀

    嵌入式軟件測試與專業(yè)測試工具的必要深度解析

    嵌入式系統(tǒng)作為控制、監(jiān)視或輔助裝置運(yùn)行的專用計(jì)算機(jī)系統(tǒng),其軟件測試面臨著獨(dú)特的挑戰(zhàn)和嚴(yán)格的要求。專業(yè)測試工具在嵌入式軟件開發(fā)過程中發(fā)揮著不可替代的作用,是確保系統(tǒng)可靠
    發(fā)表于 09-28 17:42

    優(yōu)先級線程無法調(diào)度怎么解決?

    1,設(shè)置了3,5,6,8幾個(gè)優(yōu)先級,設(shè)備在現(xiàn)場正常運(yùn)行了一年多后,顯示、前端、后端這3個(gè)低優(yōu)先級線程異常了,表現(xiàn)為屏幕不動(dòng),前端采集數(shù)據(jù)沒有變化等,其他高優(yōu)先級的線程如通訊,按鍵都能正常運(yùn)行,通訊有喂狗操作,停止通訊,會(huì)看門狗復(fù)
    發(fā)表于 09-25 07:33

    什么是RTOS中的優(yōu)先級反轉(zhuǎn)

    當(dāng)一個(gè)高優(yōu)先級任務(wù)正在等待一個(gè)資源,但一個(gè)低優(yōu)先級任務(wù)正在持有它,一個(gè)中等優(yōu)先級任務(wù)繼續(xù)在中間運(yùn)行時(shí),就會(huì)發(fā)生優(yōu)先級反轉(zhuǎn)——阻止低優(yōu)先級任務(wù)
    的頭像 發(fā)表于 09-09 14:50 ?774次閱讀

    揭秘!基于RT-Thread探究“優(yōu)先級反轉(zhuǎn)”下的任務(wù)調(diào)度究竟是什么樣的?| 技術(shù)集結(jié)

    本文將基于RT-Thread,結(jié)合RT-Trace調(diào)試器細(xì)化到實(shí)際任務(wù)調(diào)度的粒度,來調(diào)試并逐步講解“優(yōu)先級反轉(zhuǎn)”的調(diào)度和運(yùn)行邏輯。如果對RT-Trace感興趣的可以看這篇文章:國產(chǎn)嵌入式調(diào)試器之光
    的頭像 發(fā)表于 08-17 10:07 ?2808次閱讀
    揭秘!基于RT-Thread探究“<b class='flag-5'>優(yōu)先級</b>反轉(zhuǎn)”下的任務(wù)調(diào)度究竟是什么樣的?| 技術(shù)集結(jié)

    TLe9893怎么調(diào)整外設(shè)的中斷優(yōu)先級?

    你好林工,我該怎么調(diào)整外設(shè)的中斷優(yōu)先級?是否可以通過工具調(diào)整?默認(rèn)設(shè)置下,是不是Brdv的在中斷優(yōu)先級高于T20和can?
    發(fā)表于 08-01 06:20

    【干貨速遞】嵌入式數(shù)據(jù)可靠,軟件設(shè)計(jì)的這些細(xì)節(jié)不能忽視!

    問題。軟件設(shè)計(jì)軟件設(shè)計(jì)在嵌入式數(shù)據(jù)存儲(chǔ)可靠中扮演著至關(guān)重要的角色。它不僅包括系統(tǒng)驅(qū)動(dòng)的開發(fā),還涉及應(yīng)用層面的優(yōu)化。一個(gè)精心設(shè)計(jì)的
    的頭像 發(fā)表于 07-31 11:34 ?366次閱讀
    【干貨速遞】<b class='flag-5'>嵌入式</b>數(shù)據(jù)可靠<b class='flag-5'>性</b>,<b class='flag-5'>軟件</b>設(shè)計(jì)的這些細(xì)節(jié)不能忽視!

    一文讀懂:嵌入式Linux實(shí)時(shí)進(jìn)階

    與Xenomai雙核方案成為兩大主流技術(shù)路線。 本文將深入剖析它們的原理與性能差異,助您在學(xué)習(xí)道路上少走彎路,事半功倍! 1嵌入式Linux實(shí)時(shí)是指什么 Linux的實(shí)時(shí)指的是Linux系統(tǒng)
    發(fā)表于 07-10 15:26

    CyU3PDebugPrint的最高優(yōu)先級和最低優(yōu)先級是什么?

    [i]CyU3PDebugPrint的最高優(yōu)先級和最低優(yōu)先級是什么?
    發(fā)表于 05-13 08:22

    一天一個(gè)嵌入式面試知識(shí)(1:中斷處理機(jī)制詳解)

    一、中斷處理:嵌入式系統(tǒng)的\"心跳\"機(jī)制 在嵌入式系統(tǒng)中,中斷是硬件或軟件觸發(fā)的事件,會(huì)立即打斷當(dāng)前程序執(zhí)行,轉(zhuǎn)而執(zhí)行特定的中斷服務(wù)程序(ISR)。其核心作用是實(shí)現(xiàn)實(shí)時(shí)響應(yīng)
    發(fā)表于 03-21 10:18

    嵌入式系統(tǒng)測試必備:9大理由解析報(bào)告與可追溯重要性(附工具推薦TESSY)

    嵌入式系統(tǒng)的軟件測試項(xiàng)目中,報(bào)告和可追溯至關(guān)重要,原因有多個(gè)。它們是確保嵌入式系統(tǒng)可靠、合規(guī)且高質(zhì)量的基礎(chǔ)。報(bào)告和可追溯
    的頭像 發(fā)表于 03-13 10:47 ?734次閱讀
    <b class='flag-5'>嵌入式</b>系統(tǒng)測試必備:9大理由解析報(bào)告與可追溯<b class='flag-5'>性</b>的<b class='flag-5'>重要性</b>(附工具推薦TESSY)

    配電柜—斷電危機(jī)?配電柜故障排查優(yōu)先級指南

    在排查配電柜故障過程中,合理安排排查優(yōu)先級至關(guān)重要。下面聊一下如何科學(xué)合理安排配電柜故障排查優(yōu)先級順序。
    的頭像 發(fā)表于 03-06 18:55 ?817次閱讀
    配電柜—斷電危機(jī)?配電柜故障排查<b class='flag-5'>優(yōu)先級</b>指南