STM32 CubeMX (第三步Freertos中断管理和软件定时)

STM32 CubeMX


STM32 CubeMX (第三步Freertos中断管理和软件定时)


学习使用Freertos第三步
在 FreeRTOS 中,中断管理和软件定时:

  1. ·taskENTER_CRITICAL()·; 是一个函数在 FreeRTOS 中使用的,用于进入临界区(critical section)。在临界区内,中断会被禁用,这样可以确保在多任务环境下共享资源的安全性。你可以在需要保护共享资源的代码段中使用
  2. · taskENTER_CRITICAL()·; 来禁用中断,然后在临界区结束时使用 taskEXIT_CRITICAL();
    来重新启用中断。这样可以防止多个任务同时访问共享资源而导致的竞态条件。

一、STM32 CubeMX设置

时钟配置

HAL时基选择TIM1(不要选择滴答定时器;滴答定时器留给OS系统做时基)

使用STM32 CubeMX 库,配置Freertos

选择CMISS_V1接口就可以满足Freertos接口;且代码量比CMISS_V2小(CMISS_V2支持更多的RTOS接口,所以代码量比CMISS_V1多)

使能定时器,计时1s中断

配置定时器中断优先级

优先级(0~4)不归freertos管理

二、实验一,中断管理

  1. taskENTER_CRITICAL(); 是一个函数在 FreeRTOS 中使用的,用于进入临界区(critical section)。在临界区内,中断会被禁用,这样可以确保在多任务环境下共享资源的安全性。你可以在需要保护共享资源的代码段中使用
  2. taskENTER_CRITICAL(); 来禁用中断,然后在临界区结束时使用 taskEXIT_CRITICAL();
    来重新启用中断。这样可以防止多个任务同时访问共享资源而导致的竞态条件。
c 复制代码
HAL_TIM_Base_Start_IT(&htim2);//使能
HAL_TIM_Base_Start_IT(&htim3);//使能
void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{
  /* USER CODE BEGIN Callback 0 */

  /* USER CODE END Callback 0 */
  if (htim->Instance == TIM1) {
    HAL_IncTick();
  }
  /* USER CODE BEGIN Callback 1 */
  if (htim->Instance == TIM2) {
    printf("htim2\r\n");		// printf输出字符串
  }
	
   if (htim->Instance == TIM3) {
    printf("htim3\r\n");		// printf输出字符串
  }
  /* USER CODE END Callback 1 */
}

任务代码

c 复制代码
void sendTask1(void const * argument)
{
  /* USER CODE BEGIN sendTask1 */
	BaseType_t xsatus;
	uint32_t buff=9600;
  /* Infinite loop */
  for(;;)
  {
		
  		   HAL_Delay(5000);
		    printf("关闭中断\r\n");		// printf输出字符串
	 	    taskENTER_CRITICAL();//进入临界区,被管理的中断会被禁用
	    	  HAL_Delay(5000);
        printf("打开中断\r\n");		// printf输出字符串
		    taskEXIT_CRITICAL();//退出临界区
  }
  /* USER CODE END sendTask1 */
}

实验现象

三,实验二:软件定时器

初始化配置


初始化代码

c 复制代码
  /* definition and creation of myTimer01 */
  osTimerDef(myTimer01, Callback01);
  myTimer01Handle = osTimerCreate(osTimer(myTimer01), osTimerPeriodic, NULL);

  /* definition and creation of myTimer02 */
  osTimerDef(myTimer02, Callback02);
  myTimer02Handle = osTimerCreate(osTimer(myTimer02), osTimerPeriodic, NULL);
  xTimerChangePeriod(myTimer01Handle,1000,100);
	xTimerChangePeriod(myTimer02Handle,1500,100);

任务代码

c 复制代码
void sendTask1(void const * argument)
{
  /* USER CODE BEGIN sendTask1 */
	BaseType_t xsatus;
	uint32_t buff=9600;
  /* Infinite loop */
  for(;;)
  {
		
 
				xTimerStart(myTimer01Handle,portMAX_DELAY);
				xTimerStart(myTimer02Handle,portMAX_DELAY);
				printf("打开中断\r\n");		// printf输出字符串
		    osDelay(10000);
				xTimerStop(myTimer01Handle,portMAX_DELAY);
				xTimerStop(myTimer02Handle,portMAX_DELAY);
				printf("关闭中断\r\n");		// printf输出字符串
				osDelay(5000);
 
  }
  /* USER CODE END sendTask1 */
}

实验现象

相关推荐
LCG元1 小时前
STM32MP1边缘网关:Linux系统下Modbus转MQTT协议转换实战
linux·stm32·嵌入式硬件
Max_uuc4 小时前
【硬件心法】打破软硬边界:从原理图剖析探秘“微安级”精密电流采样的底层架构
单片机·嵌入式硬件
2501_918126916 小时前
stm32核心板是什么属性?
linux·c语言·stm32·嵌入式硬件·个人开发
古译汉书7 小时前
RTOS:ISR与互斥量的关系
运维·服务器·stm32·嵌入式硬件
国科安芯13 小时前
实战验证:ASM1042S2S CANFD收发器的质子单粒子效应试验与在轨性能
网络·人工智能·单片机·嵌入式硬件·物联网·fpga开发
Zevalin爱灰灰13 小时前
基于STM32实现OTA&BootLoader 第二章——外设功能开发
stm32·单片机·物联网·嵌入式
2501_9181269113 小时前
stm32能刷什么程序?
linux·stm32·单片机·嵌入式硬件·学习
国科安芯13 小时前
ASP4644S电源芯片引脚功能与参考设计输出电压计算方法
网络·单片机·嵌入式硬件·fpga开发·性能优化
国科安芯14 小时前
抗辐照MCU芯片在核工业水下探测耐辐照数字摄像机中的应用研究
网络·单片机·嵌入式硬件
VALENIAN瓦伦尼安教学设备14 小时前
品牌故事:1964年塞纳河畔ASHOOTER激光对中仪诞生的夜晚
数据库·人工智能·嵌入式硬件