Quality RTOS & Embedded Software

 Real time embedded FreeRTOS RSS feed 
Real time embedded FreeRTOS mailing list 
Quick Start Supported MCUs PDF Books Trace Tools Ecosystem TCP & FAT Training

SAMA5D4 (ARM Cortex-A5) RTOS Demo
Including FreeRTOS+CLI, and Using the IAR Embedded Compiler
[RTOS Ports]

Atmel Cortex-A5 RTOS


This page documents the FreeRTOS demo for the Atmel ATSAMA5D4 embedded processor, which has an ARM Cortex-A5 core, and uses the Atmel Advanced Interrupt Controller (AIC). A pre-configured RTOS example project that targets the SAMA5D4-EK evaluation hardware is provided for the IAR Embedded Workbench for ARM embedded development tools.

Atmel Cortex-A5 RTOS
The RTOS State Viewer Windows in EWARM Running the SAMA5 RTOS Demo
Click to Enlarge

IMPORTANT! Notes on using the ARM Cortex-A5 RTOS demo project

Please read all the following points before using this RTOS port.

  1. Source Code Organisation
  2. The Demo Application Functionality
  3. Build Instructions
  4. RTOS Configuration and Usage Details
See also:

Source Code Organisation

The official FreeRTOS zip file download includes source files for all the RTOS ports, and all the RTOS demo projects. Only a small subset of the files are required by this Atmel SAMA5D4 ARM Cortex-A5 RTOS demo application. The Source Code Organization page describes the structure of the FreeRTOS zip file download, and provides information on creating a new RTOS project.

The IAR Embedded Workbench project used to build this demo is located in the FreeRTOS/Demo/CORTEX_A5_SAMA5D4x_EK_IAR directory. The project includes source files from the /FreeRTOS-Plus/Source directory, so will not build if the /FreeRTOS-Plus directory has been moved from its default location, or deleted.

The Atmel SAMA5D4 ARM Cortex-A5 Demo Application

Hardware and software set up

No hardware configuration specific to this demo is required.


The constant mainCREATE_SIMPLE_BLINKY_DEMO_ONLY is used to switch between a basic 'blinky' style demo, and a larger test and demo application. mainCREATE_SIMPLE_BLINKY_DEMO_ONLY is defined at the top of main.c.

Functionality when mainCREATE_SIMPLE_BLINKY_DEMO_ONLY is set to 1

When mainCREATE_SIMPLE_BLINKY_DEMO_ONLY is set to 1 main() calls main_blinky().

main_blinky() creates a very basic demo that creates just two tasks and one queue. The first task (the queue send task) repeatedly sends the number 100 to the second task (the queue receive task) over the queue. The queue receive task toggles an LED each time it receives the data. The data is sent to the queue every 200 milliseconds, so the queue receive task will toggle the LED every 200 milliseconds.

Functionality when mainCREATE_SIMPLE_BLINKY_DEMO_ONLY is set to 0

Atmel Cortex-A5 RTOS
Run-time stats viewed in the CLI
Click to Enlarge
When mainCREATE_SIMPLE_BLINKY_DEMO_ONLY is set to 0 main() calls main_full().

main_full() creates a comprehensive demo and test application that demonstrates:

The .inf file necessary to install the CDC virtual COM port on a Windows computer is called 6119.inf, and is located in the same directory as the IAR project. A dumb terminal program, such as Tera Term or Hyperterminal, can be used to connect to the CLI via the enumerated virtual COM port. 115200 baud is used. As always with FreeRTOS+CLI, type 'help' in the CLI to see a list of the registered commands.

The USB CDC device will enumerate as soon as the RTOS demo application starts executing, and will re-enumerate each time the RTOS demo application is restarted. That means a terminal program cannot be connected to the virtual COM port until the RTOS application is actually running, and must be disconnected from, and then reconnected to, the CDC virtual COM port each time the RTOS demo is re-started. If the dumb terminal is not disconnected from the CDC port before the RTOS demo is stopped or restarted then it might be necessary to shut down and restart the dumb terminal program before another connection can be created.

Many of the other tasks created in the full demo are from the set of standard demo tasks. The standard demo tasks are used by the RTOS demos applications for every RTOS port, and have no specific functionality. Their purpose is to demonstrate the RTOS API functions being used, and test the RTOS architecture port.

The demo also creates a 'check' task. The check task periodically inspects the status of the standard RTOS demo tasks to ensure they are functioning as expected. The check task toggles an LED to give a visual indication of the system status; If the LED is toggling every 3 seconds then all the tasks are executing as expected. If the LED is toggling every 200ms then the check task has detected a possible error in one or more of the demo tasks..

