pub struct PartitionProxy { /* private fields */ }
Implementations§
Source§impl PartitionProxy
impl PartitionProxy
Sourcepub fn new(channel: AsyncChannel) -> Self
pub fn new(channel: AsyncChannel) -> Self
Create a new Proxy for fuchsia.hardware.block.partition/Partition.
Sourcepub fn take_event_stream(&self) -> PartitionEventStream
pub fn take_event_stream(&self) -> PartitionEventStream
Get a Stream of events from the remote end of the protocol.
§Panics
Panics if the event stream was already taken.
Sourcepub fn get_info(
&self,
) -> QueryResponseFut<BlockGetInfoResult, DefaultFuchsiaResourceDialect>
pub fn get_info( &self, ) -> QueryResponseFut<BlockGetInfoResult, DefaultFuchsiaResourceDialect>
Get information about the underlying block device.
Sourcepub fn get_stats(
&self,
clear: bool,
) -> QueryResponseFut<BlockGetStatsResult, DefaultFuchsiaResourceDialect>
pub fn get_stats( &self, clear: bool, ) -> QueryResponseFut<BlockGetStatsResult, DefaultFuchsiaResourceDialect>
Returns stats about block device operations. Setting clear
will reset stats counters.
Sourcepub fn open_session(
&self,
session: ServerEnd<SessionMarker>,
) -> Result<(), Error>
pub fn open_session( &self, session: ServerEnd<SessionMarker>, ) -> Result<(), Error>
Opens a new FIFO-based session on the block device.
Sourcepub fn open_session_with_offset_map(
&self,
session: ServerEnd<SessionMarker>,
offset_map: Option<ClientEnd<OffsetMapMarker>>,
initial_mappings: Option<&[BlockOffsetMapping]>,
) -> Result<(), Error>
pub fn open_session_with_offset_map( &self, session: ServerEnd<SessionMarker>, offset_map: Option<ClientEnd<OffsetMapMarker>>, initial_mappings: Option<&[BlockOffsetMapping]>, ) -> Result<(), Error>
Opens a new FIFO-based session on the block device, providing an offset lookup map which transparently translates device offsets in block FIFO requests.
initial_mappings
is a static set of mappings which the server can immediately use. If
offset_map
is not provided, this must be non-empty, and requests that fall outside of the
mapped range will fail.
If offset_map
is provided, whenever the server receives a request with a dev_offset that
falls outside of the known range, it will consult offset_map
to attempt to resolve the
offset. Because these offset mappings must be stable for the duration of the session, the
server may cache any mappings.
This interface is intended to be used internally between nested Block implementations, in order to provide passthrough I/O. For example, a fixed partition map (e.g. GPT) will serve a Block protocol for each partition, and will respond to OpenSession requests by calling OpenSessionWithOffsetMap on the underlying block device, establishing itself as the source for translating client block offsets (relative to the partition start) to absolute offsets. The client can then communicate directly with the underlying block device, and the partition offsets can be transparently applied to requests.
Sourcepub fn get_type_guid(
&self,
) -> QueryResponseFut<(i32, Option<Box<Guid>>), DefaultFuchsiaResourceDialect>
pub fn get_type_guid( &self, ) -> QueryResponseFut<(i32, Option<Box<Guid>>), DefaultFuchsiaResourceDialect>
Gets the type GUID of the partition (if one exists). If the partition has no type GUID, ZX_ERR_NOT_SUPPORTED is returned.
Sourcepub fn get_instance_guid(
&self,
) -> QueryResponseFut<(i32, Option<Box<Guid>>), DefaultFuchsiaResourceDialect>
pub fn get_instance_guid( &self, ) -> QueryResponseFut<(i32, Option<Box<Guid>>), DefaultFuchsiaResourceDialect>
Gets the instance GUID of the partition (if one exists). If the partition has no instance GUID, ZX_ERR_NOT_SUPPORTED is returned.
Sourcepub fn get_name(
&self,
) -> QueryResponseFut<(i32, Option<String>), DefaultFuchsiaResourceDialect>
pub fn get_name( &self, ) -> QueryResponseFut<(i32, Option<String>), DefaultFuchsiaResourceDialect>
Gets the name of the partition (if one exists). If the partition has no name, ZX_ERR_NOT_SUPPORTED is returned.
Sourcepub fn get_metadata(
&self,
) -> QueryResponseFut<PartitionGetMetadataResult, DefaultFuchsiaResourceDialect>
pub fn get_metadata( &self, ) -> QueryResponseFut<PartitionGetMetadataResult, DefaultFuchsiaResourceDialect>
Gets the metadata for the partition.
Fields may be absent if the partition doesn’t have the given metadata.
Trait Implementations§
Source§impl Clone for PartitionProxy
impl Clone for PartitionProxy
Source§fn clone(&self) -> PartitionProxy
fn clone(&self) -> PartitionProxy
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for PartitionProxy
impl Debug for PartitionProxy
Source§impl PartitionProxyInterface for PartitionProxy
impl PartitionProxyInterface for PartitionProxy
type GetInfoResponseFut = QueryResponseFut<Result<BlockInfo, i32>>
type GetStatsResponseFut = QueryResponseFut<Result<BlockStats, i32>>
type GetTypeGuidResponseFut = QueryResponseFut<(i32, Option<Box<Guid>>)>
type GetInstanceGuidResponseFut = QueryResponseFut<(i32, Option<Box<Guid>>)>
type GetNameResponseFut = QueryResponseFut<(i32, Option<String>)>
type GetMetadataResponseFut = QueryResponseFut<Result<PartitionGetMetadataResponse, i32>>
fn get_info(&self) -> Self::GetInfoResponseFut
fn get_stats(&self, clear: bool) -> Self::GetStatsResponseFut
fn open_session(&self, session: ServerEnd<SessionMarker>) -> Result<(), Error>
fn open_session_with_offset_map( &self, session: ServerEnd<SessionMarker>, offset_map: Option<ClientEnd<OffsetMapMarker>>, initial_mappings: Option<&[BlockOffsetMapping]>, ) -> Result<(), Error>
fn get_type_guid(&self) -> Self::GetTypeGuidResponseFut
fn get_instance_guid(&self) -> Self::GetInstanceGuidResponseFut
fn get_name(&self) -> Self::GetNameResponseFut
fn get_metadata(&self) -> Self::GetMetadataResponseFut
Source§impl Proxy for PartitionProxy
impl Proxy for PartitionProxy
Source§type Protocol = PartitionMarker
type Protocol = PartitionMarker
Proxy
controls.