日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 嵌入式 > 技術(shù)讓夢想更偉大
[導(dǎo)讀]關(guān)注、星標(biāo)公眾號,直達(dá)精彩內(nèi)容ID:技術(shù)讓夢想更偉大作者:李肖遙FreeRTOS提供了兩個系統(tǒng)延時函數(shù):相對延時函數(shù)vTaskDelay()和絕對延時函數(shù)vTaskDelayUntil()。相對延時是指每次延時都是從任務(wù)執(zhí)行函數(shù)vTaskDelay()開始,延時指定的時間結(jié)束;絕...


關(guān)注、星標(biāo)公眾號,直達(dá)精彩內(nèi)容

ID:技術(shù)讓夢想更偉大

作者:李肖遙


FreeRTOS提供了兩個系統(tǒng)延時函數(shù):相對延時函數(shù)vTaskDelay()和絕對延時函數(shù)vTaskDelayUntil()。

相對延時是指每次延時都是從任務(wù)執(zhí)行函數(shù)vTaskDelay()開始,延時指定的時間結(jié)束;

絕對延時是指每隔指定的時間,執(zhí)行一次調(diào)用vTaskDelayUntil()函數(shù)的任務(wù),換句話說:任務(wù)以固定的頻率執(zhí)行。

在《FreeRTOS系列第11篇---FreeRTOS任務(wù)控制》一文中,已經(jīng)介紹了這兩個API函數(shù)的原型和用法,本文將分析這兩個函數(shù)的實現(xiàn)原理。

1. 相對延時函數(shù)vTaskDelay()

考慮下面的任務(wù),任務(wù)A在執(zhí)行任務(wù)主體代碼后,調(diào)用相對延時函數(shù)vTaskDelay()進(jìn)入阻塞狀態(tài)。

系統(tǒng)中除了任務(wù)A外,還有其它任務(wù),但是任務(wù)A的優(yōu)先級最高。

void?vTaskA(?void?*?pvParameters?)??
?{??
?????/*?阻塞500ms.?注:宏pdMS_TO_TICKS用于將毫秒轉(zhuǎn)成節(jié)拍數(shù),FreeRTOS?V8.1.0及
????????以上版本才有這個宏,如果使用低版本,可以使用?500?/?portTICK_RATE_MS?*/??
?????const?portTickType?xDelay?=?pdMS_TO_TICKS(500);??
???
?????for(?;;?)??
?????{??
?????????//??...
?????????//??這里為任務(wù)主體代碼
?????????//??...
????????
?????????/*?調(diào)用系統(tǒng)延時函數(shù),阻塞500ms?*/
?????????vTaskDelay(?xDelay?);??
?????}??
}??
對于這樣一個任務(wù),執(zhí)行過程如圖1-1所示。

當(dāng)任務(wù)A獲取CPU使用權(quán)后,先執(zhí)行任務(wù)A的主體代碼,之后調(diào)用系統(tǒng)延時函數(shù)vTaskDelay()進(jìn)入阻塞狀態(tài)。

任務(wù)A進(jìn)入阻塞后,其它任務(wù)得以執(zhí)行。

FreeRTOS內(nèi)核會周期性的檢查任務(wù)A的阻塞是否達(dá)到,如果阻塞時間達(dá)到,則將任務(wù)A設(shè)置為就緒狀態(tài)。

由于任務(wù)A的優(yōu)先級最高,會搶占CPU,再次執(zhí)行任務(wù)主體代碼,不斷循環(huán)。

從圖1-1可以看出,任務(wù)A每次延時都是從調(diào)用延時函數(shù)vTaskDelay()開始算起的,延時是相對于這一時刻開始的,所以叫做相對延時函數(shù)。

從圖1-1還可以看出,如果執(zhí)行任務(wù)A的過程中發(fā)生中斷,那么任務(wù)A執(zhí)行的周期就會變長,所以使用相對延時函數(shù)vTaskDelay(),不能周期性的執(zhí)行任務(wù)A。

圖1-1:相對延時函數(shù)執(zhí)行示意圖

