# `acid_alloc` [![CI](https://github.com/dataphract/acid_alloc/actions/workflows/ci.yaml/badge.svg)](https://github.com/dataphract/acid_alloc/actions) [![crates-io](https://img.shields.io/crates/v/acid_alloc.svg)](https://crates.io/crates/acid_alloc) [![api-docs](https://docs.rs/acid_alloc/badge.svg)](https://docs.rs/acid_alloc) ## Bare-metal allocators. This crate provides allocators that are suitable for use on bare metal or with OS allocation facilities like `mmap(2)`/`brk(2)`. The following allocator types are available: - **`Buddy`, a binary-buddy allocator**. O(log2_levels_) worst-case allocation and deallocation. Supports splitting and coalescing blocks by powers of 2. Good choice for periodic medium-to-large allocations. - **`Bump`, a bump allocator**. O(1) allocation. Extremely fast to allocate and flexible in terms of allocation layout, but unable to deallocate individual items. Good choice for allocations that will never be deallocated or that will be deallocated en masse. - **`Slab`, a slab allocator**. O(1) allocation and deallocation. All allocated blocks are the same size, making this allocator a good choice when allocating many similarly-sized objects. ## Features All allocators provided by this crate are available in a `#![no_std]`, `#![cfg(no_global_oom_handling)]` environment. Additional functionality is available when enabling feature flags:
Flag | Default? | Requires nightly? | Description |
---|---|---|---|
sptr |
Yes | No |
Uses the sptr polyfill for Strict Provenance.
|
unstable |
No | Yes |
Exposes constructors for allocators backed by implementors of the
unstable Allocator trait, and enables the internal use of
nightly-only Rust features. Obviates sptr .
|
alloc |
No | No | Exposes constructors for allocators backed by the global allocator. |