精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

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

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

RTOS多線程訪問同一硬件(如UART)的方法

黃工的嵌入式技術(shù)圈 ? 來源:黃工的嵌入式技術(shù)圈 ? 2020-03-12 11:28 ? 次閱讀

讀者*石 三*問:博主可以介紹下在RTOS下多個(gè)任務(wù)訪問同一硬件的方法嗎?比如說,多個(gè)任務(wù)都要用到串口打印信息

我的回答是:使用互斥量、隊(duì)列兩種方式都能解決訪問沖突的問題。

多線程訪問同一串行硬件在許多系統(tǒng)中經(jīng)常使用,如多個(gè)線程都使用UART收發(fā)數(shù)據(jù)、多個(gè)線程使用讀寫SPI_FLASH、I2C_E2PROM,CAN總線收發(fā)數(shù)據(jù)等······

如果每個(gè)線程都同時(shí)搶占同一串口去讀寫操作,那么很容易出現(xiàn)問題。為了解決其中的沖突問題,就需要使用一定的辦法。下面以UART為例,基于FreeRTOS講述一下基本的互斥量和隊(duì)列方式的解決方法。

Ⅰ互斥訪問方法

互斥量:是一個(gè)可以處于兩態(tài)之一的變量:解鎖和加鎖。

原理:創(chuàng)建一個(gè)互斥量,線程A在需要占用資源(使用UART發(fā)送數(shù)據(jù)),把資源(UART)占用。此時(shí),線程B及其他線程就不能占用該資源。當(dāng)線程A使用完資源(UART發(fā)送完數(shù)據(jù)),釋放資源,其他線程就可以搶占該資源。

創(chuàng)建互斥量

線程A占用資源

使用資源(發(fā)送數(shù)據(jù))

線程A釋放資源

優(yōu)先級(jí)高的線程B占用資源

使用資源

線程B釋放資源

依次,優(yōu)先級(jí)線程占用資源

代碼:

//創(chuàng)建互斥量資源 SemaphoreHandle_t xSemaphore = NULL;xSemaphore = xSemaphoreCreateMutex(); void TaskA(void *pvParameters){ for(;;) { //占用資源 if(xSemaphoreTake(xSemaphore, 10 ) == pdTRUE) { //使用資源(發(fā)送數(shù)據(jù)) USART_SendNByte(); //釋放資源 xSemaphoreGive(xSemaphore); } }}

信號(hào)量與互斥量區(qū)別:

信號(hào)量:多線程同步使用的;一個(gè)線程完成某個(gè)動(dòng)作后通過信號(hào)告訴別的線程,別的線程才可以執(zhí)行某些動(dòng)作;

互斥量:多線程互斥使用的;一個(gè)線程占用某個(gè)資源,那么別的線程就無法訪問,直到該線程離開,其他線程才可以訪問該資源;

Ⅱ隊(duì)列操作方法

隊(duì)列操作方法就是FIFO,先入先出的原理。比如:線程A要使用UART發(fā)送一串?dāng)?shù)據(jù),將其加入隊(duì)列;接著線程B也要使用UART發(fā)送一串?dāng)?shù)據(jù)。

那么,線程A將這串?dāng)?shù)據(jù)加入隊(duì)列,接著線程B又將要發(fā)送的一串?dāng)?shù)據(jù)加入隊(duì)列。

在另外一個(gè)UART發(fā)送的線程中,從隊(duì)列中按照FIFO方式讀取隊(duì)列里面的數(shù)據(jù),依次發(fā)送出去即可。

創(chuàng)建一個(gè)隊(duì)列(發(fā)送數(shù)據(jù)隊(duì)列)

創(chuàng)建一個(gè)任務(wù)(UART發(fā)送數(shù)據(jù)線程)

線程A加入隊(duì)列

線程B加入隊(duì)列

另外一邊的線程,依次讀取隊(duì)列數(shù)據(jù),使用UART發(fā)送出去。

代碼:

