Skip to content

C++ Example Implementation of the Buddy Memory System

License

Notifications You must be signed in to change notification settings

lyrahgames/buddy-system

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Buddy Memory System

A simple example implementation of the buddy memory system. It was put into an easy-to-use C++ header-only library curently based on the build2 build system.

master
Current

Author

Requirements

  • C++17
  • build2 (or some manual work for other build systems)
  • x86 or x86_64 architecture (support for the bsr instruction)

Tested Platforms

  • Operating System: Linux
  • Compiler: GCC | Clang
  • Build System: build2

Usage with build2

Add this repository to the repositories.manifest file of your build2 package.

:
role: prerequisite
location: https://github.com/lyrahgames/buddy-system.git

Add the following entry to the manifest file with a possible version dependency.

depends: lyrahgames-buddy-system

Add these entries to your buildfile.

import libs = lyrahgames-buddy-system%lib{lyrahgames-buddy-system}
exe{your-executable}: {hxx cxx}{**} $libs

Installation

The standard installation process will only install the header-only library with some additional description, library, and package files.

bpkg -d build2-packages cc \
  config.install.root=/usr/local \
  config.install.sudo=sudo

Get the latest package release and build it.

bpkg build https://github.com/lyrahgames/buddy-system.git

Install the built package.

bpkg install lyrahgames-buddy-system

For uninstalling, do the following.

bpkg uninstall lyrahgames-buddy-system

If your package uses an explicit depends: lyrahgames-buddy-system make sure to initialize this dependency as a system dependency when creating a new configuration.

bdep init -C @build cc config.cxx=g++ "config.cxx.coptions=-O3" -- "?sys:lyrahgames-buddy-system/*"

Example

In the following two basic examples are shown on how to use the memory arena and the memory allocators. For more examples, take a look inside the examples directory where can you can further find the listed examples.

  • Random Allocation and Deallocation
  • Command-Line Interpreter for Allocations and Deallocations
  • Usage of Custom new and delete Operators

Bare-Bones Malloc and Free Example

#include <lyrahgames/buddy_system/buddy_system.hpp>

using namespace lyrahgames;

int main(){
    // Construct the allocator and reserve 2 GiB to manage.
    buddy_system::arena arena{size_t{1} << 31};
    // Allocate actual memory in bytes.
    void* ptr = arena.malloc(123);
    // Free the memory after usage by providing the pointer.
    arena.free(ptr);
}

C++ Containers with Buddy System Allocator

#include <vector>
//
#include <lyrahgames/buddy_system/buddy_system.hpp>

using namespace std;
using namespace lyrahgames;

template <typename T>
using my_vector = vector<T, buddy_system::allocator<T>>;

int main() {
  buddy_system::arena arena{size_t{1} << 12};  // 4096 B
  my_vector<int> v{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16},
                   arena};
}

API

Constructor

    lyrahgames::buddy_system::arena::arena(size_t s);

Bare-Bones Allocation Member Function

    void* lyrahgames::buddy_system::arena::malloc(size_t size) noexcept;

This function returns nullptr if allocation was not successful. Every pointer returned by a successful memory allocation is at least 64-byte aligned.

Throwing Allocation Member Function

    void* lyrahgames::buddy_system::arena::allocate(size_t size);

This functions throws std::bad_alloc if allocation was not successful. Otherwise, this function is the same as buddy_system::arena::malloc.

Bare-Bones Deallocation Member Function

    void lyrahgames::buddy_system::arena::free(void* address) noexcept;
    void lyrahgames::buddy_system::arena::deallocate(void* address) noexcept;

These functions do the same and do not throw any exception. If the given pointer was not allocated before by the system, nothing should happen.

Features

  • low memory consumption
  • fast allocation
  • expectation of fast deallocation
  • returned pointers are at least 64-byte aligned
  • thread-safe

Background

Implementation Details

  • no binary tree used
  • allocation sizes will be rounded to the next power of two together with page header
  • every page contains an 8-byte header with its size
  • table of one-directional linked lists stored with the use of the free memory blocks so no other dynamic memory management is needed
  • Threads lock the data structure when allocating or deallocating memory. Therefore allocations and deallocations are serialized.

References

Further Reading

About

C++ Example Implementation of the Buddy Memory System

Resources

License

Code of conduct

Stars

Watchers

Forks

Sponsor this project

Packages

No packages published