libopencm3
A free/libre/open-source firmware library for various ARM Cortex-M3 microcontrollers.
|
Functions | |
bool | adc_eoc (uint32_t adc) |
ADC Read the End-of-Conversion Flag. More... | |
bool | adc_eos (uint32_t adc) |
ADC Read the End-of-Sequence Flag for Regular Conversions. More... | |
void | adc_power_on_async (uint32_t adc) |
Turn on the ADC (async) More... | |
bool | adc_is_power_on (uint32_t adc) |
Is the ADC powered up and ready? More... | |
void | adc_power_on (uint32_t adc) |
Turn on the ADC. More... | |
void | adc_power_off_async (uint32_t adc) |
Turn off the ADC (async) This will actually block if it needs to turn off a currently running conversion, as per ref man. More... | |
bool | adc_is_power_off (uint32_t adc) |
Is the ADC powered down? More... | |
void | adc_power_off (uint32_t adc) |
Turn off the ADC This will actually block if it needs to turn off a currently running conversion, as per ref man. More... | |
void | adc_calibrate_async (uint32_t adc) |
Start the ADC calibration and immediately return. More... | |
bool | adc_is_calibrating (uint32_t adc) |
Is the ADC Calibrating? More... | |
void | adc_calibrate (uint32_t adc) |
Start ADC calibration and wait for it to finish. More... | |
void | adc_set_continuous_conversion_mode (uint32_t adc) |
Enable Continuous Conversion Mode In this mode the ADC starts a new conversion of a single channel or a channel group immediately following completion of the previous channel group conversion. More... | |
void | adc_set_single_conversion_mode (uint32_t adc) |
Enable Single Conversion Mode In this mode the ADC performs a conversion of one channel or a channel group and stops. More... | |
void | adc_set_resolution (uint32_t adc, uint16_t resolution) |
ADC Set Resolution. More... | |
void | adc_set_left_aligned (uint32_t adc) |
ADC Set the Data as Left Aligned. More... | |
void | adc_set_right_aligned (uint32_t adc) |
ADC Set the Data as Right Aligned. More... | |
void | adc_enable_dma (uint32_t adc) |
ADC Enable DMA Transfers. More... | |
void | adc_disable_dma (uint32_t adc) |
ADC Disable DMA Transfers. More... | |
void | adc_enable_overrun_interrupt (uint32_t adc) |
ADC Enable the Overrun Interrupt. More... | |
void | adc_disable_overrun_interrupt (uint32_t adc) |
ADC Disable the Overrun Interrupt. More... | |
bool | adc_get_overrun_flag (uint32_t adc) |
ADC Read the Overrun Flag. More... | |
void | adc_clear_overrun_flag (uint32_t adc) |
ADC Clear Overrun Flags. More... | |
void | adc_enable_eoc_interrupt (uint32_t adc) |
ADC Enable Regular End-Of-Conversion Interrupt. More... | |
void | adc_disable_eoc_interrupt (uint32_t adc) |
ADC Disable Regular End-Of-Conversion Interrupt. More... | |
uint32_t | adc_read_regular (uint32_t adc) |
ADC Read from the Regular Conversion Result Register. More... | |
void | adc_enable_temperature_sensor (void) |
Enable the temperature sensor (only) The channel this is available on is unfortunately not consistent, even though the bit used to enable it is. More... | |
void | adc_disable_temperature_sensor (void) |
Disable the temperature sensor (only) More... | |
void | adc_enable_vrefint (void) |
Enable the internal voltage reference (only) The channel this is available on is unfortunately not consistent, even though the bit used to enable it is. More... | |
void | adc_disable_vrefint (void) |
Disable the internal voltage reference (only) More... | |
void | adc_start_conversion_regular (uint32_t adc) |
ADC Software Triggered Conversion on Regular Channels. More... | |
void | adc_enable_dma_circular_mode (uint32_t adc) |
Enable circular mode for DMA transfers. More... | |
void | adc_disable_dma_circular_mode (uint32_t adc) |
Disable circular mode for DMA transfers. More... | |
void | adc_enable_delayed_conversion_mode (uint32_t adc) |
Enable Delayed Conversion Mode. More... | |
void | adc_disable_delayed_conversion_mode (uint32_t adc) |
Enable Delayed Conversion Mode. More... | |
This library supports one style of the Analog to Digital Conversion System in the STM32 series of ARM Cortex Microcontrollers by ST Microelectronics.
The style of ADC Peripheral supported by this code is found in the F0, L0 and F30x series devices (at the time of writing)
LGPL License Terms libopencm3 License
void adc_calibrate | ( | uint32_t | adc | ) |
Start ADC calibration and wait for it to finish.
adc | ADC Block register address base ADC register base addresses |
Definition at line 175 of file adc_common_v2.c.
References adc_calibrate_async(), and adc_is_calibrating().
void adc_calibrate_async | ( | uint32_t | adc | ) |
Start the ADC calibration and immediately return.
adc | ADC Block register address base ADC register base addresses |
Definition at line 156 of file adc_common_v2.c.
References ADC_CR, and ADC_CR_ADCAL.
Referenced by adc_calibrate().
void adc_clear_overrun_flag | ( | uint32_t | adc | ) |
ADC Clear Overrun Flags.
The overrun flag is cleared. Note that if an overrun occurs, DMA is terminated. The flag must be cleared and the DMA stream and ADC reinitialised to resume conversions (see the reference manual).
[in] | adc | Unsigned int32. ADC base address (ADC register base addresses) |
Definition at line 299 of file adc_common_v2.c.
References ADC_ISR, and ADC_ISR_OVR.
void adc_disable_delayed_conversion_mode | ( | uint32_t | adc | ) |
Enable Delayed Conversion Mode.
[in] | adc | ADC block register address base ADC register base addresses |
Definition at line 425 of file adc_common_v2.c.
References ADC_CFGR1.
void adc_disable_dma | ( | uint32_t | adc | ) |
ADC Disable DMA Transfers.
[in] | adc | Unsigned int32. ADC base address (ADC register base addresses) |
Definition at line 250 of file adc_common_v2.c.
References ADC_CFGR1.
void adc_disable_dma_circular_mode | ( | uint32_t | adc | ) |
Disable circular mode for DMA transfers.
[in] | adc | Unsigned int32. ADC base address (ADC register base addresses) |
Definition at line 407 of file adc_common_v2.c.
References ADC_CFGR1.
void adc_disable_eoc_interrupt | ( | uint32_t | adc | ) |
ADC Disable Regular End-Of-Conversion Interrupt.
[in] | adc | Unsigned int32. ADC base address (ADC register base addresses) |
Definition at line 317 of file adc_common_v2.c.
References ADC_IER.
void adc_disable_overrun_interrupt | ( | uint32_t | adc | ) |
ADC Disable the Overrun Interrupt.
[in] | adc | Unsigned int32. ADC base address (ADC register base addresses) |
Definition at line 272 of file adc_common_v2.c.
References ADC_IER.
void adc_disable_temperature_sensor | ( | void | ) |
Disable the temperature sensor (only)
Definition at line 351 of file adc_common_v2.c.
void adc_disable_vrefint | ( | void | ) |
Disable the internal voltage reference (only)
Definition at line 372 of file adc_common_v2.c.
void adc_enable_delayed_conversion_mode | ( | uint32_t | adc | ) |
Enable Delayed Conversion Mode.
[in] | adc | ADC block register address base ADC register base addresses |
Definition at line 416 of file adc_common_v2.c.
References ADC_CFGR1, and ADC_CFGR1_AUTDLY.
void adc_enable_dma | ( | uint32_t | adc | ) |
ADC Enable DMA Transfers.
[in] | adc | Unsigned int32. ADC base address (ADC register base addresses) |
Definition at line 241 of file adc_common_v2.c.
References ADC_CFGR1, and ADC_CFGR1_DMAEN.
void adc_enable_dma_circular_mode | ( | uint32_t | adc | ) |
Enable circular mode for DMA transfers.
For this to work it needs to be ebabled on the DMA side as well.
[in] | adc | Unsigned int32. ADC base address (ADC register base addresses) |
Definition at line 398 of file adc_common_v2.c.
References ADC_CFGR1, and ADC_CFGR1_DMACFG.
void adc_enable_eoc_interrupt | ( | uint32_t | adc | ) |
ADC Enable Regular End-Of-Conversion Interrupt.
[in] | adc | Unsigned int32. ADC base address (ADC register base addresses) |
Definition at line 308 of file adc_common_v2.c.
References ADC_IER, and ADC_IER_EOCIE.
void adc_enable_overrun_interrupt | ( | uint32_t | adc | ) |
ADC Enable the Overrun Interrupt.
The overrun interrupt is generated when data is not read from a result register before the next conversion is written. If DMA is enabled, all transfers are terminated and any conversion sequence is aborted.
[in] | adc | Unsigned int32. ADC base address (ADC register base addresses) |
Definition at line 263 of file adc_common_v2.c.
References ADC_IER, and ADC_IER_OVRIE.
void adc_enable_temperature_sensor | ( | void | ) |
Enable the temperature sensor (only) The channel this is available on is unfortunately not consistent, even though the bit used to enable it is.
Definition at line 342 of file adc_common_v2.c.
References ADC1, ADC_CCR, and ADC_CCR_TSEN.
void adc_enable_vrefint | ( | void | ) |
Enable the internal voltage reference (only) The channel this is available on is unfortunately not consistent, even though the bit used to enable it is.
FIXME - on f3, you can actually have it on ADC34 as well!
Definition at line 363 of file adc_common_v2.c.
References ADC1, ADC_CCR, and ADC_CCR_VREFEN.
bool adc_eoc | ( | uint32_t | adc | ) |
ADC Read the End-of-Conversion Flag.
This flag is set by hardware at the end of each regular conversion of a channel when a new data is available in the ADCx_DR register.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 49 of file adc_common_v2.c.
References ADC_ISR, and ADC_ISR_EOC.
bool adc_eos | ( | uint32_t | adc | ) |
ADC Read the End-of-Sequence Flag for Regular Conversions.
This flag is set after all channels of an regular group have been converted.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 63 of file adc_common_v2.c.
References ADC_ISR, and ADC_ISR_EOS.
bool adc_get_overrun_flag | ( | uint32_t | adc | ) |
ADC Read the Overrun Flag.
The overrun flag is set when data is not read from a result register before the next conversion is written. If DMA is enabled, all transfers are terminated and any conversion sequence is aborted.
[in] | adc | Unsigned int32. ADC base address (ADC register base addresses) |
Definition at line 285 of file adc_common_v2.c.
References ADC_ISR, and ADC_ISR_OVR.
bool adc_is_calibrating | ( | uint32_t | adc | ) |
Is the ADC Calibrating?
adc | ADC Block register address base ADC register base addresses |
Definition at line 166 of file adc_common_v2.c.
References ADC_CR, and ADC_CR_ADCAL.
Referenced by adc_calibrate().
bool adc_is_power_off | ( | uint32_t | adc | ) |
Is the ADC powered down?
adc | ADC Block register address base ADC register base addresses |
Definition at line 132 of file adc_common_v2.c.
References ADC_CR, and ADC_CR_ADEN.
Referenced by adc_power_off(), and adc_power_off_async().
bool adc_is_power_on | ( | uint32_t | adc | ) |
Is the ADC powered up and ready?
adc | ADC Block register address base ADC register base addresses |
Definition at line 84 of file adc_common_v2.c.
References ADC_ISR, and ADC_ISR_ADRDY.
Referenced by adc_power_on().
void adc_power_off | ( | uint32_t | adc | ) |
Turn off the ADC This will actually block if it needs to turn off a currently running conversion, as per ref man.
adc | ADC Block register address base ADC register base addresses |
Definition at line 144 of file adc_common_v2.c.
References adc_is_power_off(), and adc_power_off_async().
void adc_power_off_async | ( | uint32_t | adc | ) |
Turn off the ADC (async) This will actually block if it needs to turn off a currently running conversion, as per ref man.
(Handles injected on hardware that supports injected conversions.
adc | ADC Block register address base ADC register base addresses |
Definition at line 108 of file adc_common_v2.c.
References ADC_CR, ADC_CR_ADDIS, ADC_CR_ADSTART, ADC_CR_ADSTP, and adc_is_power_off().
Referenced by adc_power_off().
void adc_power_on | ( | uint32_t | adc | ) |
Turn on the ADC.
adc | ADC Block register address base ADC register base addresses |
Definition at line 94 of file adc_common_v2.c.
References adc_is_power_on(), and adc_power_on_async().
void adc_power_on_async | ( | uint32_t | adc | ) |
Turn on the ADC (async)
adc | ADC Block register address base ADC register base addresses |
Definition at line 73 of file adc_common_v2.c.
References ADC_CR, and ADC_CR_ADEN.
Referenced by adc_power_on().
uint32_t adc_read_regular | ( | uint32_t | adc | ) |
ADC Read from the Regular Conversion Result Register.
The result read back is 12 bits, right or left aligned within the first 16 bits.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 331 of file adc_common_v2.c.
References ADC_DR.
void adc_set_continuous_conversion_mode | ( | uint32_t | adc | ) |
Enable Continuous Conversion Mode In this mode the ADC starts a new conversion of a single channel or a channel group immediately following completion of the previous channel group conversion.
[in] | adc | ADC block register address base ADC register base addresses |
Definition at line 189 of file adc_common_v2.c.
References ADC_CFGR1, and ADC_CFGR1_CONT.
void adc_set_left_aligned | ( | uint32_t | adc | ) |
ADC Set the Data as Left Aligned.
[in] | adc | Unsigned int32. ADC base address (ADC register base addresses) |
Definition at line 223 of file adc_common_v2.c.
References ADC_CFGR1, and ADC_CFGR1_ALIGN.
void adc_set_resolution | ( | uint32_t | adc, |
uint16_t | resolution | ||
) |
ADC Set Resolution.
ADC Resolution can be reduced from 12 bits to 10, 8 or 6 bits for a corresponding reduction in conversion time.
[in] | adc | Unsigned int32. ADC base address (ADC register base addresses) |
[in] | resolution | Unsigned int16. Resolution value (adc_api_res) |
Definition at line 214 of file adc_common_v2.c.
References ADC_CFGR1.
void adc_set_right_aligned | ( | uint32_t | adc | ) |
ADC Set the Data as Right Aligned.
[in] | adc | Unsigned int32. ADC base address (ADC register base addresses) |
Definition at line 232 of file adc_common_v2.c.
References ADC_CFGR1.
void adc_set_single_conversion_mode | ( | uint32_t | adc | ) |
Enable Single Conversion Mode In this mode the ADC performs a conversion of one channel or a channel group and stops.
[in] | adc | ADC block register address base ADC register base addresses |
Definition at line 201 of file adc_common_v2.c.
References ADC_CFGR1.
void adc_start_conversion_regular | ( | uint32_t | adc | ) |
ADC Software Triggered Conversion on Regular Channels.
This starts conversion on a set of defined regular channels. Depending on the configuration bits EXTEN, a conversion will start immediately (software trigger configuration) or once a regular hardware trigger event occurs (hardware trigger configuration)
[in] | adc | ADC block register address base ADC register base addresses |
Definition at line 386 of file adc_common_v2.c.
References ADC_CR, and ADC_CR_ADSTART.