目錄
- AIR32F103(一) 合宙AIR32F103CBT6開發板上手報告
- AIR32F103(二) Linux環境和LibOpenCM3專案模板
- AIR32F103(三) Linux環境基于標準外設庫的專案模板
- AIR32F103(四) 27倍頻216MHz,CoreMark跑分測驗
- AIR32F103(五) FreeRTOSv202112核心庫的集成和示例代碼
關于
先貼一下已經集成好的專案地址, 如果對如何集成不感興趣, 想直接使用的, 可以跳過這部分, 直接看使用部分
- GitHub https://github.com/IOsetting/air32f103-template/tree/master/Examples/FreeRTOS
- Gitee https://gitee.com/iosetting/air32f103-template/tree/master/Examples/FreeRTOS
AIR32F103CBT6的存盤是128K Flash + 32K RAM, CCT6是256K Flash + 64K RAM, 大容量加上206MHz的作業頻率, 跑FreeRTOS是非常合適的. 關于FreeRTOS的介紹和集成, 網路上已經有不少文章, 可以直接百度搜索查看, 這里主要介紹一下專案中的FreeRTOS集成步驟和代碼說明.
集成步驟
添加 FreeRTOS 核心庫檔案
參考之前的文章 STM32F10x SPL 集成 FreeRTOS, 因為 AIR32F103 和 STM32 基本上是兼容的, 低位的中斷定義一樣, 直接套用就可以.
從 https://www.freertos.org/下載 FreeRTOS 202112.00 , 解開后到 FreeRTOS/Source 目錄下, 復制以下的檔案到專案目錄下
- FreeRTOS/Source/include 整個目錄, 這些是頭檔案
- FreeRTOS/Source 下的所有C檔案
- FreeRTOS/Source/portable/GCC/ARM_CM3 目錄, 這是針對 STM32F103 的適配檔案
- FreeRTOS/Source/portable/MemMang 目錄, 里面包含一些現成的記憶體管理實作
只需要保留這些檔案
FreeRTOS
├── include
│ ├── atomic.h
│ ├── croutine.h
│ ├── deprecated_definitions.h
│ ├── event_groups.h
│ ├── FreeRTOS.h
│ ├── list.h
│ ├── message_buffer.h
│ ├── mpu_prototypes.h
│ ├── mpu_wrappers.h
│ ├── portable.h
│ ├── projdefs.h
│ ├── queue.h
│ ├── semphr.h
│ ├── stack_macros.h
│ ├── StackMacros.h
│ ├── stdint.readme
│ ├── stream_buffer.h
│ ├── task.h
│ └── timers.h
├── portable
│ ├── GCC
│ │ └── ARM_CM3
│ │ ├── port.c
│ │ └── portmacro.h
│ └── MemMang
│ ├── heap_1.c
│ ├── heap_2.c
│ ├── heap_3.c
│ ├── heap_4.c
│ └── heap_5.c
├── croutine.c
├── event_groups.c
├── list.c
├── queue.c
├── stream_buffer.c
├── tasks.c
└── timers.c
然后準備 FreeRTOSConfig.h
編輯 FreeRTOSConfig.h
下面是一個完整的例子, 說明寫到了注釋里, 可以刪掉
#ifndef FREERTOS_CONFIG_H
#define FREERTOS_CONFIG_H
// [重要]開啟搶占模式, 大部分組件會默認FreeRTOS是開啟搶占模式的, 否則不能保障其實時性
#define configUSE_PREEMPTION 1
/* 不使用 idle task hook. RTOS的調度器在啟動時會自動創建一個idle task, 這樣保證在沒有任務執行時也會運行一個任務, 這個任務會運行在最低的優先級. An idle task hook is a function that is called during each cycle of the idle task. 如果自定義了 idle task 方法, 就將其設為1.
*/
#define configUSE_IDLE_HOOK 0
// 不使用 tick hook. 和 idle task hook 一樣, 就是tick中斷時可以定義一個callback方法.
#define configUSE_TICK_HOOK 0
// [重要]定義主頻, 別定義錯, 會導致延時和定時器計算有偏差, 如果設定了216MHz或者256MHz, 這里需要修改
#define configCPU_CLOCK_HZ ( ( unsigned long ) 72000000 )
// [重要]定義Tick的頻率(每秒多少個tick), 和主頻和SysTick的定義要結合看, 一般用1毫秒, 或者1/10毫秒
#define configTICK_RATE_HZ ( ( TickType_t ) 1000 )
// [重要]task中可以用的優先級個數
#define configMAX_PRIORITIES ( 5 )
// [重要]任務的最小堆疊尺寸, 如果stack是32位, 就是4byte, 128就是128*4=512 byte
#define configMINIMAL_STACK_SIZE ( ( unsigned short ) 128 )
// [重要]堆的尺寸, 根據自己的MCU RAM容量調整
#define configTOTAL_HEAP_SIZE ( ( size_t ) ( 17 * 1024 ) )
// 任務名長度限制
#define configMAX_TASK_NAME_LEN ( 16 )
// 用于需要包含額外的變數和函式結構用于協助跟蹤和可視化, 不使用就設為0
#define configUSE_TRACE_FACILITY 0
// Tick使用16位計數值, 針對8位和16位的核使用的. 對M0 M3這種32位的不需要
#define configUSE_16_BIT_TICKS 0
// 開啟低功耗的空閑模式, 0則永遠打開tick中斷. 這個配置要和 configUSE_TICKLESS_IDLE 結合看
#define configIDLE_SHOULD_YIELD 1
// 用于設定是否允許低優先級任務使用taskENTER_CRITICAL(), 設為0可以提高安全性, 不定義會報warning
#define configALLOW_UNPRIVILEGED_CRITICAL_SECTIONS 0
// 協程基本用不上, 按默認即可
/* Co-routine definitions. */
#define configUSE_CO_ROUTINES 0
#define configMAX_CO_ROUTINE_PRIORITIES ( 2 )
/* Set the following definitions to 1 to include the API function, or zero
to exclude the API function. */
// 這些是屬于功能裁剪的部分, 如果你使用了某些功能, 就要加上, 沒用到的可以設為0或者不定義
#define INCLUDE_vTaskPrioritySet 1
#define INCLUDE_uxTaskPriorityGet 1
#define INCLUDE_vTaskDelete 1
#define INCLUDE_vTaskCleanUpResources 0
#define INCLUDE_vTaskSuspend 1
#define INCLUDE_vTaskDelayUntil 1
#define INCLUDE_vTaskDelay 1
/*
對于Cortex-M3核最低的中斷優先級
This is the raw value as per the Cortex-M3 NVIC. Values can be 255
(lowest) to 0 (1?) (highest). */
#define configKERNEL_INTERRUPT_PRIORITY 255
/*
在新的移植中, configMAX_SYSCALL_INTERRUPT_PRIORITY改名為configMAX_API_CALL_INTERRUPT_PRIORITY, 這兩個是等價的. 這個值代表了最高的, 可以安全呼叫 FreeRTOS API 的中斷優先級. 如果一個中斷的優先級比這個高, 那么 FreeRTOS 是無法屏蔽這個中斷的, 哪怕在 critical section 內部, 也會被這個中斷打斷.
!!!! configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to zero !!!!
See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html. */
#define configMAX_SYSCALL_INTERRUPT_PRIORITY 191 /* equivalent to 0xb0, or priority 11. */
/*
將 FreeRTOS 中的關鍵中斷處理函式設定為宏, 避免修改startup檔案
Use MACRO to replace the handlers without changing startup file */
#define vPortSVCHandler SVC_Handler
#define xPortPendSVHandler PendSV_Handler
#define xPortSysTickHandler SysTick_Handler
在專案中使用 FreeRTOS
開啟 FreeRTOS 支持
在專案中啟用 FreeRTOS 支持, 只需要編輯 Makefile, 將 USE_FREERTOS ?= n 配置修改為 USE_FREERTOS ?= y
# Build with FreeRTOS, y:yes, n:no
USE_FREERTOS ?= y
默認使用的記憶體管理方式是heap_4.c, 如果希望換成其它的記憶體管理方式, 可以修改這一行
CFILES += Libraries/FreeRTOS/portable/MemMang/heap_4.c
執行示例代碼
專案中已經針對AIR32F103準備了一些FreeRTOS的代碼示例, 根據FreeRTOS的功能, 分別提供了以下示例的集合
├── Mem
│ └── Malloc_And_Free # 記憶體申請和釋放
├── Queue
│ ├── Queue_And_Notification # 佇列和定時器中斷觸發的通知
│ ├── Queue_And_Notification_DMA # 和上面一樣, 但是換成了DMA中斷
│ └── Queue_Send_And_Receive # 佇列的接收和發送
├── Semaphore
│ ├── Binary_Semaphore # 單值信號量
│ ├── Counting_Semaphore # 計數信號量
│ └── Mutex # 鎖
├── Tasks
│ ├── Blink # 多任務閃燈
│ ├── Blink_Controlled_By_UART # 用一個任務讀取UART控制另一個任務的閃燈頻率
│ ├── DelayUntil # 帶提前量的延遲
│ └── Task_Notification # 任務間的等待和通知
└── Timers
└── TimerCallback # 軟體定時器
修改 Makefile 啟用 FreeRTOS 支持后, 可以將示例代碼復制到 User 目錄下編譯燒錄.
針對合宙AIR32F103CBT6開發板的閃燈示例代碼位于 Examples/FreeRTOS/Tasks/Blink 目錄, 這個示例會創建三個任務, 按不同的周期控制板載的三個LED的亮滅. 編譯和燒錄的步驟參考 AIR32F103(三) Linux環境基于標準外設庫的專案模板
更多閱讀
- Mastering the FreeRTOS Real Time Kernel 電子書 https://www.freertos.org/fr-content-src/uploads/2018/07/161204_Mastering_the_FreeRTOS_Real_Time_Kernel-A_Hands-On_Tutorial_Guide.pdf
- FreeRTOSConfig.h 引數說明 https://www.freertos.org/a00110.html
- 寫得比較詳細的 FreeRTOS 介紹 https://blog.csdn.net/qq_61672347/article/details/125748646
轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/531780.html
標籤:嵌入式
上一篇:UBOOT編譯--- include/config.h、 include/autoconf.mk、include/autoconf.mk.dep、u-boot.cfg(三)
