Skip to content

Commit

Permalink
Add README, improve descriptions
Browse files Browse the repository at this point in the history
  • Loading branch information
hky1999 committed Oct 12, 2024
1 parent 5b61f01 commit 4c02dc1
Show file tree
Hide file tree
Showing 3 changed files with 67 additions and 11 deletions.
10 changes: 9 additions & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,14 @@
name = "cpumask"
version = "0.1.0"
edition = "2021"
authors = ["[email protected]"]
description = "CPU mask library in Rust"
license = "GPL-3.0-or-later OR Apache-2.0 OR MulanPSL-2.0"
homepage = "https://github.com/arceos-org/arceos"
repository = "https://github.com/arceos-org/cpumask"
documentation = "https://docs.rs/cpumask"
keywords = ["arceos", "cpu-affinity", "cpumask"]
categories = ["os", "no-std"]

[dependencies]
bitmaps = { version = "3.2.1", default-features = false }
bitmaps = { version = "3.2.1", default-features = false }
57 changes: 57 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
# cpumask

[![Crates.io](https://img.shields.io/crates/v/cpumask)](https://crates.io/crates/cpumask)
[![Docs.rs](https://docs.rs/cpumask/badge.svg)](https://docs.rs/cpumask)
[![CI](https://github.com/arceos-org/cpumask/actions/workflows/ci.yml/badge.svg?branch=main)](https://github.com/arceos-org/cpumask/actions/workflows/ci.yml)

CPU mask library

Cpumasks provide a bitmap suitable for representing the set of CPUs in a system, one bit position per CPU number.
In general, only nr_cpu_ids (<= NR_CPUS) bits are valid.
Refering to `cpumask_t` in Linux.
Reference:

* <https://man7.org/linux/man-pages/man2/sched_setaffinity.2.html>
* <https://man7.org/linux/man-pages/man3/CPU_SET.3.html>
* <https://elixir.bootlin.com/linux/v6.11/source/include/linux/cpumask_types.h>

## Examples

```Rust
use cpumask::CpuMask;
const SMP: usize = 32;

let mut cpumask = CpuMask::<SMP>::new();

assert!(cpumask.is_empty());
cpumask.set(0, true);

assert!(!cpumask.is_empty());
assert!(cpumask.get(0));
assert_eq!(cpumask.len(), 1);

assert!(!cpumask.set(1, true));
assert_eq!(cpumask.len(), 2);
assert_eq!(cpumask.first_false_index(), Some(2));

let mut oneshot = CpuMask::<SMP>::one_shot(SMP - 1);
assert!(!oneshot.is_empty());
assert!(oneshot.get(SMP - 1));
assert_eq!(oneshot.first_index(), Some(SMP - 1));
assert_eq!(oneshot.len(), 1);

oneshot.set(0, false);
assert!(!oneshot.is_empty());
oneshot.set(SMP - 1, false);
assert!(oneshot.is_empty());
assert_eq!(oneshot.len(), 0);
assert_eq!(oneshot.first_index(), None);

let mut cpumask_full = CpuMask::<SMP>::full();
assert_eq!(cpumask_full.len(), SMP);
assert_eq!(cpumask_full.first_index(), Some(0));
assert_eq!(cpumask_full.first_false_index(), None);
cpumask_full.set(SMP-1, false);
assert_eq!(cpumask_full.len(), SMP - 1);
assert_eq!(cpumask_full.first_false_index(), Some(SMP-1));
```
11 changes: 1 addition & 10 deletions src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,14 +1,5 @@
//! CPU mask library
//! Cpumasks provide a bitmap suitable for representing the set of CPUs in a system,
//! one bit position per CPU number.
//! In general, only nr_cpu_ids (<= NR_CPUS) bits are valid.
//! Refering to `cpumask_t` in Linux.
//! Reference:
//! * <https://man7.org/linux/man-pages/man2/sched_setaffinity.2.html>
//! * <https://man7.org/linux/man-pages/man3/CPU_SET.3.html>
//! * <https://elixir.bootlin.com/linux/v6.11/source/include/linux/cpumask_types.h>
#![cfg_attr(not(test), no_std)]
#![doc = include_str!("../README.md")]

use core::hash::{Hash, Hasher};
use core::ops::*;
Expand Down

0 comments on commit 4c02dc1

Please sign in to comment.