Skip to content
View RTEdbg's full-sized avatar
  • Maribor, Slovenia
  • 23:36 (UTC +01:00)

Block or report RTEdbg

Block user

Prevent this user from interacting with your repositories and sending you notifications. Learn more about blocking users.

You must be logged in to block users.

Please don't include any personal information such as legal names or email addresses. Maximum 100 characters, markdown supported. This note will be visible to only you.
Report abuse

Contact GitHub support about this user’s behavior. Learn more about reporting abuse.

Report abuse
RTEdbg/README.md

Real-time binary data logging/tracing toolkit   Twitter

LogoRTEdbg–small

The toolkit includes a library of functions for minimally intrusive code instrumentation (data logging/tracing), tools for transferring data to the host, a tool for decoding data on the host, and demo code. The solution helps embedded programmers test and debug C/C++ firmware, optimize system performance, reverse engineer poorly documented code, and find hard-to-reproduce problems.

The RTEdbg library and tools are suitable for both large, hard-real-time RTOS-based systems and small, resource-constrained systems. The tools provide better insight into the operation of real-time systems than traditional debuggers because real-time systems cannot be stopped. Restarting the system changes the conditions, leading to different results. In addition, loss of control can cause damage.

This is the main repository used to distribute the RTEdbg toolkit only. See a List of repositories that are part of the RTEdbg toolkit.

View the RTEdbg Presentation to learn about the key benefits and to see the basic features.

Newsflash                       ⇒ See also all News

  • RTEmsg utility source code released and command line argument -ts added
  • Improved RTEdbg library compile time check
  • Added rtedbg_generic_non_reentrant.h - buffer space reservation driver
  • Added rtedbg_zero_timer.h - timestamp timer driver for projects that do not need timestamps
  • Added rtedbg_inline.h - inline versions of data logging functions
  • Updated manual and several Readme files

Table of contents:

Introduction

The solution was designed with a focus on maximum execution speed, low memory and stack requirements, and portability. It is essentially a reentrant timestamped fprintf() function that runs on the host instead of the embedded system. Flexible filtering and sorting of data into user-defined files helps manage the flood of data from the embedded system. The new data logging/tracing solution is not a replacement for existing event-oriented solutions such as SystemView or Tracealyzer, as it is based on a different concept. It is optimized for minimally intrusive logging and flexible data decoding. Flexible decoding (printing) of data enables analysis of log files with existing tools (log viewers, graphing and event analysis tools). The code is optimized for 32-bit devices. For example: Only 35 CPU cycles and 4 bytes of stack are required to log a simple event on a device with a Cortex-M4 core. The total program memory footprint is only about 1 kB (using all functions, not including function calls and function parameter preparation). For the SystemView nearly 200 CPU cycles and a maximum of 150 to 510 bytes of stack are required for event generation and encoding. Even faster execution and lower stack usage can be achieved while using the inline versions of the data logging functions at the expense of higher program memory usage - for example, the inline versions can be used in the most time critical parts of the code only.

Code instrumentation is minimally intrusive because raw binary data is logged along with an automatically assigned format definition ID (transparent to the programmer) and timestamp. Raw data logging also minimizes circular buffer requirements. Any data type or entire structures/buffers can be logged and decoded, including bit fields and packed structures. In addition, there is no need for format strings or data formatting/tagging functions in the embedded system. Any debug probe, communication channel, or media can be used to transfer data to the host. Because data is logged in raw binary form, bandwidth requirements are low. The RTEgdbData tool for transferring binary log data to a host using the debug probe GDB server is part of the RTEdbg project.

The toolkit can be used for any type of project, from small resource-constrained to large RTOS-based, including hard real-time or functional safety. Low stack requirements virtually eliminate the possibility of stack overflows after existing code instrumentation. Data logging functions are reentrant and do not disable interrupts if the microcontroller supports the exclusive access (mutex) instructions. See the RTEdbg Toolkit Suitability Guide for examples where the toolkit could be used.

Using this library avoids all the problems of non-reentrant printf-style debugging modes. All format strings are stored only on the host computer, where the decoding of the logged data is performed. Since the data is recorded in binary form, the number of functions is very small and it is possible to learn how to use them quickly. Format definitions are printf-style strings, so they are familiar to programmers.

Getting Started

Complete documentation can be found in the RTEdbg Manual. See the GETTING STARTED GUIDE section for quick start instructions and INTRODUCTION AND KEY FEATURES for a look at the main features and benefits. A ZIP file containing the complete documentation and demo projects is available on the download page.

RTEdbg Schematic Presentation

RTEdbg_presentation

The schematic shows how data logging can be integrated into embedded system firmware. Only a C source file with logging functions and some header files need to be added to the project. Any C or C++ code can be instrumented – including drivers, exception handlers, RTOS kernel. The logging functions store raw binary data in the circular buffer (no time-consuming data tagging or encoding). Any interface or media can be used to transfer data to the host for decoding and analysis, since only the contents of a data structure need be transferred. The captured data can be transferred to the host, decoded, and analyzed while the target code is running normally.

