#x86-64 #msr #linux #x86-64-linux

msru

A Rust-safe library for interracting with Model Specific Registers in user-space

2 unstable releases

0.2.0 May 25, 2023
0.1.0 May 19, 2023

#5 in #msr

Download history 423/week @ 2025-11-14 391/week @ 2025-11-21 365/week @ 2025-11-28 389/week @ 2025-12-05 250/week @ 2025-12-12 214/week @ 2025-12-19 272/week @ 2025-12-26 484/week @ 2026-01-02 453/week @ 2026-01-09 576/week @ 2026-01-16 552/week @ 2026-01-23 776/week @ 2026-01-30 768/week @ 2026-02-06 1138/week @ 2026-02-13 1355/week @ 2026-02-20 1082/week @ 2026-02-27

4,440 downloads per month
Used in 3 crates

Apache-2.0

7KB
71 lines

As most of the existing crates require kernel-mode, this provides a Rust-friendly interface for reading and writing to MSRs while in user-space. This does require the msr kernel module to be loaded.

Currently this crate only supports Linux.


msru

msru provides a Rust-friendly interface for x86_64 CPU MSRs (Model Specific Registers). It allows you to read and write to MSRs via a specified CPU msr device file (/dev/cpu/{cpu_number}/msr).

Installation

Add the following line to your Cargo.toml file:

[dependencies]
msru = "0.2.0"

Usage

use msru::Msr;

// X86_64 SYSCFG MSR
let msr: Msr = Msr::new(0xC0010010, 0)?;

let raw_value: u64 = msr.read()?;

// ...

No runtime deps