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

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

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

一種實現(xiàn)亞毫秒定時分辨率的RTOS新方法

麥克泰技術(shù) ? 來源:麥克泰技術(shù) ? 2024-12-17 13:58 ? 次閱讀

你在使用實時操作系統(tǒng)(RTOS)時是否發(fā)現(xiàn)無法將任務(wù)調(diào)度或延遲精度降到毫秒以下?你可能不得不在RTOS之外編寫大量應(yīng)用代碼。雖然這種方式可行,但這會讓你懷疑應(yīng)用程序是否滿足其截止期限,是否可維護(hù)和可擴(kuò)展。RTOS不應(yīng)該能夠管理整個應(yīng)用程序的時間嗎,不管這個時間是一秒還是一微秒?

對于嵌入式系統(tǒng)領(lǐng)域的開發(fā)和管理人員來說,平衡時間精度和能源效率可能是一項持續(xù)的斗爭。隨著應(yīng)用的發(fā)展,無論是在汽車、物聯(lián)網(wǎng)、醫(yī)療設(shè)備還是工業(yè)自動化領(lǐng)域,對精確定時控制的需求都在增長。雖然傳統(tǒng)的RTOS解決方案在管理實時任務(wù)方面很有效,但在這兩個關(guān)鍵領(lǐng)域往往存在不足。

1. 傳統(tǒng)RTOS的不足

首先,傳統(tǒng)RTOS有精度限制?;诘未鸬南到y(tǒng)不能提供超出滴答(Tick)間隔(如1毫秒)的時間粒度。這種限制影響了執(zhí)行超精細(xì)定時操作的能力,例如精密傳感器讀數(shù)或先進(jìn)機(jī)器人的高分辨率控制。事實上,如果不仔細(xì),你甚至可能任務(wù)時序中注入抖動,從而破壞系統(tǒng)的實時性能!

其次,基于滴答的RTOS能效低!即使沒有任務(wù)調(diào)度,周期系統(tǒng)滴答中斷也會使CPU保持活動狀態(tài),從而導(dǎo)致能源浪費,這在電池供電和低功耗設(shè)備中尤為嚴(yán)重。雖然一些RTOS試圖通過引入tickless省電模式來克服這個缺陷,但這些解決方案更多的是權(quán)宜之計,而不是完整的功能。

這些限制迫使開發(fā)人員采用效率低下的解決方案,例如輪詢硬件計時器或使用特定于目標(biāo)的技術(shù)來實現(xiàn)更高的分辨率和更低的功耗,這種方法使開發(fā)過程復(fù)雜化,降低了軟件的可移植性和可維護(hù)性。

本文中,我們將探索一種新的機(jī)制來精確地調(diào)度低于一毫秒的任務(wù),這種機(jī)制可以提高應(yīng)用程序的實時性能,同時提高能效,其好處來自于利用周期精度定時的新RTOS實現(xiàn)。

2. 從基于滴答的調(diào)度到基于周期的調(diào)度

傳統(tǒng)的RTOS使用周期性的系統(tǒng)滴答來跟蹤時間和調(diào)度任務(wù)。例如,大多數(shù)RTOS,如FreeRTOS、Zephyr和embOS-Base,默認(rèn)使用1毫秒的滴答間隔。這個間隔依賴于每毫秒產(chǎn)生一次中斷的計時器。所有時間相關(guān)的操作(任務(wù)延遲、超時和軟件計時器)都與滴答對齊。如果我們使用SEGGER SystemView這樣的工具來記錄和分析應(yīng)用程序的運行時行為,將看到類似圖1所示的內(nèi)容。

98cfd856-b8ff-11ef-8732-92fbcf53809c.png

圖1:使用周期滴答來跟蹤系統(tǒng)時間的傳統(tǒng)RTOS

如圖所示,系統(tǒng)每隔一毫秒就會中斷一次應(yīng)用,如果系統(tǒng)處于睡眠狀態(tài)并且沒有其他的工作要做,它也會被喚醒以增加計數(shù)并返回睡眠狀態(tài)!

基于滴答的設(shè)計限制了計時精度,并引入了延遲,因為不能以比滴答間隔更細(xì)的粒度調(diào)度任務(wù),這是我在許多應(yīng)用中遇到的一個問題,它迫使你思考RTOS之外的實現(xiàn)。

