|  | ||
|---|---|---|
| .github/workflows | ||
| ci | ||
| jemalloc-ctl | ||
| jemalloc-sys | ||
| jemallocator | ||
| jemallocator-global | ||
| .gitignore | ||
| .gitmodules | ||
| Cargo.toml | ||
| CHANGELOG.md | ||
| LICENSE-APACHE | ||
| LICENSE-MIT | ||
| README.md | ||
tikv-jemallocator
This project is the successor of jemallocator.
The project is also published as jemallocator for historical reasons. The two crates are the same except names. For new projects, it's recommended to use tikv-xxx versions instead.
Links against
jemallocand provides aJemallocunit type that implements the allocator APIs and can be set as the#[global_allocator]
Overview
The jemalloc support ecosystem consists of the following crates:
- tikv-jemalloc-sys: builds and links against- jemallocexposing raw C bindings to it.
- tikv-jemallocator: provides the- Jemalloctype which implements the- GlobalAllocand- Alloctraits.
- tikv-jemalloc-ctl: high-level wrapper over- jemalloc's control and introspection APIs (the- mallctl*()family of functions and the MALLCTL NAMESPACE)'
Documentation
To use tikv-jemallocator add it as a dependency:
# Cargo.toml
[dependencies]
[target.'cfg(not(target_env = "msvc"))'.dependencies]
tikv-jemallocator = "0.6"
To set tikv_jemallocator::Jemalloc as the global allocator add this to your project:
// main.rs
#[cfg(not(target_env = "msvc"))]
use tikv_jemallocator::Jemalloc;
#[cfg(not(target_env = "msvc"))]
#[global_allocator]
static GLOBAL: Jemalloc = Jemalloc;
And that's it! Once you've defined this static then jemalloc will be used for
all allocations requested by Rust code in the same program.
Platform support
The following table describes the supported platforms:
- build: does the library compile for the target?
- run: do- tikv-jemallocatorand- tikv-jemalloc-systests pass on the target?
- jemalloc: do- tikv-jemalloc's tests pass on the target?
Tier 1 targets are tested on all Rust channels (stable, beta, and nightly). All other targets are only tested on Rust nightly.
| Linux targets: | build | run | jemalloc | 
|---|---|---|---|
| aarch64-unknown-linux-gnu | ✓ | ✓ | ✗ | 
| powerpc64le-unknown-linux-gnu | ✓ | ✓ | ✗ | 
| x86_64-unknown-linux-gnu(tier 1) | ✓ | ✓ | ✓ | 
| MacOSX targets: | build | run | jemalloc | 
| aarch64-apple-darwin | ✓ | ✓ | ✗ | 
Features
This crate provides following cargo feature flags:
- 
alloc_traitWhen thealloc_traitfeature of this crate is enabled, it also implements theAlloctrait, allowing usage in collections.
- 
defaultfeature isbackground_threads_runtime_support.
- 
The tikv-jemallocatorcrate re-exports the features of thetikv-jemalloc-sysdependency.
License
This project is licensed under either of
- Apache License, Version 2.0, (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in tikv-jemallocator by you, as defined in the Apache-2.0 license,
shall be dual licensed as above, without any additional terms or conditions.