女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

【飛凌嵌入式】基于i.MX9352開發板M核的FreeRTOS設計例程

飛凌嵌入式 ? 2025-06-13 16:14 ? 次閱讀

嵌入式系統領域,嵌入式實時操作系統(RTOS) 的應用正日益廣泛,采用RTOS能夠更合理、更高效地利用CPU資源,FreeRTOS作為一款輕量級且成熟的實時操作系統內核,其核心功能完備,包括任務管理、時間管理(如延時、定時器)、同步機制(信號量、互斥鎖)、進程間通信(消息隊列)等等。這些特性使其能夠很好地滿足資源相對有限的中小型嵌入式系統的需求。

i.MX 9352作為NXP 推出的新一代輕量級邊緣AI處理器,集成2個Cortex-A55核和1個Cortex-M33實時核,其架構設計充分體現了對實時性與復雜任務處理能力的兼顧。為了幫助開發者充分利用i.MX 9352 M33核的實時能力,其配套的M核SDK包提供的FreeRTOS例程分為兩類,一類介紹FreeRTOS系統組件特性,如信號量、互斥量、隊列等,另一類是介紹外設接口如何在FreeRTOS使用,我們分別挑選這兩類下的例程進行演示。

演示平臺:飛凌嵌入式OK-MX9352-C開發板

947ec1d118914d02ad1aa7e1e4e7710a~tplv-tt-origin-web:gif.jpeg?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1750406773&x-signature=8X4xOjMgo7JENGAUiQ7QpbXJQVc%3D

1、FreeRTOS-generic

飛凌嵌入式OK-MX9352-C開發板支持FreeRTOS功能特性示例代碼如下:

  • freertos_event:任務事件演示例程
  • freertos_queue:隊列消息實現任務間通信的演示例程
  • freertos_mutex:互斥鎖使用例程
  • freertos_sem:信號量使用例程
  • freertos_swtimer:軟件計數器及其回調的用法。
  • freertos_tickless:使用 LPTMR 延時喚醒或者硬件中斷喚醒例程
  • freertos_generic:task、queue、swtimer、tick hook 、semaphore 組合利用演示例程。

因FreeRTOS_generic例程使用的FreeRTOS特性較多,我們重點分析此例程。

(1)軟件實現

示例程序內容包括:任務創建、隊列、軟定時器、系統節拍時鐘、信號量、異常處理。具體如下:

任務創建:

主函數創建了隊列發送、接收,信號量三個任務。

// 創建隊列接收任務 if(xTaskCreate(prvQueueReceiveTask,"Rx",configMINIMAL_STACK_SIZE+166,NULL,mainQUEUE_RECEIVE_TASK_PRIORITY,NULL)!=pdPASS) // 創建隊列發送任務 if(xTaskCreate(prvQueueSendTask,"TX",configMINIMAL_STACK_SIZE+166, NULL, mainQUEUE_SEND_TASK_PRIORITY, NULL) !=pdPASS) // 創建信號量任務 if(xTaskCreate(prvEventSemaphoreTask,"Sem",configMINIMAL_STACK_SIZE+166,NULL,mainEVENT_SEMAPHORE_TASK_PRIORITY, NULL) != pdPASS)

隊列:

隊列發送任務,阻塞200ms后向隊列發送數據;隊列接收任務,任務阻塞讀取隊列,數據讀取正確,則打印此時的隊列接收數量。

