isr

Crates.ioisr
lib.rsisr
version0.1.2
sourcesrc
created_at2024-10-29 20:34:51.564054
updated_at2024-11-25 00:58:18.832752
descriptionIntermediate Symbol Representation
homepagehttps://github.com/vmi-rs/isr
repositoryhttps://github.com/vmi-rs/isr
max_upload_size
id1427623
size16,488
Petr Beneš (wbenny)

documentation

README

Crates.io Downloads Docs License

Intermediate Symbol Representation

The isr crate provides a unified, version-agnostic way to access and utilize debugging symbols from various sources, including PDB files (Windows) and DWARF debug info (Linux). This allows developers to write code that interacts with different operating system versions without needing to hardcode offsets or constantly update for new releases.

Features

  • Unified Representation: Abstracts away the underlying symbol format (PDB, DWARF) into a common, easy-to-use structure.

  • Version Agnostic: Enables writing code that works seamlessly across different OS versions, avoiding the need for version-specific logic.

  • Fast Symbol Parsing: The ISR parsing process is highly optimized for speed, enabling quick access to symbol information.

  • Automated Symbol Download and Caching: For Windows, automatically downloads and caches PDB symbols based on CodeView information extracted from executables or the kernel itself.

    For Linux (currently Ubuntu), automatically downloads and extracts the kernel debug symbols and the System.map file.

  • Convenient Macros: Provides [symbols!] and [offsets!] macros for streamlined symbol definition and type-safe access in your code.

  • Codec Support: Supports multiple serialization formats (Bincode, JSON, MessagePack) for storing and loading profiles, letting users choose between speed and human-readability.

Usage

use isr::{
    cache::JsonCodec,
    download::pdb::CodeView,
    macros::{symbols, offsets, Field},
    IsrCache, Profile,
};

symbols! {
    struct Symbols {
        NtCreateFile: u64,
    }
}

offsets! {
    struct Offsets {
        struct _EPROCESS {
            UniqueProcessId: Field,
        }
    }
}

// Create a cache instance.
let cache = IsrCache::<JsonCodec>::new("cache")?;

// Use the CodeView information of the Windows 10.0.18362.356 kernel.
let entry = cache.entry_from_codeview(CodeView {
    path: String::from("ntkrnlmp.pdb"),
    guid: String::from("ce7ffb00c20b87500211456b3e905c471"),
})?;

// You can also use `entry_from_pe` method:
// let entry = cache.entry_from_pe("path/to/ntoskrnl.exe")?;

let profile = entry.profile()?;

// Instantiate your symbol and offset structures using the profile.
let symbols = Symbols::new(&profile)?;
let offsets = Offsets::new(&profile)?;

Downloading Ubuntu Kernel Profiles

Downloading the required files for creating an Ubuntu kernel profile can take a considerable amount of time due to the large size of the debug symbol packages. The download may exceed 1GB of data.

Additional Notes

People familiar with the Volatility 3 or Rekall framework might notice that the ISR format shares some conceptual similarities with their profiles (or Intermediate Symbol Format (ISF), respectively). All of them aim to provide a unified representation of kernel symbols and structures. However, it's crucial to note that the ISR format is not compatible with other frameworks. ISR is specifically designed for the [vmi] crate.

License

This project is licensed under the MIT license.

Commit count: 10

cargo fmt