GitXplorerGitXplorer
f

shuffling-allocator

public
24 stars
3 forks
0 issues

Commits

List of commits on branch main.
Unverified
983334621d6c6fd6aa4d40d24edd3221208bf085

Bump to version 1.1.2

ffitzgen committed 4 years ago
Unverified
26539fc39e89eedc3fb4629c9dffb39213053fc1

Fix typos in docs

ffitzgen committed 4 years ago
Verified
44d056ea286e80ebd17e2cc0cfc5cff6b9c7c20a

Merge pull request #2 from alexcrichton/update-rand

ffitzgen committed 4 years ago
Unverified
e3061b709dec23721a8677383a8ce63bb10e5403

Update rand dependency to 0.8

aalexcrichton committed 4 years ago
Unverified
c8bad85f491294510f32792c3c406889201173c3

Bump to version 1.1.1

ffitzgen committed 4 years ago
Verified
1d9d4fa6bac9d4d342ebb135e296e28ef825cbc7

Merge pull request #1 from fitzgen/add-windows-support

ffitzgen committed 4 years ago

README

The README file for this repository.

shuffling-allocator

A shuffling allocator.

This crate provides the ShufflingAllocator type, which wraps an existing allocator and shuffles the order of heap allocations it yields, effectively randomizing the placement of heap allocations.

Randomizing the locations of heap allocations is useful for testing, benchmarking, and performance evaluation. It helps you separate the performance effects of a given code change from accidental heap object locality and the effects this may have on performance due to memory caches in the CPU. This is the use case that this crate focuses on.

While randomizing the locations of heap allocations can also be used for defense-in-depth security, similar to ASLR, this crate is not written to support that use case. As a result, this crate may not be the right choice if your use case is the defense-in-depth security use case. Some trade offs and design decisions made in this crate's implementation might not be the choices you want for your use case.

This crate is inspired by the allocator described in Stabilizer: Statistically Sound Performance Evaluation by Curtsinger and Berger.

How Does It Work?

An array of available objects for each size class is always maintained. Allocating a new object involves making the allocation, choosing a random index in the array, swapping the new allocation for array[i] and returning the swapped out value. Freeing an object is similar: choose a random index in the array, swap the pointer being freed with array[i], and then use the underlying allocator to actually free the swapped out pointer. The larger the array in the shuffling layer, the closer to truly randomized heap allocations we get, but also the greater the overhead. Curtsinger and Berger found that arrays of size 256 gave good randomization for acceptable overhead, and that is also the array size that this crate uses.

Example

Wrap the system allocator in a ShufflingAllocator, randomizing the location of the system allocator's heap objects:

use shuffling_allocator::ShufflingAllocator;
use std::alloc::System;

static SHUFFLED_SYSTEM_ALLOC: ShufflingAllocator<System> =
    shuffling_allocator::wrap!(&System);