Home

Awesome

<h1 align="center">Cartographer</h1> <h3 align="center">Mapping Out Code Coverage</h3> <p align="center"> <a href="https://github.com/nccgroup/Cartographer/releases/latest"><img src="https://img.shields.io/github/v/release/nccgroup/Cartographer" alt="Version"></a> <a href="https://github.com/nccgroup/Cartographer/actions"><img src="https://img.shields.io/github/actions/workflow/status/nccgroup/Cartographer/build.yml" alt="Build Status"></a> <a href="LICENSE"><img src="https://img.shields.io/github/license/nccgroup/Cartographer" alt="License"></a> <br> <img src="https://img.shields.io/github/watchers/nccgroup/Cartographer" alt="Watchers"> <img src="https://img.shields.io/github/stars/nccgroup/Cartographer" alt="Stars"> <img src="https://img.shields.io/github/downloads/nccgroup/Cartographer/total" alt="Downloads"> </p>

Developed by Austin Peavy - https://github.com/aus10pv

Released as open source by NCC Group Plc - https://www.nccgroup.com/
Released under the Apache 2.0 license (see LICENSE for more information)

Cartographer interface

Description

Cartographer is a code coverage mapping plugin for Ghidra, enabling researchers to observe which parts of a program have been executed without requiring source code.

Table of Contents

Key Features

Installation

The latest stable version of Cartographer can be downloaded from the Releases page.

Loading the Plugin

  1. Launch Ghidra.
  2. Navigate to the Install Extensions window.
    • File -> Install Extensions...
  3. Click the green "+" icon at the top-right corner.
  4. Select the downloaded ZIP file to load the plugin into Ghidra.
  5. Click the "OK" button to exit the Install Extensions window.
  6. Restart Ghidra when prompted.

Usage

Once the plugin is loaded, there will be additional controls in the CodeBrowser window for working with code coverage data.

Loading Code Coverage Files

Code coverage files can be loaded via the Tools menu: Tools -> Code Coverage -> Load Code Coverage File(s)...

When a code coverage file is loaded, all of the coverage data is immediately highlighted in the Listing view and the Decompiler view.

Loading a code coverage file

Code Coverage Details

Detailed information about the coverage data for each function can be found within the Code Coverage window.

The Code Coverage window can be opened by navigating to Window -> Code Coverage, or by pressing Ctrl-Shift-C on Windows (Cmd-Shift-C on Mac).

This window shows various details about each function in the program:

Clicking on any function will navigate to the specified function in the Listing view and Decompiler view.

Opening the Code Coverage window

Searching and Filtering

The Filter input box can be used to search for a function by name.

Any of the data displayed in the coverage table can be used as a column filter.

Searching and filtering data

Swapping Between Coverages

The dropdown at the bottom-right of the Code Coverage window can be used to quickly and easily swap between loaded code coverage files.

Swapping between coverages

Expression Parser

The text box at the bottom of the Code Coverage window can be used to perform logical operations on loaded code coverage files.

This can be extremely useful for examining differences and similarities between different runs of a program.

Using the expression parser

Syntax

Below are the logical operators that can be used within the expression parser.

Coverages are referenced by their alphabetical IDs in the dropdown menu, such as A, B, XY, etc.

Each logical operation is grouped using parentheses, and expressions can be of any length or complexity.

Examples

  1. Show the code that was executed in both coverages A and B:

    A & B
    
  2. Show the executed code that was different between coverages A and B:

    A ^ B
    
  3. Show code that was only executed in B:

    B - A
    
  4. Combine all of the coverage data found in A and B, then find any differences from C:

    (A | B) ^ C
    

Contributing

Building from Source

Gradle can be used to build Cartographer from its source code.

  1. Clone the Cartographer GitHub repository.

    $ git clone https://github.com/nccgroup/Cartographer.git
    
  2. Enter the repository and build with gradle.

    $ cd Cartographer
    $ gradle -PGHIDRA_INSTALL_DIR=<ghidra_install_dir>
    
    • Replace <ghidra_install_dir> with the path to your local Ghidra installation path.
  3. After building, the plugin ZIP file will be located in the dist/ folder.

Reporting Bugs

If you've found a bug in Cartographer, please open an issue via GitHub.

Credits

Originally inspired by Lighthouse - https://github.com/gaasedelen/lighthouse