#reference #pointers #static #distributed #serde

sys relative

A type to wrap vtable references such that they can be safely sent between other processes running the same binary

9 releases

0.2.2 Nov 21, 2019
0.2.1 Oct 31, 2019
0.1.5 Aug 10, 2019
0.1.4 Jul 31, 2019
0.1.0 Jul 21, 2018

#1698 in Encoding

Download history 109/week @ 2024-07-21 102/week @ 2024-07-28 125/week @ 2024-08-04 120/week @ 2024-08-11 109/week @ 2024-08-18 110/week @ 2024-08-25 100/week @ 2024-09-01 95/week @ 2024-09-08 86/week @ 2024-09-15 131/week @ 2024-09-22 108/week @ 2024-09-29 38/week @ 2024-10-06 64/week @ 2024-10-13 82/week @ 2024-10-20 82/week @ 2024-10-27 81/week @ 2024-11-03

313 downloads per month
Used in 10 crates (via serde_traitobject)

MIT/Apache

16KB
257 lines

relative

Crates.io MIT / Apache 2.0 licensed Build Status

Docs

A type to wrap vtable references such that they can be safely sent between other processes running the same binary.

References are adjusted relative to a base when (de)serialised, which is what enables it to work across binaries that are dynamically loaded at different addresses under multiple invocations.

It being the same binary is checked by serialising the build_id alongside the relative pointer, which is validated at deserialisation.

Example

Local process

use std::{fmt::Display, mem::transmute, raw::TraitObject};

let mut x: Box<dyn Display> = Box::new("hello world");
let x_ptr: *mut dyn Display = &mut *x;
let x_ptr: TraitObject = unsafe { transmute(x_ptr) };
let relative = unsafe { Vtable::<dyn Display>::from(&*x_ptr.vtable) };
// send `relative` to remote...

Remote process

// receive `relative`
let x: Box<&str> = Box::new("goodbye world");
let x_ptr = Box::into_raw(x);
let y_ptr = TraitObject { data: x_ptr.cast(), vtable: relative.to() as *const () as *mut () };
let y_ptr: *mut dyn Display = unsafe { transmute(y_ptr) };
let y: Box<dyn Display> = unsafe { Box::from_raw(y_ptr) };
println!("{}", y);
// prints "goodbye world"

License

Licensed under either of

at your option.

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~0.6–1.6MB
~28K SLoC