亚洲精品久久久久久久久久久,亚洲国产精品一区二区制服,亚洲精品午夜精品,国产成人精品综合在线观看,最近2019中文字幕一页二页

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

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

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

FreeRTOS中osDelay和HAL_Delay的區(qū)別

撞上電子 ? 2023-10-29 08:00 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

問題場景

FreeRTOS中創(chuàng)建了線程A、線程B,其中線程A優(yōu)先級大于線程B。線程A、B任務(wù)代碼如下:

void A(void *argument)
{
while (1)
{
printf("A\r\n");
HAL_Delay(1000);
}
}

void B(void *argument)
{
while (1)
{
printf("B\r\n");
HAL_Delay(1000);
}
}

燒錄程序后查看串口數(shù)據(jù)發(fā)現(xiàn)只打印了A而不打印B,說明只執(zhí)行了A線程沒有執(zhí)行B線程。

問題原因

HAL_Delay是由ST提供的STM32 Cube HAL庫中的一個(gè)函數(shù),通常用于在STM32微控制器上實(shí)現(xiàn)簡單的延時(shí)。HAL_Delay函數(shù)使用系統(tǒng)時(shí)鐘來進(jìn)行延時(shí),并且在延時(shí)期間會阻塞整個(gè)處理器,也就是說,它會使處理器暫時(shí)停止執(zhí)行其他任務(wù)和代碼。

在開始運(yùn)行線程之前,線程A、B處于就緒態(tài),由于線程A優(yōu)先級比線程B高,F(xiàn)reeRTOS任務(wù)控制器優(yōu)先選擇線程A運(yùn)行,此時(shí)線程A進(jìn)入運(yùn)行態(tài)。隨后線程A打印A,然后被HAL_Delay函數(shù)"阻塞",注意此時(shí)的"阻塞"并不意味著程序進(jìn)入了阻塞態(tài),由于HAL_Delay阻塞的是整個(gè)處理器,因此FreeRTOS無法進(jìn)行其他線程的調(diào)度,也就是說,HAL_Delay同時(shí)阻塞了線程B。當(dāng)HAL_Delay函數(shù)運(yùn)行結(jié)束后,線程A重回就緒態(tài),由于線程A優(yōu)先級比線程B高,F(xiàn)reeRTOS任務(wù)控制器優(yōu)先選擇線程A運(yùn)行,循環(huán)往復(fù),線程B不被執(zhí)行。

解決辦法

osDelay是FreeRTOS(Real-Time Operating System)中的一個(gè)函數(shù),用于實(shí)現(xiàn)任務(wù)的延時(shí)。FreeRTOS是一個(gè)開源的實(shí)時(shí)操作系統(tǒng),專門用于嵌入式系統(tǒng)。osDelay函數(shù)允許任務(wù)掛起一段時(shí)間,然后由操作系統(tǒng)調(diào)度器在指定的時(shí)間后重新運(yùn)行該任務(wù)。在等待期間,任務(wù)會被放入掛起狀態(tài),讓其他任務(wù)有機(jī)會運(yùn)行。

也就是說,當(dāng)調(diào)用osDelay時(shí),線程A進(jìn)入阻塞態(tài),此時(shí)任務(wù)控制器選擇進(jìn)入就緒態(tài)的線程B執(zhí)行,循環(huán)往復(fù),線程A、B同時(shí)被執(zhí)行。我們可以將任務(wù)A和B進(jìn)行如下改動,即可看到既打印A又打印B。

void A(void *argument)
{
while (1)
{
printf("A\r\n");
osDelay(1000);
}
}

void B(void *argument)
{
while (1)
{
printf("B\r\n");
osDelay(1000);
}
}

使用osDelay可能帶來的問題

觀察一下HAL_Delay和osDelay的函數(shù)原型:

/**
* @brief This function provides minimum delay (in milliseconds) based
*/
__weak void HAL_Delay(uint32_t Delay);

