每個(gè)任務(wù)都有一個(gè)32位的通知值,該值在創(chuàng)建任務(wù)時(shí)初始化為零。
配置相關(guān)資源
//為1時(shí)開啟任務(wù)通知
#define configUSE_TASK_NOTIFICATIONS 1
發(fā)送
BaseType_t xTaskNotifyGive( TaskHandle_t xTaskToNotify );
xTaskToNotify:被通知并使其通知值遞增的任務(wù)句柄
接收
uint32_t ulTaskNotifyTake( BaseType_t xClearCountOnExit, TickType_t xTicksToWait );
參數(shù):
xClearCountOnExit:是否需要清零
xTicksToWait:等待時(shí)間
實(shí)驗(yàn)程序
#include "stm32f10x.h"
#include
#include "FreeRTOS.h"
#include "task.h"
void KEY_Init(void)
{
GPIO_InitTypeDef GPIO_InitStructure; //定義結(jié)構(gòu)體變量
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOE,ENABLE);
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_0; //選擇你要設(shè)置的IO口
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IPD;//下拉輸入
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz; //設(shè)置傳輸速率
GPIO_Init(GPIOA,&GPIO_InitStructure); /* 初始化GPIO */
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_3|GPIO_Pin_2|GPIO_Pin_4;
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IPU; //上拉輸入
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_Init(GPIOE,&GPIO_InitStructure);
}
void USART_init(uint32_t bound)
{
GPIO_InitTypeDef GPIO_InitStruct; //定義GPIO結(jié)構(gòu)體變量
USART_InitTypeDef USART_InitStruct; //定義串口結(jié)構(gòu)體變量
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_USART1,ENABLE); //使能GPIOC的時(shí)鐘
GPIO_InitStruct.GPIO_Pin=GPIO_Pin_9; //配置TX引腳
GPIO_InitStruct.GPIO_Mode=GPIO_Mode_AF_PP; //配置PA9為復(fù)用推挽輸出
GPIO_InitStruct.GPIO_Speed=GPIO_Speed_50MHz; //配置PA9速率
GPIO_Init(GPIOA,&GPIO_InitStruct); //GPIO初始化函數(shù)
GPIO_InitStruct.GPIO_Pin=GPIO_Pin_10; //配置RX引腳
GPIO_InitStruct.GPIO_Mode=GPIO_Mode_IN_FLOATING; //配置PA10為浮空輸入
GPIO_InitStruct.GPIO_Speed=GPIO_Speed_50MHz; //配置PA10速率
GPIO_Init(GPIOA,&GPIO_InitStruct); //GPIO初始化函數(shù)
USART_InitStruct.USART_Mode=USART_Mode_Tx|USART_Mode_Rx; //發(fā)送接收模式
USART_InitStruct.USART_Parity=USART_Parity_No; //無奇偶校驗(yàn)
USART_InitStruct.USART_BaudRate=bound; //波特率
USART_InitStruct.USART_StopBits=USART_StopBits_1; //停止位1位
USART_InitStruct.USART_WordLength=USART_WordLength_8b; //字長8位
USART_InitStruct.USART_HardwareFlowControl=USART_HardwareFlowControl_None; //無硬件數(shù)據(jù)流控制
USART_Init(USART1,&USART_InitStruct); //串口初始化函數(shù)
USART_Cmd(USART1,ENABLE); //使能USART1
}
int fputc(int ch,FILE *f) //printf重定向函數(shù)
{
USART_SendData(USART1,(uint8_t)ch); //發(fā)送一字節(jié)數(shù)據(jù)
while(USART_GetFlagStatus(USART1,USART_FLAG_TXE) == RESET); //等待發(fā)送完成
return ch;
}
#define START_TASK_PRIO 1 //任務(wù)優(yōu)先級
#define START_STK_SIZE 128 //任務(wù)堆棧大小
TaskHandle_t StartTask_Handler; //任務(wù)句柄
void Start_Task(void *pvParameters);//任務(wù)函數(shù)
#define Send_TASK_PRIO 2 //任務(wù)優(yōu)先級
#define Send_STK_SIZE 50 //任務(wù)堆棧大小
TaskHandle_t SendTask_Handler; //任務(wù)句柄
void Send_Task(void *p_arg); //任務(wù)函數(shù)
#define Read_1_TASK_PRIO 3 //任務(wù)優(yōu)先級
#define Read_1_STK_SIZE 50 //任務(wù)堆棧大小
TaskHandle_t ReadTask_1_Handler; //任務(wù)句柄
void Read_1_Task(void *p_arg); //任務(wù)函數(shù)
#define Read_2_TASK_PRIO 3 //任務(wù)優(yōu)先級
#define Read_2_STK_SIZE 50 //任務(wù)堆棧大小
TaskHandle_t ReadTask_2_Handler; //任務(wù)句柄
void Read_2_Task(void *p_arg); //任務(wù)函數(shù)
int main( void )
{
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_4);//設(shè)置系統(tǒng)中斷優(yōu)先級分組 4
KEY_Init();
USART_init(9600);
//創(chuàng)建開始任務(wù)
xTaskCreate(
(TaskFunction_t )Start_Task, //任務(wù)函數(shù)
(const char* )"Start_Task", //任務(wù)名稱
(uint16_t )START_STK_SIZE, //任務(wù)堆棧大小
(void* )NULL, //傳遞給任務(wù)函數(shù)的參數(shù)
(UBaseType_t )START_TASK_PRIO, //任務(wù)優(yōu)先級
(TaskHandle_t* )&StartTask_Handler //任務(wù)句柄
);
vTaskStartScheduler(); //開啟調(diào)度
}
//開始任務(wù)函數(shù)
void Start_Task(void *pvParameters)
{
taskENTER_CRITICAL(); //進(jìn)入臨界區(qū)
//創(chuàng)建 Send_Task 任務(wù)
xTaskCreate(
(TaskFunction_t )Send_Task,
(const char* )"Send_Task",
(uint16_t )Send_STK_SIZE,
(void* )NULL,
(UBaseType_t )Send_TASK_PRIO,
(TaskHandle_t* )&SendTask_Handler
);
//創(chuàng)建 Read_1_Task 任務(wù)
xTaskCreate(
(TaskFunction_t )Read_1_Task,
(const char* )"Read_1_Task",
(uint16_t )Read_1_STK_SIZE,
(void* )NULL,
(UBaseType_t )Read_1_TASK_PRIO,
(TaskHandle_t* )&ReadTask_1_Handler
);
//創(chuàng)建 Read_2_Task 任務(wù)
xTaskCreate(
(TaskFunction_t )Read_2_Task,
(const char* )"Read_2_Task",
(uint16_t )Read_2_STK_SIZE,
(void* )NULL,
(UBaseType_t )Read_2_TASK_PRIO,
(TaskHandle_t* )&ReadTask_2_Handler
);
vTaskDelete(StartTask_Handler); //刪除開始任務(wù)
taskEXIT_CRITICAL(); //退出臨界區(qū)
}
//Send_Task 任務(wù)函數(shù)
void Send_Task(void *pvParameters)
{
while(1)
{
if(GPIO_ReadInputDataBit( GPIOE, GPIO_Pin_2)==0)
{
xTaskNotifyGive( ReadTask_1_Handler );
}
if(GPIO_ReadInputDataBit( GPIOE, GPIO_Pin_3)==0)
{
xTaskNotifyGive( ReadTask_2_Handler );
}
printf("正在發(fā)送n");
vTaskDelay(1000);
}
}
//Read_1_Task 任務(wù)函數(shù)
void Read_1_Task(void *pvParameters)
{
uint32_t xReturn = 0;
while(1)
{
xReturn = ulTaskNotifyTake( pdTRUE, //是否清零
portMAX_DELAY );//等待時(shí)間
printf("Task1 = %dn",xReturn);
printf("正在獲取n");
vTaskDelay(1000);
}
}
//Read_2_Task 任務(wù)函數(shù)
void Read_2_Task(void *pvParameters)
{
uint32_t xReturn = 0;
while(1)
{
xReturn = ulTaskNotifyTake( pdTRUE, //是否清零
portMAX_DELAY );//等待時(shí)間
printf("task2 = %dn",xReturn);
printf("正在獲取n");
vTaskDelay(1000);
}
}
實(shí)驗(yàn)現(xiàn)象
![poYBAGPl-neAS6muAABxNr5KJuM826.png](https://file.elecfans.com/web2/M00/8F/D4/poYBAGPl-neAS6muAABxNr5KJuM826.png)
--END--
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報(bào)投訴
-
FreeRTOS
+關(guān)注
關(guān)注
12文章
484瀏覽量
62414 -
任務(wù)
+關(guān)注
關(guān)注
1文章
20瀏覽量
8566 -
初始化
+關(guān)注
關(guān)注
0文章
50瀏覽量
11954
發(fā)布評論請先 登錄
相關(guān)推薦
FreeTRTOS可以通過哪些方法向接收任務(wù)更新通知呢
每個(gè)RTOS任務(wù)都有一個(gè)32位的通知值,任務(wù)創(chuàng)建時(shí),這個(gè)值被初始化為0。
Free RTOS移植問題的解決辦法?
按照原子哥的free rtos抑制說明文檔做第一個(gè)工程,改完代碼編譯出現(xiàn)xPortSysTickHandler()函數(shù)未定義,頭文件中加入task.h和FreeRTOS.h。實(shí)在找不出問題所在,,,there must be anther problem???
發(fā)表于 06-11 07:57
任務(wù)通知的問題如何解決
在一個(gè)最高優(yōu)先級任務(wù)1里面發(fā)送通知:xTaskNotify((TaskHandle_t)BatTask_Handler,//接收任務(wù)通知的電
發(fā)表于 07-13 10:36
LEDs狀態(tài)燈任務(wù)(線程)設(shè)計(jì) (基于RTOS)
LEDs狀態(tài)燈任務(wù)(線程)設(shè)計(jì)(基于RTOS)
FreeRTOS的直接任務(wù)(消息)通知
速度。 嵌入式專欄 1 寫在前面幾乎所有RTOS操作系統(tǒng)都提供了隊(duì)列和信號量的功能,對于大部分新手來說,使用隊(duì)列和信號量是必備技能。 但是,在大多數(shù)情況下,他們都是使用“中介對象”進(jìn)行通信,而并非“直接任務(wù)消息”通信。 通過“中
RTOS任務(wù)的堆棧大小與代碼量有啥關(guān)系嗎?
最近有小伙伴問了這樣一個(gè)問題:我有個(gè)任務(wù)中的代碼量很多,是不是這個(gè)任務(wù)的堆棧需要分配很大才行? 下面就圍繞任務(wù)代碼量,以及堆棧進(jìn)行描述相關(guān)內(nèi)容。 1RTOS
FreeRTOS系列第14篇---FreeRTOS任務(wù)通知
每個(gè)RTOS任務(wù)都有一個(gè)32位的通知值,任務(wù)創(chuàng)建時(shí),這個(gè)值被初始化為0。RTOS任務(wù)
發(fā)表于 01-26 17:49
?5次下載
![FreeRTOS系列第14篇---FreeRTOS<b class='flag-5'>任務(wù)</b><b class='flag-5'>通知</b>](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
FreeRTOS任務(wù)通知簡介及實(shí)現(xiàn)
每個(gè)系統(tǒng)任務(wù)都會有一個(gè)任務(wù)通知。然后每個(gè)任務(wù)通知都具有掛起或者未掛起的狀態(tài),以及32位的通知。常
FreeRTOS任務(wù)通知簡介
任務(wù)通知簡介 任務(wù)通知在 FreeRTOS 中是一個(gè)可選的功能,要使用任務(wù)通知的話就需要將宏co
使用任務(wù)通知提高RTOS應(yīng)用的效率
在實(shí)時(shí)嵌入式系統(tǒng)中,性能和資源效率是決定設(shè)計(jì)成敗的關(guān)鍵因素。傳統(tǒng)的實(shí)時(shí)操作系統(tǒng)(RTOS)提供了如隊(duì)列、信號量和事件組機(jī)制,實(shí)現(xiàn)任務(wù)之間的同步和通信。FreeRTOS/SAFERTOS還提供一種方法可以使這些過程更快、更輕量化,即任務(wù)
評論