// 隊列發送任務,阻塞200ms后 向隊列發送數據 static void prvQueueSendTask(void *pvParameters) { TickType_t xNextWakeTime; const uint32_t ulValueToSend = 100UL; xNextWakeTime = xTaskGetTickCount(); for (;;) { // 任務阻塞,直至200ms延時結束 vTaskDelayUntil(&xNextWakeTime, mainQUEUE_SEND_PERIOD_MS); // 向隊列發送數據,阻塞時間為0表示當隊列滿的時候就立即返回 xQueueSend(xQueue, &ulValueToSend, 0); } } // 隊列接收任務,任務阻塞讀取隊列,數據讀取正確,則打印此時的隊列接收數量。 static void prvQueueReceiveTask(void *pvParameters) { uint32_t ulReceivedValue; for (;;) { // 任務一直阻塞,知道隊列內讀取到數據 xQueueReceive(xQueue, &ulReceivedValue, portMAX_DELAY); // 隊列數據和發送一致,隊列接收數量+1 輸出此時的隊列接收數量 if (ulReceivedValue == 100UL) { ulCountOfItemsReceivedOnQueue++; PRINTF("Receive message counter: %d.\r\n", ulCountOfItemsReceivedOnQueue); } } }

軟定時器:

設置軟定時器周期1s,時間到后,調用回調函數,記錄次數并串口打印。

// 創建軟件定時器任務 時間為1s,周期循環 xExampleSoftwareTimer = xTimerCreate( "LEDTimer", mainSOFTWARE_TIMER_PERIOD_MS, pdTRUE, (void *)0, vExampleTimerCallback); // 啟動軟件定時器 xTimerStart(xExampleSoftwareTimer, 0); // 回調函數 static void vExampleTimerCallback(TimerHandle_t xTimer) { // 每1s進入一次回調函數,計數增加 ulCountOfTimerCallbackExecutions++; PRINTF("Soft timer: %d s.\r\n", ulCountOfTimerCallbackExecutions); }

系統節拍時鐘:

通過設置文件 FreeRTOSConfig.h 中 configTICK_RATE_HZ 設置任務節拍中斷頻率, 在啟動任務調度器時,系統會根據另一個變量CPU的頻率configCPU_CLOCK_HZ計算對應寫入節拍計數器的值,啟動定時器中斷。

// 設置系統時鐘節拍為 1000/200=5ms #define configTICK_RATE_HZ ((TickType_t)200)

信號量:

每個系統節拍時鐘中斷中,調用函數vApplicationTickHook,累積500次即500*5ms=2.5s后,發送信號量。信號量任務獲取信號后,計數并打印累積次數。

// 系統節拍為5ms,每個500*5ms=2.5s 釋放事件信號量 void vApplicationTickHook(void) { BaseType_t xHigherPriorityTaskWoken = pdFALSE; static uint32_t ulCount = 0; ulCount++; if (ulCount >= 500UL) { // 在中斷中釋放事件信號量 xSemaphoreGiveFromISR(xEventSemaphore, &xHigherPriorityTaskWoken); ulCount = 0UL; } } // 任務阻塞等待信號量,收到后,接收次數增加,并通過串口打印 static void prvEventSemaphoreTask(void *pvParameters) { for (;;) { // 任務阻塞,直到能獲取信號量 if (xSemaphoreTake(xEventSemaphore, portMAX_DELAY) != pdTRUE) { PRINTF("Failed to take semaphore.\r\n"); } // 接收到信號量的次數累加 ulCountOfReceivedSemaphores++; PRINTF("Event task is running. Get semaphore :%d \r\n",ulCountOfReceivedSemaphores); } }

異常處理:

當內存分配失敗、堆棧發生錯誤或任務空閑時,進入相應的函數,用戶可添加相應的處理函數。

// 內存分配失敗函數,當內存分配失敗時,進入此函數 void vApplicationMallocFailedHook(void) { for (;;) ; } // 堆棧錯誤檢查函數,當堆棧發生溢出時,進入此函數 void vApplicationStackOverflowHook(TaskHandle_t xTask, char *pcTaskName) { (void)pcTaskName; (void)xTask; for (;;) ; } // 空閑任務,優先級最低,沒有實際意義,只是讓CPU有事情做,用戶可以自己添加自己的函數 void vApplicationIdleHook(void) { volatile size_t xFreeStackSpace; xFreeStackSpace = xPortGetFreeHeapSize(); if (xFreeStackSpace > 100) { } }

(2)實驗現象

① 編譯程序:在uboot手動加載M核程序。

