STM32CubeMX的FreeRTOS使用配置


前言

使用STM32CubeMX去使用FreeRTOS比较适合想快速上手FreeRTOS,免去了较繁杂的基础工程的创建和FreeRTOS的移植,同时FreeRTOS又具有较高的裁剪性,在CubeMX中可以轻松改变配置。另外在使用上面,只需要编写应用层,底层和驱动层都是自动生产且配置好的

配置基础工程的注意事项

SYS一栏中的Timebase Source配置选项,默认为SysTick,需要改成其他的时基源例如TIM1
因为在OS中需要一个时基来维护运行,一般都是通过SysTick来维护的。而在HAL库中也需要为各种 timeout 的时基,默认也是SysTick。当OS和HAL库同时使用SysTick来作时基时,潜在一定风险,所以建议给HAL库换一个时基。

在这里插入图片描述

OS基础配置

Middleware一栏中的FREERTOSInterface选择CMSIS_V1

CMSIS_V1使得软件能够在不同的实时操作系统下运行(屏蔽不同RTOS提供的API的差别),而CMSIS_V2则是拓展了CMSIS_V1,兼容更多的CPU架构和实时操作系统。
因此我们在使用时可以根据实际情况选择,如果学习过程中使用STM32F1、F4等单片机时没必要选择CMSIS_V2,更高的兼容性背后时更加冗余的代码,理解起来比较困难。

Configuration中有很多选项卡
在这里插入图片描述

Config parameter(配置): 进行具体参数配置

Kernel settings:内核设置

USE_PREEMPTION(使用抢占式):设置为1表示使用 抢占式 RTOS调度器,设置为0表示使用 协作式 RTOS调度器。
CPU_CLOCK_HZ:这必须设置为驱动用于生成内核周期性滴答中断的外设的时钟频率(SysTick)。这通常(但不总是)等于主系统时钟频率。
TICK_RATE_HZ:设置时钟中断频率,必须设定在1~1000之内,单位Hz
MAX_PRIORITIES:设置可分配给任务的最大优先级,可以从0(最低)到MAX_PRIORITIES-1(最高),必须设定在4~32之间
MINIMAL_STACK_SIZE:设置空闲任务的最小任务堆栈大小,以字为单位,而不是字节。如该值设置为128 Words,那么真正的堆栈大小就是 128*4 = 512 Byte,必须设定在64Words~768Words之间
MAX_TASK_NAME_LEN: 设置任务名最大长度,必须在12~255之间
USE_16_BIT_TICKS:设置Ticks的数据类型,设置为1表示使用无符型16位的类型,设置为0表示使用无符型32位的类型,因为STM32为32为所以强制设置为0
IDLE_SHOULD_YIELD: 设置为1时空闲任务放弃CPU使用权给其他同优先级的用户任务,这确保了当应用程序任务可以运行时,在空闲任务上花费的时间最少。 设置为0时空闲任务的CPU使用权永远不会被另一个任务占用,只有在被抢占后才会离开运行状态
USE_MUTEXES:设置为1时使用互斥信号量
USE_RECURSIVE_MUTEXES:设置为1时使用递归互斥信号量
USE_COUNTING_SEMAPHORES:设置为1时启用计数型信号量
QUEUE_REGISTRY_SIZE:设置可以注册的队列和信号量的最大数量,在使用内核调试器查看信号量和队列的时候需要设置此宏,而且要先将消息队列和信号量进行注册,只有注册了的队列和信号量才会在内核调试器中看到,如果不使用内核调试器的话次宏设置为0即可。必须在0~255之间
USE_APPLICATION_TASK_TAG:为1才能使用vTaskSetApplicationTaskTag函数,此功能仅供高级用户使用,可以为每个任务分配一个“标签”值
ENABLE_BACKWARD_COMPATIBILITY: 为1时可以使V8.0.0之前的FreeRTOS用户代码直接升级到V8.0.0之后,而不需要做任何修改
USE_PORT_OPTIMISED_TASK_SELECTION: FreeRTOS有两种方法来选择下一个要运行的任务,一个是通用的方法,另外一个是特殊的方法,也就是硬件方法,使用MCU自带的硬件指令来实现。STM32有计算前导零指令吗,所以这里强制置1
USE_TICKLESS_IDLE:为1使能低功耗tickless模式,为0保持系统节拍(tick)中断一直运行。假设开启低功耗的话可能会导致下载出现问题,因为程序在睡眠中
USE_TASK_NOTIFICATIONS:为1时使用任务通知功能。开启了此功能,每个任务会多消耗8个字节。RTOS任务通知是直接发送给任务的事件,可以解除接收任务的阻塞,并可选地更新接收任务的通知值
RECORD_STACK_HIGH_ADDRESS:为1时栈开始地址会被保存到每个任务的TCB中(假设栈是向下生长的)

