libopencm3
A free/libre/open-source firmware library for various ARM Cortex-M3 microcontrollers.
|
Defined Constants and Types for the STM32G4xx Analog to Digital converter More...
Functions | |
void | adc_enable_analog_watchdog_regular (uint32_t adc) |
ADC Enable Analog Watchdog for Regular Conversions. More... | |
void | adc_disable_analog_watchdog_regular (uint32_t adc) |
ADC Enable Analog Watchdog for Regular Conversions. More... | |
void | adc_enable_analog_watchdog_injected (uint32_t adc) |
ADC Enable Analog Watchdog for Injected Conversions. More... | |
void | adc_disable_analog_watchdog_injected (uint32_t adc) |
ADC Disable Analog Watchdog for Injected Conversions. More... | |
void | adc_enable_discontinuous_mode_regular (uint32_t adc, uint8_t length) |
ADC Enable Discontinuous Mode for Regular Conversions. More... | |
void | adc_disable_discontinuous_mode_regular (uint32_t adc) |
ADC Disable Discontinuous Mode for Regular Conversions. More... | |
void | adc_enable_discontinuous_mode_injected (uint32_t adc) |
ADC Enable Discontinuous Mode for Injected Conversions. More... | |
void | adc_disable_discontinuous_mode_injected (uint32_t adc) |
ADC Disable Discontinuous Mode for Injected Conversions. More... | |
void | adc_enable_automatic_injected_group_conversion (uint32_t adc) |
ADC Enable Automatic Injected Conversions. More... | |
void | adc_disable_automatic_injected_group_conversion (uint32_t adc) |
ADC Disable Automatic Injected Conversions. More... | |
void | adc_enable_analog_watchdog_on_all_channels (uint32_t adc) |
ADC Enable Analog Watchdog for All Regular and/or Injected Channels. More... | |
void | adc_enable_analog_watchdog_on_selected_channel (uint32_t adc, uint8_t channel) |
ADC Enable Analog Watchdog for a Selected Channel. More... | |
void | adc_enable_eoc_interrupt_injected (uint32_t adc) |
ADC Enable Injected End-Of-Conversion Interrupt. More... | |
void | adc_disable_eoc_interrupt_injected (uint32_t adc) |
ADC Disable Injected End-Of-Conversion Interrupt. More... | |
void | adc_enable_eos_interrupt_injected (uint32_t adc) |
ADC Enable Injected End-Of-Sequence Interrupt. More... | |
void | adc_disable_eos_interrupt_injected (uint32_t adc) |
ADC Disable Injected End-Of-Sequence Interrupt. More... | |
void | adc_enable_all_awd_interrupt (uint32_t adc) |
ADC Enable Analog Watchdog Interrupt. More... | |
void | adc_disable_all_awd_interrupt (uint32_t adc) |
ADC Disable Analog Watchdog Interrupt. More... | |
void | adc_enable_eos_interrupt (uint32_t adc) |
ADC Enable Regular End-Of-Sequence Interrupt. More... | |
void | adc_disable_eos_interrupt (uint32_t adc) |
ADC Disable Regular End-Of-Sequence Interrupt. More... | |
void | adc_start_conversion_injected (uint32_t adc) |
ADC Software Triggered Conversion on Injected Channels. More... | |
void | adc_disable_external_trigger_regular (uint32_t adc) |
ADC Disable an External Trigger for Regular Channels. More... | |
void | adc_disable_external_trigger_injected (uint32_t adc) |
ADC Disable an External Trigger for Injected Channels. More... | |
void | adc_set_watchdog_high_threshold (uint32_t adc, uint16_t threshold) |
ADC Set Analog Watchdog Upper Threshold. More... | |
void | adc_set_watchdog_low_threshold (uint32_t adc, uint16_t threshold) |
ADC Set Analog Watchdog Lower Threshold. More... | |
void | adc_set_injected_sequence (uint32_t adc, uint8_t length, uint8_t channel[]) |
ADC Set an Injected Channel Conversion Sequence. More... | |
bool | adc_eoc_injected (uint32_t adc) |
ADC Read the End-of-Conversion Flag for Injected Conversion. More... | |
bool | adc_eos_injected (uint32_t adc) |
ADC Read the End-of-Sequence Flag for Injected Conversions. More... | |
uint32_t | adc_read_injected (uint32_t adc, uint8_t reg) |
ADC Read from an Injected Conversion Result Register. More... | |
void | adc_set_injected_offset (uint32_t adc, uint8_t reg, uint32_t offset) |
ADC Set the Injected Channel Data Offset. More... | |
void | adc_set_clk_source (uint32_t adc, uint32_t source) |
ADC Set Clock Source. More... | |
void | adc_set_clk_prescale (uint32_t adc, uint32_t prescale) |
ADC Set Clock Prescale. More... | |
void | adc_set_multi_mode (uint32_t adc, uint32_t mode) |
ADC set multi mode. More... | |
void | adc_enable_external_trigger_regular (uint32_t adc, uint32_t trigger, uint32_t polarity) |
ADC Enable an External Trigger for Regular Channels. More... | |
void | adc_enable_external_trigger_injected (uint32_t adc, uint32_t trigger, uint32_t polarity) |
ADC Enable an External Trigger for Injected Channels. More... | |
bool | adc_awd (uint32_t adc) |
ADC Read the Analog Watchdog Flag. More... | |
void | adc_enable_deeppwd (uint32_t adc) |
ADC Enable Deep-Power-Down Mdoe. More... | |
void | adc_disable_deeppwd (uint32_t adc) |
ADC Disable Deep-Power-Down Mdoe. More... | |
void | adc_power_on_async (uint32_t adc) |
Turn on the ADC (async) More... | |
void | adc_power_on (uint32_t adc) |
Turn on the ADC. More... | |
bool | adc_is_power_on (uint32_t adc) |
Is the ADC powered up and ready? 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... | |
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... | |
bool | adc_is_power_off (uint32_t adc) |
Is the ADC powered down? 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_regular_sequence (uint32_t adc, uint8_t length, uint8_t channel[]) |
ADC Set a Regular Channel Conversion Sequence. More... | |
void | adc_set_sample_time_on_all_channels (uint32_t adc, uint8_t time) |
ADC Set the Sample Time for All Channels. 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_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... | |
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_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... | |
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... | |
uint32_t | adc_read_regular (uint32_t adc) |
ADC Read from the Regular Conversion Result Register. 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... | |
void | adc_set_sample_time (uint32_t adc, uint8_t channel, uint8_t time) |
ADC Set the Sample Time for a Single Channel. More... | |
void | adc_enable_regulator (uint32_t adc) |
Enable the ADC Voltage regulator Before any use of the ADC, the ADC Voltage regulator must be enabled. More... | |
void | adc_disable_regulator (uint32_t adc) |
Disable the ADC Voltage regulator You can disable the adc vreg when not in use to save power. More... | |
Defined Constants and Types for the STM32G4xx Analog to Digital converter
LGPL License Terms libopencm3 License
#define ADC12_CFGR1_EXTSEL_EXTI11 ADC_CFGR1_EXTSEL_VAL(6) |
#define ADC12_CFGR1_EXTSEL_HRTIM_ADC_TRG1 ADC_CFGR1_EXTSEL_VAL(21) |
#define ADC12_CFGR1_EXTSEL_HRTIM_ADC_TRG10 ADC_CFGR1_EXTSEL_VAL(28) |
#define ADC12_CFGR1_EXTSEL_HRTIM_ADC_TRG3 ADC_CFGR1_EXTSEL_VAL(22) |
#define ADC12_CFGR1_EXTSEL_HRTIM_ADC_TRG5 ADC_CFGR1_EXTSEL_VAL(23) |
#define ADC12_CFGR1_EXTSEL_HRTIM_ADC_TRG6 ADC_CFGR1_EXTSEL_VAL(24) |
#define ADC12_CFGR1_EXTSEL_HRTIM_ADC_TRG7 ADC_CFGR1_EXTSEL_VAL(25) |
#define ADC12_CFGR1_EXTSEL_HRTIM_ADC_TRG8 ADC_CFGR1_EXTSEL_VAL(26) |
#define ADC12_CFGR1_EXTSEL_HRTIM_ADC_TRG9 ADC_CFGR1_EXTSEL_VAL(27) |
#define ADC12_CFGR1_EXTSEL_LPTIMOUT ADC_CFGR1_EXTSEL_VAL(29) |
#define ADC12_CFGR1_EXTSEL_TIM15_TRGO ADC_CFGR1_EXTSEL_VAL(14) |
#define ADC12_CFGR1_EXTSEL_TIM1_CC1 ADC_CFGR1_EXTSEL_VAL(0) |
#define ADC12_CFGR1_EXTSEL_TIM1_CC2 ADC_CFGR1_EXTSEL_VAL(1) |
#define ADC12_CFGR1_EXTSEL_TIM1_CC3 ADC_CFGR1_EXTSEL_VAL(2) |
#define ADC12_CFGR1_EXTSEL_TIM1_TRGO ADC_CFGR1_EXTSEL_VAL(9) |
#define ADC12_CFGR1_EXTSEL_TIM1_TRGO2 ADC_CFGR1_EXTSEL_VAL(10) |
#define ADC12_CFGR1_EXTSEL_TIM20_CC1 ADC_CFGR1_EXTSEL_VAL(18) |
#define ADC12_CFGR1_EXTSEL_TIM20_CC2 ADC_CFGR1_EXTSEL_VAL(19) |
#define ADC12_CFGR1_EXTSEL_TIM20_CC3 ADC_CFGR1_EXTSEL_VAL(20) |
#define ADC12_CFGR1_EXTSEL_TIM20_TRGO ADC_CFGR1_EXTSEL_VAL(16) |
#define ADC12_CFGR1_EXTSEL_TIM20_TRGO2 ADC_CFGR1_EXTSEL_VAL(17) |
#define ADC12_CFGR1_EXTSEL_TIM2_CC2 ADC_CFGR1_EXTSEL_VAL(3) |
#define ADC12_CFGR1_EXTSEL_TIM2_TRGO ADC_CFGR1_EXTSEL_VAL(11) |
#define ADC12_CFGR1_EXTSEL_TIM3_CC4 ADC_CFGR1_EXTSEL_VAL(15) |
#define ADC12_CFGR1_EXTSEL_TIM3_TRGO ADC_CFGR1_EXTSEL_VAL(4) |
#define ADC12_CFGR1_EXTSEL_TIM4_CC4 ADC_CFGR1_EXTSEL_VAL(5) |
#define ADC12_CFGR1_EXTSEL_TIM4_TRGO ADC_CFGR1_EXTSEL_VAL(12) |
#define ADC12_CFGR1_EXTSEL_TIM6_TRGO ADC_CFGR1_EXTSEL_VAL(13) |
#define ADC12_CFGR1_EXTSEL_TIM7_TRGO ADC_CFGR1_EXTSEL_VAL(30) |
#define ADC12_CFGR1_EXTSEL_TIM8_TRGO ADC_CFGR1_EXTSEL_VAL(7) |
#define ADC12_CFGR1_EXTSEL_TIM8_TRGO2 ADC_CFGR1_EXTSEL_VAL(8) |
#define ADC12_JSQR_JEXTSEL_EXTI15 (6 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_HRTIM_ADC_TRG10 (26 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_HRTIM_ADC_TRG2 (19 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_HRTIM_ADC_TRG4 (20 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_HRTIM_ADC_TRG5 (21 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_HRTIM_ADC_TRG6 (22 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_HRTIM_ADC_TRG7 (23 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_HRTIM_ADC_TRG8 (24 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_HRTIM_ADC_TRG9 (25 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_LPTIMOUT (29 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM15_TRGO (15 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM16_CC1 (27 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM1_CC4 (1 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM1_TRGO (0 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM1_TRGO2 (8 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM20_CC4 (18 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM20_TRGO (16 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM20_TRGO2 (17 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM2_CC1 (3 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM2_TRGO (2 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM3_CC1 (13 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM3_CC3 (11 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM3_CC4 (4 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM3_TRGO (12 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM4_TRGO (5 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM6_TRGO (14 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM7_TRGO (30 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM8_CC4 (7 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM8_TRGO (9 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC12_JSQR_JEXTSEL_TIM8_TRGO2 (10 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_CFGR1_EXTSEL_EXTI2 ADC_CFGR1_EXTSEL_VAL(5) |
#define ADC345_CFGR1_EXTSEL_HRTIM_ADC_TRG1 ADC_CFGR1_EXTSEL_VAL(21) |
#define ADC345_CFGR1_EXTSEL_HRTIM_ADC_TRG10 ADC_CFGR1_EXTSEL_VAL(28) |
#define ADC345_CFGR1_EXTSEL_HRTIM_ADC_TRG2 ADC_CFGR1_EXTSEL_VAL(19) |
#define ADC345_CFGR1_EXTSEL_HRTIM_ADC_TRG3 ADC_CFGR1_EXTSEL_VAL(22) |
#define ADC345_CFGR1_EXTSEL_HRTIM_ADC_TRG4 ADC_CFGR1_EXTSEL_VAL(20) |
#define ADC345_CFGR1_EXTSEL_HRTIM_ADC_TRG5 ADC_CFGR1_EXTSEL_VAL(23) |
#define ADC345_CFGR1_EXTSEL_HRTIM_ADC_TRG6 ADC_CFGR1_EXTSEL_VAL(24) |
#define ADC345_CFGR1_EXTSEL_HRTIM_ADC_TRG7 ADC_CFGR1_EXTSEL_VAL(25) |
#define ADC345_CFGR1_EXTSEL_HRTIM_ADC_TRG8 ADC_CFGR1_EXTSEL_VAL(26) |
#define ADC345_CFGR1_EXTSEL_HRTIM_ADC_TRG9 ADC_CFGR1_EXTSEL_VAL(27) |
#define ADC345_CFGR1_EXTSEL_LPTIMOUT ADC_CFGR1_EXTSEL_VAL(29) |
#define ADC345_CFGR1_EXTSEL_TIM15_TRGO ADC_CFGR1_EXTSEL_VAL(14) |
#define ADC345_CFGR1_EXTSEL_TIM1_CC3 ADC_CFGR1_EXTSEL_VAL(2) |
#define ADC345_CFGR1_EXTSEL_TIM1_TRGO ADC_CFGR1_EXTSEL_VAL(9) |
#define ADC345_CFGR1_EXTSEL_TIM1_TRGO2 ADC_CFGR1_EXTSEL_VAL(10) |
#define ADC345_CFGR1_EXTSEL_TIM20_CC1 ADC_CFGR1_EXTSEL_VAL(18) |
#define ADC345_CFGR1_EXTSEL_TIM20_TRGO ADC_CFGR1_EXTSEL_VAL(16) |
#define ADC345_CFGR1_EXTSEL_TIM20_TRGO2 ADC_CFGR1_EXTSEL_VAL(17) |
#define ADC345_CFGR1_EXTSEL_TIM2_CC1 ADC_CFGR1_EXTSEL_VAL(15) |
#define ADC345_CFGR1_EXTSEL_TIM2_CC3 ADC_CFGR1_EXTSEL_VAL(1) |
#define ADC345_CFGR1_EXTSEL_TIM2_TRGO ADC_CFGR1_EXTSEL_VAL(11) |
#define ADC345_CFGR1_EXTSEL_TIM3_CC1 ADC_CFGR1_EXTSEL_VAL(0) |
#define ADC345_CFGR1_EXTSEL_TIM3_TRGO ADC_CFGR1_EXTSEL_VAL(4) |
#define ADC345_CFGR1_EXTSEL_TIM4_CC1 ADC_CFGR1_EXTSEL_VAL(6) |
#define ADC345_CFGR1_EXTSEL_TIM4_TRGO ADC_CFGR1_EXTSEL_VAL(12) |
#define ADC345_CFGR1_EXTSEL_TIM6_TRGO ADC_CFGR1_EXTSEL_VAL(13) |
#define ADC345_CFGR1_EXTSEL_TIM7_TRGO ADC_CFGR1_EXTSEL_VAL(30) |
#define ADC345_CFGR1_EXTSEL_TIM8_CC1 ADC_CFGR1_EXTSEL_VAL(3) |
#define ADC345_CFGR1_EXTSEL_TIM8_TRGO ADC_CFGR1_EXTSEL_VAL(7) |
#define ADC345_CFGR1_EXTSEL_TIM8_TRGO2 ADC_CFGR1_EXTSEL_VAL(8) |
#define ADC345_JSQR_JEXTSEL_EXTI3 (13 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_HRTIM_ADC_TRG1 (27 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_HRTIM_ADC_TRG10 (26 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_HRTIM_ADC_TRG2 (19 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_HRTIM_ADC_TRG3 (28 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_HRTIM_ADC_TRG4 (20 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_HRTIM_ADC_TRG5 (21 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_HRTIM_ADC_TRG6 (22 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_HRTIM_ADC_TRG7 (23 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_HRTIM_ADC_TRG8 (24 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_HRTIM_ADC_TRG9 (25 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_LPTIMOUT (29 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM15_TRGO (15 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM1_CC3 (11 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM1_CC4 (1 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM1_TRGO (0 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM1_TRGO2 (8 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM20_CC2 (18 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM20_TRGO (16 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM20_TRGO2 (17 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM2_TRGO (2 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM3_TRGO (12 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM4_CC3 (4 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM4_CC4 (6 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM4_TRGO (5 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM6_TRGO (14 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM7_TRGO (30 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM8_CC2 (3 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM8_CC4 (7 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM8_TRGO (9 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC345_JSQR_JEXTSEL_TIM8_TRGO2 (10 << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC_CFGR1_DISCNUM_MASK (0x7 << ADC_CFGR1_DISCNUM_SHIFT) |
Definition at line 143 of file adc_common_v2_multi.h.
#define ADC_CFGR1_DISCNUM_SHIFT 17 |
Definition at line 142 of file adc_common_v2_multi.h.
#define ADC_CFGR1_DISCNUM_VAL | ( | x | ) | (((x) - 1) << ADC_CFGR1_DISCNUM_SHIFT) |
Definition at line 144 of file adc_common_v2_multi.h.
#define ADC_CFGR1_EXTSEL_MASK (0x1f << ADC_CFGR1_EXTSEL_SHIFT) |
#define ADC_CFGR1_EXTSEL_SHIFT 5 |
#define ADC_CFGR1_EXTSEL_VAL | ( | x | ) | ((x) << ADC_CFGR1_EXTSEL_SHIFT) |
#define ADC_CFGR1_JAUTO (1 << 25) |
Definition at line 130 of file adc_common_v2_multi.h.
#define ADC_CFGR1_JAWD1EN (1 << 24) |
Definition at line 133 of file adc_common_v2_multi.h.
#define ADC_CFGR1_JDISCEN (1 << 20) |
Definition at line 139 of file adc_common_v2_multi.h.
#define ADC_CFGR1_JQM (1 << 21) |
Definition at line 136 of file adc_common_v2_multi.h.
#define ADC_CFGR2_GCOMP (1 << 16) |
#define ADC_CFGR2_JOVSE (1 << 1) |
#define ADC_CFGR2_OVSR_128x ADC_CFGR2_OVSR_VAL(6) |
#define ADC_CFGR2_OVSR_16x ADC_CFGR2_OVSR_VAL(3) |
#define ADC_CFGR2_OVSR_256x ADC_CFGR2_OVSR_VAL(7) |
#define ADC_CFGR2_OVSR_2x ADC_CFGR2_OVSR_VAL(0) |
#define ADC_CFGR2_OVSR_32x ADC_CFGR2_OVSR_VAL(4) |
#define ADC_CFGR2_OVSR_4x ADC_CFGR2_OVSR_VAL(1) |
#define ADC_CFGR2_OVSR_64x ADC_CFGR2_OVSR_VAL(5) |
#define ADC_CFGR2_OVSR_8x ADC_CFGR2_OVSR_VAL(2) |
#define ADC_CFGR2_OVSR_MASK (0x7 << ADC_CFGR2_OVSR_SHIFT) |
#define ADC_CFGR2_OVSR_SHIFT 2 |
#define ADC_CFGR2_OVSR_VAL | ( | x | ) | ((x) << ADC_CFGR2_OVSR_SHIFT) |
#define ADC_CFGR2_OVSS_MASK (0xf << ADC_CFGR2_OVSS_SHIFT) |
#define ADC_CFGR2_OVSS_SHIFT 5 |
#define ADC_CFGR2_OVSS_VAL | ( | x | ) | ((x) << ADC_CFGR2_OVSS_SHIFT) |
#define ADC_CFGR2_ROVSE (1 << 0) |
#define ADC_CFGR2_ROVSM (1 << 10) |
#define ADC_CFGR2_SMPTRIG (1 << 27) |
#define ADC_CFGR2_SWTRIG (1 << 25) |
#define ADC_CFGR2_TROVS (1 << 9) |
#define ADC_CR_ADCALDIF (1 << 30) |
Definition at line 121 of file adc_common_v2_multi.h.
#define ADC_CR_ADVREGEN (1 << 28) |
#define ADC_CR_JADSTART (1 << 3) |
Definition at line 125 of file adc_common_v2_multi.h.
#define ADC_CR_JADSTP (1 << 5) |
Definition at line 123 of file adc_common_v2_multi.h.
#define ADC_GCOMP | ( | adc | ) | MMIO32((adc) + 0xC0) |
#define ADC_IER_AWD2IE (1 << 8) |
Definition at line 112 of file adc_common_v2_multi.h.
#define ADC_IER_AWD3IE (1 << 9) |
Definition at line 110 of file adc_common_v2_multi.h.
#define ADC_IER_JEOCIE (1 << 5) |
Definition at line 116 of file adc_common_v2_multi.h.
#define ADC_IER_JEOSIE (1 << 6) |
Definition at line 114 of file adc_common_v2_multi.h.
#define ADC_IER_JQOVFIE (1 << 10) |
Definition at line 108 of file adc_common_v2_multi.h.
#define ADC_ISR_AWD2 (1 << 8) |
Definition at line 99 of file adc_common_v2_multi.h.
#define ADC_ISR_AWD3 (1 << 9) |
Definition at line 97 of file adc_common_v2_multi.h.
#define ADC_ISR_JEOC (1 << 5) |
Definition at line 103 of file adc_common_v2_multi.h.
#define ADC_ISR_JEOS (1 << 6) |
Definition at line 101 of file adc_common_v2_multi.h.
#define ADC_ISR_JQOVF (1 << 10) |
Definition at line 95 of file adc_common_v2_multi.h.
#define ADC_JSQR_JEXTSEL_MASK (0x1F << ADC_JSQR_JEXTSEL_SHIFT) |
#define ADC_JSQR_JL_VAL | ( | val | ) | (((val) - 1) << ADC_JSQR_JL_SHIFT) |
#define ADC_JSQR_JSQ_VAL | ( | n, | |
val | |||
) | ((val) << (((n) - 1) * 6 + 8)) |
#define ADC_SQR1_L_MASK 0xf |
Definition at line 149 of file adc_common_v2_multi.h.
#define ADC_SQR1_L_SHIFT 0 |
Definition at line 148 of file adc_common_v2_multi.h.
#define ADC_SQR1_SQ1_SHIFT 6 |
Definition at line 151 of file adc_common_v2_multi.h.
#define ADC_SQR1_SQ2_SHIFT 12 |
Definition at line 152 of file adc_common_v2_multi.h.
#define ADC_SQR1_SQ3_SHIFT 18 |
Definition at line 153 of file adc_common_v2_multi.h.
#define ADC_SQR1_SQ4_SHIFT 24 |
Definition at line 154 of file adc_common_v2_multi.h.
#define ADC_SQR2_SQ5_SHIFT 0 |
Definition at line 155 of file adc_common_v2_multi.h.
#define ADC_SQR2_SQ6_SHIFT 6 |
Definition at line 156 of file adc_common_v2_multi.h.
#define ADC_SQR2_SQ7_SHIFT 12 |
Definition at line 157 of file adc_common_v2_multi.h.
#define ADC_SQR2_SQ8_SHIFT 18 |
Definition at line 158 of file adc_common_v2_multi.h.
#define ADC_SQR2_SQ9_SHIFT 24 |
Definition at line 159 of file adc_common_v2_multi.h.
#define ADC_SQR3_SQ10_SHIFT 0 |
Definition at line 160 of file adc_common_v2_multi.h.
#define ADC_SQR3_SQ11_SHIFT 6 |
Definition at line 161 of file adc_common_v2_multi.h.
#define ADC_SQR3_SQ12_SHIFT 12 |
Definition at line 162 of file adc_common_v2_multi.h.
#define ADC_SQR3_SQ13_SHIFT 18 |
Definition at line 163 of file adc_common_v2_multi.h.
#define ADC_SQR3_SQ14_SHIFT 24 |
Definition at line 164 of file adc_common_v2_multi.h.
#define ADC_SQR4_SQ15_SHIFT 0 |
Definition at line 165 of file adc_common_v2_multi.h.
#define ADC_SQR4_SQ16_SHIFT 6 |
Definition at line 166 of file adc_common_v2_multi.h.
#define ADC_SQRx_SQx_MASK 0x1f |
Definition at line 150 of file adc_common_v2_multi.h.
bool adc_awd | ( | uint32_t | adc | ) |
ADC Read the Analog Watchdog Flag.
This flag is set when the converted voltage crosses the high or low thresholds.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 658 of file adc.c.
References ADC_ISR, ADC_ISR_AWD1, ADC_ISR_AWD2, and ADC_ISR_AWD3.
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_all_awd_interrupt | ( | uint32_t | adc | ) |
ADC Disable Analog Watchdog Interrupt.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 306 of file adc.c.
References ADC_IER.
void adc_disable_analog_watchdog_injected | ( | uint32_t | adc | ) |
ADC Disable Analog Watchdog for Injected Conversions.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 88 of file adc.c.
References ADC_CFGR1.
void adc_disable_analog_watchdog_regular | ( | uint32_t | adc | ) |
ADC Enable Analog Watchdog for Regular Conversions.
The analog watchdog allows the monitoring of an analog signal between two threshold levels. The thresholds must be preset. Comparison is done before data alignment takes place, so the thresholds are left-aligned.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 60 of file adc.c.
References ADC_CFGR1.
void adc_disable_automatic_injected_group_conversion | ( | uint32_t | adc | ) |
ADC Disable Automatic Injected Conversions.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 180 of file adc.c.
References ADC_CFGR1.
void adc_disable_deeppwd | ( | uint32_t | adc | ) |
ADC Disable Deep-Power-Down Mdoe.
Deep-power-down mode allows additional power saving by internally switching off to reduce leakage currents.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 688 of file adc.c.
References ADC_CR.
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_discontinuous_mode_injected | ( | uint32_t | adc | ) |
ADC Disable Discontinuous Mode for Injected Conversions.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 151 of file adc.c.
References ADC_CFGR1.
void adc_disable_discontinuous_mode_regular | ( | uint32_t | adc | ) |
ADC Disable Discontinuous Mode for Regular Conversions.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 123 of file adc.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_eoc_interrupt_injected | ( | uint32_t | adc | ) |
ADC Disable Injected End-Of-Conversion Interrupt.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 255 of file adc.c.
References ADC_IER.
void adc_disable_eos_interrupt | ( | uint32_t | adc | ) |
ADC Disable Regular End-Of-Sequence Interrupt.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 332 of file adc.c.
References ADC_IER.
void adc_disable_eos_interrupt_injected | ( | uint32_t | adc | ) |
ADC Disable Injected End-Of-Sequence Interrupt.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 279 of file adc.c.
References ADC_IER.
void adc_disable_external_trigger_injected | ( | uint32_t | adc | ) |
ADC Disable an External Trigger for Injected Channels.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 641 of file adc.c.
References ADC_JSQR.
Referenced by adc_enable_automatic_injected_group_conversion().
void adc_disable_external_trigger_regular | ( | uint32_t | adc | ) |
ADC Disable an External Trigger for Regular Channels.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 605 of file adc.c.
References ADC_CFGR1.
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_regulator | ( | uint32_t | adc | ) |
Disable the ADC Voltage regulator You can disable the adc vreg when not in use to save power.
[in] | adc | ADC block register address base |
Definition at line 712 of file adc.c.
References ADC_CR.
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_all_awd_interrupt | ( | uint32_t | adc | ) |
ADC Enable Analog Watchdog Interrupt.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 292 of file adc.c.
References ADC_IER, ADC_IER_AWD1IE, ADC_IER_AWD2IE, and ADC_IER_AWD3IE.
void adc_enable_analog_watchdog_injected | ( | uint32_t | adc | ) |
ADC Enable Analog Watchdog for Injected Conversions.
The analog watchdog allows the monitoring of an analog signal between two threshold levels. The thresholds must be preset. Comparison is done before data alignment takes place, so the thresholds are left-aligned.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 76 of file adc.c.
References ADC_CFGR1, and ADC_CFGR1_JAWD1EN.
void adc_enable_analog_watchdog_on_all_channels | ( | uint32_t | adc | ) |
ADC Enable Analog Watchdog for All Regular and/or Injected Channels.
The analog watchdog allows the monitoring of an analog signal between two threshold levels. The thresholds must be preset. Comparison is done before data alignment takes place, so the thresholds are left-aligned.
adc_enable_analog_watchdog_injected, adc_enable_analog_watchdog_regular.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 202 of file adc.c.
References ADC_CFGR1.
void adc_enable_analog_watchdog_on_selected_channel | ( | uint32_t | adc, |
uint8_t | channel | ||
) |
ADC Enable Analog Watchdog for a Selected Channel.
The analog watchdog allows the monitoring of an analog signal between two threshold levels. The thresholds must be preset. Comparison is done before data alignment takes place, so the thresholds are left-aligned.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
[in] | channel | Unsigned int8. ADC channel numbe adc_watchdog_channel |
Definition at line 226 of file adc.c.
References ADC_CFGR1, ADC_CFGR1_AWD1CH_VAL, ADC_CFGR1_AWD1EN, and ADC_CFGR1_AWD1SGL.
void adc_enable_analog_watchdog_regular | ( | uint32_t | adc | ) |
ADC Enable Analog Watchdog for Regular Conversions.
The analog watchdog allows the monitoring of an analog signal between two threshold levels. The thresholds must be preset. Comparison is done before data alignment takes place, so the thresholds are left-aligned.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 45 of file adc.c.
References ADC_CFGR1, and ADC_CFGR1_AWD1EN.
void adc_enable_automatic_injected_group_conversion | ( | uint32_t | adc | ) |
ADC Enable Automatic Injected Conversions.
The ADC converts a defined injected group of channels immediately after the regular channels have been converted. The external trigger on the injected channels is disabled as required.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 167 of file adc.c.
References ADC_CFGR1, ADC_CFGR1_JAUTO, and adc_disable_external_trigger_injected().
void adc_enable_deeppwd | ( | uint32_t | adc | ) |
ADC Enable Deep-Power-Down Mdoe.
Deep-power-down mode allows additional power saving by internally switching off to reduce leakage currents.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 674 of file adc.c.
References ADC_CR, and ADC_CR_DEEPPWD.
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_discontinuous_mode_injected | ( | uint32_t | adc | ) |
ADC Enable Discontinuous Mode for Injected Conversions.
In this mode the ADC converts sequentially one channel of the defined group of injected channels, cycling back to the first channel in the group once the entire group has been converted.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 139 of file adc.c.
References ADC_CFGR1, and ADC_CFGR1_JDISCEN.
void adc_enable_discontinuous_mode_regular | ( | uint32_t | adc, |
uint8_t | length | ||
) |
ADC Enable Discontinuous Mode for Regular Conversions.
In this mode the ADC converts, on each trigger, a subgroup of up to 8 of the defined regular channel group. The subgroup is defined by the number of consecutive channels to be converted. After a subgroup has been converted the next trigger will start conversion of the immediately following subgroup of the same length or until the whole group has all been converted. When the whole group has been converted, the next trigger will restart conversion of the subgroup at the beginning of the whole group.
[in] | adc | ADC block register address base ADC register base addresses |
[in] | length | Number of channels in the group adc_cr1_discnum |
Definition at line 107 of file adc.c.
References ADC_CFGR1, ADC_CFGR1_DISCEN, and ADC_CFGR1_DISCNUM_SHIFT.
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_eoc_interrupt_injected | ( | uint32_t | adc | ) |
ADC Enable Injected End-Of-Conversion Interrupt.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 243 of file adc.c.
References ADC_IER, and ADC_IER_JEOCIE.
void adc_enable_eos_interrupt | ( | uint32_t | adc | ) |
ADC Enable Regular End-Of-Sequence Interrupt.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 320 of file adc.c.
References ADC_IER, and ADC_IER_EOSIE.
void adc_enable_eos_interrupt_injected | ( | uint32_t | adc | ) |
ADC Enable Injected End-Of-Sequence Interrupt.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 267 of file adc.c.
References ADC_IER, and ADC_IER_JEOSIE.
void adc_enable_external_trigger_injected | ( | uint32_t | adc, |
uint32_t | trigger, | ||
uint32_t | polarity | ||
) |
ADC Enable an External Trigger for Injected Channels.
This enables an external trigger for set of defined injected channels, and sets the polarity of the trigger event: rising or falling edge or both.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
[in] | trigger | Unsigned int8. Trigger identifier adc_trigger_injected |
[in] | polarity | Unsigned int32. Trigger polarity adc_trigger_polarity_injected |
Definition at line 624 of file adc.c.
References ADC_JSQR, ADC_JSQR_JEXTEN_MASK, and ADC_JSQR_JEXTSEL_MASK.
void adc_enable_external_trigger_regular | ( | uint32_t | adc, |
uint32_t | trigger, | ||
uint32_t | polarity | ||
) |
ADC Enable an External Trigger for Regular Channels.
This enables an external trigger for set of defined regular channels, and sets the polarity of the trigger event: rising or falling edge or both. Note that if the trigger polarity is zero, triggering is disabled.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
[in] | trigger | Unsigned int32. Trigger identifier adc_trigger_regular |
[in] | polarity | Unsigned int32. Trigger polarity adc_trigger_polarity_regular |
Definition at line 588 of file adc.c.
References ADC_CFGR1, ADC_CFGR1_EXTEN_MASK, and ADC_CFGR1_EXTSEL_MASK.
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_regulator | ( | uint32_t | adc | ) |
Enable the ADC Voltage regulator Before any use of the ADC, the ADC Voltage regulator must be enabled.
You must wait up to 10uSecs afterwards before trying anything else.
[in] | adc | ADC block register address base |
Definition at line 701 of file adc.c.
References ADC_CR, and ADC_CR_ADVREGEN.
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_eoc_injected | ( | uint32_t | adc | ) |
ADC Read the End-of-Conversion Flag for Injected Conversion.
This flag is set by hardware at the end of each injected conversion of a channel when a new data is available in the corresponding ADCx_JDRy register.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 437 of file adc.c.
References ADC_ISR, and ADC_ISR_JEOC.
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_eos_injected | ( | uint32_t | adc | ) |
ADC Read the End-of-Sequence Flag for Injected Conversions.
This flag is set after all channels of an injected group have been converted.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 452 of file adc.c.
References ADC_ISR, and ADC_ISR_JEOS.
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, ADC_CR_JADSTART, ADC_CR_JADSTP, 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_injected | ( | uint32_t | adc, |
uint8_t | reg | ||
) |
ADC Read from an Injected Conversion Result Register.
The result read back from the selected injected result register (one of four) is 12 bits, right or left aligned within the first 16 bits. The result can have a negative value if the injected channel offset has been set
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
[in] | reg | Unsigned int8. Register number (1 ... 4). |
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_clk_prescale | ( | uint32_t | adc, |
uint32_t | prescale | ||
) |
ADC Set Clock Prescale.
The ADC clock taken from the APB2 clock can be scaled down by 2, 4, 6 or 8.
adc | peripheral of choice ADC register base addresses | |
[in] | prescale | Prescale value for ADC Clock ADC clock prescaler |
Definition at line 545 of file adc.c.
References ADC_CCR, ADC_CCR_PRESC_MASK, and ADC_CCR_PRESC_SHIFT.
void adc_set_clk_source | ( | uint32_t | adc, |
uint32_t | source | ||
) |
ADC Set Clock Source.
The ADC clock taken from the APB2 clock can be scaled down by 2, 4, 6 or 8.
adc | peripheral of choice ADC register base addresses | |
[in] | source | Unsigned int32. Source value for ADC Clock adc_ccr_adcpre |
Definition at line 531 of file adc.c.
References ADC_CCR.
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_injected_offset | ( | uint32_t | adc, |
uint8_t | reg, | ||
uint32_t | offset | ||
) |
ADC Set the Injected Channel Data Offset.
This value is subtracted from the injected channel results after conversion is complete, and can result in negative results. A separate value can be specified for each injected data register.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
[in] | reg | Unsigned int8. Register number (1 ... 4). |
[in] | offset | Unsigned int32. |
Definition at line 500 of file adc.c.
References ADC_OFR1, ADC_OFR1_OFFSET1_EN, ADC_OFR2, ADC_OFR2_OFFSET2_EN, ADC_OFR3, ADC_OFR3_OFFSET3_EN, ADC_OFR4, and ADC_OFR4_OFFSET4_EN.
void adc_set_injected_sequence | ( | uint32_t | adc, |
uint8_t | length, | ||
uint8_t | channel[] | ||
) |
ADC Set an Injected Channel Conversion Sequence.
Defines a sequence of channels to be converted as an injected group with a length from 1 to 4 channels. If this is called during conversion, the current conversion is reset and conversion begins again with the newly defined group.
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
[in] | length | Unsigned int8. Number of channels in the group. |
[in] | channel | Unsigned int8[]. Set of channels in sequence, integers 0..18 |
Definition at line 407 of file adc.c.
References ADC_JSQR, ADC_JSQR_JL_VAL, and ADC_JSQR_JSQ_VAL.
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_multi_mode | ( | uint32_t | adc, |
uint32_t | mode | ||
) |
ADC set multi mode.
The multiple mode can uses these arrangement:
This setting is applied to ADC master only (ADC1 or ADC3).
The various modes possible are described in the reference manual.
adc | peripheral of choice ADC register base addresses | |
[in] | mode | Multiple mode selection from ADC Multi mode selection |
Definition at line 567 of file adc.c.
References ADC_CCR, ADC_CCR_DUAL_MASK, and ADC_CCR_DUAL_SHIFT.
void adc_set_regular_sequence | ( | uint32_t | adc, |
uint8_t | length, | ||
uint8_t | channel[] | ||
) |
ADC Set a Regular Channel Conversion Sequence.
Define a sequence of channels to be converted as a regular group with a length from 1 to 16 channels. If this is called during conversion, the current conversion is reset and conversion begins again with the newly defined group.
[in] | adc | ADC block register address base ADC register base addresses |
[in] | length | Number of channels in the group, range 0..16 |
[in] | channel | Set of channels in sequence, range ADC Channel Numbers |
Definition at line 100 of file adc_common_v2_multi.c.
References ADC_SQR1, ADC_SQR1_L_SHIFT, ADC_SQR2, ADC_SQR3, and ADC_SQR4.
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_sample_time | ( | uint32_t | adc, |
uint8_t | channel, | ||
uint8_t | time | ||
) |
ADC Set the Sample Time for a Single Channel.
The sampling time can be selected in ADC clock cycles, exact values depend on the device.
[in] | adc | ADC block register address base ADC register base addresses |
[in] | channel | ADC Channel integer ADC Channel Numbers |
[in] | time | Sampling time selection from ADC Sample Time Selection values |
Definition at line 47 of file adc_common_v2_multi.c.
void adc_set_sample_time_on_all_channels | ( | uint32_t | adc, |
uint8_t | time | ||
) |
ADC Set the Sample Time for All Channels.
The sampling time can be selected in ADC clock cycles, exact values depend on the device.
[in] | adc | ADC block register address base ADC register base addresses |
[in] | time | Sampling time selection from ADC Sample Time Selection values |
Definition at line 72 of file adc_common_v2_multi.c.
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_set_watchdog_high_threshold | ( | uint32_t | adc, |
uint16_t | threshold | ||
) |
void adc_set_watchdog_low_threshold | ( | uint32_t | adc, |
uint16_t | threshold | ||
) |
void adc_start_conversion_injected | ( | uint32_t | adc | ) |
ADC Software Triggered Conversion on Injected Channels.
This starts conversion on a set of defined injected channels. Depending on the configuration bits JEXTEN, a conversion will start immediately (software trigger configuration) or once an injected hardware trigger event occurs (hardware trigger configuration).
[in] | adc | Unsigned int32. ADC block register address base ADC register base addresses |
Definition at line 350 of file adc.c.
References ADC_CR, and ADC_CR_JADSTART.
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.