Customize Consent Preferences

We use cookies to help you navigate efficiently and perform certain functions. You will find detailed information about all cookies under each consent category below.

The cookies that are categorized as "Necessary" are stored on your browser as they are essential for enabling the basic functionalities of the site. ... 

Always Active

Necessary cookies are required to enable the basic features of this site, such as providing secure log-in or adjusting your consent preferences. These cookies do not store any personally identifiable data.

No cookies to display.

Functional cookies help perform certain functionalities like sharing the content of the website on social media platforms, collecting feedback, and other third-party features.

No cookies to display.

Analytical cookies are used to understand how visitors interact with the website. These cookies help provide information on metrics such as the number of visitors, bounce rate, traffic source, etc.

No cookies to display.

Performance cookies are used to understand and analyze the key performance indexes of the website which helps in delivering a better user experience for the visitors.

No cookies to display.

Advertisement cookies are used to provide visitors with customized advertisements based on the pages you visited previously and to analyze the effectiveness of the ad campaigns.

No cookies to display.

RDK-V Debugging and Logging

Created on April 4, 2023

Debugging and logging are both inseparable aspects of any software system during it’s development as well as in the deployment stage. These tools greatly assist the developer & support teams to quickly find a solution.

  • Debugging tools and methodologies identifies what went wrong thus enabling developer to fix the issue quickly.
  • Logging enables to maintain a history of how a software or the piece of code behave in different environments (whether it is in development or in field deployment). It helps in catching nagging field issues which are otherwise impossible to reproduce in a simulated environment. Also the other advantage it provides by generating a solid data set for any analytics process.

Debugging

In the development process of a feature rich software like RDK, debugging the code or modules bears great significance.

An IDE provide great deal by helping to solve certain debug functionalities but when working with a Set-top, it is also important to have debuggers that can collect core dumps and real time code traces.

RDK supports following tools for making the debugging task easier for developers.

Logging

Presentation of system events, errors and application traces altogether in form of console messages or persistent log files constitutes the logging process in RDK.

Generating and reading system logs is an important aspect of system administration. The information in system logs can be used to detect hardware and software issues as well as application and system configuration errors. This information also plays an important role in assessing device health, security loopholes and incident response.

There are multiple levels of logging supported by RDK right from having the native Linux syslog (or more recently : journal logs) facility to having a dedicated logging facility such as RDK logger library.

RDK Logger

Description

RDK Logger is responsible for centralizing logging feature which otherwise was done by printf or other similar functionalities. It provides enable/disable log feature as well as defines logging levels thus providing a way to control amount of outgoing log messages. Available as a library, it can be easily plugged into different application to enable them in creating logs in a way that is common among the RDK system.

Capabilities

  • Abstracts logging client from underlying logging utility.
  • Dynamically enable/disable logging level at run time.
  • Provide logging format that complies with the existing format understood across RDK components(e.g. <timestamp> [mod=*, level=*]).

A detailed description on the RDK logger component can be found here: RDK Logger

Systemd Journals

systemd has its own logging system called the journal; therefore, running a syslog daemon is no longer required.

  • Journal stores all logs in a specified folder
  • journalctl allows you to filter the output as needed
  • In order to comply with the RDK logging formats, journalctl is used to redirect logs to specific module level log .txt files
  • The future plan is to switch to using journald systems-journal-upload to upload logs