Memory management settings:内存管理设置

Memory Allocation: 设置为 Dynamic/Static 支持动态/静态内存申请
TOTAL_HEAP_SIZE: 设置堆大小,如果使用了动态内存管理,FreeRTOS在创建 task, queue, mutex, software timer or semaphore的时候就会使用heap_x.c(x为1~5)中的内存申请函数来申请内存。这些内存就是从堆ucHeap[configTOTAL_HEAP_SIZE]中申请的。用户选择的值应该考虑到应用程序对RAM的消耗,否则会导致链接问题,最小值 = configMINIMAL_STACK_SIZE*4
Memory Management scheme:内存管理策略

Hook function related definitions:钩子函数相关定义

USE_IDLE_HOOK: 置1:使用空闲钩子(Idle Hook类似于回调函数);置0:忽略空闲钩子。
USE_TICK_HOOK: 置1:使用时间片钩子(Tick Hook);置0:忽略时间片钩子。
USE_MALLOC_FAILED_HOOK: 使用内存申请失败钩子函数。
USE_DAEMON_TASK_STARTUP_HOOK:如果USE_TIMERS和USE_DAEMON_TASK_STARTUP_HOOK都被设置为1 (Enabled),那么应用程序必须定义一个钩子函数:void vApplicationDaemon TaskStartupHook(void)。注意:当设置为1时,在freertos.c文件中生成一个空函数(由用户完成)。当USE_TIMERS等于0(禁用)时,强制为0(禁用)。
CHECK_FOR_STACK_OVERFLOW: 大于0时启用堆栈溢出检测功能,如果使用此功能用户必须提供一个栈溢出钩子函数,如果使用的话此值可以为1或者2,因为有两种栈溢出检测方法。

Run time and task stats gathering related definitions:收集相关定义的运行时和任务统计信息

GENERATE_RUN_TIME_STATS: 启用运行时间统计功能。
USE_TRACE_FACILITY: 启用可视化跟踪调试。
USE_STATS_FORMATTING_FUNCTIONS: 与宏configUSE_TRACE_FACILITY同时为1时会编译下面3个函数prvWriteNameToBuffer()、vTaskList()、vTaskGetRunTimeStats()。

Co-routine related definitions:协程相关定义

USE_CO_ROUTINES: 启用协程。
MAX_CO_ROUTINE_PRIORITIES: 协程的有效优先级数目。必须在1~255之间

Software timer definitions:软件定时器相关定义

USE_TIMERS: 启用软件定时器。

Interrupt nesting behaviour configuration:中断嵌套行为配置

LIBRARY_LOWEST_INTERRUPT_PRIORITY: 中断最低优先级。必须在1~15之间
LIBRARY_LOWEST_INTERRUPT_PRIORITY: 系统可管理的最高中断优先级。必须在1~15之间

Include parameters(包含):对包含的定义进行配置

这部分都为FreeRTOS中可裁剪的函数

Include definitions:包含的宏定义