The RTEmsg utility performs offline decoding of binary data. Logged messages are decoded (printed) to files using fprintf-style format definitions (defined in C header files). The data logged with a log function call can hold multiple values, and each of them can be printed to any number of files using different format definitions (different print strings). This allows the decoded information to be sorted so that the important information is collected together and can be quickly reviewed by the tester (rather than having to search through a long main log file). This tool not only decodes and sorts the recorded data, but also generates statistical report for the decoded values and times, allowing testers to quickly find extreme values. If errors are found in the binary file or in the format definition files, they are reported in the Errors.log file.

Real-time systems generate a flood of data, and it is important to sort the data before analyzing it to quickly identify potential problems (data extremes, errors, warnings). Programmers specify how the logged data is printed and into how many output files it is sorted (printed). Important messages or values can be written to more than one output file, each value in a different format. Existing data and event analysis tools can be used because flexible data formatting allows adaptation to the needs of existing data/event analysis or graphing tools.

Repository Structure

The code and documentation for the libraries and tools can be found in the following repositories.

Repository Description
RTEdbg Main repository used to distribute the RTEdbg toolkit - see the Releases - download page. This repository does not contain any source code. See other repositories below for library and tool source code.
RTElib A re-entrant library of functions for minimally intrusive code instrumentation (data logging and tracing). Functions collect data in a circular buffer in RAM.
RTEgdbData A tool for transferring binary log data to a host using the GDB server (it is part of the Debug Probe software). Other ways to transfer data to the host are described in the RTEdbg manual.
RTEmsg Offline binary logged data decoding application that runs on the host.
RTEcomLib Functions for log data transfer to host via serial channel.
RTEcomLib_NUCLEO_C071RB_Demo Demo code for the RTEcomLib library running on the STM NUCLEO-C071RB demo board.
RTEcomData Utility for log data transfer to host via serial channel.

Note: Demo code is currently only included in the distribution ZIP files - see Releases.


Installation Instructions

The full toolkit can only be downloaded from download page. The toolkit is currently available for Windows only. Extract the ZIP file into the "c:\RTEdbg folder". This will ensure that the correct paths are used in the demo projects.

Demo Projects

Demo projects are currently only provided in the project distribution ZIP file. Complete settings are provided for the STM32CubeIDE, MCUXpresso, Keil MDK and IAR EWARM IDEs. Follow the instructions in the RTEdbg ManualDemo Projects. The demo projects also include a demonstration of how to transfer data from the embedded system to the host using the RTEgdbData utility (see "TEST RTEgdbData" folders) or using the tools that are part of the Debug Probe software.

How to Contribute or Get Help

Follow the Contributing Guidelines for bug reports and feature requests regarding the RTEdbg library. Source code for other parts of the toolkit will be released later, after their documentation has been translated to English. Please use RTEdbg.freeforums.net for general discussions about the RTEmsg application and the RTEdbg toolkit.

When asking a support question, be clear and take the time to explain your problem properly. If your problem is not strictly related to this project, we recommend that you use Stack Overflow or similar question-and-answer website instead. First, check if the RTEdbg manual already contains an answer to your question or a solution to your problem.

About the Author

The author works in real-time control and power electronics design for battery-powered systems. He has been developing his own debugging solutions since learning to program on a Sinclair ZX80. This project is the author's first universal toolkit. Credits go to Stefan Milivojčev, who participated in the development of the RTEmsg format definition parser as part of his master's thesis and helped with the Github workflows.

English is not the native language of the author. Google Translate and DeepL Write were used to improve the documentation. Thanks in advance for your comments and contributions that will help improve the library, tools, and documentation. This is the author's first open source project published on Github and his contribution to the open source community. Please be patient. The author is working on this project in his spare time.

Popular repositories Loading

  1. RTEdbg RTEdbg Public

    Fast and flexible data logging/tracing toolkit for software testing and debugging. Minimally intrusive C/C++ code instrumentation, host-based decoding application, demo code included.

    71 1

  2. RTElib RTElib Public

    Minimally intrusive binary data logging/tracing library

    C 5 2

  3. RTEmsg RTEmsg Public

    RTEdbg toolkit binary data decoding application

    C 4

  4. RTEgdbData RTEgdbData Public

    Utility for transferring log data to host using GDB Server

    C++ 1 1

  5. Extract_msg Extract_msg Public

    Processing of the message.h file for the compilation process of the RTEmsg utility

    C++

  6. RTEcomLib_NUCLEO_C071RB_Demo RTEcomLib_NUCLEO_C071RB_Demo Public

    Demo firmware for RTEcom running on NUCLEO_C071RB

    C