**我們來看一下源碼。**
void?vTaskDelay(?const?TickType_t?xTicksToDelay?)
{
BaseType_t?xAlreadyYielded?=?pdFALSE;
?
?
????/*?如果延時時間為0,則不會將當(dāng)前任務(wù)加入延時列表?*/
????if(?xTicksToDelay?>?(?TickType_t?)?0U?)
????{
????????vTaskSuspendAll();
????????{
????????????/*?將當(dāng)前任務(wù)從就緒列表中移除,并根據(jù)當(dāng)前系統(tǒng)節(jié)拍計數(shù)器值計算喚醒時間,然后將任務(wù)加入延時列表?*/
????????????prvAddCurrentTaskToDelayedList(?xTicksToDelay,?pdFALSE?);
????????}
????????xAlreadyYielded?=?xTaskResumeAll();
????}
?
?
????/*?強制執(zhí)行一次上下文切換*/
????if(?xAlreadyYielded?==?pdFALSE?)
????{
????????portYIELD_WITHIN_API();
????}
}
如果延時大于0,則會將當(dāng)前任務(wù)從就緒列表刪除,然后加入到延時列表。

是調(diào)用函數(shù)prvAddCurrentTaskToDelayedList()完成這一過程的。

我們在前面一系列博文中多次提到,tasks.c中定義了很多局部靜態(tài)變量,其中有一個變量xTickCount定義如下所示:

static?volatile?TickType_t?xTickCount?=?(?TickType_t?)?0U;
這個變量用來計數(shù),記錄系統(tǒng)節(jié)拍中斷的次數(shù),它在啟動調(diào)度器時被清零,在每次系統(tǒng)節(jié)拍時鐘發(fā)生中斷后加1。

相對延時函數(shù)會使用到這個變量,xTickCount表示了當(dāng)前的系統(tǒng)節(jié)拍中斷次數(shù),這個值加上參數(shù)規(guī)定的延時時間(以系統(tǒng)節(jié)拍數(shù)表示)xTicksToDelay,就是下次喚醒任務(wù)的時間,xTickCount xTicksToDelay會被記錄到任務(wù)TCB中,隨著任務(wù)一起被掛接到延時列表。

我們知道變量xTickCountTickType_t類型的,它也會溢出。

在32位架構(gòu)中,當(dāng)xTicksToDelay達(dá)到4294967295后再增加,就會溢出變成0。

為了解決xTickCount溢出問題,F(xiàn)reeRTOS使用了兩個延時列表:xDelayedTaskList1xDelayedTaskList2,并使用兩個列表指針類型變量pxDelayedTaskListpxOverflowDelayedTaskList分別指向上面的延時列表1和延時列表2(在創(chuàng)建任務(wù)時將延時列表指針指向延時列表)。

「順便說一下」,上面的兩個延時列表指針變量和兩個延時列表變量都是在tasks.c中定義的靜態(tài)局部變量。

如果內(nèi)核判斷出xTickCount xTicksToDelay溢出,就將當(dāng)前任務(wù)掛接到列表指針pxOverflowDelayedTaskList指向的列表中,否則就掛接到列表指針pxDelayedTaskList指向的列表中。

每次系統(tǒng)節(jié)拍時鐘中斷,中斷服務(wù)函數(shù)都會檢查這兩個延時列表,查看延時的任務(wù)是否到期,如果時間到期,則將任務(wù)從延時列表中刪除,重新加入就緒列表。如果新加入就緒列表的任務(wù)優(yōu)先級大于當(dāng)前任務(wù),則會觸發(fā)一次上下文切換。

2. 絕對延時函數(shù)vTaskDelayUntil()

考慮下面的任務(wù),任務(wù)B首先調(diào)用絕對延時函數(shù)vTaskDelayUntil ()進(jìn)入阻塞狀態(tài),阻塞時間到達(dá)后,執(zhí)行任務(wù)主體代碼。

系統(tǒng)中除了任務(wù)B外,還有其它任務(wù),但是任務(wù)B的優(yōu)先級最高。

void?vTaskB(?void?*?pvParameters?)??
{??
????static?portTickType?xLastWakeTime;??
????const?portTickType?xFrequency?=?pdMS_TO_TICKS(500);??
???
????//?使用當(dāng)前時間初始化變量xLastWakeTime?,注意這和vTaskDelay()函數(shù)不同?
????xLastWakeTime?=?xTaskGetTickCount();??
???
????for(?;;?)??
????{??
????????/*?調(diào)用系統(tǒng)延時函數(shù),周期性阻塞500ms?*/????????
????????vTaskDelayUntil(?
本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護(hù)是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機(jī)驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機(jī)驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