Crates.io | plthook |
lib.rs | plthook |
version | 0.2.2 |
source | src |
created_at | 2021-07-29 21:34:02.702229 |
updated_at | 2021-08-12 21:29:32.657128 |
description | Bindings for the plthook library |
homepage | https://github.com/ayosec/plthook-rust |
repository | https://github.com/ayosec/plthook-rust.git |
max_upload_size | |
id | 428995 |
size | 97,880 |
This crates provides Rust bindings for the plthook library.
Please see the API documentation and the description in the plthook library for more details.
To print symbols in the current process:
use plthook::ObjectFile;
fn main() {
let object = ObjectFile::open_main_program().unwrap();
for symbol in object.symbols() {
println!("{:?} {:?}", symbol.func_address, symbol.name);
}
}
To replace a symbol:
use plthook::ObjectFile;
use std::mem::{self, MaybeUninit};
use std::os::raw::{c_char, c_int};
static mut ATOI_FN: MaybeUninit<fn(*const c_char) -> c_int> = MaybeUninit::uninit();
extern "C" fn neg_atoi(nptr: *const c_char) -> c_int {
let i = unsafe { (ATOI_FN.assume_init())(nptr) };
-i
}
fn main() {
let object = ObjectFile::open_main_program().expect("Failed to open main program");
unsafe {
let mut atoi_entry = object.replace("atoi", neg_atoi as *const _).unwrap();
ATOI_FN = MaybeUninit::new(mem::transmute(atoi_entry.original_address()));
atoi_entry.discard();
};
let i = unsafe { libc::atoi(b"100\0".as_ptr().cast()) };
assert_eq!(i, -100);
}