NOTE: Some of the standard demo tasks check their own timing, and the timing checks will fail (resulting in an error being reported to the 'check' task) if excessive time is spent processing USB interrupts.

Build Instructions

Building and executing the RTOS demo application

Note the RTOS demo project references common files from the /FreeRTOS-Plus and /FreeRTOS/Demo/Common directories and will not compile if either of these directories have been deleted or moved from their default locations.
  1. Open FreeRTOS/Demo/CORTEX_A5_SAMA5D4x_EK_IAR/RTOSDemo.eww in the IAR Embedded Workbench (EWARM) IDE.

  2. Set mainCREATE_SIMPLE_BLINKY_DEMO_ONLY at the top of main.c to generate either the simple blinky demo, or the full test and demo application, as described above.

  3. Select "Build All" from the IDE's "Project" menu, or press F7, to build the RTOS demo.

  4. Ensure the target hardware is powered, and connected to the host computer using both the target's J-Link USB connection for the debugger, and (if running the full demo with CLI), the target's USB-A connection.

  5. Select "Download and Debug" from the IDE's "Project" window. The built executable with be downloaded to the ARM Cortex-A5 RAM before a debug session is started.

RTOS Configuration and Usage Details

FreeRTOS ARM Cortex-A port specific configuration

Attention please!: The SAMA5D4 uses a proprietary Atmel interrupt controller, rather than ARM's own Generic Interrupt Controller (GIC). Separate web pages provide instruction on using the RTOS in both scenarios. When using the SAMA5D4 please refer to the web page that provides instruction on using the RTOS on ARM Cortex-A embedded processors that do not incorporate an ARM GIC.

Configuration items specific to this demo are contained in the FreeRTOS/Demo/CORTEX_A5_SAMA5D4x_EK_IAR/FreeRTOSConfig.h header file.

Resources used by FreeRTOS

The RTOS demo is configured to generate the RTOS tick interrupt from the PIT (Periodic Interrupt Controller). Other resources used by the RTOS are documented on the page that provides instruction on using the RTOS on ARM Cortex-A embedded processors that do not incorporate ARM's Generic Interrupt Controller, as already referenced.

Memory allocation

Source/Portable/MemMang/heap_4.c is included in the ARM Cortex-A demo application project to provide the memory allocation required by the RTOS kernel. Please refer to the Memory Management section of the API documentation for full information.


Note that vPortEndScheduler() has not been implemented.

[ Back to the top ]    [ About FreeRTOS ]    [ Sitemap ]    [ ]

Copyright (C) 2004-2010 Richard Barry. Copyright (C) 2010-2016 Real Time Engineers Ltd.
Any and all data, files, source code, html content and documentation included in the FreeRTOSTM distribution or available on this site are the exclusive property of Real Time Engineers Ltd.. See the files license.txt (included in the distribution) and this copyright notice for more information. FreeRTOSTM and FreeRTOS.orgTM are trade marks of Real Time Engineers Ltd.

Latest News:

FreeRTOS V9.0.0 is now available for download.

Free TCP/IP and file system demos for the RTOS

Sponsored Links

⇓ Now With No Code Size Limit! ⇓
⇑ Free Download Without Registering ⇑

FreeRTOS Partners

ARM Connected RTOS partner for all ARM microcontroller cores

Renesas Electronics Gold Alliance RTOS Partner.jpg

Microchip Premier RTOS Partner

RTOS partner of NXP for all NXP ARM microcontrollers

Atmel RTOS partner supporting ARM Cortex-M3 and AVR32 microcontrollers

STMicro RTOS partner supporting ARM7, ARM Cortex-M3, ARM Cortex-M4 and ARM Cortex-M0

Xilinx Microblaze and Zynq partner

Silicon Labs low power RTOS partner

Altera RTOS partner for Nios II and Cortex-A9 SoC

Freescale Alliance RTOS Member supporting ARM and ColdFire microcontrollers

Infineon ARM Cortex-M microcontrollers

Texas Instruments MCU Developer Network RTOS partner for ARM and MSP430 microcontrollers

Cypress RTOS partner supporting ARM Cortex-M3

Fujitsu RTOS partner supporting ARM Cortex-M3 and FM3

Microsemi (previously Actel) RTOS partner supporting ARM Cortex-M3

Atollic Partner

IAR Partner

Keil ARM Partner

Embedded Artists