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§
Source§impl AnonSocket
impl AnonSocket
fn peer_fd(&self) -> &WeakFileDescriptionRef
Trait Implementations§
Source§impl Debug for AnonSocket
impl Debug for AnonSocket
Source§impl FileDescription for AnonSocket
impl FileDescription for AnonSocket
fn name(&self) -> &'static str
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>
fn read<'tcx>( &self, self_ref: &FileDescriptionRef, _communicate_allowed: bool, ptr: Pointer, len: usize, dest: &MPlaceTy<'tcx>, ecx: &mut MiriInterpCx<'tcx>, ) -> InterpResult<'tcx>
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>
fn write<'tcx>( &self, self_ref: &FileDescriptionRef, _communicate_allowed: bool, ptr: Pointer, len: usize, dest: &MPlaceTy<'tcx>, ecx: &mut MiriInterpCx<'tcx>, ) -> InterpResult<'tcx>
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.fn as_unix(&self) -> &dyn UnixFileDescription
Source§fn seek<'tcx>(
&self,
_communicate_allowed: bool,
_offset: SeekFrom,
) -> InterpResult<'tcx, Result<u64>>
fn seek<'tcx>( &self, _communicate_allowed: bool, _offset: SeekFrom, ) -> InterpResult<'tcx, Result<u64>>
fn metadata<'tcx>(&self) -> InterpResult<'tcx, Result<Metadata>>
fn is_tty(&self, _communicate_allowed: bool) -> bool
Source§impl UnixFileDescription for AnonSocket
impl UnixFileDescription for AnonSocket
Source§fn get_epoll_ready_events<'tcx>(&self) -> InterpResult<'tcx, EpollReadyEvents>
fn get_epoll_ready_events<'tcx>(&self) -> InterpResult<'tcx, EpollReadyEvents>
Source§fn pread<'tcx>(
&self,
_communicate_allowed: bool,
_offset: u64,
_ptr: Pointer,
_len: usize,
_dest: &MPlaceTy<'tcx>,
_ecx: &mut MiriInterpCx<'tcx>,
) -> InterpResult<'tcx>
fn pread<'tcx>( &self, _communicate_allowed: bool, _offset: u64, _ptr: Pointer, _len: usize, _dest: &MPlaceTy<'tcx>, _ecx: &mut MiriInterpCx<'tcx>, ) -> InterpResult<'tcx>
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>
fn pwrite<'tcx>( &self, _communicate_allowed: bool, _ptr: Pointer, _len: usize, _offset: u64, _dest: &MPlaceTy<'tcx>, _ecx: &mut MiriInterpCx<'tcx>, ) -> InterpResult<'tcx>
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.fn flock<'tcx>( &self, _communicate_allowed: bool, _op: FlockOp, ) -> InterpResult<'tcx, Result<()>>
Auto Trait Implementations§
impl !Freeze for AnonSocket
impl !RefUnwindSafe for AnonSocket
impl !Send for AnonSocket
impl !Sync for AnonSocket
impl Unpin for AnonSocket
impl !UnwindSafe for AnonSocket
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
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