基于周期的調(diào)度通過用單次硬件定時器(single-shot hardware timer)代替周期滴答中斷消除了這種約束。計時器只在需要時產(chǎn)生中斷,而非每毫秒喚醒CPU,從而允許將事件調(diào)度精確到微秒或CPU周期。這種方法提高了精度,減少了CPU的活動,節(jié)約了能源。

讓我們來看一個例子。考慮一個需要持續(xù)4.7毫秒的任務(wù)延遲。在擁有1毫秒滴答間隔的RTOS中,延遲要么提前結(jié)束(4毫秒),要么延長(5毫秒),具體取決于滴答計時。使用基于周期的調(diào)度可以實現(xiàn)精確的4.7毫秒延遲,因為它不再依賴于滴答間隔。

3. embOS-Ultra:高精度和高效率的技術(shù)解決方案

如果調(diào)查當(dāng)今的RTOS市場,你會發(fā)現(xiàn)SEGGER的embOS-Ultra是唯一支持基于周期調(diào)度的RTOS。因此,我們將關(guān)注embOS-Ultra如何通過引入周期分辨率定時來解決精度和效率方面的挑戰(zhàn),以及這種創(chuàng)新方法如何改善應(yīng)用。

讓我們來分析一下embOS-Ultra是如何在不增加不必要復(fù)雜性的情況下解決精度和效率問題。

通過單次計時器提高能效

通過移除周期滴答,embOS-Ultra顯著降低了CPU負(fù)載。即使沒有待處理的工作,傳統(tǒng)的RTOS也會在每個滴答喚醒CPU,這種行為增加了功耗,因為CPU必須保存其當(dāng)前狀態(tài),處理中斷,并恢復(fù)其狀態(tài),這些不必要的CPU周期消耗了能量。

embOS-Ultra的單次計時器僅在特定事件發(fā)生時喚醒CPU,使系統(tǒng)長時間處于低功耗狀態(tài)。這一特性對于低功耗和電池供電的應(yīng)用尤其有利,例如可穿戴設(shè)備或遠(yuǎn)程物聯(lián)網(wǎng)傳感器,在這些應(yīng)用中,節(jié)省的每一點能量都將延長運行時間。然而,即使是連接到恒定電源的設(shè)備也可以通過降低其整體能量配置和減少對電網(wǎng)的需求而受益。

在許多微控制器架構(gòu)中,計時器可以配置為各種模式。EmbOS-Ultra利用定時器計數(shù)到零或到指定值的模式,在需要時觸發(fā)中斷。這種靈活性使開發(fā)人員能夠精確地控制時間事件,而不依賴于周期滴答。正如想象的那樣,允許計時器自由計數(shù)用于調(diào)度,比計數(shù)為零后重置更有好處。

維護(hù)系統(tǒng)的長期穩(wěn)定性

你可能會認(rèn)為,雖然使用單個計時器來提供高分辨率、亞毫秒級的調(diào)度聽起來很棒,但丟失系統(tǒng)滴答將破壞應(yīng)用程序。好消息是它不會,embOS-Ultra使用兩個硬件計時器。一個計時器用于長期連續(xù)運行而不產(chǎn)生中斷。第二個計時器,即我們在前一節(jié)中討論的單次計時器,用于任務(wù)調(diào)度。

這意味著沒有復(fù)雜的算法在后臺運行,試圖確定自系統(tǒng)啟動以來已經(jīng)過了多少毫秒。誠實地說:我們大多數(shù)人都利用系統(tǒng)滴答來提供時間戳、計算過濾器和執(zhí)行其他日?;顒?。如果從RTOS中刪除它,我們的開發(fā)將變得更加困難。

添加第二個計時器似乎會增加系統(tǒng)的復(fù)雜性和能效,但事實并非如此。如今,大多數(shù)32位微控制器擁有多個計時器,而且與CPU相比,計數(shù)器使用的電流很少。使用第二計時器的權(quán)衡仍然確保我們最大限度地減少能耗,同時保持系統(tǒng)實時性能的長期穩(wěn)定性。

4. 基于周期調(diào)度的應(yīng)用