② 隊列:每隔200ms,隊列發送任務發送數據,隊列接收任務獲取數據,從阻塞態到運行態,打印計數。

③ 軟定時器:每隔1s,時間到達,調用回調函數,打印計數。

④ 信號量:每隔5ms,系統時鐘節拍中斷調用函數,超過500次后,釋放信號量。信號量任務獲的信號量,從阻塞態到運行態,打印計數。

33843bd8361044e79919a58d36fdc4f0~tplv-tt-origin-web:gif.jpeg?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1750406773&x-signature=bnnvbawRXcHwr2ClIoJaxzxyoy4%3D

2、FreeRTOS-外設

飛凌嵌入式OK-MX9352-C開發板支持外設使用FreeRTOS完成相應功能,示例代碼如下:

  • freertos_uart:freertos串口演示例程
  • freertos_lpi2c_b2b:freertos I2C演示例程
  • freertos_lpspi_b2b:freertos SPI演示例程

因freertos_uart例程使用的FreeRTOS特性比較典型,我們重點分析此例程。

(1)軟件實現

示例程序內容包括:串口初始化任務、串口發送任務、串口接收任務。具體如下:

串口初始化任務:

主要包含串口外設初始化,發送、接收互斥量,發送和接收事件組。串口外設初始化在裸跑串口例程中已展現,此處不再詳述。

// 創建串口發送互斥量 handle->txSemaphore = xSemaphoreCreateMutex(); // 創建串口接收互斥量 handle->rxSemaphore = xSemaphoreCreateMutex(); // 創建發送事件標志組 handle->txEvent = xEventGroupCreate(); // 創建接收事件標志組 handle->rxEvent = xEventGroupCreate();

串口發送:

發送前獲取信號量,啟動發送流程,在中斷中置位發送完成事件標志。發送任務獲取到事件后,釋放發送信號量。

// 1 獲取發送信號量 if (pdFALSE == xSemaphoreTake(handle->txSemaphore, 0)) { return kStatus_Fail; } handle->txTransfer.data = (uint8_t *)buffer; handle->txTransfer.dataSize = (uint32_t)length; // 2 阻塞式發送 status = UART_TransferSendNonBlocking(handle->base, handle->t_state, &handle->txTransfer); if (status != kStatus_Success) { (void)xSemaphoreGive(handle->txSemaphore); return kStatus_Fail; } // 3 等待發送完成的事件 ev = xEventGroupWaitBits(handle->txEvent, RTOS_UART_COMPLETE, pdTRUE, pdFALSE, portMAX_DELAY);// 等待并判斷多個事件位 if ((ev & RTOS_UART_COMPLETE) == 0U) { retval = kStatus_Fail; } // 4 發送完成,釋放發送信號量 if (pdFALSE == xSemaphoreGive(handle->txSemaphore)) // 釋放信號量 { retval = kStatus_Fail; }

串口接收:

接收前獲取信號量,調用串口接收函數,在中斷中置位獲取事件標志。接收任務獲取到事件后,釋放接收信號量。