/*
Wait for Timeout (Time Delay).
*/
osStatus_t osDelay (uint32_t ticks);

可以看到HAL_Delay函數(shù)的目的是提供毫秒級別的延時(shí),意味著當(dāng)你輸入HAL_Delay(500),硬件會盡量延時(shí)精確到500ms的時(shí)間。

與之不同的是,osDelay函數(shù)的輸入是ticks。ticks是一個(gè)計(jì)時(shí)單位,表示任務(wù)將被掛起的時(shí)間長度。每個(gè)tick的時(shí)間取決于FreeRTOS配置的時(shí)鐘節(jié)拍(tick)周期。例如,如果tick周期為1毫秒,那么傳遞參數(shù)ticks為10就會使任務(wù)掛起10毫秒。由此可見,osDelay函數(shù)延時(shí)的時(shí)間和一個(gè)ticks記時(shí)時(shí)間長度有很大關(guān)系。

那么如何確定ticks具體代表多長時(shí)間呢?首先我們應(yīng)該找到用于配置的頭文件,通常這個(gè)頭文件名字叫做FreeRTOSConfig.h。其中,configTICK_RATE_HZ配置選項(xiàng)的值表示每秒鐘系統(tǒng)時(shí)鐘節(jié)拍(tick)的數(shù)量。configTICK_RATE_HZ的值一般默認(rèn)被設(shè)置為1000,表示系統(tǒng)時(shí)鐘每秒產(chǎn)生1000個(gè)tick,即每個(gè)tick的時(shí)間間隔為1毫秒,此時(shí)osDelay對單個(gè)任務(wù)延時(shí)的時(shí)間長度和HAL_Delay近似。

