1.8 TrustZone FreeRTOS Basic

This example application blinks an LED to show the FreeRTOS threads that are running in non-secure mode and to indicate status.

Description

This demonstrates TrustZone feature and uses two projects viz., Secure and Non-Secure Project that work together on the same MCU and offering security isolation between the Trusted and the Non-trusted resources in the device.

FreeRTOS and BSP are configured and run in Non-Secure mode.

This demonstration creates three tasks and a queue. Task1 sends message to Task2 and Task3 to unblock and toggle an LED. Task1 priority is low compared to Task2 and Task3 which shares same priority.

  • Task1: This task sends the data (i.e.: delay, the amount of time for which the task need blocked) to Task2 and Task3 using a queue, then Task1 blocks itself for 200ms to allow other tasks to schedule and run
  • Task2: This task blocks until it receives the data from queue, if the Task2 receives the expected delay (i.e.: 1000ms) from Task1 then toggles the LED and blocks itself for the amount of delay received
  • Task3: This task blocks until it receives the data from queue, if the Task3 receives the expected delay (i.e.: 100ms) from Task1 then toggles the LED and blocks itself for the amount of delay received

Downloading and Building the Application

To clone or download this application from Github, go to the main page of this repository and then click Clone button to clone this repository or download as zip file. This content can also be downloaded using content manager by following these instructions.

Path of the application within the repository is as shown below:
TypePath
Project groupapps/rtos/freertos/basic_freertos_trustZone
Secure Projectapps/rtos/freertos/basic_freertos_trustZone/Secure/firmware
Non-Secure Projectapps/rtos/freertos/basic_freertos_trustZone/NonSecure/firmware
To build the application, refer to the following table and open the project using its IDE.
Project NameDescription
pic32cm_ls00_cpro_Secure.X

pic32cm_ls00_cpro_NonSecure.X

Secure and Non-secure MPLABX project for PIC32CM LS00 Curiosity Pro Evaluation Kit

Setting Up the Hardware

The following table shows the target hardware for the application projects.

Project NameDescription
pic32cm_ls00_cpro_Secure.X

pic32cm_ls00_cpro_NonSecure.X

PIC32CM LS00 Curiosity Pro Evaluation Kit

Setting Up PIC32CM LS00 Curiosity Pro Evaluation Kit

  • Connect the Debug USB port on the board to the computer using a micro USB cable

Running the Application

  1. Build and program the application using its IDE
  2. The LED indicates the success or failure.
    • The LED toggles on success i.e.: each time when the Task2 or Task3 receives a valid message
Refer to the following table for LED name: