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

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

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

RTOS中如何確定任務(wù)堆棧的大?。?/h1>

基于RTOS的應(yīng)用中,每個(gè)任務(wù)都擁有自己的堆棧空間。堆棧設(shè)置過大,會(huì)造成內(nèi)存資源浪費(fèi);設(shè)置過小,可能導(dǎo)致運(yùn)行過程中的任務(wù)棧溢出,從而導(dǎo)致一些奇怪的系統(tǒng)行為。

事實(shí)上,當(dāng)應(yīng)用程序行為“奇怪”時(shí),我們首先想到的就是堆棧大小不足。

但任務(wù)所需的堆棧大小與具體應(yīng)用相關(guān),如何確定任務(wù)堆棧的大???

通過分析任務(wù)實(shí)現(xiàn),我們可以通過手動(dòng)計(jì)算的方法獲取任務(wù)所需的堆??臻g:

1.所有函數(shù)嵌套調(diào)用所需的內(nèi)存

對(duì)于每個(gè)層級(jí)的函數(shù)調(diào)用:

根據(jù)CPU架構(gòu),存儲(chǔ)一個(gè)指向函數(shù)調(diào)用返回地址的指針。一些CPU實(shí)際上將函數(shù)返回地址保存在特殊寄存器中(通常稱為鏈接寄存器LR)。但如果該函數(shù)嵌套調(diào)用其它函數(shù),則調(diào)用者必須保存鏈接寄存器的內(nèi)容,因此,計(jì)算時(shí)我們假設(shè)指針也被壓入堆棧。

函數(shù)調(diào)用時(shí),傳遞參數(shù)所需的內(nèi)存。參數(shù)通常使用寄存器傳遞,但同樣,如果一個(gè)函數(shù)調(diào)用其它函數(shù),寄存器內(nèi)容需要保存到堆棧中。因此,假設(shè)使用堆棧傳遞所有參數(shù)以確定任務(wù)堆棧的大小。

存儲(chǔ)函數(shù)的局部變量所需內(nèi)存空間。

用于函數(shù)運(yùn)行過程中內(nèi)部狀態(tài)保存所需的堆棧空間。

2.完整的CPU上下文存儲(chǔ)空間,上下文通常指CPU的寄存器現(xiàn)場,如果需要FPU功能,還需保存相應(yīng)的FPU寄存器

3.中斷處理現(xiàn)場保存。如果沒有獨(dú)立的中斷堆棧,還需在任務(wù)堆棧中為每個(gè)可能嵌套的ISR增加存儲(chǔ)CPU上下文的空間,以及ISR中的局部變量所需的堆棧空間。

將所有這些信息加起來是一件繁瑣的工作,而得到的數(shù)字僅是堆棧的最低需求。計(jì)算是假定已知代碼的確切路徑,但有時(shí)并不可能。例如調(diào)用printf()函數(shù)時(shí),很難猜測(cè)printf()需要多少堆??臻g。為了應(yīng)用安全,我們還需要在計(jì)算值的基礎(chǔ)上,乘以一些安全系數(shù),如1.5到2.0。推算出任務(wù)堆棧值后,我們可以通過調(diào)試手段進(jìn)一步優(yōu)化設(shè)置。

許多IDE的調(diào)試器都提供了內(nèi)核感知插件,該插件允許用戶查看某些內(nèi)核數(shù)據(jù)結(jié)構(gòu)如任務(wù)的狀態(tài),如圖1所示,IAR提供了FreeRTOS感知插件。通過IDE的內(nèi)核感知插件,應(yīng)用停止運(yùn)行時(shí),可以查看當(dāng)前任務(wù)堆棧使用情況,基于插件提供的信息調(diào)整任務(wù)堆棧設(shè)置,但只能獲得某個(gè)瞬間的快照。

b2467436-e22c-11ec-ba43-dac502259ad0.png

圖1IDE提供的內(nèi)核感知功能

