[![Crates.io](https://img.shields.io/crates/v/isr.svg)](https://crates.io/crates/isr) [![Downloads](https://img.shields.io/crates/d/isr.svg)](https://crates.io/crates/isr) [![Docs](https://docs.rs/isr/badge.svg)](https://docs.rs/isr/latest/isr/) [![License](https://img.shields.io/badge/license-MIT-blue.svg)](https://github.com/vmi-rs/isr/blob/master/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 ```rust,ignore 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::::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.