// 1獲取接收信號量 if (pdFALSE == xSemaphoreTake(handle->rxSemaphore, portMAX_DELAY)) { return kStatus_Fail; } handle->rxTransfer.data = buffer; handle->rxTransfer.dataSize = (uint32_t)length; // 2 串口接收函數 status = UART_TransferReceiveNonBlocking(handle->base, handle->t_state, &handle->rxTransfer, &n); if (status != kStatus_Success) { (void)xSemaphoreGive(handle->rxSemaphore); return kStatus_Fail; } // 3 獲取接收事件 ev = xEventGroupWaitBits(handle->rxEvent,RTOS_UART_COMPLETE | RTOS_UART_RING_BUFFER_OVERRUN | RTOS_UART_HARDWARE_BUFFER_OVERRUN, pdTRUE, pdFALSE, portMAX_DELAY); // 等待并判斷接收完成事件位 // 3.1 硬件接收錯誤 if ((ev & RTOS_UART_HARDWARE_BUFFER_OVERRUN) != 0U) { UART_TransferAbortReceive(handle->base, handle->t_state); (void)xEventGroupClearBits(handle->rxEvent, RTOS_UART_COMPLETE); // 將接收完成的事件位清零, retval = kStatus_UART_RxHardwareOverrun; local_received = 0; } // 3.2 接收緩沖區過載錯誤 else if ((ev & RTOS_UART_RING_BUFFER_OVERRUN) != 0U) { UART_TransferAbortReceive(handle->base, handle->t_state); (void)xEventGroupClearBits(handle->rxEvent, RTOS_UART_COMPLETE); // 將接收完成的事件位清零, retval = kStatus_UART_RxRingBufferOverrun; local_received = 0; } // 3.3 接收完成 else if ((ev & RTOS_UART_COMPLETE) != 0U) { retval = kStatus_Success; local_received = length; } else { retval = kStatus_UART_Error; local_received = 0; } // 4 釋放接收信號量 if (pdFALSE == xSemaphoreGive(handle->rxSemaphore)) { retval = kStatus_Fail; }

(2)實驗現象

① 編譯程序,在uboot手動加載M核程序。

② 裝置上電后,串口打印程序信息,此時通過鍵盤輸入4個字符,M核調試串口將回顯,重復輸入和回顯字符,證明程序運行成功。

4353b0d8f34c483480f70cc3b602e913~tplv-tt-origin-web:gif.jpeg?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1750406773&x-signature=DnmR9MNzFFyT684zNG2BqZrJdN8%3D


