Struct SType

Source
pub struct SType { /* private fields */ }

Implementations§

Source§

impl SType

Source

pub const fn new() -> Self

Returns an instance with zero initialized data.

Source§

impl SType

Source

pub const fn into_bytes(self) -> [u8; 4]

Returns the underlying bits.

§Layout

The returned byte array is layed out in the same way as described here.

Source

pub const fn from_bytes(bytes: [u8; 4]) -> Self

Converts the given bytes directly into the bitfield struct.

Source§

impl SType

Source

pub fn opcode(&self) -> <B7 as Specifier>::InOut

Returns the value of opcode.

Source

pub fn opcode_or_err( &self, ) -> Result<<B7 as Specifier>::InOut, InvalidBitPattern<<B7 as Specifier>::Bytes>>

Returns the value of opcode.

#Errors

If the returned value contains an invalid bit pattern for opcode.

Source

pub fn with_opcode(self, new_val: <B7 as Specifier>::InOut) -> Self

Returns a copy of the bitfield with the value of opcode set to the given value.

#Panics

If the given value is out of bounds for opcode.

Source

pub fn with_opcode_checked( self, new_val: <B7 as Specifier>::InOut, ) -> Result<Self, OutOfBounds>

Returns a copy of the bitfield with the value of opcode set to the given value.

#Errors

If the given value is out of bounds for opcode.

Source

pub fn set_opcode(&mut self, new_val: <B7 as Specifier>::InOut)

Sets the value of opcode to the given value.

#Panics

If the given value is out of bounds for opcode.

Source

pub fn set_opcode_checked( &mut self, new_val: <B7 as Specifier>::InOut, ) -> Result<(), OutOfBounds>

Sets the value of opcode to the given value.

#Errors

If the given value is out of bounds for opcode.

Source

pub fn imm4_0(&self) -> <B5 as Specifier>::InOut

Returns the value of imm4_0.

Source

pub fn imm4_0_or_err( &self, ) -> Result<<B5 as Specifier>::InOut, InvalidBitPattern<<B5 as Specifier>::Bytes>>

Returns the value of imm4_0.

#Errors

If the returned value contains an invalid bit pattern for imm4_0.

Source

pub fn with_imm4_0(self, new_val: <B5 as Specifier>::InOut) -> Self

Returns a copy of the bitfield with the value of imm4_0 set to the given value.

#Panics

If the given value is out of bounds for imm4_0.

Source

pub fn with_imm4_0_checked( self, new_val: <B5 as Specifier>::InOut, ) -> Result<Self, OutOfBounds>

Returns a copy of the bitfield with the value of imm4_0 set to the given value.

#Errors

If the given value is out of bounds for imm4_0.

Source

pub fn set_imm4_0(&mut self, new_val: <B5 as Specifier>::InOut)

Sets the value of imm4_0 to the given value.

#Panics

If the given value is out of bounds for imm4_0.

Source

pub fn set_imm4_0_checked( &mut self, new_val: <B5 as Specifier>::InOut, ) -> Result<(), OutOfBounds>

Sets the value of imm4_0 to the given value.

#Errors

If the given value is out of bounds for imm4_0.

Source

pub fn funct3(&self) -> <B3 as Specifier>::InOut

Returns the value of funct3.

Source

pub fn funct3_or_err( &self, ) -> Result<<B3 as Specifier>::InOut, InvalidBitPattern<<B3 as Specifier>::Bytes>>

Returns the value of funct3.

#Errors

If the returned value contains an invalid bit pattern for funct3.

Source

pub fn with_funct3(self, new_val: <B3 as Specifier>::InOut) -> Self

Returns a copy of the bitfield with the value of funct3 set to the given value.

#Panics

If the given value is out of bounds for funct3.

Source

pub fn with_funct3_checked( self, new_val: <B3 as Specifier>::InOut, ) -> Result<Self, OutOfBounds>

Returns a copy of the bitfield with the value of funct3 set to the given value.

#Errors

If the given value is out of bounds for funct3.

Source

pub fn set_funct3(&mut self, new_val: <B3 as Specifier>::InOut)

Sets the value of funct3 to the given value.

#Panics

If the given value is out of bounds for funct3.

Source

pub fn set_funct3_checked( &mut self, new_val: <B3 as Specifier>::InOut, ) -> Result<(), OutOfBounds>

Sets the value of funct3 to the given value.

#Errors

If the given value is out of bounds for funct3.

Source

pub fn rs1(&self) -> <B5 as Specifier>::InOut

