embassy-stm32

Crates

0.3.0

Versions

stm32g471qc

Flavors

Struct DacChannel

Source
pub struct DacChannel<'d, T: Instance, C: Channel, M: PeriMode> { /* private fields */ }
Expand description

Driver for a single DAC channel.

If you want to use both channels, either together or independently, create a Dac first and use it to access each channel.

Implementations§

Source§

impl<'d, T: Instance, C: Channel> DacChannel<'d, T, C, Async>

Source

pub fn new( peri: Peri<'d, T>, dma: Peri<'d, impl Dma<T, C>>, pin: Peri<'d, impl DacPin<T, C>>, ) -> Self

Create a new DacChannel instance, consuming the underlying DAC peripheral.

The channel is enabled on creation and begin to drive the output pin. Note that some methods, such as set_trigger() and set_mode(), will disable the channel; you must re-enable it with enable().

By default, triggering is disabled, but it can be enabled using DacChannel::set_trigger().

Source

pub fn new_internal(peri: Peri<'d, T>, dma: Peri<'d, impl Dma<T, C>>) -> Self

Create a new DacChannel instance where the external output pin is not used, so the DAC can only be used to generate internal signals. The GPIO pin is therefore available to be used for other functions.

The channel is set to Mode::NormalInternalUnbuffered and enabled on creation. Note that some methods, such as set_trigger() and set_mode(), will disable the channel; you must re-enable it with enable().

By default, triggering is disabled, but it can be enabled using DacChannel::set_trigger().

Source

pub async fn write(&mut self, data: ValueArray<'_>, circular: bool)

Write data to this channel via DMA.

To prevent delays or glitches when outputing a periodic waveform, the circular flag can be set. This configures a circular DMA transfer that continually outputs data. Note that for performance reasons in circular mode the transfer-complete interrupt is disabled.

Source§

impl<'d, T: Instance, C: Channel> DacChannel<'d, T, C, Blocking>

Source

pub fn new_blocking(peri: Peri<'d, T>, pin: Peri<'d, impl DacPin<T, C>>) -> Self

Create a new DacChannel instance, consuming the underlying DAC peripheral.

The channel is enabled on creation and begin to drive the output pin. Note that some methods, such as set_trigger() and set_mode(), will disable the channel; you must re-enable it with enable().

By default, triggering is disabled, but it can be enabled using DacChannel::set_trigger().

Source

pub fn new_internal_blocking(peri: Peri<'d, T>) -> Self

Create a new DacChannel instance where the external output pin is not used, so the DAC can only be used to generate internal signals. The GPIO pin is therefore available to be used for other functions.

The channel is set to Mode::NormalInternalUnbuffered and enabled on creation. Note that some methods, such as set_trigger() and set_mode(), will disable the channel; you must re-enable it with enable().

By default, triggering is disabled, but it can be enabled using DacChannel::set_trigger().

Source§

impl<'d, T: Instance, C: Channel, M: PeriMode> DacChannel<'d, T, C, M>

Source

pub fn set_enable(&mut self, on: bool)

Enable or disable this channel.

Source

pub fn enable(&mut self)

Enable this channel.

Source

pub fn disable(&mut self)

Disable this channel.

Source

pub fn set_trigger(&mut self, source: TriggerSel)

Set the trigger source for this channel.

This method disables the channel, so you may need to re-enable afterwards.

Source

pub fn set_triggering(&mut self, on: bool)

Enable or disable triggering for this channel.

Source

pub fn trigger(&mut self)

Software trigger this channel.

Source

pub fn set_mode(&mut self, mode: Mode)

Set mode of this channel.

This method disables the channel, so you may need to re-enable afterwards.

Source

pub fn set(&mut self, value: Value)

Write a new value to this channel.

If triggering is not enabled, the new value is immediately output; otherwise, it will be output after the next trigger.

Source

pub fn read(&self) -> u16

Read the current output value of the DAC.

Trait Implementations§

Source§

impl<'d, T: Instance, C: Channel, M: PeriMode> Drop for DacChannel<'d, T, C, M>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

§

impl<'d, T, C, M> Freeze for DacChannel<'d, T, C, M>

§

impl<'d, T, C, M> RefUnwindSafe for DacChannel<'d, T, C, M>

§

impl<'d, T, C, M> Send for DacChannel<'d, T, C, M>
where T: Send, C: Send, M: Send,

§

impl<'d, T, C, M> Sync for DacChannel<'d, T, C, M>
where T: Sync, C: Sync, M: Sync,

§

impl<'d, T, C, M> Unpin for DacChannel<'d, T, C, M>

§

impl<'d, T, C, M> !UnwindSafe for DacChannel<'d, T, C, M>

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, 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.