fidl_fuchsia_fuzzer

Enum CoverageDataProviderRequest

Source
pub enum CoverageDataProviderRequest {
    SetOptions {
        options: Options,
        control_handle: CoverageDataProviderControlHandle,
    },
    WatchCoverageData {
        responder: CoverageDataProviderWatchCoverageDataResponder,
    },
}
Expand description

Provides the process Handles and VMOs used to share code coverage to the fuzzing engine.

This protocol is implemented by test_manager’s fuzz_coverage component. The fuzzing engine acts as a client, although it does not connect directly. Instead the fuzz_test_runner makes the connection and passes it off to fuzzing engine on process start. It allows the engine to retrieve the coverage-related Handles published by instrumented target processes.

The channel is closed on FIDL error. Clients should exit and not attempt to reconnect.

Variants§

§

SetOptions

Sets the options to be returned by fuchsia.fuzzer.CoverageDataCollector/Initialize.

Fields

§options: Options
§

WatchCoverageData

Provides coverage data collected from multiple processes.

Returns a vector of CoverageData structs containing the information provided by clients of fuchsia.fuzzer.CoverageDataCollector. This method uses the “hanging get” pattern: The initial call will immediately return whatever data is available, up to MAX_COVERAGE_DATA. If no fuzzed components have been started yet, this be an empty vector. If there are more than MAX_COVERAGE_DATA elements available, the remainder are retained for subsequent calls. If there is no more data available, subsequent calls will block until new coverage data is available.

The channel is closed on FIDL error. Clients should exit and not attempt to reconnect.

Implementations§

Trait Implementations§

Source§

impl Debug for CoverageDataProviderRequest

Source§

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

Formats the value using the given formatter. Read more

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.

§

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.