6 releases (breaking)
0.4.0+9.0.241217 | Dec 19, 2024 |
---|---|
0.3.0+9.0.240925 | Dec 4, 2024 |
0.2.2+9.0.240925 | Nov 16, 2024 |
0.1.0+9.0.240930 | Sep 30, 2024 |
0.0.0 | Aug 28, 2024 |
#1265 in Development tools
420 downloads per month
Used in 4 crates
13KB
134 lines
idalib
Idiomatic Rust bindings for the IDA SDK, enabling the development of standalone analysis tools using IDA v9.0’s idalib.
IDA support and dependencies
The bindings and examples have been tested against IDA Pro v9.0 on Windows (11), Linux (Ubuntu 24.04 LTS), and macOS Sequoia (Apple Silicon).
In addition to the latest v9.0 IDA SDK and IDA itself, a recent version of LLVM/Clang is required (this is to help generate bindings from the SDK), it can be obtained from, e.g., here.
Developing with idalib
For development, only the IDA SDK is required, whereas to run tests, an IDA installation (with a valid license) is required. During build, the crates locate the SDK and IDA installation using the following environment variables:
IDASDKDIR
set to the IDA Pro v9.0 SDKIDADIR
(optional) set to the directory containing theida
executable (e.g.,/Applications/IDA Professional v9.0/Contents/macOS
for macOS, or$HOME/ida-pro-9.0
for Linux). If not set, the build script will check common locations.
Projects using idalib
- xorpse/idalib-mp: example project demonstrating idalib + multi-processing.
- xorpse/parascope: mass-scan source/decompiled code using weggli rulesets.
- 0xdea/rhabdomancer: locate calls to insecure API functions in a binary file.
- 0xdea/haruspex: extract pseudo-code from the IDA Hex-Rays decompiler.
Examples
A minimal project to working with idalib
requires the following components:
Cargo.toml
:
name = "example-analyser"
# ...
[dependencies]
idalib = "0.4"
[build-dependencies]
idalib-build = "0.4"
build.rs
:
fn main() -> Result<(), Box<dyn std::error::Error>> {
idalib_build::configure_linkage()?;
Ok(())
}
src/main.rs
:
fn main() -> Result<(), Box<dyn std::error::Error>> {
let idb = idalib::IDB::open("/path/to/binary")?;
// ...
Ok(())
}
More comprehensive examples can be found in idalib/examples
. To run them:
Linux/macOS:
export IDASDKDIR=...
export IDADIR=...
cargo run --example=dump_ls
Windows:
$env:PATH="C:\Program Files\IDA Professional 9.0;$env:PATH"
$env:IDADIR="C:\Program Files\IDA Professional 9.0"
$env:IDASDKDIR=...
cargo run --example=dump_ls
Linking
The idalib-build
crate provides various build script helpers to simplify
linking:
idalib_build::configure_idalib_linkage
: links against(lib)ida
and(lib)idalib
in the IDA installation directory.idalib_build::configure_idasdk_linkage
: links against the(lib)ida
and(lib)idalib
stub libraries bundled with the SDK.idalib_build::configure_linkage
: links against the(lib)ida
and(lib)idalib
stub libraries and for Linux/macOS sets the RPATH to refer to the detected (or specified viaIDADIR
) installation directory.
⚠️ Warning: If you copy the build.rs
from idalib/examples
, you may encounter
unexpected behaviour when IDA is installed in a non-default location and
IDADIR
is not set, for example:
error while loading shared libraries: [libida.so]
This issue can be worked around by ensuring IDADIR
is correctly set at build
time, or by ensuring the (lib)ida
and (lib)idalib
shared libraries are
available to the dynamic linker at runtime, e.g., via LD_LIBRARY_PATH
or
/etc/ld.so.conf{,.d}
. Note that using the stub libraries provided by the SDK,
e.g., those located at $IDASDK/lib/...
as opposed to the
libraries in the IDA installation directory will result in
crashes.
For users wanting to use the build.rs
from idalib/examples
, e.g., so builds
succeed via GitHub
Actions
without an IDA installation, we recommend using the following build.rs
which
will help debug issues related to linking:
fn main() -> Result<(), Box<dyn std::error::Error>> {
let (_, ida_path, idalib_path) = idalib_build::idalib_install_paths_with(false);
if !ida_path.exists() || !idalib_path.exists() {
println!("cargo::warning=IDA installation not found.");
idalib_build::configure_idasdk_linkage();
} else {
idalib_build::configure_linkage()?;
}
Ok(())
}
Note that for idalib
-based tools being installed via
crates.io, e.g.,
rhabdomancer, the warning will only be
visible when installing with cargo -vv
, as explained in the cargo documentation:
The warning instruction tells Cargo to display a warning after the build script has finished running. Warnings are only shown for path dependencies (that is, those you’re working on locally), so for example warnings printed out in crates.io crates are not emitted by default. The -vv “very verbose” flag may be used to have Cargo display warnings for all crates.
Extending idalib
To expose unimplemented IDA SDK functionality, modify the idasdk-sys
crate,
add appropriate high-level wrappers in idalib
, and submit a pull request.
Ensure that the additions are portable and build with the latest SDK. We won't
accept PRs to support older beta releases.
Contributors
Please see CONTRIBUTORS.md for a full list of acknowledgments.
Dependencies
~135KB