vTaskPrioritySet:为1允许使用vTaskPrioritySet()这个函数,用来动态地更改任务的优先级
uxTaskPriorityGet:为1允许使用uxTaskPriorityGet()这个函数,用于获取任务当前优先级的函数
vTaskDelete:为1允许使用vTaskDelete()这个函数,用于删除任务的函数
vTaskCleanUpResources:为1允许使用vTaskCleanUpResources()这个函数,用于清理任务资源
vTaskSuspend:为1允许使用vTaskSuspend()这个函数,用于挂起(暂停)特定任务的函数
vTaskDelayUntil:为1允许使用vTaskDelayUntil()这个函数,用于绝对延时任务
vTaskDelay:为1允许使用vTaskDelay()这个函数,用于相对延时任务
xTaskGetSchedulerState:为1允许使用xTaskGetSchedulerState()这个函数,用于获取调度器状态的函数,强制为1
xTaskResumeFromISR:为1允许使用xTaskResumeFromISR()这个函数,用于将任务从ISR中恢复
xQueueGetMutexHolder:为1允许使用xQueueGetMutexHolder()这个函数,用于获取互斥量持有者的函数
xSemaphoreGetMutexHolder:为1允许使用xSemaphoreGetMutexHolder()这个函数,和xQueueGetMutexHolder一样
pcTaskGetTaskName:为1允许使用pcTaskGetTaskName()这个函数,用于获取当前任务的名称
uxTaskGetStackHighWaterMark:为1允许使用uxTaskGetStackHighWaterMark()这个函数,用于获取任务堆栈的最高空闲水位(即剩余堆栈空间的峰值)
xTaskGetCurrentTaskHandle:为1允许使用xTaskGetCurrentTaskHandle()这个函数,用于获取当前任务的句柄
eTaskGetState:为1允许使用eTaskGetState()这个函数,用于获取当前任务的状态
xEventGroupSetBitFromISR:为1允许使用xEventGroupSetBitFromISR()这个函数,用于在中断服务例程中设置事件组位的函数
xTimerPendFunctionCall:为1允许使用xTimerPendFunctionCall()这个函数
xTaskAbortDelay:为1允许使用xTaskAbortDelay()这个函数,用于中止任务延迟阻塞的函数
xTaskGetHandle:为1允许使用xTaskGetHandle()这个函数,用于获取任务的句柄

  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: STM32CubeMX是ST公司提供的一款STM32微控制器的配置工具,可以帮助用户快速配置STM32的外设和中断。FreeRTOS是一个免费的嵌入式实时操作系统。 在STM32CubeMX使用FreeRTOS需要先在STM32CubeMX配置好外设并生成代码,然后将FreeRTOS的文件加入工程中,最后在生成的代码中添加FreeRTOS相关的代码即可。 教程步骤: 1. 下载并安装STM32CubeMX 2. 下载FreeRTOS源代码 3. 在STM32CubeMX配置好外设并生成代码 4. 将FreeRTOS的文件加入工程中 5. 在STM32CubeMX生成的代码中添加FreeRTOS相关的代码 6. 编译并下载程序到STM32微控制器中 具体的实现方法可以参考ST官方提供的教程或者网上的相关资料。 ### 回答2: STM32CubeMXSTMicroelectronics公司开发的一个可视化的嵌入式软件配置工具。它支持多种STM32系列微控制器,可以方便地进行Pinout、时钟、电源、GPIO、外设配置,并生成代码框架。这些框架可以方便地集成在任意IDE中,如IAR、KEIL和Atollic TrueSTUDIO等,以便进行开发和调试。 FreeRTOS是一款基于MIT许可证的实时操作系统(RTOS)。它是免费、开源的,具有许多实用的功能,如任务管理、调度、同步、信号量、消息队列等。FreeRTOS支持多种微控制器,如ARM Cortex-M系列、MSP430、PIC32等。 在STM32CubeMX中,可以方便地选择FreeRTOS作为操作系统,在初始化时生成FreeRTOS的代码框架。这些框架包含了FreeRTOS的全部功能,并且集成了STM32的底层驱动程序和HAL库。 生成的FreeRTOS代码框架中包含了三个任务(task):任务A、任务B和任务C。每个任务的优先级从高到低分别为1、2和3。在main函数中,首先进行HAL库的初始化,然后创建三个任务,并启动调度程序。 任务A和任务B分别使用vTaskDelay函数实现1s的间隔,任务C则不停地输出信息。在任务A和任务B等待的过程中,FreeRTOS会让出CPU资源,把执行权交给其他任务。 在代码框架中还包含了一个定时器(Timer)和一个队列(Queue)。这些功能可以在任务之间进行通信和同步。例如,在任务A中使用Queue发送消息,在任务B中使用Queue接收消息。在任务C中使用定时器来定时输出信息。 总之,STM32CubeMXFreeRTOS的结合提供了一种方便、快速、高效的嵌入式软件开发方式。它可以帮助开发人员更好地了解STM32微控制器和FreeRTOS操作系统的功能和特性,提高开发效率和代码质量。 ### 回答3: STM32CubeMXSTM32系列芯片的一款图形化配置工具,可以快速生成基于HAL库的项目代码。而FreeRTOS是一款实时操作系统,在嵌入式系统应用中得到广泛应用。本文主要围绕STM32CubeMXFreeRTOS的组合应用教程进行阐述。 在使用STM32CubeMX生成工程时,可以在中间的软件栏中勾选FreeRTOS。此时,代码将自动生成FreeRTOS的头文件和源文件以及部分配置文件。需要注意的是,FreeRTOS的版本也可以在中间的软件栏中进行选择。选择完成后,可以对FreeRTOS进行进一步的配置,包括任务数量、栈空间大小、时间片轮询优先级等。这些配置都可以在头文件中手动修改,但使用STM32CubeMX可以大大节省时间。 在生成工程后,需要在主函数中添加创建FreeRTOS任务的代码,这部分的代码可以在头文件中找到。上手难度较低,基本相当于“复制粘贴”。通过FreeRTOS,可以很方便地创建多个任务,并对它们进行优先级调度,达到开发设计需求。 需要注意的是,FreeRTOS使用需要一定的操作系统知识,例如任务调度、信号量等概念。建议在学习使用FreeRTOS前,先对操作系统有一定程度的了解。同时,FreeRTOS使用还需要注意堆栈空间、资源抢占等问题。如果不妥善处理这些问题,会导致系统死锁、运行错误等问题。 总之,使用STM32CubeMXFreeRTOS,可以大大提高嵌入式系统应用的开发效率,是一款非常实用的工具和操作系统。但是,在使用前需要了解一些必要的操作系统知识,并正确处理堆栈空间、资源抢占等问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值