An open API service indexing awesome lists of open source software.

https://github.com/embarkstudios/rpmalloc-rs

🐏 rpmalloc global memory allocator for Rust 🦀
https://github.com/embarkstudios/rpmalloc-rs

memory-allocation rpmalloc rust rust-crate

Last synced: 6 months ago
JSON representation

🐏 rpmalloc global memory allocator for Rust 🦀

Awesome Lists containing this project

README

          

# `🐏 rpmalloc-rs`

**Cross-platform Rust global memory allocator using [rpmalloc](https://github.com/rampantpixels/rpmalloc).**

[![Embark](https://img.shields.io/badge/embark-open%20source-blueviolet.svg)](https://embark.dev)
[![Embark](https://img.shields.io/badge/discord-ark-%237289da.svg?logo=discord)](https://discord.gg/dAuKfZS)
[![Crates.io](https://img.shields.io/crates/v/rpmalloc.svg)](https://crates.io/crates/rpmalloc)
[![Docs](https://docs.rs/rpmalloc/badge.svg)](https://docs.rs/rpmalloc)
[![dependency status](https://deps.rs/repo/github/EmbarkStudios/rpmalloc-rs/status.svg)](https://deps.rs/repo/github/EmbarkStudios/rpmalloc-rs)
[![Build Status](https://github.com/EmbarkStudios/rpmalloc-rs/workflows/CI/badge.svg)](https://github.com/EmbarkStudios/rpmalloc-rs/actions?workflow=CI)

## Overview

See the [rpmalloc README](https://github.com/mjansson/rpmalloc/blob/master/README.md) for a detailed description of how the allocator works, peforms, and compares with other allocators.

## How to use

To use rpmalloc as the global allocator in your Rust binary crate, in `Cargo.toml` add:

```toml
[dependencies]
rpmalloc = "0.2.0"
```

And then in one of your `.rs` files:

```rust
#[global_allocator]
static ALLOC: rpmalloc::RpMalloc = rpmalloc::RpMalloc;
```

### Configuration

It is also possible to configure how the allocator should be built through a set of feature flags that correspond to the rpmalloc C library `ENABLE_x` defines:

- Overall: `statistics`, `validate_args`, `asserts`, `guards`
- Cache: `unlimited_cache`, `unlimited_global_cache`, `unlimited_thread_cache`, `global_cache`, `thread_cache`, `adaptive_thread_cache`

Example usage:

```toml
[dependencies]
rpmalloc = { version = "0.2.0", features = ["guards", "statistics"] }
```

See [rpmalloc README](https://github.com/mjansson/rpmalloc/blob/master/README.md) for detailed descriptions of the config options.

Note that all of these have not been tested together with this Rust crate.

## Support

This crate has been tested to support the following platforms and Rust targets:

- `x86_64-pc-windows-msvc`
- `x86_64-apple-darwin`
- `x86_64-unknown-linux-gnu`

PRs to increase the amount of supported targets are welcome, but they should add CI verification and avoid adding additional dependencies.

## Contributing

[![Contributor Covenant](https://img.shields.io/badge/contributor%20covenant-v1.4-ff69b4.svg)](../CODE_OF_CONDUCT.md)

We welcome community contributions to this project.

Please read our [Contributor Guide](CONTRIBUTING.md) for more information on how to get started.

## License

Licensed under either of

* Apache License, Version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
* MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)

at your option.

Note that the [rpmalloc](https://github.com/rampantpixels/rpmalloc) library this crate uses is under public domain, and can also be licensed under MIT.

### Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.