#![warn(clippy::all)]
#![warn(rust_2018_idioms)]
#![deny(missing_docs)]
#![deny(unsafe_code)]
#![warn(
clippy::all,
clippy::await_holding_lock,
clippy::dbg_macro,
clippy::debug_assert_with_mut_call,
clippy::doc_markdown,
clippy::empty_enum,
clippy::enum_glob_use,
clippy::exit,
clippy::explicit_into_iter_loop,
clippy::filter_map_next,
clippy::fn_params_excessive_bools,
clippy::if_let_mutex,
clippy::imprecise_flops,
clippy::inefficient_to_string,
clippy::large_types_passed_by_value,
clippy::let_unit_value,
clippy::linkedlist,
clippy::lossy_float_literal,
clippy::macro_use_imports,
clippy::map_err_ignore,
clippy::map_flatten,
clippy::map_unwrap_or,
clippy::match_on_vec_items,
clippy::match_same_arms,
clippy::match_wildcard_for_single_variants,
clippy::mem_forget,
clippy::mismatched_target_os,
clippy::needless_borrow,
clippy::needless_continue,
clippy::option_option,
clippy::pub_enum_variant_names,
clippy::ref_option_ref,
clippy::rest_pat_in_fully_bound_structs,
clippy::string_add_assign,
clippy::string_add,
clippy::string_to_string,
clippy::suboptimal_flops,
clippy::todo,
clippy::unimplemented,
clippy::unnested_or_patterns,
clippy::unused_self,
clippy::verbose_file_reads,
future_incompatible,
nonstandard_style,
rust_2018_idioms
)]
#![allow(unsafe_code)]
use rpmalloc_sys as ffi;
use std::alloc::{GlobalAlloc, Layout};
use std::mem::MaybeUninit;
pub struct RpMalloc;
unsafe impl GlobalAlloc for RpMalloc {
unsafe fn alloc(&self, layout: Layout) -> *mut u8 {
ffi::rpaligned_alloc(layout.align(), layout.size()) as *mut u8
}
unsafe fn alloc_zeroed(&self, layout: Layout) -> *mut u8 {
ffi::rpaligned_calloc(layout.align(), 1, layout.size()) as *mut u8
}
unsafe fn dealloc(&self, ptr: *mut u8, _layout: Layout) {
ffi::rpfree(ptr as *mut ffi::c_void)
}
}
impl RpMalloc {
pub fn global_stats() -> ffi::rpmalloc_global_statistics_t {
let mut stats: MaybeUninit<ffi::rpmalloc_global_statistics_t> = MaybeUninit::uninit();
unsafe {
ffi::rpmalloc_global_statistics(stats.as_mut_ptr());
stats.assume_init()
}
}
pub fn thread_stats() -> ffi::rpmalloc_thread_statistics_t {
let mut stats: MaybeUninit<ffi::rpmalloc_thread_statistics_t> = MaybeUninit::uninit();
unsafe {
ffi::rpmalloc_thread_statistics(stats.as_mut_ptr());
stats.assume_init()
}
}
}