聲明:本文內(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)注

    117

    文章

    3832

    瀏覽量

    84573
  • RTOS
    +關(guān)注

    關(guān)注

    24

    文章

    858

    瀏覽量

    122378
  • FreeRTOS
    +關(guān)注

    關(guān)注

    14

    文章

    496

    瀏覽量

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

    關(guān)注

    0

    文章

    508

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    在rtthread的main函數(shù)里用HAL_Delay函數(shù)不起作用是哪里的問題?

    在rtthread的main函數(shù)里用HAL_Delay函數(shù)無效,我設(shè)置延時(shí)500ms打印一次,但是實(shí)際上,一秒打印了幾百次,很顯然是HAL_Delay出現(xiàn)了問題。用RT_thread_mdelay
    發(fā)表于 09-15 07:53

    【RA4E2開發(fā)板評測】4.RA4E2 移植coremark跑分性能測試

    ) { SerialDecode(); /* switch(key_count) { case 1: led2_off(); led1_on();HAL_Delay(200); led1_off
    發(fā)表于 08-25 13:10

    詳解FreeRTOS與SAFERTOS的區(qū)別

    開源免費(fèi)的FreeRTOS由Richard Barry在WHIS工作時(shí)創(chuàng)建,WHIS基于FreeRTOS的功能模型,通過完整的HAZOP分析,確定了功能模型和API的所有的弱點(diǎn),減輕所有薄弱環(huán)節(jié),并采用IEC 61508 SI
    的頭像 發(fā)表于 06-04 16:58 ?589次閱讀
    詳解<b class='flag-5'>FreeRTOS</b>與SAFERTOS的<b class='flag-5'>區(qū)別</b>

    HAL15xy_SOT23

    HAL1501SU-A,HAL1502SU-A,HAL1503SU-A,HAL1504SU-A,HAL1505SU-A,
    發(fā)表于 05-14 15:03 ?0次下載

    cubemx生成HAL庫+FreeRTOS,當(dāng)編寫程序時(shí)卻代碼無法自動提示怎么解決?

    各位佬,請問一下,我用的是cubemx生成HAL庫+FreeRTOS,編譯時(shí)并沒有錯(cuò)誤,但當(dāng)我編寫程序時(shí)卻代碼無法自動提示(我設(shè)置好了),并且連uint8_t這種變量也不會變成藍(lán)色,當(dāng)我查看工程文件
    發(fā)表于 03-12 08:21

    cubemx生成的freertos代碼在keil ac6下不能編譯,怎么解決?

    ../Middlewares/Third_Party/FreeRTOS/Source/portable/RVDS/ARM_CM3portmacro.h(167): error: unknown
    發(fā)表于 03-12 08:19

    STM32C031C6在按鍵中斷處理程序中使用HAL_Delay()延時(shí)函數(shù),程序則無法運(yùn)行怎么解決?

    測試STM32C031C6開發(fā)板的長短按鍵,在按鍵中斷處理程序中使用HAL_Delay()延時(shí)函數(shù),程序則無法運(yùn)行,類似進(jìn)入了死循環(huán),于是則添加了延時(shí)函數(shù)如下: /[i
    發(fā)表于 03-07 06:50

    關(guān)于freertos任務(wù)usb文件系統(tǒng)寫入數(shù)據(jù)的問題

    請問一下,我用freertos系統(tǒng)的定時(shí)器,sendtime++滿500的時(shí)候執(zhí)行usb文件系統(tǒng)寫入數(shù)據(jù)的函數(shù)Flash_Write();這個(gè)函數(shù)需要300多ms跑完,按理來說他就算300多ms
    發(fā)表于 02-20 20:55

    【正點(diǎn)原子STM32H7R3開發(fā)套件試用體驗(yàn)】流水燈

    , GPIO_Pin_0); HAL_GPIO_TogglePin(GPIOC, GPIO_PIN_0); HAL_Delay(200); HAL_GPIO_TogglePin(GPIOD
    發(fā)表于 12-28 18:51

    HAL庫在STM32開發(fā)的重要性

    HAL庫(Hardware Abstraction Layer Library,硬件抽象層庫)在STM32開發(fā)扮演著至關(guān)重要的角色。以下是HAL庫在STM32開發(fā)的重要性分析: 一
    的頭像 發(fā)表于 12-02 13:35 ?1717次閱讀

    如何快速入門HAL庫編程 HAL庫與裸機(jī)編程的比較

    如何快速入門HAL庫編程 要快速入門HAL庫編程,可以遵循以下步驟: 了解基礎(chǔ)知識 : 掌握C語言編程基礎(chǔ),包括變量、數(shù)據(jù)類型、函數(shù)、指針等。 了解嵌入式系統(tǒng)的基本概念,如微控制器、中斷、外設(shè)等
    的頭像 發(fā)表于 12-02 11:39 ?1569次閱讀

    HAL庫在嵌入式系統(tǒng)的應(yīng)用

    HAL庫(Hardware Abstraction Layer Library,硬件抽象層庫)在嵌入式系統(tǒng)扮演著至關(guān)重要的角色。以下是HAL庫在嵌入式系統(tǒng)的應(yīng)用的分析: 一、
    的頭像 發(fā)表于 12-02 11:32 ?2748次閱讀

    ADS1259轉(zhuǎn)換結(jié)果一直比輸入真實(shí)值小5.525倍左右,是什么原因?qū)е碌难剑?/a>

    ADS1259_INIT(void) { HAL_Delay(20); ADS1259_RESET_H; ADS1259_START_H; ADS1259_CS_L; HAL_Delay(20
    發(fā)表于 11-20 08:25

    ADS1299內(nèi)部產(chǎn)生信號測試,SPI接收到的數(shù)據(jù)不對,為什么?

    ;amp;amp;tmp,1,1000);//===fff===í£?1á?D??á?£ê? HAL_Delay(1000);LED1_TOGGLE();HAL
    發(fā)表于 11-13 06:23

    hali2c卡死在HAL_I2C_Master_Transmit

    _ERROR; } / Check for the Timeout */ if (Timeout != HAL_MAX_DELAY) { if (((HAL_GetTick() - Tickstart) >
    發(fā)表于 10-31 09:03