Returns the value of rs1.

Source

pub fn rs1_or_err( &self, ) -> Result<<B5 as Specifier>::InOut, InvalidBitPattern<<B5 as Specifier>::Bytes>>

Returns the value of rs1.

#Errors

If the returned value contains an invalid bit pattern for rs1.

Source

pub fn with_rs1(self, new_val: <B5 as Specifier>::InOut) -> Self

Returns a copy of the bitfield with the value of rs1 set to the given value.

#Panics

If the given value is out of bounds for rs1.

Source

pub fn with_rs1_checked( self, new_val: <B5 as Specifier>::InOut, ) -> Result<Self, OutOfBounds>

Returns a copy of the bitfield with the value of rs1 set to the given value.

#Errors

If the given value is out of bounds for rs1.

Source

pub fn set_rs1(&mut self, new_val: <B5 as Specifier>::InOut)

Sets the value of rs1 to the given value.

#Panics

If the given value is out of bounds for rs1.

Source

pub fn set_rs1_checked( &mut self, new_val: <B5 as Specifier>::InOut, ) -> Result<(), OutOfBounds>

Sets the value of rs1 to the given value.

#Errors

If the given value is out of bounds for rs1.

Source

pub fn rs2(&self) -> <B5 as Specifier>::InOut

Returns the value of rs2.

Source

pub fn rs2_or_err( &self, ) -> Result<<B5 as Specifier>::InOut, InvalidBitPattern<<B5 as Specifier>::Bytes>>

Returns the value of rs2.

#Errors

If the returned value contains an invalid bit pattern for rs2.

Source

pub fn with_rs2(self, new_val: <B5 as Specifier>::InOut) -> Self

Returns a copy of the bitfield with the value of rs2 set to the given value.

#Panics

If the given value is out of bounds for rs2.

Source

pub fn with_rs2_checked( self, new_val: <B5 as Specifier>::InOut, ) -> Result<Self, OutOfBounds>

Returns a copy of the bitfield with the value of rs2 set to the given value.

#Errors

If the given value is out of bounds for rs2.

Source

pub fn set_rs2(&mut self, new_val: <B5 as Specifier>::InOut)

Sets the value of rs2 to the given value.

#Panics

If the given value is out of bounds for rs2.

Source

pub fn set_rs2_checked( &mut self, new_val: <B5 as Specifier>::InOut, ) -> Result<(), OutOfBounds>

Sets the value of rs2 to the given value.

#Errors

If the given value is out of bounds for rs2.

Source

pub fn imm11_5(&self) -> <B7 as Specifier>::InOut

Returns the value of imm11_5.

Source

pub fn imm11_5_or_err( &self, ) -> Result<<B7 as Specifier>::InOut, InvalidBitPattern<<B7 as Specifier>::Bytes>>

Returns the value of imm11_5.

#Errors

If the returned value contains an invalid bit pattern for imm11_5.

Source

pub fn with_imm11_5(self, new_val: <B7 as Specifier>::InOut) -> Self

Returns a copy of the bitfield with the value of imm11_5 set to the given value.

#Panics

If the given value is out of bounds for imm11_5.

Source

pub fn with_imm11_5_checked( self, new_val: <B7 as Specifier>::InOut, ) -> Result<Self, OutOfBounds>

Returns a copy of the bitfield with the value of imm11_5 set to the given value.

#Errors

If the given value is out of bounds for imm11_5.

Source

pub fn set_imm11_5(&mut self, new_val: <B7 as Specifier>::InOut)

Sets the value of imm11_5 to the given value.

#Panics

If the given value is out of bounds for imm11_5.

Source

pub fn set_imm11_5_checked( &mut self, new_val: <B7 as Specifier>::InOut, ) -> Result<(), OutOfBounds>

Sets the value of imm11_5 to the given value.

#Errors

If the given value is out of bounds for imm11_5.

Trait Implementations§

Source§

impl CheckFillsUnalignedBits for SType

Source§

impl Clone for SType

Source§

fn clone(&self) -> SType

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for SType

Source§

fn fmt(&self, __bf_f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl PartialEq for SType

Source§

fn eq(&self, other: &SType) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Copy for SType

Source§

impl Eq for SType

Source§

impl StructuralPartialEq for SType

Auto Trait Implementations§

§

impl Freeze for SType

§

impl RefUnwindSafe for SType

§

impl Send for SType

§

impl Sync for SType

§

impl Unpin for SType

§

impl UnwindSafe for SType

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.