miri::shims::unix::unnamed_socket

Struct AnonSocket

Source
struct AnonSocket {
    readbuf: Option<RefCell<Buffer>>,
    peer_fd: OnceCell<WeakFileDescriptionRef>,
    peer_lost_data: Cell<bool>,
    blocked_read_tid: RefCell<Vec<ThreadId>>,
    blocked_write_tid: RefCell<Vec<ThreadId>>,
    is_nonblock: bool,
}
Expand description

One end of a pair of connected unnamed sockets.

Fields§

§readbuf: Option<RefCell<Buffer>>

The buffer we are reading from, or None if this is the writing end of a pipe. (In that case, the peer FD will be the reading end of that pipe.)

§peer_fd: OnceCell<WeakFileDescriptionRef>

The AnonSocket file descriptor that is our “peer”, and that holds the buffer we are writing to. This is a weak reference because the other side may be closed before us; all future writes will then trigger EPIPE.

§peer_lost_data: Cell<bool>

Indicates whether the peer has lost data when the file description is closed. This flag is set to true if the peer’s readbuf is non-empty at the time of closure.

§blocked_read_tid: RefCell<Vec<ThreadId>>

A list of thread ids blocked because the buffer was empty. Once another thread writes some bytes, these threads will be unblocked.

§blocked_write_tid: RefCell<Vec<ThreadId>>

A list of thread ids blocked because the buffer was full. Once another thread reads some bytes, these threads will be unblocked.

§is_nonblock: bool

Implementations§

Trait Implementations§

Source§

impl Debug for AnonSocket

Source§

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

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

impl FileDescription for AnonSocket

Source§

fn name(&self) -> &'static str

Source§

fn close<'tcx>( self: Box<Self>, _communicate_allowed: bool, ecx: &mut MiriInterpCx<'tcx>, ) -> InterpResult<'tcx, Result<()>>

Source§

fn read<'tcx>( &self, self_ref: &FileDescriptionRef, _communicate_allowed: bool, ptr: Pointer, len: usize, dest: &MPlaceTy<'tcx>, ecx: &mut MiriInterpCx<'tcx>, ) -> InterpResult<'tcx>

Reads as much as possible into the given buffer ptr. len indicates how many bytes we should try to read. dest is where the return value should be stored: number of bytes read, or -1 in case of error.
Source§

fn write<'tcx>( &self, self_ref: &FileDescriptionRef, _communicate_allowed: bool, ptr: Pointer, len: usize, dest: &MPlaceTy<'tcx>, ecx: &mut MiriInterpCx<'tcx>, ) -> InterpResult<'tcx>

Writes as much as possible from the given buffer ptr. len indicates how many bytes we should try to write. dest is where the return value should be stored: number of bytes written, or -1 in case of error.
Source§

fn as_unix(&self) -> &dyn UnixFileDescription

Source§

fn seek<'tcx>( &self, _communicate_allowed: bool, _offset: SeekFrom, ) -> InterpResult<'tcx, Result<u64>>

Seeks to the given offset (which can be relative to the beginning, end, or current position). Returns the new position from the start of the stream.
Source§

fn metadata<'tcx>(&self) -> InterpResult<'tcx, Result<Metadata>>

Source§

fn is_tty(&self, _communicate_allowed: bool) -> bool

Source§

impl UnixFileDescription for AnonSocket

Source§

fn get_epoll_ready_events<'tcx>(&self) -> InterpResult<'tcx, EpollReadyEvents>

Check the readiness of file description.
Source§

fn pread<'tcx>( &self, _communicate_allowed: bool, _offset: u64, _ptr: Pointer, _len: usize, _dest: &MPlaceTy<'tcx>, _ecx: &mut MiriInterpCx<'tcx>, ) -> InterpResult<'tcx>

Reads as much as possible into the given buffer ptr from a given offset. len indicates how many bytes we should try to read. dest is where the return value should be stored: number of bytes read, or -1 in case of error.
Source§

fn pwrite<'tcx>( &self, _communicate_allowed: bool, _ptr: Pointer, _len: usize, _offset: u64, _dest: &MPlaceTy<'tcx>, _ecx: &mut MiriInterpCx<'tcx>, ) -> InterpResult<'tcx>

Writes as much as possible from the given buffer ptr starting at a given offset. ptr is the pointer to the user supplied read buffer. len indicates how many bytes we should try to write. dest is where the return value should be stored: number of bytes written, or -1 in case of error.
Source§

fn flock<'tcx>( &self, _communicate_allowed: bool, _op: FlockOp, ) -> InterpResult<'tcx, Result<()>>

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> 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> Same for T

Source§

type Output = T

Should always be Self
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

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 192 bytes