diff --git a/CHANGELOG.md b/CHANGELOG.md index 6fdad6f3..237c4bc6 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/). ## [Unreleased] +- Add unsafe `write_bits` to all writtable registers - Revert #711 - Add `defmt` impls for `TryFromInterruptError`, riscv interrupt enums - Fix calculating `modifiedWriteValues` bitmasks with field arrays diff --git a/src/generate/generic.rs b/src/generate/generic.rs index 706b7e12..8b978732 100644 --- a/src/generate/generic.rs +++ b/src/generate/generic.rs @@ -478,7 +478,7 @@ macro_rules! bit_proxy { pub const fn width(&self) -> u8 { Self::WIDTH } - + /// Field offset #[inline(always)] pub const fn offset(&self) -> u8 { diff --git a/src/generate/generic_reg_vcell.rs b/src/generate/generic_reg_vcell.rs index b0ca0d5e..ad3ec646 100644 --- a/src/generate/generic_reg_vcell.rs +++ b/src/generate/generic_reg_vcell.rs @@ -179,6 +179,16 @@ impl Reg { result } + + /// Writes raw value to register. + /// + /// # Safety + /// + /// Unsafe as it passes value without checks. + #[inline(always)] + pub unsafe fn write_bits(&self, bits: REG::Ux) { + self.register.set(bits); + } } impl Reg {