| # buddy_system_allocator |
| |
| [![Crates.io version][crate-img]][crate] |
| [![docs.rs][docs-img]][docs] |
| |
| An (almost) drop-in replacement for [phil-opp/linked-list-allocator](https://github.com/phil-opp/linked-list-allocator). But it uses buddy system instead. |
| |
| ## Usage |
| |
| To use buddy_system_allocator for global allocator: |
| |
| ```rust |
| use buddy_system_allocator::LockedHeap; |
| |
| #[global_allocator] |
| static HEAP_ALLOCATOR: LockedHeap = LockedHeap::<32>::empty(); |
| ``` |
| |
| To init the allocator: |
| |
| ```rust |
| unsafe { |
| HEAP_ALLOCATOR.lock().init(heap_start, heap_size); |
| // or |
| HEAP_ALLOCATOR.lock().add_to_heap(heap_start, heap_end); |
| } |
| ``` |
| |
| You can also use `FrameAllocator` and `LockedHeapWithRescue`, see their documentation for usage. |
| |
| ## Features |
| |
| - **`alloc`** (default): Provide `FrameAllocator` and `LockedFrameAllocator`, which depend on a |
| global allocator. |
| - **`use_spin`** (default): Provide a `LockedHeap` type that implements the [`GlobalAlloc`] trait by |
| using a spinlock. |
| |
| [`GlobalAlloc`]: https://doc.rust-lang.org/nightly/core/alloc/trait.GlobalAlloc.html |
| |
| ## License |
| |
| Some code comes from phil-opp's linked-list-allocator. |
| |
| Licensed under MIT License. Thanks phill-opp's linked-list-allocator for inspirations and interface. |
| |
| [crate-img]: https://img.shields.io/crates/v/buddy_system_allocator.svg |
| [crate]: https://crates.io/crates/buddy_system_allocator |
| [docs-img]: https://docs.rs/buddy_system_allocator/badge.svg |
| [docs]: https://docs.rs/buddy_system_allocator |