Branch Tracer for Linux


What is btrax? | The features of btrax | Screen shots | Link

The development of this program is partly supported by IPA (Information-Technology Promotion Agency, Japan).

What is btrax?

btrax(Branch Tracer for Linux) is a branch instruction tracer using the branch record mechanism that is the debugging function of Pentium4 and Xeon CPU. It can trace branch instruction of kernel, driver, application and library without making a change to the kernel source code. Traced log information is analyzed, and branch coverage information and the execution path can be displayed.

btrax programs

btrax consists of the following two parts. As for the branch instruction tracing part, the development result of another project shown as follows is included excluding the driver of the branch tracer. To facilitate the installation of btrax, these drivers are bundling it to the btrax package. The future, there is a possibility not to be bundled. Branch coverage information and the execution path can be displayed by the log analysis part. It is composed by the following programs.

Compile/Execution environment

Because btrax uses the debugging function of Pentium4 and Xeon CPU, the machine equipped with these processors is necessary.
The following are necessary to compile, and to execute btrax. Moreover, it is necessary to support the following by the kernel. btrax can work on the following environment.

The features of btrax

Getting trace log

btrax supports the application, library, kernel, and driver's trace. In the trace of the application and the kernel, the following points are different. Starting or terminating of the kernel trace uses the hook that is inserted by djprobe, and djprobe has the limitation in the hook insert point. Please refer to djprobe's home page for details.

Analyzing trace log

The range of the address to be analyzed can be specified. The following information can be analyzed and referred to. As the branch coverage information, the function coverage and branch execution coverage can be analyzed.
Moreover, it has an simple repetition check function, and it is possible to display it omitting repeating in the execution path analysis function.

Screen shots

Example of tracing application(dav) execution. Example of tracing since function ext3_unlink execution.

Link


All Right Reserved, Copyright (C) 2006, Hitachi, Ltd.
This website is hosted by SourceForge.net