pub enum ControlMessage<'a> {
ScmRights(&'a [RawFd]),
ScmCredentials(&'a UnixCredentials),
AlgSetIv(&'a [u8]),
AlgSetOp(&'a c_int),
AlgSetAeadAssoclen(&'a u32),
UdpGsoSegments(&'a u16),
Ipv4PacketInfo(&'a in_pktinfo),
Ipv6PacketInfo(&'a in6_pktinfo),
RxqOvfl(&'a u32),
}
Expand description
A type-safe zero-copy wrapper around a single control message, as used wih
sendmsg
. More types may be added to this enum; do not
exhaustively pattern-match it.
Variants
ScmRights(&'a [RawFd])
A message of type SCM_RIGHTS
, containing an array of file
descriptors passed between processes.
See the description in the “Ancillary messages” section of the unix(7) man page.
Using multiple ScmRights
messages for a single sendmsg
call isn’t
recommended since it causes platform-dependent behaviour: It might
swallow all but the first ScmRights
message or fail with EINVAL
.
Instead, you can put all fds to be passed into a single ScmRights
message.
ScmCredentials(&'a UnixCredentials)
A message of type SCM_CREDENTIALS
, containing the pid, uid and gid of
a process connected to the socket.
This is similar to the socket option SO_PEERCRED
, but requires a
process to explicitly send its credentials. A process running as root is
allowed to specify any credentials, while credentials sent by other
processes are verified by the kernel.
For further information, please refer to the
unix(7)
man page.
AlgSetIv(&'a [u8])
Set IV for AF_ALG
crypto API.
For further information, please refer to the
documentation
AlgSetOp(&'a c_int)
Set crypto operation for AF_ALG
crypto API. It may be one of
ALG_OP_ENCRYPT
or ALG_OP_DECRYPT
For further information, please refer to the
documentation
AlgSetAeadAssoclen(&'a u32)
Set the length of associated authentication data (AAD) (applicable only to AEAD algorithms)
for AF_ALG
crypto API.
For further information, please refer to the
documentation
UdpGsoSegments(&'a u16)
UDP GSO makes it possible for applications to generate network packets for a virtual MTU much greater than the real one. The length of the send data no longer matches the expected length on the wire. The size of the datagram payload as it should appear on the wire may be passed through this control message. Send buffer should consist of multiple fixed-size wire payloads following one by one, and the last, possibly smaller one.
Ipv4PacketInfo(&'a in_pktinfo)
Configure the sending addressing and interface for v4
For further information, please refer to the
ip(7)
man page.
Ipv6PacketInfo(&'a in6_pktinfo)
Configure the sending addressing and interface for v6
For further information, please refer to the
ipv6(7)
man page.
RxqOvfl(&'a u32)
SO_RXQ_OVFL indicates that an unsigned 32 bit value ancilliary msg (cmsg) should be attached to recieved skbs indicating the number of packets dropped by the socket between the last recieved packet and this received packet.
Trait Implementations
sourceimpl<'a> Clone for ControlMessage<'a>
impl<'a> Clone for ControlMessage<'a>
sourcefn clone(&self) -> ControlMessage<'a>
fn clone(&self) -> ControlMessage<'a>
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
sourceimpl<'a> Debug for ControlMessage<'a>
impl<'a> Debug for ControlMessage<'a>
sourceimpl<'a> PartialEq<ControlMessage<'a>> for ControlMessage<'a>
impl<'a> PartialEq<ControlMessage<'a>> for ControlMessage<'a>
sourcefn eq(&self, other: &ControlMessage<'a>) -> bool
fn eq(&self, other: &ControlMessage<'a>) -> bool
This method tests for self
and other
values to be equal, and is used
by ==
. Read more
sourcefn ne(&self, other: &ControlMessage<'a>) -> bool
fn ne(&self, other: &ControlMessage<'a>) -> bool
This method tests for !=
.
impl<'a> Copy for ControlMessage<'a>
impl<'a> Eq for ControlMessage<'a>
impl<'a> StructuralEq for ControlMessage<'a>
impl<'a> StructuralPartialEq for ControlMessage<'a>
Auto Trait Implementations
impl<'a> RefUnwindSafe for ControlMessage<'a>
impl<'a> Send for ControlMessage<'a>
impl<'a> Sync for ControlMessage<'a>
impl<'a> Unpin for ControlMessage<'a>
impl<'a> UnwindSafe for ControlMessage<'a>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more