Expand description
Provides wrapper types Volatile
, ReadOnly
, WriteOnly
, ReadWrite
, which wrap any copy-able type and allows for
volatile memory access to wrapped value. Volatile memory accesses are never optimized away by
the compiler, and are useful in many low-level systems programming and concurrent contexts.
The wrapper types do not enforce any atomicity guarantees; to also get atomicity, consider
looking at the Atomic
wrapper type found in libcore
or libstd
.
These wrappers do not depend on the standard library and never panic.
Dealing with Volatile Pointers
Frequently, one may have to deal with volatile pointers, eg, writes to specific memory locations. The canonical way to solve this is to cast the pointer to a volatile wrapper directly, eg:
use volatile::Volatile;
let mut_ptr = 0xFEE00000 as *mut u32;
let volatile_ptr = mut_ptr as *mut Volatile<u32>;
and then perform operations on the pointer as usual in a volatile way. This method works as all of the volatile wrapper types are the same size as their contained values.
Structs
A volatile wrapper which only allows read operations.
A wrapper type around a volatile variable, which allows for volatile reads and writes
to the contained value. The stored type needs to be Copy
, as volatile reads and writes
take and return copies of the value.
A volatile wrapper which only allows write operations.
Type Definitions
A volatile wrapper which allows both read and write operations;
functionally equivalent to the Volatile
type, as it is a type
alias for it.