timekeeper_integration_lib

Enum RtcOptions

Source
pub enum RtcOptions {
    None,
    InitialRtcTime(SyntheticInstant),
    InjectedRtc(DirectoryProxy),
}
Expand description

The RTC configuration options.

Variants§

§

None

No real-time clock available. This configuration simulates a system that does not have a RTC circuit available.

§

InitialRtcTime(SyntheticInstant)

Fake real-time clock. Supplied initial RTC time to report.

§

InjectedRtc(DirectoryProxy)

Injected real-time clock.

This is the handle that will appear as the directory /dev/class/rtc in the Timekeeper’s namespace.

The caller must set this directory up so that it serves a RTC device (e.g. named /dev/class/rtc/000, and serving the FIDL fuchsia.hardware.rtc/Device) from this directory.

It is also possible to serve more RTCs from the directory, or other files and file types at the caller’s option.

Use this option if you need to implement corner cases, or very specific RTC behavior, such as abnormal configuration or anomalous behavior.

Trait Implementations§

Source§

impl From<Instant<SyntheticTimeline>> for RtcOptions

Source§

fn from(value: SyntheticInstant) -> Self

Converts to this type from the input type.
Source§

impl From<Option<Instant<SyntheticTimeline>>> for RtcOptions

Source§

fn from(value: Option<SyntheticInstant>) -> Self

Converts to this type from the input type.
Source§

impl From<RtcOptions> for RtcOptions

Source§

fn from(value: RtcOptions) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

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, D> Encode<Ambiguous1, D> for T
where D: ResourceDialect,

Source§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
Source§

impl<T, D> Encode<Ambiguous2, D> for T
where D: ResourceDialect,

Source§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. 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> IntoAny for T
where T: 'static + Send + Sync,

Source§

fn into_any(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Cast the given object into a dyn std::any::Any.
§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. 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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

Source§

impl<St> WithTag for St

Source§

fn tagged<T>(self, tag: T) -> Tagged<T, St>

Produce a new stream from this one which yields item tupled with a constant tag