Struct soapysdr::TxStream

source ·
pub struct TxStream<E: StreamSample> { /* private fields */ }
Expand description

A stream open for transmitting.

To obtain a TxStream, call Device::tx_stream. The type parameter E represents the type of this stream’s samples.

Streams may involve multiple channels.

Implementations§

source§

impl<E: StreamSample> TxStream<E>

source

pub fn mtu(&self) -> Result<usize, Error>

Get the stream’s maximum transmission unit (MTU) in number of elements.

The MTU specifies the maximum payload transfer in a stream operation. This value can be used as a stream buffer allocation size that can best optimize throughput given the underlying stream implementation.

source

pub fn activate(&mut self, time_ns: Option<i64>) -> Result<(), Error>

Activate a stream.

Call activate to enable a stream before using write()

Arguments:
  • time_ns – optional activation time in nanoseconds
source

pub fn deactivate(&mut self, time_ns: Option<i64>) -> Result<(), Error>

Deactivate a stream. The implementation will control switches or halt data flow.

Arguments:
  • time_ns – optional deactivation time in nanoseconds
source

pub fn write( &mut self, buffers: &[&[E]], at_ns: Option<i64>, end_burst: bool, timeout_us: i64 ) -> Result<usize, Error>

Attempt to write samples to the device from the provided buffer.

The stream must first be activated.

buffers contains one source slice for each channel of the stream.

at_ns is an optional nanosecond precision device timestamp at which the device is to begin the transmission (c.f. get_hardware_time).

end_burst indicates when this packet ends a burst transmission.

Returns the number of samples written, which may be smaller than the size of the passed arrays.

Panics
  • If buffers is not the same length as the channels array passed to Device::tx_stream.
  • If all the buffers in buffers are not the same length.
source

pub fn write_all( &mut self, buffers: &[&[E]], at_ns: Option<i64>, end_burst: bool, timeout_us: i64 ) -> Result<(), Error>

Write all samples to the device.

This method repeatedly calls write until the entire provided buffer has been written.

The stream must first be activated.

buffers contains one source slice for each channel of the stream.

at_ns is an optional nanosecond precision device timestamp at which the device is to begin the transmission (c.f. get_hardware_time).

end_burst indicates when this packet ends a burst transmission.

Panics
  • If buffers is not the same length as the channels array passed to Device::rx_stream.
  • If all the buffers in buffers are not the same length.

Trait Implementations§

source§

impl<E: StreamSample> Drop for TxStream<E>

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl<E: StreamSample> Send for TxStream<E>

Streams may only be used on one thread at a time but may be sent between threads

Auto Trait Implementations§

§

impl<E> RefUnwindSafe for TxStream<E>

§

impl<E> !Sync for TxStream<E>

§

impl<E> Unpin for TxStream<E>

§

impl<E> UnwindSafe for TxStream<E>

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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 Twhere 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, U> TryFrom<U> for Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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.