Skip to content

Latest commit

 

History

History
52 lines (41 loc) · 1.8 KB

README.md

File metadata and controls

52 lines (41 loc) · 1.8 KB

Trace Tools

This is a repo of trace dumping and analysis tools based on the STF format.

These are built for RISC-V use, but can be augmented for other architectures.

Required Packages

Install all packages needed to build stf_lib.

Building

mkdir release
cd release
cmake .. -DCMAKE_BUILD_TYPE=Release
make

Or for debug:

mkdir debug
cd debug
cmake .. -DCMAKE_BUILD_TYPE=Debug
make

Ensure you have cython installed on your machine, can be done easily using

pip3 install cython

OS X users may need to add the following to their cmake invocation if Python was installed via Homebrew:

-DPYTHON_LIBRARY=$(python3-config --prefix)/lib/libpython3.8.dylib -DPYTHON_INCLUDE_DIR=$(python3-config --prefix)/include/python3.8

Ubuntu users may need to install the following dependencies for binutils

sudo apt-get install libmpc-dev liblzma-dev libbz2-dev

May also need to install the following dependencies for libdwarf

sudo apt-get install autoconf automake libtool pkg-config

RISC-V Disassembly Support

RISC-V binutils is the default disassembly backend. You can optionally use the Mavis backend instead.

Different RISC-V ISA extensions can be activated by setting the STF_DISASM_ISA environment variable. It defaults to rv64gcv_zba_zbb.

The Mavis disassembly backend can be selected by setting the environment variable STF_DISASM=MAVIS.

Building binutils can optionally be disabled by running cmake with -DDISABLE_BINUTILS=1. In this case the tools will automatically default to using Mavis.