為了實(shí)時(shí)監(jiān)控任務(wù)堆棧使用,優(yōu)化堆棧設(shè)置,我們還可以借助RTOS的可視化分析工具,如Tracealyzer,在運(yùn)行時(shí)監(jiān)控堆棧使用情況。通過堆棧使用視圖顯示隨時(shí)間的變化,每個(gè)任務(wù)使用或未使用的堆棧數(shù)量,從而調(diào)整任務(wù)堆棧設(shè)置,優(yōu)化內(nèi)存使用。

b2a19d84-e22c-11ec-ba43-dac502259ad0.png

圖2Tracealyzer的堆棧使用捕獲

一般來說,任務(wù)堆??梢詮囊粋€(gè)比較大的堆棧空間開始,在運(yùn)行時(shí)監(jiān)視堆棧空間的使用情況,以查看應(yīng)用程序運(yùn)行一段時(shí)間后實(shí)際使用了多少堆棧空間。基于可視化分析,用戶可以更清晰直觀的掌握系統(tǒng)中內(nèi)存的使用情況,進(jìn)而開發(fā)出更高質(zhì)量的代碼。

審核編輯 :李倩

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

    關(guān)注

    0

    文章

    176

    瀏覽量

    19668
  • RTOS
    +關(guān)注

    關(guān)注

    20

    文章

    804

    瀏覽量

    119117

