16 unstable releases (4 breaking)

Uses old Rust 2015

0.8.1 Aug 3, 2023
0.8.0 Jan 26, 2023
0.7.6 Dec 1, 2022
0.7.5 Nov 29, 2022
0.5.9 Oct 10, 2017

#22 in Operating systems

Download history 300582/week @ 2024-09-18 325248/week @ 2024-09-25 676228/week @ 2024-10-02 726678/week @ 2024-10-09 687251/week @ 2024-10-16 259331/week @ 2024-10-23 202761/week @ 2024-10-30 215326/week @ 2024-11-06 202886/week @ 2024-11-13 182910/week @ 2024-11-20 93049/week @ 2024-11-27 157128/week @ 2024-12-04 194757/week @ 2024-12-11 113425/week @ 2024-12-18 47158/week @ 2024-12-25 96757/week @ 2025-01-01

490,933 downloads per month
Used in 216 crates (96 directly)

MIT/Apache

20KB
433 lines

core_affinity_rs is a Rust crate for managing CPU affinities. It currently supports Linux, Mac OSX, and Windows.

Documentation

Linux Status Build status

Example

This example shows how create a thread for each available processor and pin each thread to its corresponding processor.

extern crate core_affinity;

use std::thread;

// Retrieve the IDs of all cores on which the current
// thread is allowed to run.
// NOTE: If you want ALL the possible cores, you should
// use num_cpus.
let core_ids = core_affinity::get_core_ids().unwrap();

// Create a thread for each active CPU core.
let handles = core_ids.into_iter().map(|id| {
    thread::spawn(move || {
        // Pin this thread to a single CPU core.
        let res = core_affinity::set_for_current(id);
        if (res) {
          // Do more work after this.
        }
    })
}).collect::<Vec<_>>();

for handle in handles.into_iter() {
    handle.join().unwrap();
}

Platforms

core_affinity_rs should work on Linux, Windows, Mac OSX, FreeBSD, and Android.

core_affinity_rs is continuously tested on:

  • x86_64-unknown-linux-gnu (Linux)
  • i686-unknown-linux-gnu
  • x86_64-unknown-linux-musl (Linux w/ MUSL)
  • i686-unknown-linux-musl
  • x86_64-apple-darwin (Mac OSX)
  • i686-apple-darwin
  • x86_64-pc-windows-msvc (Windows)
  • i686-pc-windows-msvc
  • x86_64-pc-windows-gnu
  • i686-pc-windows-gnu

core_affinity_rs is continuously cross-compiled for:

  • arm-unknown-linux-gnueabihf
  • aarch64-unknown-linux-gnu
  • mips-unknown-linux-gnu
  • aarch64-unknown-linux-musl
  • i686-linux-android
  • x86_64-linux-android
  • arm-linux-androideabi
  • aarch64-linux-android

Dependencies

~28–250KB