Struct simics_api_sys::bindings::register_view_interface
source · #[repr(C)]pub struct register_view_interface {
pub description: Option<unsafe extern "C" fn(obj: *mut conf_object_t) -> *const c_char>,
pub big_endian_bitorder: Option<unsafe extern "C" fn(obj: *mut conf_object_t) -> bool>,
pub number_of_registers: Option<unsafe extern "C" fn(obj: *mut conf_object_t) -> c_uint>,
pub register_info: Option<unsafe extern "C" fn(obj: *mut conf_object_t, reg: c_uint) -> attr_value_t>,
pub get_register_value: Option<unsafe extern "C" fn(obj: *mut conf_object_t, reg: c_uint) -> uint64>,
pub set_register_value: Option<unsafe extern "C" fn(obj: *mut conf_object_t, reg: c_uint, val: uint64)>,
}
Fields§
§description: Option<unsafe extern "C" fn(obj: *mut conf_object_t) -> *const c_char>
§big_endian_bitorder: Option<unsafe extern "C" fn(obj: *mut conf_object_t) -> bool>
§number_of_registers: Option<unsafe extern "C" fn(obj: *mut conf_object_t) -> c_uint>
§register_info: Option<unsafe extern "C" fn(obj: *mut conf_object_t, reg: c_uint) -> attr_value_t>
Returns the static information about a register in the list [NAME, DESC, SIZE, OFFSET, BITFIELDS, BIG_ENDIAN_BYTE_ORDER]. All but the two last element in the list are required and the client should tolerate if more than 6 elements are presented in the list. NAME must be a valid identifier. DESC is a short description of the register. SIZE is the number of bytes of the register, could only be 1, 2, 4, or 8. OFFSET is the offset into the bank and can be Nil denoting non-memory-mapped registers. BITFIELDS is optional and if present, is a list where each element itself being a list of [NAME, DESC, LSB, MSB] where NAME and DESC is the identifier and description of the field and LSB and MSB are the least significant and the most significant bit in little-endian bitorder. MSB is optional and if omitted, is assumed to be the same as LSB, i.e., the bitfield specifies a single bit. BIG_ENDIAN_BYTE_ORDER is an optional boolean value, assumed to be False if omitted. It controls the byte order of the register’s memory-mapped representation; the byte at OFFSET is the most significant byte if BIG_ENDIAN_BYTE_ORDER is True, and the least significant byte otherwise.
get_register_value: Option<unsafe extern "C" fn(obj: *mut conf_object_t, reg: c_uint) -> uint64>
Get the current value of a register, must be side-effect free.
set_register_value: Option<unsafe extern "C" fn(obj: *mut conf_object_t, reg: c_uint, val: uint64)>
Set the current value of a register, must be side-effect free except from updating the value.
Trait Implementations§
source§impl Clone for register_view_interface
impl Clone for register_view_interface
source§fn clone(&self) -> register_view_interface
fn clone(&self) -> register_view_interface
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for register_view_interface
impl Debug for register_view_interface
source§impl Default for register_view_interface
impl Default for register_view_interface
source§fn default() -> register_view_interface
fn default() -> register_view_interface
source§impl Hash for register_view_interface
impl Hash for register_view_interface
source§impl Ord for register_view_interface
impl Ord for register_view_interface
source§fn cmp(&self, other: ®ister_view_interface) -> Ordering
fn cmp(&self, other: ®ister_view_interface) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
source§impl PartialEq for register_view_interface
impl PartialEq for register_view_interface
source§impl PartialOrd for register_view_interface
impl PartialOrd for register_view_interface
impl Copy for register_view_interface
impl Eq for register_view_interface
impl StructuralPartialEq for register_view_interface
Auto Trait Implementations§
impl Freeze for register_view_interface
impl RefUnwindSafe for register_view_interface
impl Send for register_view_interface
impl Sync for register_view_interface
impl Unpin for register_view_interface
impl UnwindSafe for register_view_interface
Blanket Implementations§
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§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)