了解了周期調(diào)度如何工作后,我們來研究一個示例。SEGGER的網(wǎng)站上提供了一個live comparison示例(https://www.segger.com/products/rtos/embos/editions/embos-ultra/#live-comparison),模擬滴答調(diào)度和周期調(diào)度行為。我建議嘗試一下,獲得一些實際操作經(jīng)驗。

Live comparison示例允許你通過print語句查看每秒產(chǎn)生了多少次滴答。測試應(yīng)用包含兩個任務(wù):一個201毫秒的任務(wù)和一個50毫秒的任務(wù)?;诘未鸬恼{(diào)度器,每秒1000個節(jié)拍。如果使用基于周期的調(diào)度來模擬相同的應(yīng)用程序,則每秒只能獲得24 - 25個節(jié)拍。

遺憾的是,對于模擬程序,無法使用SystemView來記錄和分析應(yīng)用程序行為,因此,我使用live comparison示例運行在開發(fā)板上來分析周期調(diào)度。結(jié)果如圖2所示:

98e3c3de-b8ff-11ef-8732-92fbcf53809c.png

圖2:圖1所示的相同應(yīng)用程序的基于周期調(diào)度實現(xiàn)

如果查看圖2中分析窗口底部的計時差異,你將看到系統(tǒng)的滴答間隔不是固定的。只有在必要時才有一個滴答,在圖2的底部可以看到,滴答之間有49.9毫秒的間隔,然后是16.9毫秒的延遲,以此類推。這是基于周期的計時!基于周期的調(diào)度應(yīng)用程序每秒只有24 - 25個滴答,具體取決于任務(wù)的截止時限。

5. 使用基于周期的調(diào)度,同時保持向后兼容性

遷移到新的RTOS帶來的風(fēng)險和復(fù)雜性,可能是開發(fā)人員和管理人員非常關(guān)心的問題。embOS-Ultra通過在提供擴(kuò)展功能的同時保持與現(xiàn)有API兼容來解決這個問題。

首先,對使用embOS-Base或其他滴答RTOS API的應(yīng)用程序,可以在embOS-Ultra中繼續(xù)發(fā)揮預(yù)期的作用。embOS-Ultra中保留了基于毫秒的計時功能,確保已有代碼無需修改。如果使用的是embOS-Base,則API直接兼容。如果使用其它RTOS,你可能會有一天左右的時間將RTOS調(diào)用更新為embOS-Ultra。

其次,對于需要更高精度的開發(fā)人員,embOS-Ultra引入了擴(kuò)展的API,例如用于微秒延遲的OS_TASK_Delay_us()或用于周期調(diào)度的OS_TASK_Delay_Cycles()。這些函數(shù)與傳統(tǒng)API調(diào)用共存,允許開發(fā)人員在不修改整個代碼庫的情況下逐步采用高級功能。

讓我們來看一個例子。假設(shè)我們想每1,000,000個周期向終端發(fā)送一次打印“Hello World!”,我可能會用下面的語法創(chuàng)建一個名為Hello的RTOS任務(wù):

98f6ffe4-b8ff-11ef-8732-92fbcf53809c.png

OS_TASK_Delay_Cycles以周期方式指定了任務(wù)掛起操作的最小時間間隔,因此,當(dāng)調(diào)用OS_TASK_Delay_Cycles時,如果系統(tǒng)周期計數(shù)為1,000,000,則100萬周期的延遲將在系統(tǒng)周期計數(shù)為2,000,000時到期。

注意,作為開發(fā)人員,你可以控制單個周期所代表的時間間隔。它可以是單個CPU周期,也可以是更長的時間,這取決于你如何為使用的計時器配置時鐘分頻器。好消息是,SEGGER為各種微控制器提供了許多移植實現(xiàn),所以你不必自己編寫這些;只有當(dāng)默認(rèn)值不能滿足需要時,才需要知道如何通過API來調(diào)整。

這種雙重計時方法意味著工程師不必在傳統(tǒng)實現(xiàn)和高精度之間做出選擇,他們可以在同一應(yīng)用中同時使用這兩種方法。無論是從embOS-Base還是其他基于滴答的系統(tǒng)(如CMSIS-RTOS)遷移,開發(fā)人員都可以很方便的使用embOS-Ultra,因為必要的應(yīng)用更改很小且簡單。

6. 下一步工作

基于周期的調(diào)度代表了一種技術(shù)進(jìn)步,它解決了開發(fā)人員和管理人員在當(dāng)今嵌入式系統(tǒng)中面臨的核心挑戰(zhàn),在實現(xiàn)微秒精度的同時最大限度地提高能效。通過消除傳統(tǒng)的系統(tǒng)滴答,并提供靈活的、基于周期的方法,embOS-Ultra提供了一種精確、節(jié)能且與現(xiàn)有RTOS設(shè)置兼容的解決方案。

基于周期的調(diào)度為希望在沒有復(fù)雜遷移風(fēng)險的情況下提高系統(tǒng)的性能和能源配置的嵌入式專業(yè)人員提供了一種實用而先進(jìn)的替代方案。你可以通過下列步驟了解更多關(guān)于周期調(diào)度的信息。

首先,查看embOS-Ultra RTOS手冊(https://www.segger.com/downloads/embos/UM01076_embOS_Ultra.pdf),它包含了許多示例,描述了高精度和周期調(diào)度如何工作。

接下來,可以下載并試用基于SEGGER的示例仿真項目(https://www.segger.com/products/rtos/embos/editions/embos-ultra/#live-comparison),你可以使用它來測試embOS-Base和embOS-Ultra之間的差異,甚至可以在開發(fā)板上嘗試。

最后,確認(rèn)了更精確的計時和節(jié)能的好處后,即可在嵌入式系統(tǒng)采用基于周期計時功能了。

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

    關(guān)注

    22

    文章

    817

    瀏覽量

    119746
  • 應(yīng)用程序
    +關(guān)注

    關(guān)注

    37

    文章

    3284

    瀏覽量

    57773

原文標(biāo)題:一種實現(xiàn)亞毫秒定時分辨率的RTOS新方法

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

收藏 人收藏

    評論

    相關(guān)推薦

    如何提高透鏡成像的分辨率

    透鏡成像分辨率是指透鏡系統(tǒng)能夠分辨的最小細(xì)節(jié)的能力。提高透鏡成像分辨率對于許多應(yīng)用領(lǐng)域,如顯微鏡、望遠(yuǎn)鏡、相機(jī)等,都是至關(guān)重要的。以下是些提高透鏡成像
    的頭像 發(fā)表于 12-25 16:54 ?390次閱讀

    一種降低VIO/VSLAM系統(tǒng)漂移的新方法

    本文提出了一種新方法,通過使用點到平面匹配將VIO/VSLAM系統(tǒng)生成的稀疏3D點云與數(shù)字孿生體進(jìn)行對齊,從而實現(xiàn)精確且全球致的定位,無需視覺數(shù)據(jù)關(guān)聯(lián)。所提
    的頭像 發(fā)表于 12-13 11:18 ?194次閱讀
    <b class='flag-5'>一種</b>降低VIO/VSLAM系統(tǒng)漂移的<b class='flag-5'>新方法</b>

    HDMI接口支持哪些視頻分辨率

    支持最大分辨率4K(3840x2160)@60Hz。與HDMI 1.4相比,HDMI 2.0在4K分辨率下的刷新提高了倍,達(dá)到每秒60幀,提供更流暢的視頻體驗。 也支持1080p
    的頭像 發(fā)表于 11-27 14:14 ?2516次閱讀

    使用MSP430高分辨率定時器的PWM DAC

    電子發(fā)燒友網(wǎng)站提供《使用MSP430高分辨率定時器的PWM DAC.pdf》資料免費下載
    發(fā)表于 09-20 10:53 ?0次下載
    使用MSP430高<b class='flag-5'>分辨率</b><b class='flag-5'>定時</b>器的PWM DAC

    什么是高分辨率示波器?它有哪些優(yōu)勢?

    分辨率示波器是一種在信息與系統(tǒng)科學(xué)相關(guān)工程與技術(shù)領(lǐng)域中廣泛應(yīng)用的科學(xué)儀器,其設(shè)計旨在提供更高的信號分辨率和更精細(xì)的信號分析能力。以下是對高分辨率示波器的詳細(xì)解析,包括其定義、優(yōu)勢以及
    的頭像 發(fā)表于 08-08 11:49 ?1037次閱讀

    一種無透鏡成像的新方法

    使用OAM-HHG EUV光束對高度周期性結(jié)構(gòu)進(jìn)行成像的EUV聚光顯微鏡 為了研究微電子或光子元件中的納米級圖案,一種基于無透鏡成像的新方法可以實現(xiàn)近乎完美的高分辨率顯微鏡。 層析成像
    的頭像 發(fā)表于 07-19 06:20 ?416次閱讀
    <b class='flag-5'>一種</b>無透鏡成像的<b class='flag-5'>新方法</b>

    用于波長分辨率的新型衍射成像儀

    ? 研究人員提出了一種對相位和振幅物體進(jìn)行波長分辨率成像的新方法。他們的技術(shù)依靠帶有固體浸透層的衍射編碼和解碼來恢復(fù)與物體波長特征相對應(yīng)
    的頭像 發(fā)表于 06-28 06:32 ?236次閱讀

    伺服編碼器分辨率是什么意思

    。 伺服編碼器分辨率的概念 伺服編碼器是一種用于測量電機(jī)軸或負(fù)載位置和速度的傳感器。它通過將機(jī)械位置轉(zhuǎn)換為電信號,為伺服控制系統(tǒng)提供反饋信息。編碼器的分辨率是指它能夠檢測到的最小角度或位置變化,通常以脈沖數(shù)或位表
    的頭像 發(fā)表于 06-17 11:16 ?996次閱讀

    只用STM32的RTC的話,如何讀取到分辨率毫秒的時刻?

    設(shè)備要記錄某個事件發(fā)生時的時刻,但如果只用STM32的RTC的話,如何讀取到分辨率毫秒的時刻,大概看了下RTC的資料,基本上都是計時到1秒。
    發(fā)表于 05-10 06:48

    研究人員發(fā)現(xiàn)提高激光加工分辨率新方法

    通過透明玻璃聚焦定制激光束可以在材料內(nèi)部形成個小光斑。東北大學(xué)的研究人員研發(fā)了一種利用這種小光斑改進(jìn)激光材料加工、提高加工分辨率方法。 他們的研究成果發(fā)表在《光學(xué)通訊》(Optic
    的頭像 發(fā)表于 04-18 06:30 ?375次閱讀
    研究人員發(fā)現(xiàn)提高激光加工<b class='flag-5'>分辨率</b>的<b class='flag-5'>新方法</b>

    EVAL_PASCO2_SENSOR為什么無法從較低的分辨率高速獲得更高的分辨率?

    捕獲,同時高速傳輸較低分辨率(640x480,1280x720,1920x1080)時,靜止請求被觸發(fā),它正在從一種分辨率轉(zhuǎn)移到另一種分辨率
    發(fā)表于 02-22 07:58

    編碼器分辨率是什么意思 編碼器分辨率和脈沖數(shù)的關(guān)系

    線稱為分辨率,也稱解析分度、或直接稱多少線,般在每轉(zhuǎn)分度5~10000線。 按照編碼器支持的分辨率可以把編碼器分成標(biāo)清編碼器(720X480及以下,PAL制幀率最高為50, NTSC制幀率最高為60),高清編碼器(1280X7
    的頭像 發(fā)表于 02-21 18:07 ?4393次閱讀
    編碼器<b class='flag-5'>分辨率</b>是什么意思 編碼器<b class='flag-5'>分辨率</b>和脈沖數(shù)的關(guān)系

    臺階儀:埃級垂直分辨率,新材料納米加工的測量利器!

    臺階儀埃級垂直分辨率能夠實現(xiàn)納米級別的測量和分析,儀器具備出色的精確性和穩(wěn)定性。在納米加工領(lǐng)域,臺階儀不僅能準(zhǔn)確評估材料的表面形貌和結(jié)構(gòu),同時也為納米加工過程的控制和優(yōu)化提供了可靠的依據(jù)。利用臺階
    發(fā)表于 02-20 09:11 ?0次下載

    臺階儀:埃級垂直分辨率,領(lǐng)跑新材料納米加工的測量利器!

    臺階儀具備埃級垂直分辨率,可實現(xiàn)納米級別測量和分析。在納米加工領(lǐng)域,臺階儀能評估材料表面形貌和結(jié)構(gòu),優(yōu)化納米加工過程。其線性可變差動電容傳感器具有高分辨率,可測量蝕刻、濺射等多種工藝
    的頭像 發(fā)表于 02-19 13:49 ?681次閱讀
    臺階儀:<b class='flag-5'>亞</b>埃級垂直<b class='flag-5'>分辨率</b>,領(lǐng)跑新材料納米加工的測量利器!

    鏡頭分辨率簡述

    分辨率可以從顯示分辨率與圖像分辨率兩個方向來分類。
    的頭像 發(fā)表于 01-15 11:12 ?966次閱讀