以上就是在飛凌嵌入式i.MX 9352開發板M核上軟件設計FreeRTOS的例程演示,希望能夠對各位工程師朋友有所幫助。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • ARM
    ARM
    +關注

    關注

    134

    文章

    9321

    瀏覽量

    375385
  • 嵌入式
    +關注

    關注

    5142

    文章

    19561

    瀏覽量

    315399
  • NXP
    NXP
    +關注

    關注

    61

    文章

    1336

    瀏覽量

    187632
  • FreeRTOS
    +關注

    關注

    12

    文章

    492

    瀏覽量

    63825
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    i.MX9352開發板試用】+機械臂游戲3—游戲源代碼(開源)原創首發

    i.MX9352開發板試用】+機械臂游戲 3游戲操縱桿控制四自由度機械臂(開源)原創首發 -
    的頭像 發表于 07-26 11:28 ?1332次閱讀

    5分鐘學會網絡服務搭建,i.MX9352 + Linux 6.1實戰示例

    本文將以嵌入式OK-MX9352-C開發板(搭載了在工業物聯網領域廣泛應用的NXP i.MX9352
    的頭像 發表于 05-30 11:08 ?1499次閱讀
    5分鐘學會網絡服務搭建,<b class='flag-5'>飛</b><b class='flag-5'>凌</b><b class='flag-5'>i.MX9352</b> + Linux 6.1實戰示例

    嵌入式率先推出NXP i.MX6UL開發板

    6UltraLite處理器的OKMX6UL開發板,并于3月8日正式發布!嵌入式i.MX6UL核心
    發表于 03-12 15:11

    嵌入式 NXP i.MX6UL開發板

    嵌入式 NXP i.MX6UL開發板試用報告發布在哪里呢?
    發表于 01-15 15:10

    全球首發搭載i.MX 9352處理器的核心

    嵌入式正式全球首發搭載i.MX 9352處理器的FET-MX9352-C核心!?A
    發表于 12-28 10:27

    i.MX9352開發板試用】+ 開箱報告

    很幸運的這次成為了i.MX9352開發板的試用者,今天收到快遞開始拆箱,做個簡單的點評吧。 拆開后還是很驚艷的,板子設計的很精良,而且從元器件上也能看得出
    發表于 06-05 16:41

    i.MX 9352新品開發板強勢來襲:高效安全的智能化升級,就用它!

    為了讓更多設備實現高能效、高安全性和智能化升級,恩智浦推出了全新的 i.MX 93x系列處理器 。恩智浦金牌合作伙伴之一,嵌入式技術有限公司在i
    的頭像 發表于 02-02 10:40 ?1243次閱讀

    【精選直播】嵌入式:NXP i.MX 9352處理器的I3C接口詳解

    直播簡介 為了讓更多設備實現高能效、高安全性和智能化升級,NXP推出了全新的i.MX 93x系列處理器。作為NXP的重要合作伙伴,嵌入式i.M
    的頭像 發表于 05-16 09:35 ?1516次閱讀

    首發!嵌入式i.MX9系列核心重磅發布

    嵌入式正式全球首發搭載i.MX 9352處理器的FET-MX9352-C核心
    的頭像 發表于 12-28 14:37 ?1463次閱讀
    首發!<b class='flag-5'>飛</b><b class='flag-5'>凌</b><b class='flag-5'>嵌入式</b><b class='flag-5'>i.MX</b>9系列核心<b class='flag-5'>板</b>重磅發布

    嵌入式技術帖——i.MX9352的GPIO怎么用?

    讓我們一起走近i.MX9352處理器,深入了解這位i.MX系列新成員的GPIO該如何操作,以及它與前輩i.MX6ULL處理器又有哪些異同。
    的頭像 發表于 05-16 15:07 ?1356次閱讀
    <b class='flag-5'>飛</b><b class='flag-5'>凌</b><b class='flag-5'>嵌入式</b>技術帖——<b class='flag-5'>i.MX9352</b>的GPIO怎么用?

    嵌入式i.MX9352開發板,讓通信安全又穩定

    嵌入式OK-MX9352-C開發板特意增加了接口防護電路設計,除了作為設計參考之外,還可以保障使用過程中的安全和穩定。
    的頭像 發表于 08-11 14:09 ?907次閱讀
    <b class='flag-5'>飛</b><b class='flag-5'>凌</b><b class='flag-5'>嵌入式</b><b class='flag-5'>i.MX9352</b><b class='flag-5'>開發板</b>,讓通信安全又穩定

    OK-MX9352-C開發板 產品資料發布記錄-20230206

    嵌入式OK-MX9352-C開發板產品資料發布記錄-(20230206版)后續會有版本更新,請持續關注。
    發表于 02-13 09:04 ?9次下載

    3.1s啟動!嵌入式i.MX93開發板部署LVGL,打造更高效的GUI

    近期,嵌入式為基于NXP i.MX93系列處理器打造的OK-MX9352-C開發板成功移植了
    的頭像 發表于 01-16 11:52 ?640次閱讀
    3.1s啟動!<b class='flag-5'>飛</b><b class='flag-5'>凌</b><b class='flag-5'>嵌入式</b><b class='flag-5'>i.MX</b>93<b class='flag-5'>開發板</b>部署LVGL,打造更高效的GUI

    「2025恩智浦創新技術峰會」嵌入式亮相上海首站

    ,展示其在低成本人工智能、工業物聯網等領域的創新成果。此次峰會,嵌入式帶來了基于恩智浦i.MX95xx、i.MX9352
    的頭像 發表于 05-15 13:38 ?541次閱讀
    「2025恩智浦創新技術峰會」<b class='flag-5'>飛</b><b class='flag-5'>凌</b><b class='flag-5'>嵌入式</b>亮相上海首站

    5分鐘學會網絡服務搭建!i.MX9352開發板 + Linux 6.1實戰示例

    本文就將以嵌入式OK-MX9352-C開發板(搭載了在工業物聯網領域廣泛應用的NXP i.MX935
    的頭像 發表于 06-13 16:42 ?201次閱讀
    5分鐘學會網絡服務搭建!<b class='flag-5'>飛</b><b class='flag-5'>凌</b><b class='flag-5'>i.MX9352</b><b class='flag-5'>開發板</b> + Linux 6.1實戰示例