5 releases
0.1.2 | Nov 25, 2024 |
---|---|
0.1.1 | Nov 9, 2024 |
0.1.0 | Nov 9, 2024 |
0.0.1-rc.1 | Nov 6, 2024 |
0.0.0 | Oct 29, 2024 |
#166 in Procedural macros
Used in 2 crates
78KB
1.5K
SLoC
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!
andoffsets!
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.
Dependencies
~2–17MB
~234K SLoC