pub struct FpRev1CompX(pub u32);
Expand description
Flash Patch Comparator register, FP_COMPn (see armv7-M Architecture Reference Manual C1.11.5)
Tuple Fields§
§0: u32
Implementations§
Source§impl FpRev1CompX
impl FpRev1CompX
Sourcepub fn replace(&self) -> u32
pub fn replace(&self) -> u32
For an instruction address comparator:
Defines the behavior when the COMP address is matched:
00
Remap to remap address, see Flash Patch Remap register,
FP_REMAP on page C1-758.
When the comparators are enabled in the FP_CTRL register, if the implementation does not support remapping, the effect of an instruction address match with an enabled comparator with REPLACE programmed to 0b00 is UNPREDICTABLE.
01
: Breakpoint on instruction at '000':COMP:'00'
.
10
: Breakpoint on instruction at '000':COMP:'10'
.
11
: Breakpoint on both instructions at '000':COMP:'00'
and '000':COMP:'10'
.
The reset value of this field is UNKNOWN.
For a literal address comparator:
Field is UNK/SBZP
Sourcepub fn comp(&self) -> u32
pub fn comp(&self) -> u32
Bits[28:2] of the address to compare with addresses from the Code memory region, see The system address map on page B3-592. Bits[31:29] of the address for comparison are zero.
For a literal address or instruction address remap, bits[1:0] of the comparison are also zero.
For an instruction address breakpoint, bits[1:0] of the comparison are encoded by the REPLACE field.
If a match occurs:
- For an instruction address comparator, the REPLACE field defines the required action.
- For a literal address comparator, the FPB remaps the access, see Flash Patch Remap register, FP_REMAP on page C1-758.
The reset value of this field is UNKNOWN.
Sourcepub fn enable(&self) -> bool
pub fn enable(&self) -> bool
Enable bit for this comparator:
0
: Comparator disabled.
1
: Comparator enabled.
A power-on reset clears this bit to 0
.
Sourcepub fn set_replace(&mut self, value: u32)
pub fn set_replace(&mut self, value: u32)
For an instruction address comparator:
Defines the behavior when the COMP address is matched:
00
Remap to remap address, see Flash Patch Remap register,
FP_REMAP on page C1-758.
When the comparators are enabled in the FP_CTRL register, if the implementation does not support remapping, the effect of an instruction address match with an enabled comparator with REPLACE programmed to 0b00 is UNPREDICTABLE.
01
: Breakpoint on instruction at '000':COMP:'00'
.
10
: Breakpoint on instruction at '000':COMP:'10'
.
11
: Breakpoint on both instructions at '000':COMP:'00'
and '000':COMP:'10'
.
The reset value of this field is UNKNOWN.
For a literal address comparator:
Field is UNK/SBZP
Sourcepub fn set_comp(&mut self, value: u32)
pub fn set_comp(&mut self, value: u32)
Bits[28:2] of the address to compare with addresses from the Code memory region, see The system address map on page B3-592. Bits[31:29] of the address for comparison are zero.
For a literal address or instruction address remap, bits[1:0] of the comparison are also zero.
For an instruction address breakpoint, bits[1:0] of the comparison are encoded by the REPLACE field.
If a match occurs:
- For an instruction address comparator, the REPLACE field defines the required action.
- For a literal address comparator, the FPB remaps the access, see Flash Patch Remap register, FP_REMAP on page C1-758.
The reset value of this field is UNKNOWN.
Sourcepub fn set_enable(&mut self, value: bool)
pub fn set_enable(&mut self, value: bool)
Enable bit for this comparator:
0
: Comparator disabled.
1
: Comparator enabled.
A power-on reset clears this bit to 0
.
Trait Implementations§
Source§impl<T> BitRange<T> for FpRev1CompX
impl<T> BitRange<T> for FpRev1CompX
Source§impl<T> BitRangeMut<T> for FpRev1CompXwhere
u32: BitRangeMut<T>,
impl<T> BitRangeMut<T> for FpRev1CompXwhere
u32: BitRangeMut<T>,
Source§fn set_bit_range(&mut self, msb: usize, lsb: usize, value: T)
fn set_bit_range(&mut self, msb: usize, lsb: usize, value: T)
Source§impl Clone for FpRev1CompX
impl Clone for FpRev1CompX
Source§fn clone(&self) -> FpRev1CompX
fn clone(&self) -> FpRev1CompX
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for FpRev1CompX
impl Debug for FpRev1CompX
Source§impl From<FpRev1CompX> for u32
impl From<FpRev1CompX> for u32
Source§fn from(value: FpRev1CompX) -> Self
fn from(value: FpRev1CompX) -> Self
Source§impl From<u32> for FpRev1CompX
impl From<u32> for FpRev1CompX
Source§impl MemoryMappedRegister<u32> for FpRev1CompX
impl MemoryMappedRegister<u32> for FpRev1CompX
Source§const ADDRESS_OFFSET: u64 = 3_758_104_584u64
const ADDRESS_OFFSET: u64 = 3_758_104_584u64
Source§fn get_mmio_address_from_base(
base_address: u64,
) -> Result<u64, RegisterAddressOutOfBounds>
fn get_mmio_address_from_base( base_address: u64, ) -> Result<u64, RegisterAddressOutOfBounds>
MemoryMappedRegister::get_mmio_address
.Source§fn get_mmio_address() -> u64
fn get_mmio_address() -> u64
MemoryMappedRegister::ADDRESS_OFFSET
.
For other architectures (e.g. ARM Cortex-A) where this address is offset from a base address, please use MemoryMappedRegister::get_mmio_address_from_base
.impl Copy for FpRev1CompX
Auto Trait Implementations§
impl Freeze for FpRev1CompX
impl RefUnwindSafe for FpRev1CompX
impl Send for FpRev1CompX
impl Sync for FpRev1CompX
impl Unpin for FpRev1CompX
impl UnwindSafe for FpRev1CompX
Blanket Implementations§
Source§impl<T> BitMut for Twhere
T: BitRangeMut<u8>,
impl<T> BitMut for Twhere
T: BitRangeMut<u8>,
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.