Posted 2017-04-11 11:49:17 +0200

blogs->nordicers

Short note how to make FreeRTOS program debugging with eclipse little simpler.

If you are looking the information how to configure the whole environment see this post: https://devzone.nordicsemi.com/tutorials/7/development-with-gcc-and-eclipse/

## What we get out of the box

Most low power applications stays most of the timer in idle. Ideally it would be tickless-idle. The problem begins if our program behaves strangely and we would like to stop it and check what is going on.

Lets get blinky_freertos example. Run it and halt just in random moment. Until you are very lucky you would stop somewhere in the FreeRTOS files:

The problem is that in most cases we would land in IDLE task. And there is no easy way to see the state of the task of our interest. Or is there?

J-link server provides proper support for info thread gdb command by special rtos plugin. To enable it just add an option to command line:

-rtos GDBServer\RTOSPlugin_FreeRTOS


See debug configuration below as a template:

Now when you run the debug and pause it, you would probably stop in idle task anyway. But all the tasks would be listed and you can easily go to the source where it waits just by clicking in the thread backtrace:

In the image above you may see that simple freertos_blinky example utilizes 3 Threads:

• IDL - Idle
• LED - our LED loop
• Tmr - Thread that processes the timers

I have experienced some issues with the -rtos option when program was compiled with -03 optimisation option - the debugger often crashes, inside RTOSPlugin_FreeRTOS.dll library, when trying to stop inside a FreeRTOS task. With -00 there was no such issue.

## Recent blog posts

Posted 2017-04-11 11:49:17 by Radosław Koppel
• ### Taking a deeper dive into Bluetooth 5

Posted 2017-04-07 14:53:51 by John Leonard
• ### Logging enabled by default in SDK Bluetooth examples

Posted 2017-03-29 11:27:02 by Håvard
• ### Monitor Mode Debugging with J-Link and GDB/Eclipse

Posted 2017-03-29 05:56:12 by Daniel Veilleux
• ### Getting started with Nordic's Secure DFU bootloader, a step by step guide

Posted 2017-03-20 17:13:52 by Hung Bui

## Recent questions

• ### nRF52832 one of output (p0.15) lost its power

Posted 2017-04-28 12:07:25 by Damian
• ### mesh dfu serial translate update file . 15 min？ why so slowlly？

Posted 2017-04-28 12:03:43 by mr_sev
• ### Ram related issue / What are the best practices (armgcc, linker) > nRF51 16 kB vs 32 kB

Posted 2017-04-28 11:39:06 by trdop
• ### SoftDevice Update size

Posted 2017-04-28 11:30:48 by Mihail
• ### How to setup a complete BLE5 enviornment ?

Posted 2017-04-28 10:33:28 by allankliu