(16 intermediate revisions by the same user not shown)
Line 1: Line 1:
 
[[category: Free RTOS with Arduino]]
 
[[category: Free RTOS with Arduino]]
In earlier tutorials, we saw how to create and use and delete the tasks.<br>
+
In this tutorial, we will see how to create and use binary semaphore.<br>
In this tutorial, we will see how to Suspend and Resume the tasks.<br>
+
Later we will be looking into priority inversion using the LPT,MPT and HPT.<br><br>
+
 
 +
==Teminologies==
 +
#<b>LPT:</b> Low Priority Task
 +
#<b>MPT:</b> Medium Priority Task
 +
#<b>HPT:</b> High Priority Task
 +
 
 +
 
 +
=Prerequisites=
 +
Please check [[Semaphores|this tutorial]] for detailed explanation on Semaphores.<br> <br>
  
 
=API Details=
 
=API Details=
Here we will discuss some of the most frequently used APIs related to tasks.
+
Below is the list of the API's used in this tutorial.
 +
 
 +
<b>1.xTaskCreate()</b>: 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 [http://www.freertos.org/a00125.html this link] for more details.<br>
 +
 
 +
<b>2.vTaskDelay()</b>: 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 [http://www.freertos.org/a00127.html this link] for more details.<br>
 +
 
 +
<b>3.vTaskDelete():</b>This function is used to delete as task. We need to pass the taskHandle of the task to be deleted.<br> To delete the own task we should pass NULL as parameter.<br>
 +
Please check [http://www.freertos.org/a00126.html this link] for details. <br>
 +
 
 +
<b>4.vSemaphoreCreateBinary():</b> This interface is used to create a binary semaphore. We need to pass a handle of type SemaphoreHandle_t to this function.<br>
 +
Please check [http://www.freertos.org/a00121.html this link] for details. <br>
 +
 
 +
<b>5.xSemaphoreTake():</b> This interface is used to acquire a binary semaphore. We need to pass a semaphore handle and the amount of time to wait for semaphore to become available.<br>
 +
Please check [http://www.freertos.org/a00122.html this link] for details. <br>
 +
 
 +
<b>6.xSemaphoreGive():</b> This interface is used to release a binary semaphore. We need to pass a semaphore handle to this function.<br>
 +
Please check [http://www.freertos.org/a00123.html this link] for details. <br>
  
<b>xTaskCreate()</b>: 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 [http://www.freertos.org/a00125.html this link] for more details.<br>
+
<b>7.vSemaphoreDelete ():</b> This interface is used to delete a binary semaphore. We need to pass a semaphore handle to this function.<br>
 +
Please check [http://www.freertos.org/a00113.html#vSemaphoreDelete this link] for details. <br>
  
<b>vTaskDelay()</b>: 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 [http://www.freertos.org/a00127.html this link] for more details.<br>
 
  
<b>vTaskDelete():</b>This function is used to delete as task. We need to pass the taskHandle of the task to be deleted.<br>
+
=Example=
To delete the own task we should pass NULL as the parameter. Please check [http://www.freertos.org/a00126.html this link] for more details. <br>
+
In this example,  HPT waits for the LPT as it is holding the resource(semaphore). Further, the LPT waits for the event/data to be received and the CPU executes the IDLE tasks. This makes the HPT wait for more time.
 +
<html><script src="https://gist.github.com/SaheblalBagwan/e18934bcd64b11307fabf8b0e0812f32.js"></script></html>  
  
<b>vTaskPrioritySet():</b> This function is used to change/Set the priority of a task.<br>
+
[[File:BinarySemaphoreExtendedPriorityInversion.png]]
For this we need to pass the handle of the task and new priority to vTaskPrioritySet() function. Check [http://www.freertos.org/a00129.html this link] for more details.
+
  
<b>vTaskPriorityGet():</b> This function is used to get the priority of a task.<br>
+
#LPT starts running and acquires the semaphore.
For this, we need to pass the handle of the task and it will return the task. Check [http://www.freertos.org/a00128.html this link] for more details.
+
#Now HPT is created and it preempts LPT and starts running. It makes the request to acquire the semaphore. Since the semaphore is already with LPT, HPT goes to blocked state.
 +
#LPT starts executing again and waits for an event(packet to be received).
 +
#Now the Idle task starts running. Now the HPT is starved because of LPT and Idle task.
 +
#LPT comes out of blocked state as the event(wait time/packet is received) has occurred. Now it releases the semaphore.
 +
#Immediately the HPT comes out of the blocked state and starts executing. It releases the semaphore and runs for some time and deletes itself.
 +
#Now control goes back to LPT which completes its job and deletes itself.
 +
#Finally the scheduler is left out with the idle task and it keeps running.
  
<b>vTaskSuspend():</b> This function is used to Suspend a task, the suspended remains in the same state util it is resumed.<br>
+
In this scenario, the HPT task waits for LPT and Idle task from 2-5 which is the extended priority inversion period.
For this, we need to pass the handle of the tasks that needs to be suspended. Passing NULL will suspend own task. Check [http://www.freertos.org/a00130.html this link] for more details.
+
  
<b>vTaskResume():</b> 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<br>
 
For this, we need to pass the handle of the task to be resumed. Check [http://www.freertos.org/a00131.html this link] for more details.
 
  
=Example1=
 
<html><script src="https://gist.github.com/SaheblalBagwan/c696f165daba3e2826cd3b9ebf33785f.js"></script></html>
 
  
=Output1=
+
Have an opinion, suggestion , question or feedback about the article let it out here!
[[FILE:VTaskList().png]]
+
{{DISQUS}}
<br>
+
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
+

Latest revision as of 18:28, 14 July 2016

In this tutorial, we will see how to create and use binary semaphore.
Later we will be looking into priority inversion using the LPT,MPT and HPT.

Teminologies

  1. LPT: Low Priority Task
  2. MPT: Medium Priority Task
  3. HPT: High Priority Task


Prerequisites

Please check this tutorial for detailed explanation on Semaphores.

API Details

Below is the list of the API's used in this tutorial.

1.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.

2.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.

3.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 parameter.
Please check this link for details.

4.vSemaphoreCreateBinary(): This interface is used to create a binary semaphore. We need to pass a handle of type SemaphoreHandle_t to this function.
Please check this link for details.

5.xSemaphoreTake(): This interface is used to acquire a binary semaphore. We need to pass a semaphore handle and the amount of time to wait for semaphore to become available.
Please check this link for details.

6.xSemaphoreGive(): This interface is used to release a binary semaphore. We need to pass a semaphore handle to this function.
Please check this link for details.

7.vSemaphoreDelete (): This interface is used to delete a binary semaphore. We need to pass a semaphore handle to this function.
Please check this link for details.


Example

In this example, HPT waits for the LPT as it is holding the resource(semaphore). Further, the LPT waits for the event/data to be received and the CPU executes the IDLE tasks. This makes the HPT wait for more time.

BinarySemaphoreExtendedPriorityInversion.png

  1. LPT starts running and acquires the semaphore.
  2. Now HPT is created and it preempts LPT and starts running. It makes the request to acquire the semaphore. Since the semaphore is already with LPT, HPT goes to blocked state.
  3. LPT starts executing again and waits for an event(packet to be received).
  4. Now the Idle task starts running. Now the HPT is starved because of LPT and Idle task.
  5. LPT comes out of blocked state as the event(wait time/packet is received) has occurred. Now it releases the semaphore.
  6. Immediately the HPT comes out of the blocked state and starts executing. It releases the semaphore and runs for some time and deletes itself.
  7. Now control goes back to LPT which completes its job and deletes itself.
  8. Finally the scheduler is left out with the idle task and it keeps running.

In this scenario, the HPT task waits for LPT and Idle task from 2-5 which is the extended priority inversion period.


Have an opinion, suggestion , question or feedback about the article let it out here!