掛起可以理解為暫時停止任務(wù),恢復(fù)可以理解為從新啟動掛起的任務(wù)
掛起API函數(shù)(可以在tasks.c中找到)
vTaskSuspend( TaskHandle_t xTaskToSuspend )
xTaskToSuspend:需要掛起的任務(wù)句柄
非中斷恢復(fù)API函數(shù)(可以在tasks.c中找到)
vTaskResume( TaskHandle_t xTaskToResume )
xTaskToSuspend:需要掛起的任務(wù)句柄
中斷恢復(fù)API函數(shù)(可以在tasks.c中找到)
xTaskResumeFromISR( TaskHandle_t xTaskToResume )
xTaskToSuspend:需要掛起的任務(wù)句柄
注意:中斷中不可以使用
vTaskDelay( const TickType_t xTicksToDelay )
實驗?zāi)康?/p>
通過按鍵控制LED0任務(wù)的掛起與恢復(fù)
任務(wù)掛起與恢復(fù)
#include "stm32f10x.h"
#include "stm32f10x.h"
#include
#include "FreeRTOS.h"
#include "task.h"
uint8_t main_temp = 0;
void LED_Init(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE); //使能PE端口時鐘
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1|GPIO_Pin_5; //端口配置
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //推挽輸出
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; //IO口速度為50MHz
GPIO_Init(GPIOC, &GPIO_InitStructure); //推挽輸出 ,IO口速度為50MHz
GPIO_SetBits(GPIOC,GPIO_Pin_1|GPIO_Pin_5); //輸出高
}
void KEY_Init(void)
{
GPIO_InitTypeDef GPIO_InitStructure; //定義結(jié)構(gòu)體變量
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,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 */
}
// 外部中斷初始化
void My_EXTI_Init(void)
{
NVIC_InitTypeDef NVIC_InitStructure;
EXTI_InitTypeDef EXTI_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);
GPIO_EXTILineConfig(GPIO_PortSourceGPIOA, GPIO_PinSource0);//選擇GPIO管腳用作外部中斷線路
//EXTI0 NVIC 配置
NVIC_InitStructure.NVIC_IRQChannel = EXTI0_IRQn;//EXTI0中斷通道
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=2;//搶占優(yōu)先級
NVIC_InitStructure.NVIC_IRQChannelSubPriority =3; //子優(yōu)先級
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQ通道使能
NVIC_Init(&NVIC_InitStructure); //根據(jù)指定的參數(shù)初始化VIC寄存器
EXTI_InitStructure.EXTI_Line=EXTI_Line0;
EXTI_InitStructure.EXTI_Mode=EXTI_Mode_Interrupt;
EXTI_InitStructure.EXTI_Trigger=EXTI_Trigger_Rising;
EXTI_InitStructure.EXTI_LineCmd=ENABLE;
EXTI_Init(&EXTI_InitStructure);
}
#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 LED0_TASK_PRIO 2 //任務(wù)優(yōu)先級
#define LED0_STK_SIZE 50 //任務(wù)堆棧大小
TaskHandle_t LED0Task_Handler; //任務(wù)句柄
void led0_task(void *p_arg); //任務(wù)函數(shù)
#define LED1_TASK_PRIO 2 //任務(wù)優(yōu)先級
#define LED1_STK_SIZE 50 //任務(wù)堆棧大小
TaskHandle_t LED1Task_Handler; //任務(wù)句柄
void led1_task(void *p_arg); //任務(wù)函數(shù)
#define KEY0_TASK_PRIO 2 //任務(wù)優(yōu)先級
#define KEY0_STK_SIZE 50 //任務(wù)堆棧大小
TaskHandle_t KEY0Task_Handler; //任務(wù)句柄
void key0_task(void *p_arg); //任務(wù)函數(shù)
int main( void )
{
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_4);//設(shè)置系統(tǒng)中斷優(yōu)先級分組 4
LED_Init(); //初始化 LED
KEY_Init();
My_EXTI_Init();
//創(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)度
}
void start_task(void *pvParameters)
{
taskENTER_CRITICAL(); //進入臨界區(qū)
//創(chuàng)建 LED0 任務(wù)
xTaskCreate(
(TaskFunction_t )led0_task,
(const char* )"led0_task",
(uint16_t )LED0_STK_SIZE,
(void* )NULL,
(UBaseType_t )LED0_TASK_PRIO,
(TaskHandle_t* )&LED0Task_Handler
);
//創(chuàng)建 LED1 任務(wù)
xTaskCreate(
(TaskFunction_t )led1_task,
(const char* )"led1_task",
(uint16_t )LED1_STK_SIZE,
(void* )NULL,
(UBaseType_t )LED1_TASK_PRIO,
(TaskHandle_t* )&LED1Task_Handler
);
//創(chuàng)建 KEY0 任務(wù)
xTaskCreate(
(TaskFunction_t )key0_task,
(const char* )"key0_task",
(uint16_t )KEY0_STK_SIZE,
(void* )NULL,
(UBaseType_t )KEY0_TASK_PRIO,
(TaskHandle_t* )&KEY0Task_Handler
);
vTaskDelete(StartTask_Handler); //刪除開始任務(wù)
taskEXIT_CRITICAL(); //退出臨界區(qū)
}
//LED0 任務(wù)函數(shù)
void led0_task(void *pvParameters)
{
while(1)
{
if(GPIO_ReadInputDataBit( GPIOC, GPIO_Pin_5))
{
GPIO_ResetBits( GPIOC, GPIO_Pin_5);
}
else
{
GPIO_SetBits( GPIOC, GPIO_Pin_5);
}
vTaskDelay(400);
}
}
//LED1 任務(wù)函數(shù)
void led1_task(void *pvParameters)
{
while(1)
{
if(GPIO_ReadInputDataBit( GPIOC, GPIO_Pin_1))
{
GPIO_ResetBits( GPIOC, GPIO_Pin_1);
}
else
{
GPIO_SetBits( GPIOC, GPIO_Pin_1);
}
vTaskDelay(200);
}
}
//KEY0 任務(wù)函數(shù)
void key0_task(void *pvParameters)
{
while(1)
{
if( main_temp == 0xff ){
//任務(wù)掛起(非中斷)
//vTaskSuspend(LED0Task_Handler);
}
else{
//任務(wù)恢復(fù)(非中斷)
//vTaskResume(LED0Task_Handler);
}
vTaskDelay(100);
}
}
//按鍵中斷服務(wù)函數(shù)
void EXTI0_IRQHandler(void)
{
if(EXTI_GetITStatus(EXTI_Line0)==1)
{
if( main_temp ){
main_temp = 0x00;
//中斷函數(shù)中進行任務(wù)恢復(fù)(區(qū)分中斷)
xTaskResumeFromISR(LED0Task_Handler);
}
else{
main_temp = 0xff;
//任務(wù)掛起(謹慎在中斷使用,雖然可以達到初步效果,不保證不會出問題)
vTaskSuspend(LED0Task_Handler);
}
}
EXTI_ClearITPendingBit(EXTI_Line0);
}
--END--
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
-
API
+關(guān)注
關(guān)注
2文章
1472瀏覽量
61749 -
函數(shù)
+關(guān)注
關(guān)注
3文章
4280瀏覽量
62325
發(fā)布評論請先 登錄
相關(guān)推薦
FreeRTOS任務(wù)掛起恢復(fù)與使用中斷遇到的坑
任務(wù)掛起簡單點理解就是現(xiàn)在不需要執(zhí)行這個任務(wù),讓它先暫停,就是掛起。恢復(fù)就是從剛才掛起的狀態(tài)下繼
FreeRTOS中的任務(wù)管理
任務(wù)是 FreeRTOS 中最基本的調(diào)度單元,它是一段可執(zhí)行的代碼,可以獨立運行。FreeRTOS 中的任務(wù)是基于優(yōu)先級的搶占式調(diào)度,優(yōu)先級高的任務(wù)
FreeRTOS的任務(wù)無故進入掛起狀態(tài)的原因?
請教大家一個問題,我子啊使用FreeRTOS的時候創(chuàng)建了一個以太網(wǎng)的任務(wù),任務(wù)在使用的過程中被無故掛起,請問一下出現(xiàn)這種現(xiàn)象有哪幾種原因呢?
發(fā)表于 04-09 07:20
FreeRTOS里在中斷中掛起任務(wù)出錯的原因?怎么解決?
各位大佬,新手剛學習FreeRTOS,現(xiàn)在想在中斷中掛起某個任務(wù),我在教程里看到說有中斷中的恢復(fù)函數(shù)xTaskResumeFromISR,但是沒有在中斷中的
發(fā)表于 04-16 08:26
freeRTOS操作系統(tǒng)的任務(wù)掛起
freeRTOS在cntTask任務(wù)中,計數(shù)到10次之后便不再進入該任務(wù)為什么?請led4Task并沒有被掛起,又是為什么?本人剛?cè)腴TfreeRTO
發(fā)表于 10-18 21:39
UCOSII的任務(wù)掛起與恢復(fù)問題
我遇到一個問題,我在用ucosII時,我任務(wù)A一直未被掛起,但我有一個任務(wù)B(優(yōu)先級比A高,1ms觸發(fā)一次),每執(zhí)行一次任務(wù)B都會恢復(fù)一下
發(fā)表于 07-04 04:35
FreeRTOS任務(wù)掛起和恢復(fù)的相關(guān)資料推薦
任務(wù)掛起和恢復(fù)要使用著些API則需要使能宏定義:INCLUDE_vTaskSuspend、INCLUDE_xTaskResumeFromISR任務(wù)掛
發(fā)表于 12-27 08:06
FreeRTOS任務(wù)掛起與刪除的區(qū)別在哪
當一個任務(wù)暫時需要停止運行,那么就可以將任務(wù)掛起,在需要運行的時候在恢復(fù)就可以了。任務(wù)恢復(fù)運行以
發(fā)表于 01-21 11:02
對FreeRTOS任務(wù)的使用
FreeRTOS學習筆記(二):任務(wù)創(chuàng)建/刪除,掛起/解掛上篇文章介紹了任務(wù)相關(guān)的基礎(chǔ)知識,本篇文章對FreeRTOS
發(fā)表于 02-18 07:14
FreeRTOS筆記(四):任務(wù)創(chuàng)建/刪除,掛起/解掛詳解
FreeRTOS筆記(四):任務(wù)創(chuàng)建/刪除,掛起/解掛詳解在第二篇筆記中介紹了任務(wù)創(chuàng)建的API,并且簡單使用了相關(guān)API,本文將詳細介紹任務(wù)
發(fā)表于 12-04 19:36
?15次下載
#FreeRTOS學習筆記(二):任務(wù)創(chuàng)建/刪除,掛起/解掛
FreeRTOS學習筆記(二):任務(wù)創(chuàng)建/刪除,掛起/解掛上篇文章介紹了任務(wù)相關(guān)的基礎(chǔ)知識,本篇文章對FreeRTOS
發(fā)表于 12-23 19:56
?2次下載
(一)FreeRTOS學習之FreeRTOS任務(wù)基礎(chǔ)知識
功能,初學者必須先掌握——任務(wù)的創(chuàng)建、刪除、掛起和恢復(fù)等操作。本章節(jié)分為如下幾部分:*什么是多任務(wù)系統(tǒng)*FreeRTOS
發(fā)表于 12-23 19:57
?3次下載
FreeRTOS系列第11篇---FreeRTOS任務(wù)控制
FreeRTOS任務(wù)控制API函數(shù)主要實現(xiàn)任務(wù)延時、任務(wù)掛起、解除任務(wù)
發(fā)表于 01-26 17:54
?12次下載
評論