21 releases

0.3.0 Jun 20, 2019
0.2.0 May 11, 2018
0.1.18 Feb 23, 2017
0.1.14 Jan 31, 2017

#230 in Hardware support

Download history 5275/week @ 2024-03-08 4782/week @ 2024-03-15 4629/week @ 2024-03-22 4577/week @ 2024-03-29 4765/week @ 2024-04-05 4707/week @ 2024-04-12 4764/week @ 2024-04-19 4388/week @ 2024-04-26 4820/week @ 2024-05-03 4860/week @ 2024-05-10 5374/week @ 2024-05-17 5316/week @ 2024-05-24 5774/week @ 2024-05-31 4850/week @ 2024-06-07 6615/week @ 2024-06-14 5253/week @ 2024-06-21

23,302 downloads per month
Used in 10 crates (7 directly)

MIT license

63KB
1K SLoC

Rust 1K SLoC // 0.0% comments Python 107 SLoC // 0.0% comments Assembly 53 SLoC Shell 27 SLoC // 0.2% comments

Portable Bitwise Manipulation Intrinsics

crates.io version Travis build status Coveralls.io code coverage Docs License

0b0000_0010_1001_1010

This #![no_std] library exposes safe and portable low-level bit manipulation instruction set architectures. The Minimum Supported Rust Version is 1.36.0.

For higher-level bitwise manipulations check the bitwise crate.

The intrinsics are exposed via traits named after their CPU instruction. These traits are implemented for all integer types except u128/i128.

The following ISAs are implemented:

The actual code generated depends on the integer types involved and the features supported by the target architecture.

Verified assembly

The check_asm.py script verifies the generated assembly of the intrinsics. It compiles the asm/arch_feature_*.rs for the appropriate architectures and target features and compares the assembly generated by rustc with that included in the corresponding asm/arch_feature_*.asm files.

License

Licensed under the MIT license.

Contribution

Yes please! Just note that all contributions shall be licensed as above without any additional terms or conditions.

No runtime deps