embassy-stm32

Crates

0.4.0

Versions

stm32g051g8

Flavors

Struct Dac

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

DAC driver.

Use this struct when you want to use both channels, either together or independently.

§Example

// Pins may need to be changed for your specific device.
let (dac_ch1, dac_ch2) = embassy_stm32::dac::Dac::new_blocking(p.DAC1, p.PA4, p.PA5).split();

Implementations§

Source§

impl<'d, T: Instance> Dac<'d, T, Async>

Source

pub fn new( peri: Peri<'d, T>, dma_ch1: Peri<'d, impl Dma<T, Ch1>>, dma_ch2: Peri<'d, impl Dma<T, Ch2>>, pin_ch1: Peri<'d, impl DacPin<T, Ch1> + Pin>, pin_ch2: Peri<'d, impl DacPin<T, Ch2> + Pin>, ) -> Self

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

This struct allows you to access both channels of the DAC, where available. You can either call split() to obtain separate DacChannels, or use methods on Dac to use the two channels together.

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

By default, triggering is disabled, but it can be enabled using the set_trigger() method on the underlying channels.

Source

pub fn new_unbuffered( peri: Peri<'d, T>, dma_ch1: Peri<'d, impl Dma<T, Ch1>>, dma_ch2: Peri<'d, impl Dma<T, Ch2>>, pin_ch1: Peri<'d, impl DacPin<T, Ch1> + Pin>, pin_ch2: Peri<'d, impl DacPin<T, Ch2> + Pin>, ) -> Self

Create a new Dac instance with external output pins and unbuffered mode.

This function consumes the underlying DAC peripheral and allows access to both channels. The channels are configured for external output with the buffer disabled.

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

By default, triggering is disabled, but it can be enabled using the set_trigger() method on the underlying channels.

§Arguments
  • peri - The DAC peripheral instance.
  • dma_ch1 - The DMA channel for DAC channel 1.
  • dma_ch2 - The DMA channel for DAC channel 2.
  • pin_ch1 - The GPIO pin for DAC channel 1 output.
  • pin_ch2 - The GPIO pin for DAC channel 2 output.
§Returns

A new Dac instance in unbuffered mode.

Source

pub fn new_internal( peri: Peri<'d, T>, dma_ch1: Peri<'d, impl Dma<T, Ch1>>, dma_ch2: Peri<'d, impl Dma<T, Ch2>>, ) -> Self

Create a new Dac instance where the external output pins are not used, so the DAC can only be used to generate internal signals but the GPIO pins remain available for other functions.

This struct allows you to access both channels of the DAC, where available. You can either call split() to obtain separate DacChannels, or use methods on Dac to use the two channels together.

The channels are 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 them with enable().

By default, triggering is disabled, but it can be enabled using the set_trigger() method on the underlying channels.

Source§

impl<'d, T: Instance> Dac<'d, T, Blocking>

Source

pub fn new_blocking( peri: Peri<'d, T>, pin_ch1: Peri<'d, impl DacPin<T, Ch1> + Pin>, pin_ch2: Peri<'d, impl DacPin<T, Ch2> + Pin>, ) -> Self

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

This struct allows you to access both channels of the DAC, where available. You can either call split() to obtain separate DacChannels, or use methods on Dac to use the two channels together.

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

By default, triggering is disabled, but it can be enabled using the set_trigger() method on the underlying channels.

Source

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

Create a new Dac instance where the external output pins are not used, so the DAC can only be used to generate internal signals but the GPIO pins remain available for other functions.

This struct allows you to access both channels of the DAC, where available. You can either call split() to obtain separate DacChannels, or use methods on Dac to use the two channels together.

The channels are 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 them with enable().

By default, triggering is disabled, but it can be enabled using the set_trigger() method on the underlying channels.

Source§

impl<'d, T: Instance, M: PeriMode> Dac<'d, T, M>

Source

pub fn split(self) -> (DacCh1<'d, T, M>, DacCh2<'d, T, M>)

Split this Dac into separate channels.

You can access and move the channels around separately after splitting.

Source

pub fn ch1(&mut self) -> &mut DacCh1<'d, T, M>

Temporarily access channel 1.

Source

pub fn ch2(&mut self) -> &mut DacCh2<'d, T, M>

Temporarily access channel 2.

Source

pub fn set(&mut self, values: DualValue)

Simultaneously update channels 1 and 2 with a new value.

If triggering is not enabled, the new values are immediately output; otherwise, they will be output after the next trigger.

Auto Trait Implementations§

§

impl<'d, T, M> Freeze for Dac<'d, T, M>

§

impl<'d, T, M> RefUnwindSafe for Dac<'d, T, M>

§

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

§

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

§

impl<'d, T, M> Unpin for Dac<'d, T, M>

§

impl<'d, T, M> !UnwindSafe for Dac<'d, T, 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.