原文標(biāo)題:如何設(shè)置RTOS任務(wù)的堆棧大?。?/p>

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

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    C2000?MCU的運(yùn)行時(shí)堆棧大小監(jiān)測(cè)

    電子發(fā)燒友網(wǎng)站提供《C2000?MCU的運(yùn)行時(shí)堆棧大小監(jiān)測(cè).pdf》資料免費(fèi)下載
    發(fā)表于 09-11 09:30 ?0次下載
    C2000?MCU的運(yùn)行時(shí)<b class='flag-5'>堆棧</b><b class='flag-5'>大小</b>監(jiān)測(cè)

    freertos最多支持多少個(gè)任務(wù)

    以下幾個(gè)因素: 系統(tǒng)資源 :FreeRTOS能夠支持的任務(wù)數(shù)量受到系統(tǒng)硬件資源的限制,特別是處理器的RAM大小和性能。RAM用于存儲(chǔ)任務(wù)的控制塊(TCB)和任務(wù)
    的頭像 發(fā)表于 09-02 14:21 ?278次閱讀

    freertos和rtos區(qū)別是什么

    (Real-Time Operating System,實(shí)時(shí)操作系統(tǒng))是一種特殊的操作系統(tǒng),它能夠?yàn)閷?shí)時(shí)任務(wù)提供確定性的響應(yīng)時(shí)間。RTOS 通常用于嵌入式系統(tǒng),如工業(yè)自動(dòng)化、汽車電子、醫(yī)療設(shè)備等領(lǐng)域
    的頭像 發(fā)表于 09-02 14:18 ?332次閱讀

    什么是實(shí)時(shí)操作系統(tǒng)(3)-在 RTOS 可以期待什么?

    RTOS使用各種機(jī)制來管理任務(wù)、事件和內(nèi)存,以確保嵌入式系統(tǒng)滿足時(shí)間約束。在本節(jié),您將了解構(gòu)建嵌入式應(yīng)用程序時(shí)需要考慮的RTOS功能,例如確定
    的頭像 發(fā)表于 07-23 12:00 ?851次閱讀
    什么是實(shí)時(shí)操作系統(tǒng)(3)-在 <b class='flag-5'>RTOS</b> <b class='flag-5'>中</b>可以期待什么?

    xTaskCreate能否把堆棧上限調(diào)整為2K或者1k?

    RTOS SDK 的系統(tǒng)任務(wù)優(yōu)先級(jí)為 15 ,創(chuàng)建任務(wù)的接?口 xTaskCreate 為 freeRTOS ?自帶接?口,使 ?用 xTaskCreate 創(chuàng)建任務(wù)時(shí),
    發(fā)表于 07-22 06:31

    esp32S2創(chuàng)建任務(wù)時(shí),若任務(wù)堆棧大小配置超過 4096*6 ,該任務(wù)會(huì)創(chuàng)建失敗,如何解決?

    esp32S2創(chuàng)建任務(wù)時(shí),若任務(wù)堆棧大小配置超過 4096*6 ,該任務(wù)會(huì)創(chuàng)建失敗, xTaskCreat 返回 xReturn = fff
    發(fā)表于 06-20 08:26

    求助,關(guān)于stm32f1使用freeRTOS和Fatfs時(shí)任務(wù)堆棧大小問題求解

    哪位使用過freeRTOS和Fatfs時(shí),使用Fatfs系統(tǒng)的函數(shù)如f_open()等等時(shí),此任務(wù)堆棧大小大致需要多大,當(dāng)前MAX_SS 定義為4096,我分配12K軟件都跑飛了,請(qǐng)哪位使用分享一下經(jīng)驗(yàn),謝謝!~~?
    發(fā)表于 05-09 06:50

    IAR調(diào)試freertos系統(tǒng)怎樣才能方便的獲得任務(wù)堆棧情況?

    在IAR中將freertos移植到STM32,在進(jìn)行任務(wù)堆棧分配時(shí)分配多大的堆棧時(shí)一個(gè)問題,如何比較方便的獲得任務(wù)
    發(fā)表于 05-07 08:15

    如何設(shè)定RTOS任務(wù)棧(線程棧)大小呢?

    首先說明的是,在 `RT-Thread` ,將本文提及的 `任務(wù)` 稱之為 `線程`。
    的頭像 發(fā)表于 12-01 16:40 ?1347次閱讀

    RTOS內(nèi)功修煉記(一)— 任務(wù)到底應(yīng)該怎么寫?

    本篇文章講述了任務(wù)的三大元素:任務(wù)控制塊、任務(wù)棧、任務(wù)入口函數(shù),并講述了編寫RTOS任務(wù)入口函數(shù)
    的頭像 發(fā)表于 12-01 16:36 ?592次閱讀
    <b class='flag-5'>RTOS</b>內(nèi)功修煉記(一)— <b class='flag-5'>任務(wù)</b>到底應(yīng)該怎么寫?

    RTOS的線程、進(jìn)程和協(xié)程詳解

    看到有小伙伴在討論【RTOS任務(wù)屬于線程還是進(jìn)程】的話題,這里就來分析一下OS的線程、進(jìn)程和協(xié)程的這幾個(gè)概念,同時(shí)一起看看RTOS
    的頭像 發(fā)表于 11-09 12:36 ?1583次閱讀
    <b class='flag-5'>RTOS</b><b class='flag-5'>中</b>的線程、進(jìn)程和協(xié)程詳解

    什么是堆棧溢出?如何分配堆棧空間大小

    前些日子bug交流群里的小哥調(diào)試了一個(gè)堆棧溢出的bug,動(dòng)不動(dòng)數(shù)據(jù)就被篡改了,應(yīng)該也是搞得焦頭爛額,頭皮發(fā)麻!當(dāng)時(shí)bug菌看了下,于是拋出了自己的一些調(diào)試經(jīng)驗(yàn),一般這樣的問題80%是越界和堆棧溢出造成的,沒想到還真是堆棧溢出。
    的頭像 發(fā)表于 11-08 09:52 ?3569次閱讀
    什么是<b class='flag-5'>堆棧</b>溢出?如何分配<b class='flag-5'>堆棧</b>空間<b class='flag-5'>大小</b>?

    怎么確定單片機(jī)堆棧大小?

    怎么確定單片機(jī)堆棧大小,例如51stack的大小怎么預(yù)留?其他單片機(jī)的不同之處,及與ARM區(qū)別
    發(fā)表于 11-02 06:36

    關(guān)于FreeRTOS創(chuàng)建任務(wù)時(shí)的堆棧問題

    usStackDepth指定堆棧大小。 請(qǐng)問,這個(gè)堆棧是用來干什么的? 是任務(wù)中分配的局部變量放在這個(gè)堆棧里嗎? 或者是
    發(fā)表于 10-31 08:08

    freertos怎么查看任務(wù)堆棧大小

    要通過什么方法來獲取當(dāng)前任務(wù)堆棧大小
    發(fā)表于 10-12 08:01