#linked-list #heap-allocator #allocator #kernel #heap #malloc #data-structures

no-std linked_list_allocator

Simple allocator usable for no_std systems. It builds a linked list from the freed blocks and thus needs no additional data structures.

44 releases

Uses old Rust 2015

0.10.5 Mar 4, 2023
0.10.4 Oct 10, 2022
0.10.3 Sep 6, 2022
0.10.1 Jul 7, 2022
0.1.2 Mar 5, 2016

#45 in Memory management

Download history 15083/week @ 2024-08-05 14731/week @ 2024-08-12 15337/week @ 2024-08-19 16383/week @ 2024-08-26 18487/week @ 2024-09-02 14390/week @ 2024-09-09 16076/week @ 2024-09-16 16472/week @ 2024-09-23 15371/week @ 2024-09-30 15104/week @ 2024-10-07 15803/week @ 2024-10-14 16653/week @ 2024-10-21 16159/week @ 2024-10-28 17154/week @ 2024-11-04 14962/week @ 2024-11-11 17660/week @ 2024-11-18

66,861 downloads per month
Used in 76 crates (37 directly)

Apache-2.0/MIT

69KB
1K SLoC

linked-list-allocator

Crates.io Build Status docs.rs

Usage

Create a static allocator in your root module:

use linked_list_allocator::LockedHeap;

#[global_allocator]
static ALLOCATOR: LockedHeap = LockedHeap::empty();

Before using this allocator, you need to init it:

pub fn init_heap() {
    let heap_start =;
    let heap_end =;
    let heap_size = heap_end - heap_start;
    unsafe {
        ALLOCATOR.lock().init(heap_start, heap_size);
    }
}

Features

  • use_spin (default): Provide a LockedHeap type that implements the GlobalAlloc trait by using a spinlock.
  • alloc_ref: Provide an implementation of the unstable AllocRef trait; requires nightly Rust.
    • Warning: The AllocRef trait is still regularly changed on the Rust side, so expect some regular breakage when using this feature.

License

This crate is dual-licensed under MIT or the Apache License (Version 2.0). See LICENSE-APACHE and LICENSE-MIT for details.

Dependencies

~37KB