Difference between revisions of "Task Suspend and Resume"
| Line 51: | Line 51: | ||
| =Example2= | =Example2= | ||
| − | This example will be similar to  | + | This example will be similar to above one except that the Task1 priority will be changed to highest. Because of this Task1 continues to run even after resuming other tasks.<br> | 
| − | + | Task1 resumes all the tasks(2-4) and deletes itself. After this, all the resumed task will start running one after the other depending on their priorities.<br> | |
| − | + | Compare the order of task execution in both the output images for better understanding.   | |
| <html><script src="https://gist.github.com/SaheblalBagwan/60d8a7c113f1f429908d2ca8771afd51.js"></script></html> | <html><script src="https://gist.github.com/SaheblalBagwan/60d8a7c113f1f429908d2ca8771afd51.js"></script></html> | ||
Revision as of 18:37, 30 June 2016
In earlier tutorials, we saw how to create, use and delete the tasks.
In this tutorial, we will see how to Suspend and Resume the tasks.
Contents
API Details
Here we will discuss some of the most frequently used APIs related to tasks.
xTaskCreate(): This interface is used to create a new Task, if the task is successfully created then it returns pdPass(1) or else errCOULD_NOT_ALLOCATE_REQUIRED_MEMORY(-1). Check this link for more details.
vTaskDelay(): This function is used to delay/block the task for specified delay time(ticks). INCLUDE_vTaskDelay needs to be set to 1 in FreeRtosConfig.h file for using this function. Check this link for more details.
vTaskDelete():This function is used to delete as task. We need to pass the taskHandle of the task to be deleted.
To delete the own task we should pass NULL as the parameter. Please check this link for more details. 
vTaskPrioritySet(): This function is used to change/Set the priority of a task.
For this we need to pass the handle of the task and new priority to vTaskPrioritySet() function. Check this link for more details.
vTaskPriorityGet(): This function is used to get the priority of a task.
For this, we need to pass the handle of the task and it will return the task. Check this link for more details.
vTaskSuspend(): This function is used to Suspend a task, the suspended remains in the same state util it is resumed.
For this, we need to pass the handle of the tasks that needs to be suspended. Passing NULL will suspend own task. Check this link for more details.
vTaskResume(): This function is used to resume a suspended task. If the Resumed task has higher priority than the running task then it will preempt the running task or else stays in ready state
For this, we need to pass the handle of the task to be resumed. Check this link for more details.
Example1
In this example, we will be creating 4-Tasks with priorities(1-4). Task4 will suspend all the tasks except Task1.
As Task2-Task4 will be in suspended state, Task1 will get the chance to run. Now Task1 will resume one task at a time and every time it resumes a task it will be preempted as the resumed task will have higher priority.
 
The resumed task will run for some time and deletes itself. Because of this, Task1 will get alternative chance to Run.
 
It resumes all the tasks one after another and finally deletes itself.
Output1
 
0. Serial port is initialised and Task1 and Task3 are created with priority 1&3.
- Task3 starts executing as it has higher priority. NowTask3 creates Task2 and Task4 with priorities 2 and 4. Since Task4 has higher priority compared to Task3, Task4 starts running preempting Task3
- Now Task4 Suspends Task2,Task3 and itself. Now Task2,Task3 and Task4 are in suspended state and will not run until they are resumed.
- At this point Task1 and IDLE are available for the scheduler, So Task1 starts running. It resumes Task2 and immediately Task2 starts running as it has higher priority compared Task1.
- Task2 will run for some time and deletes itself.
- Again we are left with Task1 and IDLE, So Task1 starts running. It resumes Task3 and immediately Task3 starts running as it has higher priority compared to Task1.
- Task3 runs for some time and deletes itself.
- Again we are left with Task1 and IDLE, So Task1 starts running. It resumes Task4 and immediately Task4 starts running as it has higher priority compared to Task1.
- Task4 runs for some time and deletes itself.
- Now we are left with Task1 and Idle, so Task1 completes it job and deletes itself.
- Finally we are left with IDLE task which continues to run. 
 
Example2
This example will be similar to above one except that the Task1 priority will be changed to highest. Because of this Task1 continues to run even after resuming other tasks.
Task1 resumes all the tasks(2-4) and deletes itself. After this, all the resumed task will start running one after the other depending on their priorities.
Compare the order of task execution in both the output images for better understanding. 
Output2
 
0. Serial port is initialised and Task1 and Task3 are created with priority 1&3.
- Task3 starts executing as it has higher priority. Now Task3 creates Task2 and Task4 with priorities 2 and 4. Since Task4 has higher priority compared to Task3, Task4 starts running preempting Task3.
- Now Task4 Suspends Task2,Task3 and itself. Now Task2,Task3 and Task4 are in suspended state and will not run until they are resumed.
- At this point Task1 and IDLE are available for the scheduler, So Task1 starts running. Now the Task1 changes its priority 5 which is highest of all. It resumes Task2, Task3 and Tas4 and continues to run as it has the highest priority and deletes itself at the end. Now we have Task2, Task3, Task1 and Idle. All will run one after other depending on priorities.
- Now Task4 starts running and deletes itself.
- Task3 runs and deletes itself.
- Task2 runs and deletes itself.
- Finally IDLE task will run continuously.