QueueHandle_t xQueue;xQueue = xQueueCreate(QUEUE_LENGTH, QUEUE_ITEM_SIZE);xTaskCreate(UART_Send_Task, "UART_Send", STACK_SIZE, NULL, TASK_PRIORITY, NULL); void TaskA(void *pvParameters){ for(;;) { //線程相關(guān)操作 //加入隊(duì)列 xQueueSend(xQueue, &TaskA_Buf, 10) }} void TaskB(void *pvParameters){ for(;;) { //線程相關(guān)操作 //加入隊(duì)列 xQueueSend(xQueue, &TaskB_Buf, 10) }} void UART_Send_Task(void *pvParameters){ for(;;) { //循環(huán)讀取隊(duì)列BUF if(xQueueReceive(xQueue, &Buf, 10) == pdTRUE) { USART_SendNByte(&Buf); } }}

以上兩種方法是常用的,希望大家都掌握一下。上述僅讓大家掌握原理,代碼不宜直接復(fù)制粘貼使用。

聲明:本文內(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)投訴
  • uart
    +關(guān)注

    關(guān)注

    22

    文章

    1199

    瀏覽量

    100819
  • 多線程
    +關(guān)注

    關(guān)注

    0

    文章

    275

    瀏覽量

    19849
  • RTOS
    +關(guān)注

    關(guān)注

    20

    文章

    804

    瀏覽量

    119110
  • 串口打印
    +關(guān)注

    關(guān)注

    0

    文章

    10

    瀏覽量

    3063
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    多線程設(shè)計(jì)模式到對(duì) CompletableFuture 的應(yīng)用

    最近在開發(fā) 延保服務(wù) 頻道頁時(shí),為了提高查詢效率,使用到了多線程技術(shù)。為了對(duì)多線程方案設(shè)計(jì)有更加充分的了解,在業(yè)余時(shí)間讀完了《圖解 Java 多線程設(shè)計(jì)模式》這本書,覺得收獲良多。本篇文章將介紹其中
    的頭像 發(fā)表于 06-26 14:18 ?177次閱讀
    從<b class='flag-5'>多線程</b>設(shè)計(jì)模式到對(duì) CompletableFuture 的應(yīng)用

    bootloader開多線程做引導(dǎo)程序,跳app初始化后直接進(jìn)hardfualt,為什么?

    標(biāo)題,想做個(gè)遠(yuǎn)程升級(jí)的項(xiàng)目,bootloader引導(dǎo)區(qū)域和app都是開多線程跑的,就是自己寫了個(gè)小的任務(wù)調(diào)度器,沒什么功能主要是想讓程序快速的響應(yīng),延時(shí)不會(huì)對(duì)其他程序造成堵塞,程序測試
    發(fā)表于 04-18 06:07

    java實(shí)現(xiàn)多線程的幾種方式

    的CompletableFuture 、繼承Thread類 繼承Thread類是實(shí)現(xiàn)多線程的最基本方式,只需創(chuàng)建個(gè)類并繼承Thread類,重寫run()方法即可。 ``
    的頭像 發(fā)表于 03-14 16:55 ?430次閱讀

    基于RTOS的應(yīng)用進(jìn)程中的典型線程

    RTOS中的關(guān)鍵因素是最小的中斷延遲和最小的線程切換延遲。RTOS的價(jià)值在于它的響應(yīng)速度或可預(yù)測性,而不是它在給定時(shí)間段內(nèi)可以執(zhí)行的工作量。
    發(fā)表于 03-05 09:32 ?415次閱讀
    基于<b class='flag-5'>RTOS</b>的應(yīng)用進(jìn)程中的典型<b class='flag-5'>線程</b>

    redis多線程還能保證線程安全嗎

    是單線程的,多個(gè)客戶端請(qǐng)求會(huì)按序執(zhí)行,每個(gè)請(qǐng)求使用個(gè)線程完成,這樣可以避免多線程之間的競爭條件和鎖等帶來的開銷。但是,由于Redis是存儲(chǔ)內(nèi)存中的數(shù)據(jù)的,當(dāng)多個(gè)客戶端同時(shí)對(duì)
    的頭像 發(fā)表于 12-05 10:28 ?1331次閱讀

    mfc多線程編程實(shí)例

    (圖形用戶界面)應(yīng)用程序的開發(fā)。在這篇文章中,我們將重點(diǎn)介紹MFC中的多線程編程。 多線程編程在軟件開發(fā)中非常重要,它可以實(shí)現(xiàn)程序的并發(fā)執(zhí)行,提高程序的效率和響應(yīng)速度。MFC提供了豐富的多線程支持,可以輕松地實(shí)現(xiàn)
    的頭像 發(fā)表于 12-01 14:29 ?1134次閱讀

    多線程如何保證數(shù)據(jù)的同步

    多線程編程是種并發(fā)編程的方法,意味著程序中同時(shí)運(yùn)行多個(gè)線程,每個(gè)線程可獨(dú)立執(zhí)行不同的任務(wù),共享同一
    的頭像 發(fā)表于 11-17 14:22 ?878次閱讀

    多線程并發(fā)查詢oracle數(shù)據(jù)庫

    多線程并發(fā)查詢Oracle數(shù)據(jù)庫是指在同一時(shí)間內(nèi)有多個(gè)線程同時(shí)執(zhí)行數(shù)據(jù)庫查詢操作。這種并發(fā)查詢的方式可以提高系統(tǒng)的吞吐量和響應(yīng)速度,提高數(shù)據(jù)庫的效率和性能。本文將詳細(xì)介紹多線程并發(fā)查詢
    的頭像 發(fā)表于 11-17 14:22 ?3092次閱讀

    多線程同步的幾種方法

    多線程同步是指在多個(gè)線程并發(fā)執(zhí)行的情況下,為了保證線程執(zhí)行的正確性和致性,需要采用特定的方法來協(xié)調(diào)線程
    的頭像 發(fā)表于 11-17 14:16 ?951次閱讀

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

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

    SCP線程模型特點(diǎn)

    。 SCP線程模型的特點(diǎn): ?軟實(shí)時(shí)調(diào)度。 ? 支持具有等優(yōu)先級(jí)線程的單線程多線程環(huán)境(無搶占)。 ? 支持協(xié)作調(diào)度,符合CMSIS的R
    的頭像 發(fā)表于 11-02 17:07 ?441次閱讀
    SCP<b class='flag-5'>線程</b>模型特點(diǎn)

    多線程idm下載軟件

    多線程idm下載軟件
    發(fā)表于 10-23 09:23 ?0次下載

    個(gè)有許多線程的進(jìn)程,如何才能改變其中個(gè)線程的工作目錄?

    個(gè)有許多線程的進(jìn)程,我們?nèi)绾尾拍芨淖兤渲?b class='flag-5'>一個(gè)線程的工作目錄,而不影響其他?
    發(fā)表于 10-17 09:01

    Java多線程的用法

    本文將介紹下Java多線程的用法。 基礎(chǔ)介紹 什么是多線程 指的是在個(gè)進(jìn)程中同時(shí)運(yùn)行多個(gè)線程,每個(gè)
    的頭像 發(fā)表于 09-30 17:07 ?842次閱讀

    Rust的多線程編程概念和使用方法

    和字段、常見用法以及多線程些實(shí)踐經(jīng)驗(yàn)。由淺入深帶你零基礎(chǔ)玩轉(zhuǎn)Rust的多線程編程。 線程的基本概念和使用方法 Thread是Rust中并
    的頭像 發(fā)表于 09-20 11:15 ?812次閱讀