Skip to content

Mimalloc implemented in Rust (not a binding to the C library) with only basic features.

License

Notifications You must be signed in to change notification settings

ouuan/baby-mimalloc

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

baby-mimalloc

Crates.io Version docs.rs

Mimalloc implemented in Rust (not a binding to the C library) with only basic features.

Lock-free multi-threading, security features, and some performance enhancements are not implemented.

It can be used in no_std environments.

Crate Features

  • mmap - Provide MimallocMmap that uses mmap as OS allocator for segments.
  • std_mutex - Provide MimallocMutexWrapper that wraps Mimalloc inside std::sync::Mutex and implements GlobalAlloc.
  • spin_mutex - Provide MimallocMutexWrapper that wraps Mimalloc inside spin::Mutex that can be used in no_std environments.
  • deferred_free - Enable registering a hook to complete deferred free events. See the documentation of mi_register_deferred_free.

Usage

[dependencies]
baby-mimalloc = { version = "*", features = ["mmap", "std_mutex"] }
# baby-mimalloc = { version = "*", features = ["mmap", "spin_mutex"] }
use baby_mimalloc::{new_mimalloc_mmap_mutex, MimallocMmapMutex};

#[global_allocator]
static ALLOCATOR: MimallocMmapMutex = new_mimalloc_mmap_mutex();

About

Mimalloc implemented in Rust (not a binding to the C library) with only basic features.

Resources

License

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages