1571 lines
111 KiB
C
1571 lines
111 KiB
C
|
/**
|
||
|
******************************************************************************
|
||
|
* @file stm32g4xx_hal_adc_ex.h
|
||
|
* @author MCD Application Team
|
||
|
* @brief Header file of ADC HAL extended module.
|
||
|
******************************************************************************
|
||
|
* @attention
|
||
|
*
|
||
|
* Copyright (c) 2019 STMicroelectronics.
|
||
|
* All rights reserved.
|
||
|
*
|
||
|
* This software is licensed under terms that can be found in the LICENSE file
|
||
|
* in the root directory of this software component.
|
||
|
* If no LICENSE file comes with this software, it is provided AS-IS.
|
||
|
*
|
||
|
******************************************************************************
|
||
|
*/
|
||
|
|
||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||
|
#ifndef STM32G4xx_HAL_ADC_EX_H
|
||
|
#define STM32G4xx_HAL_ADC_EX_H
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/* Includes ------------------------------------------------------------------*/
|
||
|
#include "stm32g4xx_hal_def.h"
|
||
|
|
||
|
/** @addtogroup STM32G4xx_HAL_Driver
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/** @addtogroup ADCEx
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/* Exported types ------------------------------------------------------------*/
|
||
|
/** @defgroup ADCEx_Exported_Types ADC Extended Exported Types
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @brief ADC Injected Conversion Oversampling structure definition
|
||
|
*/
|
||
|
typedef struct
|
||
|
{
|
||
|
uint32_t Ratio; /*!< Configures the oversampling ratio.
|
||
|
This parameter can be a value of @ref ADC_HAL_EC_OVS_RATIO */
|
||
|
|
||
|
uint32_t RightBitShift; /*!< Configures the division coefficient for the Oversampler.
|
||
|
This parameter can be a value of @ref ADC_HAL_EC_OVS_SHIFT */
|
||
|
} ADC_InjOversamplingTypeDef;
|
||
|
|
||
|
/**
|
||
|
* @brief Structure definition of ADC group injected and ADC channel affected to ADC group injected
|
||
|
* @note Parameters of this structure are shared within 2 scopes:
|
||
|
* - Scope channel: InjectedChannel, InjectedRank, InjectedSamplingTime , InjectedSingleDiff,
|
||
|
* InjectedOffsetNumber, InjectedOffset, InjectedOffsetSign, InjectedOffsetSaturation
|
||
|
* - Scope ADC group injected (affects all channels of injected group): InjectedNbrOfConversion,
|
||
|
* InjectedDiscontinuousConvMode,
|
||
|
* AutoInjectedConv, QueueInjectedContext, ExternalTrigInjecConv, ExternalTrigInjecConvEdge,
|
||
|
* InjecOversamplingMode, InjecOversampling.
|
||
|
* @note The setting of these parameters by function HAL_ADCEx_InjectedConfigChannel() is conditioned to ADC state.
|
||
|
* ADC state can be either:
|
||
|
* - For all parameters: ADC disabled (this is the only possible ADC state to modify parameter
|
||
|
* 'InjectedSingleDiff')
|
||
|
* - For parameters 'InjectedDiscontinuousConvMode', 'QueueInjectedContext', 'InjecOversampling': ADC enabled
|
||
|
* without conversion on going on injected group.
|
||
|
* - For parameters 'InjectedSamplingTime', 'InjectedOffset', 'InjectedOffsetNumber', 'InjectedOffsetSign',
|
||
|
* 'InjectedOffsetSaturation', 'AutoInjectedConv': ADC enabled without conversion on going on regular and
|
||
|
* injected groups.
|
||
|
* - For parameters 'InjectedChannel', 'InjectedRank', 'InjectedNbrOfConversion', 'ExternalTrigInjecConv',
|
||
|
* 'ExternalTrigInjecConvEdge': ADC enabled and while conversion on going
|
||
|
* on ADC groups regular and injected.
|
||
|
* If ADC is not in the appropriate state to modify some parameters, these parameters setting is bypassed
|
||
|
* without error reporting (as it can be the expected behavior in case of intended action to update another
|
||
|
* parameter (which fulfills the ADC state condition) on the fly).
|
||
|
*/
|
||
|
typedef struct
|
||
|
{
|
||
|
uint32_t InjectedChannel; /*!< Specifies the channel to configure into ADC group injected.
|
||
|
This parameter can be a value of @ref ADC_HAL_EC_CHANNEL
|
||
|
Note: Depending on devices and ADC instances, some channels may not be
|
||
|
available on device package pins. Refer to device datasheet for
|
||
|
channels availability. */
|
||
|
|
||
|
uint32_t InjectedRank; /*!< Specifies the rank in the ADC group injected sequencer.
|
||
|
This parameter must be a value of @ref ADC_INJ_SEQ_RANKS.
|
||
|
Note: to disable a channel or change order of conversion sequencer,
|
||
|
rank containing a previous channel setting can be overwritten by
|
||
|
the new channel setting (or parameter number of conversions
|
||
|
adjusted) */
|
||
|
|
||
|
uint32_t InjectedSamplingTime; /*!< Sampling time value to be set for the selected channel.
|
||
|
Unit: ADC clock cycles.
|
||
|
Conversion time is the addition of sampling time and processing time
|
||
|
(12.5 ADC clock cycles at ADC resolution 12 bits, 10.5 cycles at 10 bits,
|
||
|
8.5 cycles at 8 bits, 6.5 cycles at 6 bits).
|
||
|
This parameter can be a value of @ref ADC_HAL_EC_CHANNEL_SAMPLINGTIME.
|
||
|
Caution: This parameter applies to a channel that can be used in a
|
||
|
regular and/or injected group. It overwrites the last setting.
|
||
|
Note: In case of usage of internal measurement channels (VrefInt, ...),
|
||
|
sampling time constraints must be respected (sampling time can be
|
||
|
adjusted in function of ADC clock frequency and sampling time
|
||
|
setting). Refer to device datasheet for timings values. */
|
||
|
|
||
|
uint32_t InjectedSingleDiff; /*!< Selection of single-ended or differential input.
|
||
|
In differential mode: Differential measurement is between the selected
|
||
|
channel 'i' (positive input) and channel 'i+1' (negative input).
|
||
|
Only channel 'i' has to be configured, channel 'i+1' is configured
|
||
|
automatically.
|
||
|
This parameter must be a value of
|
||
|
@ref ADC_HAL_EC_CHANNEL_SINGLE_DIFF_ENDING.
|
||
|
Caution: This parameter applies to a channel that can be used in a
|
||
|
regular and/or injected group. It overwrites the last setting.
|
||
|
Note: Refer to Reference Manual to ensure the selected channel is
|
||
|
available in differential mode.
|
||
|
Note: When configuring a channel 'i' in differential mode, the channel
|
||
|
'i+1' is not usable separately.
|
||
|
Note: This parameter must be modified when ADC is disabled (before ADC
|
||
|
start conversion or after ADC stop conversion).
|
||
|
If ADC is enabled, this parameter setting is bypassed without error
|
||
|
reporting (as it can be the expected behavior in case of another
|
||
|
parameter update on the fly) */
|
||
|
|
||
|
uint32_t InjectedOffsetNumber; /*!< Selects the offset number.
|
||
|
This parameter can be a value of @ref ADC_HAL_EC_OFFSET_NB.
|
||
|
Caution: Only one offset is allowed per channel. This parameter
|
||
|
overwrites the last setting. */
|
||
|
|
||
|
uint32_t InjectedOffset; /*!< Defines the offset to be applied on the raw converted data.
|
||
|
Offset value must be a positive number.
|
||
|
Depending of ADC resolution selected (12, 10, 8 or 6 bits), this
|
||
|
parameter must be a number between Min_Data = 0x000 and Max_Data = 0xFFF,
|
||
|
0x3FF, 0xFF or 0x3F respectively.
|
||
|
Note: This parameter must be modified when no conversion is on going
|
||
|
on both regular and injected groups (ADC disabled, or ADC enabled
|
||
|
without continuous mode or external trigger that could launch a
|
||
|
conversion). */
|
||
|
|
||
|
uint32_t InjectedOffsetSign; /*!< Define if the offset should be subtracted (negative sign) or added
|
||
|
(positive sign) from or to the raw converted data.
|
||
|
This parameter can be a value of @ref ADCEx_OffsetSign.
|
||
|
Note: This parameter must be modified when no conversion is on going
|
||
|
on both regular and injected groups (ADC disabled, or ADC
|
||
|
enabled without continuous mode or external trigger that could
|
||
|
launch a conversion). */
|
||
|
FunctionalState InjectedOffsetSaturation; /*!< Define if the offset should be saturated upon under or over flow.
|
||
|
This parameter value can be ENABLE or DISABLE.
|
||
|
Note: This parameter must be modified when no conversion is on going
|
||
|
on both regular and injected groups (ADC disabled, or ADC enabled
|
||
|
without continuous mode or external trigger that could launch a
|
||
|
conversion). */
|
||
|
|
||
|
uint32_t InjectedNbrOfConversion; /*!< Specifies the number of ranks that will be converted within the ADC group
|
||
|
injected sequencer.
|
||
|
To use the injected group sequencer and convert several ranks, parameter
|
||
|
'ScanConvMode' must be enabled.
|
||
|
This parameter must be a number between Min_Data = 1 and Max_Data = 4.
|
||
|
Caution: this setting impacts the entire injected group. Therefore,
|
||
|
call of HAL_ADCEx_InjectedConfigChannel() to configure a channel on
|
||
|
injected group can impact the configuration of other channels previously
|
||
|
set. */
|
||
|
|
||
|
FunctionalState InjectedDiscontinuousConvMode; /*!< Specifies whether the conversions sequence of ADC group injected
|
||
|
is performed in Complete-sequence/Discontinuous-sequence
|
||
|
(main sequence subdivided in successive parts).
|
||
|
Discontinuous mode is used only if sequencer is enabled (parameter
|
||
|
'ScanConvMode'). If sequencer is disabled, this parameter is discarded.
|
||
|
Discontinuous mode can be enabled only if continuous mode is disabled.
|
||
|
This parameter can be set to ENABLE or DISABLE.
|
||
|
Note: This parameter must be modified when ADC is disabled (before ADC
|
||
|
start conversion or after ADC stop conversion).
|
||
|
Note: For injected group, discontinuous mode converts the sequence
|
||
|
channel by channel (discontinuous length fixed to 1 rank).
|
||
|
Caution: this setting impacts the entire injected group. Therefore,
|
||
|
call of HAL_ADCEx_InjectedConfigChannel() to
|
||
|
configure a channel on injected group can impact the
|
||
|
configuration of other channels previously set. */
|
||
|
|
||
|
FunctionalState AutoInjectedConv; /*!< Enables or disables the selected ADC group injected automatic conversion
|
||
|
after regular one
|
||
|
This parameter can be set to ENABLE or DISABLE.
|
||
|
Note: To use Automatic injected conversion, discontinuous mode must
|
||
|
be disabled ('DiscontinuousConvMode' and
|
||
|
'InjectedDiscontinuousConvMode' set to DISABLE)
|
||
|
Note: To use Automatic injected conversion, injected group external
|
||
|
triggers must be disabled ('ExternalTrigInjecConv' set to
|
||
|
ADC_INJECTED_SOFTWARE_START)
|
||
|
Note: In case of DMA used with regular group: if DMA configured in
|
||
|
normal mode (single shot) JAUTO will be stopped upon DMA transfer
|
||
|
complete.
|
||
|
To maintain JAUTO always enabled, DMA must be configured in
|
||
|
circular mode.
|
||
|
Caution: this setting impacts the entire injected group. Therefore,
|
||
|
call of HAL_ADCEx_InjectedConfigChannel() to configure a channel
|
||
|
on injected group can impact the configuration of other channels
|
||
|
previously set. */
|
||
|
|
||
|
FunctionalState QueueInjectedContext; /*!< Specifies whether the context queue feature is enabled.
|
||
|
This parameter can be set to ENABLE or DISABLE.
|
||
|
If context queue is enabled, injected sequencer&channels configurations
|
||
|
are queued on up to 2 contexts. If a
|
||
|
new injected context is set when queue is full, error is triggered by
|
||
|
interruption and through function
|
||
|
'HAL_ADCEx_InjectedQueueOverflowCallback'.
|
||
|
Caution: This feature request that the sequence is fully configured
|
||
|
before injected conversion start.
|
||
|
Therefore, configure channels with as many calls to
|
||
|
HAL_ADCEx_InjectedConfigChannel() as the
|
||
|
'InjectedNbrOfConversion' parameter.
|
||
|
Caution: this setting impacts the entire injected group. Therefore,
|
||
|
call of HAL_ADCEx_InjectedConfigChannel() to
|
||
|
configure a channel on injected group can impact the
|
||
|
configuration of other channels previously set.
|
||
|
Note: This parameter must be modified when ADC is disabled (before ADC
|
||
|
start conversion or after ADC stop conversion). */
|
||
|
|
||
|
uint32_t ExternalTrigInjecConv; /*!< Selects the external event used to trigger the conversion start of
|
||
|
injected group.
|
||
|
If set to ADC_INJECTED_SOFTWARE_START, external triggers are disabled
|
||
|
and software trigger is used instead.
|
||
|
This parameter can be a value of
|
||
|
@ref ADC_injected_external_trigger_source.
|
||
|
Caution: this setting impacts the entire injected group. Therefore,
|
||
|
call of HAL_ADCEx_InjectedConfigChannel() to configure a channel
|
||
|
on injected group can impact the configuration of other channels
|
||
|
previously set. */
|
||
|
|
||
|
uint32_t ExternalTrigInjecConvEdge; /*!< Selects the external trigger edge of injected group.
|
||
|
This parameter can be a value of @ref ADC_injected_external_trigger_edge.
|
||
|
If trigger source is set to ADC_INJECTED_SOFTWARE_START, this parameter
|
||
|
is discarded.
|
||
|
Caution: this setting impacts the entire injected group. Therefore,
|
||
|
call of HAL_ADCEx_InjectedConfigChannel() to
|
||
|
configure a channel on injected group can impact the
|
||
|
configuration of other channels previously set. */
|
||
|
|
||
|
FunctionalState InjecOversamplingMode; /*!< Specifies whether the oversampling feature is enabled or disabled.
|
||
|
This parameter can be set to ENABLE or DISABLE.
|
||
|
Note: This parameter can be modified only if there is no
|
||
|
conversion is ongoing (both ADSTART and JADSTART cleared). */
|
||
|
|
||
|
ADC_InjOversamplingTypeDef InjecOversampling; /*!< Specifies the Oversampling parameters.
|
||
|
Caution: this setting overwrites the previous oversampling
|
||
|
configuration if oversampling already enabled.
|
||
|
Note: This parameter can be modified only if there is no
|
||
|
conversion is ongoing (both ADSTART and JADSTART cleared).*/
|
||
|
} ADC_InjectionConfTypeDef;
|
||
|
|
||
|
#if defined(ADC_MULTIMODE_SUPPORT)
|
||
|
/**
|
||
|
* @brief Structure definition of ADC multimode
|
||
|
* @note The setting of these parameters by function HAL_ADCEx_MultiModeConfigChannel() is conditioned by ADCs state
|
||
|
* (both Master and Slave ADCs).
|
||
|
* Both Master and Slave ADCs must be disabled.
|
||
|
*/
|
||
|
typedef struct
|
||
|
{
|
||
|
uint32_t Mode; /*!< Configures the ADC to operate in independent or multimode.
|
||
|
This parameter can be a value of @ref ADC_HAL_EC_MULTI_MODE. */
|
||
|
|
||
|
uint32_t DMAAccessMode; /*!< Configures the DMA mode for multimode ADC:
|
||
|
selection whether 2 DMA channels (each ADC uses its own DMA channel) or 1 DMA channel
|
||
|
(one DMA channel for both ADC, DMA of ADC master).
|
||
|
This parameter can be a value of @ref ADC_HAL_EC_MULTI_DMA_TRANSFER_RESOLUTION. */
|
||
|
|
||
|
uint32_t TwoSamplingDelay; /*!< Configures the Delay between 2 sampling phases.
|
||
|
This parameter can be a value of @ref ADC_HAL_EC_MULTI_TWOSMP_DELAY.
|
||
|
Delay range depends on selected resolution:
|
||
|
from 1 to 12 clock cycles for 12 bits, from 1 to 10 clock cycles for 10 bits,
|
||
|
from 1 to 8 clock cycles for 8 bits, from 1 to 6 clock cycles for 6 bits. */
|
||
|
} ADC_MultiModeTypeDef;
|
||
|
#endif /* ADC_MULTIMODE_SUPPORT */
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/* Exported constants --------------------------------------------------------*/
|
||
|
|
||
|
/** @defgroup ADCEx_Exported_Constants ADC Extended Exported Constants
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ADC_injected_external_trigger_source ADC group injected trigger source
|
||
|
* @{
|
||
|
*/
|
||
|
/* ADC group regular trigger sources for all ADC instances */
|
||
|
#define ADC_INJECTED_SOFTWARE_START (LL_ADC_INJ_TRIG_SOFTWARE) /*!< ADC group injected conversion
|
||
|
trigger software start */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T1_TRGO (LL_ADC_INJ_TRIG_EXT_TIM1_TRGO) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM1 TRGO. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T1_TRGO2 (LL_ADC_INJ_TRIG_EXT_TIM1_TRGO2) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM1 TRGO2. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T1_CC3 (LL_ADC_INJ_TRIG_EXT_TIM1_CH3) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM1 channel 3 event (capture compare). */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T1_CC4 (LL_ADC_INJ_TRIG_EXT_TIM1_CH4) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM1 channel 4 event (capture compare). */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T2_TRGO (LL_ADC_INJ_TRIG_EXT_TIM2_TRGO) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM2 TRGO. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T2_CC1 (LL_ADC_INJ_TRIG_EXT_TIM2_CH1) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM2 channel 1 event (capture compare). */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T3_TRGO (LL_ADC_INJ_TRIG_EXT_TIM3_TRGO) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM3 TRGO. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T3_CC1 (LL_ADC_INJ_TRIG_EXT_TIM3_CH1) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM3 channel 1 event (capture compare). */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T3_CC3 (LL_ADC_INJ_TRIG_EXT_TIM3_CH3) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM3 channel 3 event (capture compare). */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T3_CC4 (LL_ADC_INJ_TRIG_EXT_TIM3_CH4) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM3 channel 4 event (capture compare). */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T4_TRGO (LL_ADC_INJ_TRIG_EXT_TIM4_TRGO) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM4 TRGO. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T4_CC3 (LL_ADC_INJ_TRIG_EXT_TIM4_CH3) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM4 channel 3 event (capture compare). */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T4_CC4 (LL_ADC_INJ_TRIG_EXT_TIM4_CH4) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM4 channel 4 event (capture compare). */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T6_TRGO (LL_ADC_INJ_TRIG_EXT_TIM6_TRGO) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM6 TRGO. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T7_TRGO (LL_ADC_INJ_TRIG_EXT_TIM7_TRGO) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM7 TRGO. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T8_TRGO (LL_ADC_INJ_TRIG_EXT_TIM8_TRGO) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM8 TRGO. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T8_TRGO2 (LL_ADC_INJ_TRIG_EXT_TIM8_TRGO2) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM8 TRGO2. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T8_CC2 (LL_ADC_INJ_TRIG_EXT_TIM8_CH2) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM8 channel 2 event (capture compare). */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T8_CC4 (LL_ADC_INJ_TRIG_EXT_TIM8_CH4) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM8 channel 4 event (capture compare). */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T15_TRGO (LL_ADC_INJ_TRIG_EXT_TIM15_TRGO) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM15 TRGO. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T16_CC1 (LL_ADC_INJ_TRIG_EXT_TIM16_CH1) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM8 channel 4 event (capture compare). */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T20_TRGO (LL_ADC_INJ_TRIG_EXT_TIM20_TRGO) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM20 TRGO. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T20_TRGO2 (LL_ADC_INJ_TRIG_EXT_TIM20_TRGO2) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM20 TRGO2. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T20_CC2 (LL_ADC_INJ_TRIG_EXT_TIM20_CH2) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM20 channel 2 event (capture compare). */
|
||
|
#define ADC_EXTERNALTRIGINJEC_T20_CC4 (LL_ADC_INJ_TRIG_EXT_TIM20_CH4) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: TIM20 channel 4 event (capture compare). */
|
||
|
#define ADC_EXTERNALTRIGINJEC_HRTIM_TRG1 (LL_ADC_INJ_TRIG_EXT_HRTIM_TRG1) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: HRTIMER ADC trigger 1 event. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_HRTIM_TRG2 (LL_ADC_INJ_TRIG_EXT_HRTIM_TRG2) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: HRTIMER ADC trigger 2 event. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_HRTIM_TRG3 (LL_ADC_INJ_TRIG_EXT_HRTIM_TRG3) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: HRTIMER ADC trigger 3 event. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_HRTIM_TRG4 (LL_ADC_INJ_TRIG_EXT_HRTIM_TRG4) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: HRTIMER ADC trigger 4 event. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_HRTIM_TRG5 (LL_ADC_INJ_TRIG_EXT_HRTIM_TRG5) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: HRTIMER ADC trigger 5 event. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_HRTIM_TRG6 (LL_ADC_INJ_TRIG_EXT_HRTIM_TRG6) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: HRTIMER ADC trigger 6 event. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_HRTIM_TRG7 (LL_ADC_INJ_TRIG_EXT_HRTIM_TRG7) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: HRTIMER ADC trigger 7 event. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_HRTIM_TRG8 (LL_ADC_INJ_TRIG_EXT_HRTIM_TRG8) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: HRTIMER ADC trigger 8 event. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_HRTIM_TRG9 (LL_ADC_INJ_TRIG_EXT_HRTIM_TRG9) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: HRTIMER ADC trigger 9 event. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_HRTIM_TRG10 (LL_ADC_INJ_TRIG_EXT_HRTIM_TRG10) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: HRTIMER ADC trigger 10 event. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_EXT_IT3 (LL_ADC_INJ_TRIG_EXT_EXTI_LINE3) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: external interrupt line 3. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_EXT_IT15 (LL_ADC_INJ_TRIG_EXT_EXTI_LINE15) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: external interrupt line 15. */
|
||
|
#define ADC_EXTERNALTRIGINJEC_LPTIM_OUT (LL_ADC_INJ_TRIG_EXT_LPTIM_OUT) /*!< ADC group injected conversion
|
||
|
trigger from external peripheral: LPTIMER OUT event. */
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ADC_injected_external_trigger_edge ADC group injected trigger edge (when external trigger is selected)
|
||
|
* @{
|
||
|
*/
|
||
|
#define ADC_EXTERNALTRIGINJECCONV_EDGE_NONE (0x00000000UL) /*!< Injected conversions trigger
|
||
|
disabled (SW start)*/
|
||
|
#define ADC_EXTERNALTRIGINJECCONV_EDGE_RISING (ADC_JSQR_JEXTEN_0) /*!< Injected conversions trigger
|
||
|
polarity set to rising edge */
|
||
|
#define ADC_EXTERNALTRIGINJECCONV_EDGE_FALLING (ADC_JSQR_JEXTEN_1) /*!< Injected conversions trigger
|
||
|
polarity set to falling edge */
|
||
|
#define ADC_EXTERNALTRIGINJECCONV_EDGE_RISINGFALLING (ADC_JSQR_JEXTEN) /*!< Injected conversions trigger
|
||
|
polarity set to both rising and falling edges */
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ADC_HAL_EC_CHANNEL_SINGLE_DIFF_ENDING Channel - Single or differential ending
|
||
|
* @{
|
||
|
*/
|
||
|
#define ADC_SINGLE_ENDED (LL_ADC_SINGLE_ENDED) /*!< ADC channel ending set to single ended */
|
||
|
#define ADC_DIFFERENTIAL_ENDED (LL_ADC_DIFFERENTIAL_ENDED) /*!< ADC channel ending set to differential */
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ADC_HAL_EC_OFFSET_NB ADC instance - Offset number
|
||
|
* @{
|
||
|
*/
|
||
|
#define ADC_OFFSET_NONE (ADC_OFFSET_4 + 1U) /*!< ADC offset disabled: no offset correction for the selected
|
||
|
ADC channel */
|
||
|
#define ADC_OFFSET_1 (LL_ADC_OFFSET_1) /*!< ADC offset number 1: ADC channel and offset level to which
|
||
|
the offset programmed will be applied (independently of channel mapped
|
||
|
on ADC group regular or group injected) */
|
||
|
#define ADC_OFFSET_2 (LL_ADC_OFFSET_2) /*!< ADC offset number 2: ADC channel and offset level to which
|
||
|
the offset programmed will be applied (independently of channel mapped
|
||
|
on ADC group regular or group injected) */
|
||
|
#define ADC_OFFSET_3 (LL_ADC_OFFSET_3) /*!< ADC offset number 3: ADC channel and offset level to which
|
||
|
the offset programmed will be applied (independently of channel mapped
|
||
|
on ADC group regular or group injected) */
|
||
|
#define ADC_OFFSET_4 (LL_ADC_OFFSET_4) /*!< ADC offset number 4: ADC channel and offset level to which
|
||
|
the offset programmed will be applied (independently of channel mapped
|
||
|
on ADC group regular or group injected) */
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ADCEx_OffsetSign ADC Extended Offset Sign
|
||
|
* @{
|
||
|
*/
|
||
|
#define ADC_OFFSET_SIGN_NEGATIVE (0x00000000UL) /*!< Offset sign negative, offset is subtracted */
|
||
|
#define ADC_OFFSET_SIGN_POSITIVE (ADC_OFR1_OFFSETPOS) /*!< Offset sign positive, offset is added */
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ADC_INJ_SEQ_RANKS ADC group injected - Sequencer ranks
|
||
|
* @{
|
||
|
*/
|
||
|
#define ADC_INJECTED_RANK_1 (LL_ADC_INJ_RANK_1) /*!< ADC group injected sequencer rank 1 */
|
||
|
#define ADC_INJECTED_RANK_2 (LL_ADC_INJ_RANK_2) /*!< ADC group injected sequencer rank 2 */
|
||
|
#define ADC_INJECTED_RANK_3 (LL_ADC_INJ_RANK_3) /*!< ADC group injected sequencer rank 3 */
|
||
|
#define ADC_INJECTED_RANK_4 (LL_ADC_INJ_RANK_4) /*!< ADC group injected sequencer rank 4 */
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
#if defined(ADC_MULTIMODE_SUPPORT)
|
||
|
/** @defgroup ADC_HAL_EC_MULTI_MODE Multimode - Mode
|
||
|
* @{
|
||
|
*/
|
||
|
#define ADC_MODE_INDEPENDENT (LL_ADC_MULTI_INDEPENDENT) /*!< ADC dual mode disabled
|
||
|
(ADC independent mode) */
|
||
|
#define ADC_DUALMODE_REGSIMULT (LL_ADC_MULTI_DUAL_REG_SIMULT) /*!< ADC dual mode enabled: group regular
|
||
|
simultaneous */
|
||
|
#define ADC_DUALMODE_INTERL (LL_ADC_MULTI_DUAL_REG_INTERL) /*!< ADC dual mode enabled: Combined
|
||
|
group regular interleaved */
|
||
|
#define ADC_DUALMODE_INJECSIMULT (LL_ADC_MULTI_DUAL_INJ_SIMULT) /*!< ADC dual mode enabled: group
|
||
|
injected simultaneous */
|
||
|
#define ADC_DUALMODE_ALTERTRIG (LL_ADC_MULTI_DUAL_INJ_ALTERN) /*!< ADC dual mode enabled: group
|
||
|
injected alternate trigger. Works only with external triggers (not internal
|
||
|
SW start) */
|
||
|
#define ADC_DUALMODE_REGSIMULT_INJECSIMULT (LL_ADC_MULTI_DUAL_REG_SIM_INJ_SIM) /*!< ADC dual mode enabled: Combined
|
||
|
group regular simultaneous + group injected simultaneous */
|
||
|
#define ADC_DUALMODE_REGSIMULT_ALTERTRIG (LL_ADC_MULTI_DUAL_REG_SIM_INJ_ALT) /*!< ADC dual mode enabled: Combined
|
||
|
group regular simultaneous + group injected alternate trigger */
|
||
|
#define ADC_DUALMODE_REGINTERL_INJECSIMULT (LL_ADC_MULTI_DUAL_REG_INT_INJ_SIM) /*!< ADC dual mode enabled: Combined
|
||
|
group regular interleaved + group injected simultaneous */
|
||
|
|
||
|
/** @defgroup ADC_HAL_EC_MULTI_DMA_TRANSFER_RESOLUTION Multimode - DMA transfer mode depending on ADC resolution
|
||
|
* @{
|
||
|
*/
|
||
|
#define ADC_DMAACCESSMODE_DISABLED (0x00000000UL) /*!< DMA multimode disabled: each ADC uses its own
|
||
|
DMA channel */
|
||
|
#define ADC_DMAACCESSMODE_12_10_BITS (ADC_CCR_MDMA_1) /*!< DMA multimode enabled (one DMA channel for both ADC,
|
||
|
DMA of ADC master) for 12 and 10 bits resolution */
|
||
|
#define ADC_DMAACCESSMODE_8_6_BITS (ADC_CCR_MDMA) /*!< DMA multimode enabled (one DMA channel for both ADC,
|
||
|
DMA of ADC master) for 8 and 6 bits resolution */
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ADC_HAL_EC_MULTI_TWOSMP_DELAY Multimode - Delay between two sampling phases
|
||
|
* @{
|
||
|
*/
|
||
|
#define ADC_TWOSAMPLINGDELAY_1CYCLE (LL_ADC_MULTI_TWOSMP_DELAY_1CYCLE) /*!< ADC multimode delay between two
|
||
|
sampling phases: 1 ADC clock cycle */
|
||
|
#define ADC_TWOSAMPLINGDELAY_2CYCLES (LL_ADC_MULTI_TWOSMP_DELAY_2CYCLES) /*!< ADC multimode delay between two
|
||
|
sampling phases: 2 ADC clock cycles */
|
||
|
#define ADC_TWOSAMPLINGDELAY_3CYCLES (LL_ADC_MULTI_TWOSMP_DELAY_3CYCLES) /*!< ADC multimode delay between two
|
||
|
sampling phases: 3 ADC clock cycles */
|
||
|
#define ADC_TWOSAMPLINGDELAY_4CYCLES (LL_ADC_MULTI_TWOSMP_DELAY_4CYCLES) /*!< ADC multimode delay between two
|
||
|
sampling phases: 4 ADC clock cycles */
|
||
|
#define ADC_TWOSAMPLINGDELAY_5CYCLES (LL_ADC_MULTI_TWOSMP_DELAY_5CYCLES) /*!< ADC multimode delay between two
|
||
|
sampling phases: 5 ADC clock cycles */
|
||
|
#define ADC_TWOSAMPLINGDELAY_6CYCLES (LL_ADC_MULTI_TWOSMP_DELAY_6CYCLES) /*!< ADC multimode delay between two
|
||
|
sampling phases: 6 ADC clock cycles */
|
||
|
#define ADC_TWOSAMPLINGDELAY_7CYCLES (LL_ADC_MULTI_TWOSMP_DELAY_7CYCLES) /*!< ADC multimode delay between two
|
||
|
sampling phases: 7 ADC clock cycles */
|
||
|
#define ADC_TWOSAMPLINGDELAY_8CYCLES (LL_ADC_MULTI_TWOSMP_DELAY_8CYCLES) /*!< ADC multimode delay between two
|
||
|
sampling phases: 8 ADC clock cycles */
|
||
|
#define ADC_TWOSAMPLINGDELAY_9CYCLES (LL_ADC_MULTI_TWOSMP_DELAY_9CYCLES) /*!< ADC multimode delay between two
|
||
|
sampling phases: 9 ADC clock cycles */
|
||
|
#define ADC_TWOSAMPLINGDELAY_10CYCLES (LL_ADC_MULTI_TWOSMP_DELAY_10CYCLES) /*!< ADC multimode delay between two
|
||
|
sampling phases: 10 ADC clock cycles */
|
||
|
#define ADC_TWOSAMPLINGDELAY_11CYCLES (LL_ADC_MULTI_TWOSMP_DELAY_11CYCLES) /*!< ADC multimode delay between two
|
||
|
sampling phases: 11 ADC clock cycles */
|
||
|
#define ADC_TWOSAMPLINGDELAY_12CYCLES (LL_ADC_MULTI_TWOSMP_DELAY_12CYCLES) /*!< ADC multimode delay between two
|
||
|
sampling phases: 12 ADC clock cycles */
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
#endif /* ADC_MULTIMODE_SUPPORT */
|
||
|
|
||
|
/** @defgroup ADC_HAL_EC_GROUPS ADC instance - Groups
|
||
|
* @{
|
||
|
*/
|
||
|
#define ADC_REGULAR_GROUP (LL_ADC_GROUP_REGULAR) /*!< ADC group regular (available on
|
||
|
all STM32 devices) */
|
||
|
#define ADC_INJECTED_GROUP (LL_ADC_GROUP_INJECTED) /*!< ADC group injected (not available on
|
||
|
all STM32 devices) */
|
||
|
#define ADC_REGULAR_INJECTED_GROUP (LL_ADC_GROUP_REGULAR_INJECTED) /*!< ADC both groups regular and injected */
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ADC_CFGR_fields ADCx CFGR fields
|
||
|
* @{
|
||
|
*/
|
||
|
#define ADC_CFGR_FIELDS (ADC_CFGR_AWD1CH | ADC_CFGR_JAUTO | ADC_CFGR_JAWD1EN |\
|
||
|
ADC_CFGR_AWD1EN | ADC_CFGR_AWD1SGL | ADC_CFGR_JQM |\
|
||
|
ADC_CFGR_JDISCEN | ADC_CFGR_DISCNUM | ADC_CFGR_DISCEN |\
|
||
|
ADC_CFGR_AUTDLY | ADC_CFGR_CONT | ADC_CFGR_OVRMOD |\
|
||
|
ADC_CFGR_EXTEN | ADC_CFGR_EXTSEL | ADC_CFGR_ALIGN |\
|
||
|
ADC_CFGR_RES | ADC_CFGR_DMACFG | ADC_CFGR_DMAEN )
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ADC_SMPR1_fields ADCx SMPR1 fields
|
||
|
* @{
|
||
|
*/
|
||
|
#if defined(ADC_SMPR1_SMPPLUS)
|
||
|
#define ADC_SMPR1_FIELDS (ADC_SMPR1_SMP9 | ADC_SMPR1_SMP8 | ADC_SMPR1_SMP7 |\
|
||
|
ADC_SMPR1_SMP6 | ADC_SMPR1_SMP5 | ADC_SMPR1_SMP4 |\
|
||
|
ADC_SMPR1_SMP3 | ADC_SMPR1_SMP2 | ADC_SMPR1_SMP1 |\
|
||
|
ADC_SMPR1_SMP0 | ADC_SMPR1_SMPPLUS)
|
||
|
#else
|
||
|
#define ADC_SMPR1_FIELDS (ADC_SMPR1_SMP9 | ADC_SMPR1_SMP8 | ADC_SMPR1_SMP7 |\
|
||
|
ADC_SMPR1_SMP6 | ADC_SMPR1_SMP5 | ADC_SMPR1_SMP4 |\
|
||
|
ADC_SMPR1_SMP3 | ADC_SMPR1_SMP2 | ADC_SMPR1_SMP1 |\
|
||
|
ADC_SMPR1_SMP0)
|
||
|
#endif /* ADC_SMPR1_SMPPLUS */
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ADC_CFGR_fields_2 ADCx CFGR sub fields
|
||
|
* @{
|
||
|
*/
|
||
|
/* ADC_CFGR fields of parameters that can be updated when no conversion
|
||
|
(neither regular nor injected) is on-going */
|
||
|
#define ADC_CFGR_FIELDS_2 ((ADC_CFGR_DMACFG | ADC_CFGR_AUTDLY))
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/* Exported macros -----------------------------------------------------------*/
|
||
|
|
||
|
#if defined(ADC_MULTIMODE_SUPPORT)
|
||
|
/** @defgroup ADCEx_Exported_Macro ADC Extended Exported Macros
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/** @brief Force ADC instance in multimode mode independent (multimode disable).
|
||
|
* @note This macro must be used only in case of transition from multimode
|
||
|
* to mode independent and in case of unknown previous state,
|
||
|
* to ensure ADC configuration is in mode independent.
|
||
|
* @note Standard way of multimode configuration change is done from
|
||
|
* HAL ADC handle of ADC master using function
|
||
|
* "HAL_ADCEx_MultiModeConfigChannel(..., ADC_MODE_INDEPENDENT)" )".
|
||
|
* Usage of this macro is not the Standard way of multimode
|
||
|
* configuration and can lead to have HAL ADC handles status
|
||
|
* misaligned. Usage of this macro must be limited to cases
|
||
|
* mentioned above.
|
||
|
* @param __HANDLE__ ADC handle.
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_FORCE_MODE_INDEPENDENT(__HANDLE__) \
|
||
|
LL_ADC_SetMultimode(__LL_ADC_COMMON_INSTANCE((__HANDLE__)->Instance), LL_ADC_MULTI_INDEPENDENT)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
#endif /* ADC_MULTIMODE_SUPPORT */
|
||
|
|
||
|
/* Private macros ------------------------------------------------------------*/
|
||
|
|
||
|
/** @defgroup ADCEx_Private_Macro_internal_HAL_driver ADC Extended Private Macros
|
||
|
* @{
|
||
|
*/
|
||
|
/* Macro reserved for internal HAL driver usage, not intended to be used in */
|
||
|
/* code of final user. */
|
||
|
|
||
|
/**
|
||
|
* @brief Test if conversion trigger of injected group is software start
|
||
|
* or external trigger.
|
||
|
* @param __HANDLE__ ADC handle.
|
||
|
* @retval SET (software start) or RESET (external trigger).
|
||
|
*/
|
||
|
#define ADC_IS_SOFTWARE_START_INJECTED(__HANDLE__) \
|
||
|
(((__HANDLE__)->Instance->JSQR & ADC_JSQR_JEXTEN) == 0UL)
|
||
|
|
||
|
/**
|
||
|
* @brief Check whether or not ADC is independent.
|
||
|
* @param __HANDLE__ ADC handle.
|
||
|
* @note When multimode feature is not available, the macro always returns SET.
|
||
|
* @retval SET (ADC is independent) or RESET (ADC is not).
|
||
|
*/
|
||
|
#if defined(STM32G474xx) || defined(STM32G484xx) || defined(STM32G473xx) || defined(STM32G483xx)
|
||
|
#define ADC_IS_INDEPENDENT(__HANDLE__) \
|
||
|
( ( ( ((__HANDLE__)->Instance) == ADC5) \
|
||
|
)? \
|
||
|
SET \
|
||
|
: \
|
||
|
RESET \
|
||
|
)
|
||
|
#elif defined(STM32G491xx) || defined(STM32G4A1xx) || defined(STM32G411xC)
|
||
|
#define ADC_IS_INDEPENDENT(__HANDLE__) \
|
||
|
( ( ( ((__HANDLE__)->Instance) == ADC3) \
|
||
|
)? \
|
||
|
SET \
|
||
|
: \
|
||
|
RESET \
|
||
|
)
|
||
|
#elif defined(STM32G411xB) || defined(STM32G414xx) || defined(STM32GBK1CB) || defined(STM32G431xx) || defined(STM32G441xx) || defined(STM32G471xx)
|
||
|
#define ADC_IS_INDEPENDENT(__HANDLE__) (RESET)
|
||
|
#endif /* defined(STM32G474xx) || defined(STM32G484xx) || defined(STM32G473xx) || defined(STM32G483xx) */
|
||
|
|
||
|
/**
|
||
|
* @brief Set the selected injected Channel rank.
|
||
|
* @param __CHANNELNB__ Channel number.
|
||
|
* @param __RANKNB__ Rank number.
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_JSQR_RK(__CHANNELNB__, __RANKNB__) \
|
||
|
((((__CHANNELNB__) & ADC_CHANNEL_ID_NUMBER_MASK) >> ADC_CHANNEL_ID_NUMBER_BITOFFSET_POS) \
|
||
|
<< ((__RANKNB__) & ADC_INJ_RANK_ID_JSQR_MASK))
|
||
|
|
||
|
/**
|
||
|
* @brief Configure ADC injected context queue
|
||
|
* @param __INJECT_CONTEXT_QUEUE_MODE__ Injected context queue mode.
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_CFGR_INJECT_CONTEXT_QUEUE(__INJECT_CONTEXT_QUEUE_MODE__) \
|
||
|
((__INJECT_CONTEXT_QUEUE_MODE__) << ADC_CFGR_JQM_Pos)
|
||
|
|
||
|
/**
|
||
|
* @brief Configure ADC discontinuous conversion mode for injected group
|
||
|
* @param __INJECT_DISCONTINUOUS_MODE__ Injected discontinuous mode.
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_CFGR_INJECT_DISCCONTINUOUS(__INJECT_DISCONTINUOUS_MODE__) \
|
||
|
((__INJECT_DISCONTINUOUS_MODE__) << ADC_CFGR_JDISCEN_Pos)
|
||
|
|
||
|
/**
|
||
|
* @brief Configure ADC discontinuous conversion mode for regular group
|
||
|
* @param __REG_DISCONTINUOUS_MODE__ Regular discontinuous mode.
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_CFGR_REG_DISCONTINUOUS(__REG_DISCONTINUOUS_MODE__) \
|
||
|
((__REG_DISCONTINUOUS_MODE__) << ADC_CFGR_DISCEN_Pos)
|
||
|
|
||
|
/**
|
||
|
* @brief Configure the number of discontinuous conversions for regular group.
|
||
|
* @param __NBR_DISCONTINUOUS_CONV__ Number of discontinuous conversions.
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_CFGR_DISCONTINUOUS_NUM(__NBR_DISCONTINUOUS_CONV__) \
|
||
|
(((__NBR_DISCONTINUOUS_CONV__) - 1UL) << ADC_CFGR_DISCNUM_Pos)
|
||
|
|
||
|
/**
|
||
|
* @brief Configure the ADC auto delay mode.
|
||
|
* @param __AUTOWAIT__ Auto delay bit enable or disable.
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_CFGR_AUTOWAIT(__AUTOWAIT__) ((__AUTOWAIT__) << ADC_CFGR_AUTDLY_Pos)
|
||
|
|
||
|
/**
|
||
|
* @brief Configure ADC continuous conversion mode.
|
||
|
* @param __CONTINUOUS_MODE__ Continuous mode.
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_CFGR_CONTINUOUS(__CONTINUOUS_MODE__) ((__CONTINUOUS_MODE__) << ADC_CFGR_CONT_Pos)
|
||
|
|
||
|
/**
|
||
|
* @brief Configure the ADC DMA continuous request.
|
||
|
* @param __DMACONTREQ_MODE__ DMA continuous request mode.
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_CFGR_DMACONTREQ(__DMACONTREQ_MODE__) ((__DMACONTREQ_MODE__) << ADC_CFGR_DMACFG_Pos)
|
||
|
|
||
|
#if defined(ADC_MULTIMODE_SUPPORT)
|
||
|
/**
|
||
|
* @brief Configure the ADC DMA continuous request for ADC multimode.
|
||
|
* @param __DMACONTREQ_MODE__ DMA continuous request mode.
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_CCR_MULTI_DMACONTREQ(__DMACONTREQ_MODE__) ((__DMACONTREQ_MODE__) << ADC_CCR_DMACFG_Pos)
|
||
|
#endif /* ADC_MULTIMODE_SUPPORT */
|
||
|
|
||
|
/**
|
||
|
* @brief Shift the offset with respect to the selected ADC resolution.
|
||
|
* @note Offset has to be left-aligned on bit 11, the LSB (right bits) are set to 0.
|
||
|
* If resolution 12 bits, no shift.
|
||
|
* If resolution 10 bits, shift of 2 ranks on the left.
|
||
|
* If resolution 8 bits, shift of 4 ranks on the left.
|
||
|
* If resolution 6 bits, shift of 6 ranks on the left.
|
||
|
* Therefore, shift = (12 - resolution) = 12 - (12- (((RES[1:0]) >> 3)*2)).
|
||
|
* @param __HANDLE__ ADC handle
|
||
|
* @param __OFFSET__ Value to be shifted
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_OFFSET_SHIFT_RESOLUTION(__HANDLE__, __OFFSET__) \
|
||
|
((__OFFSET__) << ((((__HANDLE__)->Instance->CFGR & ADC_CFGR_RES) >> 3UL) * 2UL))
|
||
|
|
||
|
/**
|
||
|
* @brief Shift the AWD1 threshold with respect to the selected ADC resolution.
|
||
|
* @note Thresholds have to be left-aligned on bit 11, the LSB (right bits) are set to 0.
|
||
|
* If resolution 12 bits, no shift.
|
||
|
* If resolution 10 bits, shift of 2 ranks on the left.
|
||
|
* If resolution 8 bits, shift of 4 ranks on the left.
|
||
|
* If resolution 6 bits, shift of 6 ranks on the left.
|
||
|
* Therefore, shift = (12 - resolution) = 12 - (12- (((RES[1:0]) >> 3)*2)).
|
||
|
* @param __HANDLE__ ADC handle
|
||
|
* @param __THRESHOLD__ Value to be shifted
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_AWD1THRESHOLD_SHIFT_RESOLUTION(__HANDLE__, __THRESHOLD__) \
|
||
|
((__THRESHOLD__) << ((((__HANDLE__)->Instance->CFGR & ADC_CFGR_RES) >> 3UL) * 2UL))
|
||
|
|
||
|
/**
|
||
|
* @brief Shift the AWD2 and AWD3 threshold with respect to the selected ADC resolution.
|
||
|
* @note Thresholds have to be left-aligned on bit 7.
|
||
|
* If resolution 12 bits, shift of 4 ranks on the right (the 4 LSB are discarded).
|
||
|
* If resolution 10 bits, shift of 2 ranks on the right (the 2 LSB are discarded).
|
||
|
* If resolution 8 bits, no shift.
|
||
|
* If resolution 6 bits, shift of 2 ranks on the left (the 2 LSB are set to 0).
|
||
|
* @param __HANDLE__ ADC handle
|
||
|
* @param __THRESHOLD__ Value to be shifted
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_AWD23THRESHOLD_SHIFT_RESOLUTION(__HANDLE__, __THRESHOLD__) \
|
||
|
((((__HANDLE__)->Instance->CFGR & ADC_CFGR_RES) != (ADC_CFGR_RES_1 | ADC_CFGR_RES_0)) ? \
|
||
|
((__THRESHOLD__) >> ((4UL - ((((__HANDLE__)->Instance->CFGR & ADC_CFGR_RES) >> 3UL) * 2UL)) & 0x1FUL)) : \
|
||
|
((__THRESHOLD__) << 2UL) \
|
||
|
)
|
||
|
|
||
|
/**
|
||
|
* @brief Clear Common Control Register.
|
||
|
* @param __HANDLE__ ADC handle.
|
||
|
* @retval None
|
||
|
*/
|
||
|
#if defined(ADC_MULTIMODE_SUPPORT)
|
||
|
#define ADC_CLEAR_COMMON_CONTROL_REGISTER(__HANDLE__) CLEAR_BIT(__LL_ADC_COMMON_INSTANCE((__HANDLE__)->Instance)->CCR, \
|
||
|
ADC_CCR_CKMODE | \
|
||
|
ADC_CCR_PRESC | \
|
||
|
ADC_CCR_VBATSEL | \
|
||
|
ADC_CCR_VSENSESEL | \
|
||
|
ADC_CCR_VREFEN | \
|
||
|
ADC_CCR_MDMA | \
|
||
|
ADC_CCR_DMACFG | \
|
||
|
ADC_CCR_DELAY | \
|
||
|
ADC_CCR_DUAL)
|
||
|
#endif /* ADC_MULTIMODE_SUPPORT */
|
||
|
|
||
|
#if defined(STM32G474xx) || defined(STM32G484xx) || defined(STM32G473xx) || defined(STM32G483xx)
|
||
|
/**
|
||
|
* @brief Set handle instance of the ADC slave associated to the ADC master.
|
||
|
* @param __HANDLE_MASTER__ ADC master handle.
|
||
|
* @param __HANDLE_SLAVE__ ADC slave handle.
|
||
|
* @note if __HANDLE_MASTER__ is the handle of a slave ADC or an independent ADC, __HANDLE_SLAVE__ instance is
|
||
|
* set to NULL.
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_MULTI_SLAVE(__HANDLE_MASTER__, __HANDLE_SLAVE__) \
|
||
|
( ((__HANDLE_MASTER__)->Instance == ADC1) ? \
|
||
|
((__HANDLE_SLAVE__)->Instance = ADC2) \
|
||
|
: \
|
||
|
((__HANDLE_MASTER__)->Instance == ADC3) ? \
|
||
|
((__HANDLE_SLAVE__)->Instance = ADC4) \
|
||
|
: \
|
||
|
((__HANDLE_SLAVE__)->Instance = NULL) \
|
||
|
)
|
||
|
#elif defined(STM32G411xB) || defined(STM32G411xC) || defined(STM32G414xx) || defined(STM32GBK1CB) || defined(STM32G431xx) || defined(STM32G441xx) || defined(STM32G471xx) || defined(STM32G491xx) || defined(STM32G4A1xx)
|
||
|
/**
|
||
|
* @brief Set handle instance of the ADC slave associated to the ADC master.
|
||
|
* @param __HANDLE_MASTER__ ADC master handle.
|
||
|
* @param __HANDLE_SLAVE__ ADC slave handle.
|
||
|
* @note if __HANDLE_MASTER__ is the handle of a slave ADC or an independent ADC, __HANDLE_SLAVE__ instance is set
|
||
|
* to NULL.
|
||
|
* @retval None
|
||
|
*/
|
||
|
#define ADC_MULTI_SLAVE(__HANDLE_MASTER__, __HANDLE_SLAVE__) \
|
||
|
( ((__HANDLE_MASTER__)->Instance == ADC1) ? \
|
||
|
((__HANDLE_SLAVE__)->Instance = ADC2) \
|
||
|
: \
|
||
|
((__HANDLE_SLAVE__)->Instance = NULL) \
|
||
|
)
|
||
|
#endif /* STM32G4xx */
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC instance connected to the temperature sensor.
|
||
|
* @param __HANDLE__ ADC handle.
|
||
|
* @retval SET (ADC instance is valid) or RESET (ADC instance is invalid)
|
||
|
*/
|
||
|
#if defined(STM32G474xx) || defined(STM32G484xx) || defined(STM32G473xx) || defined(STM32G483xx)
|
||
|
#define ADC_TEMPERATURE_SENSOR_INSTANCE(__HANDLE__) \
|
||
|
((((__HANDLE__)->Instance) == ADC1) || (((__HANDLE__)->Instance) == ADC5))
|
||
|
#elif defined(STM32G411xB) || defined(STM32G411xC) || defined(STM32G414xx) || defined(STM32GBK1CB) || defined(STM32G431xx) || defined(STM32G441xx) || defined(STM32G471xx) || defined(STM32G491xx) || defined(STM32G4A1xx)
|
||
|
#define ADC_TEMPERATURE_SENSOR_INSTANCE(__HANDLE__) (((__HANDLE__)->Instance) == ADC1)
|
||
|
#endif /* defined(STM32G474xx) || defined(STM32G484xx) || defined(STM32G473xx) || defined(STM32G483xx) */
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC instance connected to the battery voltage VBAT.
|
||
|
* @param __HANDLE__ ADC handle.
|
||
|
* @retval SET (ADC instance is valid) or RESET (ADC instance is invalid)
|
||
|
*/
|
||
|
#if defined(STM32G474xx) || defined(STM32G484xx) || defined(STM32G473xx) || defined(STM32G483xx)
|
||
|
#define ADC_BATTERY_VOLTAGE_INSTANCE(__HANDLE__) \
|
||
|
((((__HANDLE__)->Instance) != ADC2) || (((__HANDLE__)->Instance) != ADC4))
|
||
|
#elif defined(STM32G411xB) || defined(STM32G411xC) || defined(STM32G414xx) || defined(STM32GBK1CB) || defined(STM32G431xx) || defined(STM32G441xx) || defined(STM32G471xx)
|
||
|
#define ADC_BATTERY_VOLTAGE_INSTANCE(__HANDLE__) (((__HANDLE__)->Instance) != ADC2)
|
||
|
#elif defined(STM32G491xx) || defined(STM32G4A1xx)
|
||
|
#define ADC_BATTERY_VOLTAGE_INSTANCE(__HANDLE__) (((__HANDLE__)->Instance) == ADC1)
|
||
|
#endif /* STM32G4xx */
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC instance connected to the internal voltage reference VREFINT.
|
||
|
* @param __HANDLE__ ADC handle.
|
||
|
* @retval SET (ADC instance is valid) or RESET (ADC instance is invalid)
|
||
|
*/
|
||
|
#define ADC_VREFINT_INSTANCE(__HANDLE__) (((__HANDLE__)->Instance) != ADC2)
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the length of scheduled injected conversions group.
|
||
|
* @param __LENGTH__ number of programmed conversions.
|
||
|
* @retval SET (__LENGTH__ is within the maximum number of possible programmable injected conversions)
|
||
|
* or RESET (__LENGTH__ is null or too large)
|
||
|
*/
|
||
|
#define IS_ADC_INJECTED_NB_CONV(__LENGTH__) (((__LENGTH__) >= (1U)) && ((__LENGTH__) <= (4U)))
|
||
|
|
||
|
/**
|
||
|
* @brief Calibration factor size verification (7 bits maximum).
|
||
|
* @param __CALIBRATION_FACTOR__ Calibration factor value.
|
||
|
* @retval SET (__CALIBRATION_FACTOR__ is within the authorized size) or RESET (__CALIBRATION_FACTOR__ is too large)
|
||
|
*/
|
||
|
#define IS_ADC_CALFACT(__CALIBRATION_FACTOR__) ((__CALIBRATION_FACTOR__) <= (0x7FU))
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC channel setting.
|
||
|
* @param __HANDLE__ ADC handle.
|
||
|
* @param __CHANNEL__ programmed ADC channel.
|
||
|
* @retval SET (__CHANNEL__ is valid) or RESET (__CHANNEL__ is invalid)
|
||
|
*/
|
||
|
#if defined(STM32G474xx) || defined(STM32G484xx) || defined(STM32G473xx) || defined(STM32G483xx)
|
||
|
#define IS_ADC_CHANNEL(__HANDLE__, __CHANNEL__) ( ( ((__CHANNEL__) == ADC_CHANNEL_0) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_1) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_2) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_6) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_7) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_8) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_9) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_10) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_11) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_12) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_14) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_15)) || \
|
||
|
((((__HANDLE__)->Instance) == ADC1) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_4) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_5) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VOPAMP1) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_TEMPSENSOR_ADC1) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VBAT) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VREFINT))) || \
|
||
|
((((__HANDLE__)->Instance) == ADC2) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_4) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_5) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_13) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VOPAMP2) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_17) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VOPAMP3_ADC2))) || \
|
||
|
((((__HANDLE__)->Instance) == ADC3) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_4) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_5) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VOPAMP3_ADC3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_16) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VBAT) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VREFINT))) || \
|
||
|
((((__HANDLE__)->Instance) == ADC4) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_4) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_5) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_13) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_16) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VOPAMP6) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VREFINT))) || \
|
||
|
((((__HANDLE__)->Instance) == ADC5) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_VOPAMP5) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_TEMPSENSOR_ADC5) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VOPAMP4) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_13) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_16) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VBAT) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VREFINT))))
|
||
|
#elif defined(STM32G471xx)
|
||
|
#define IS_ADC_CHANNEL(__HANDLE__, __CHANNEL__) ( ( ((__CHANNEL__) == ADC_CHANNEL_0) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_1) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_2) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_4) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_5) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_6) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_7) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_8) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_9) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_10) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_11) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_12) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_14) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_15)) || \
|
||
|
((((__HANDLE__)->Instance) == ADC1) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_VOPAMP1) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_TEMPSENSOR_ADC1) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VBAT) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VREFINT))) || \
|
||
|
((((__HANDLE__)->Instance) == ADC2) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_13) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VOPAMP2) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_17) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VOPAMP3_ADC2))) || \
|
||
|
((((__HANDLE__)->Instance) == ADC3) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_VOPAMP3_ADC3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_16) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VBAT) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VREFINT))))
|
||
|
#elif defined(STM32G411xB) || defined(STM32G411xC) || defined(STM32G414xx) || defined(STM32GBK1CB) || defined(STM32G431xx) || defined(STM32G441xx)
|
||
|
#define IS_ADC_CHANNEL(__HANDLE__, __CHANNEL__) ( ( ((__CHANNEL__) == ADC_CHANNEL_0) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_1) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_2) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_4) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_5) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_6) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_7) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_8) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_9) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_10) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_11) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_12) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_14) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_15)) || \
|
||
|
((((__HANDLE__)->Instance) == ADC1) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_VOPAMP1) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_TEMPSENSOR_ADC1) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VBAT) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VREFINT))) || \
|
||
|
((((__HANDLE__)->Instance) == ADC2) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_13) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VOPAMP2) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_17) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VOPAMP3_ADC2))))
|
||
|
#elif defined(STM32G491xx) || defined(STM32G4A1xx)
|
||
|
#define IS_ADC_CHANNEL(__HANDLE__, __CHANNEL__) ( ( ((__CHANNEL__) == ADC_CHANNEL_0) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_1) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_2) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_4) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_5) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_6) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_7) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_8) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_9) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_10) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_11) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_12) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_14) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_15)) || \
|
||
|
((((__HANDLE__)->Instance) == ADC1) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_VOPAMP1) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_TEMPSENSOR_ADC1) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VBAT) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VREFINT))) || \
|
||
|
((((__HANDLE__)->Instance) == ADC2) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_13) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VOPAMP2) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_17) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VOPAMP3_ADC2))) || \
|
||
|
((((__HANDLE__)->Instance) == ADC3) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_VOPAMP3_ADC3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_16) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VOPAMP6) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_VREFINT))))
|
||
|
#endif /* defined(STM32G474xx) || defined(STM32G484xx) || defined(STM32G473xx) || defined(STM32G483xx) */
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC channel setting in differential mode.
|
||
|
* @param __HANDLE__ ADC handle.
|
||
|
* @param __CHANNEL__ programmed ADC channel.
|
||
|
* @retval SET (__CHANNEL__ is valid) or RESET (__CHANNEL__ is invalid)
|
||
|
*/
|
||
|
#if defined(STM32G474xx) || defined(STM32G484xx) || defined(STM32G473xx) || defined(STM32G483xx)
|
||
|
#define IS_ADC_DIFF_CHANNEL(__HANDLE__, __CHANNEL__) ( ( ((__CHANNEL__) == ADC_CHANNEL_1) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_6) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_7) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_8) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_9) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_10) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_11) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_14)) || \
|
||
|
((((__HANDLE__)->Instance) == ADC1) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_2) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_4) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_5))) || \
|
||
|
((((__HANDLE__)->Instance) == ADC2) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_2) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_4) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_5) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_12) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_13))) || \
|
||
|
((((__HANDLE__)->Instance) == ADC3) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_2) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_4) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_5) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_15))) || \
|
||
|
((((__HANDLE__)->Instance) == ADC4) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_2) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_4) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_5) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_12) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_13) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_15))) || \
|
||
|
((((__HANDLE__)->Instance) == ADC5) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_12) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_13) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_15))) )
|
||
|
#elif defined(STM32G471xx) || defined(STM32G491xx) || defined(STM32G4A1xx) || defined(STM32G411xC)
|
||
|
#define IS_ADC_DIFF_CHANNEL(__HANDLE__, __CHANNEL__) ( ( ((__CHANNEL__) == ADC_CHANNEL_1) || \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_2) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_4) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_5) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_6) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_7) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_8) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_9) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_10) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_11) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_14)) || \
|
||
|
((((__HANDLE__)->Instance) == ADC2) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_12) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_13))) || \
|
||
|
((((__HANDLE__)->Instance) == ADC3) && \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_15))) )
|
||
|
#elif defined(STM32G411xB) || defined(STM32G414xx) || defined(STM32GBK1CB) || defined(STM32G431xx) || defined(STM32G441xx)
|
||
|
#define IS_ADC_DIFF_CHANNEL(__HANDLE__, __CHANNEL__) ( ( ((__CHANNEL__) == ADC_CHANNEL_1) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_2) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_3) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_4) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_5) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_6) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_7) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_8) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_9) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_10) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_11) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_14)) || \
|
||
|
((((__HANDLE__)->Instance) == ADC2) && \
|
||
|
(((__CHANNEL__) == ADC_CHANNEL_12) || \
|
||
|
((__CHANNEL__) == ADC_CHANNEL_13))) )
|
||
|
#endif /* STM32G4xx */
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC single-ended input or differential mode setting.
|
||
|
* @param __SING_DIFF__ programmed channel setting.
|
||
|
* @retval SET (__SING_DIFF__ is valid) or RESET (__SING_DIFF__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_SINGLE_DIFFERENTIAL(__SING_DIFF__) (((__SING_DIFF__) == ADC_SINGLE_ENDED) || \
|
||
|
((__SING_DIFF__) == ADC_DIFFERENTIAL_ENDED) )
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC offset management setting.
|
||
|
* @param __OFFSET_NUMBER__ ADC offset management.
|
||
|
* @retval SET (__OFFSET_NUMBER__ is valid) or RESET (__OFFSET_NUMBER__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_OFFSET_NUMBER(__OFFSET_NUMBER__) (((__OFFSET_NUMBER__) == ADC_OFFSET_NONE) || \
|
||
|
((__OFFSET_NUMBER__) == ADC_OFFSET_1) || \
|
||
|
((__OFFSET_NUMBER__) == ADC_OFFSET_2) || \
|
||
|
((__OFFSET_NUMBER__) == ADC_OFFSET_3) || \
|
||
|
((__OFFSET_NUMBER__) == ADC_OFFSET_4) )
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC offset sign setting.
|
||
|
* @param __OFFSET_SIGN__ ADC offset sign.
|
||
|
* @retval SET (__OFFSET_SIGN__ is valid) or RESET (__OFFSET_SIGN__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_OFFSET_SIGN(__OFFSET_SIGN__) (((__OFFSET_SIGN__) == ADC_OFFSET_SIGN_NEGATIVE) || \
|
||
|
((__OFFSET_SIGN__) == ADC_OFFSET_SIGN_POSITIVE) )
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC injected channel setting.
|
||
|
* @param __CHANNEL__ programmed ADC injected channel.
|
||
|
* @retval SET (__CHANNEL__ is valid) or RESET (__CHANNEL__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_INJECTED_RANK(__CHANNEL__) (((__CHANNEL__) == ADC_INJECTED_RANK_1) || \
|
||
|
((__CHANNEL__) == ADC_INJECTED_RANK_2) || \
|
||
|
((__CHANNEL__) == ADC_INJECTED_RANK_3) || \
|
||
|
((__CHANNEL__) == ADC_INJECTED_RANK_4) )
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC injected conversions external trigger.
|
||
|
* @param __HANDLE__ ADC handle.
|
||
|
* @param __INJTRIG__ programmed ADC injected conversions external trigger.
|
||
|
* @retval SET (__INJTRIG__ is a valid value) or RESET (__INJTRIG__ is invalid)
|
||
|
*/
|
||
|
#if defined(STM32G474xx) || defined(STM32G484xx)
|
||
|
#define IS_ADC_EXTTRIGINJEC(__HANDLE__, __INJTRIG__) (((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_TRGO2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T2_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T4_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T6_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T7_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_TRGO2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T15_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T20_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T20_TRGO2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_HRTIM_TRG2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_HRTIM_TRG4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_HRTIM_TRG5) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_HRTIM_TRG6) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_HRTIM_TRG7) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_HRTIM_TRG8) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_HRTIM_TRG9) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_HRTIM_TRG10) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_LPTIM_OUT) || \
|
||
|
((((__HANDLE__)->Instance == ADC1) || \
|
||
|
((__HANDLE__)->Instance == ADC2)) && \
|
||
|
(((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T2_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC3) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T16_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T20_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_EXT_IT15))) || \
|
||
|
((((__HANDLE__)->Instance == ADC3) || \
|
||
|
((__HANDLE__)->Instance == ADC4) || \
|
||
|
((__HANDLE__)->Instance == ADC5)) && \
|
||
|
(((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_CC3) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T4_CC3) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T4_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_CC2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T20_CC2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_HRTIM_TRG1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_HRTIM_TRG3) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_EXT_IT3))) || \
|
||
|
((__INJTRIG__) == ADC_INJECTED_SOFTWARE_START) )
|
||
|
#elif defined(STM32G473xx) || defined(STM32G483xx)
|
||
|
#define IS_ADC_EXTTRIGINJEC(__HANDLE__, __INJTRIG__) (((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_TRGO2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T2_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T4_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T6_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T7_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_TRGO2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T15_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T20_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T20_TRGO2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_LPTIM_OUT) || \
|
||
|
((((__HANDLE__)->Instance == ADC1) || \
|
||
|
((__HANDLE__)->Instance == ADC2)) && \
|
||
|
(((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T2_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC3) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T16_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T20_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_EXT_IT15))) || \
|
||
|
((((__HANDLE__)->Instance == ADC3) || \
|
||
|
((__HANDLE__)->Instance == ADC4) || \
|
||
|
((__HANDLE__)->Instance == ADC5)) && \
|
||
|
(((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_CC3) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T4_CC3) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T4_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_CC2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T20_CC2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_EXT_IT3))) || \
|
||
|
((__INJTRIG__) == ADC_INJECTED_SOFTWARE_START) )
|
||
|
#elif defined(STM32G471xx)
|
||
|
#define IS_ADC_EXTTRIGINJEC(__HANDLE__, __INJTRIG__) (((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_TRGO2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T2_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T4_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T6_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T7_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_TRGO2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T15_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_LPTIM_OUT) || \
|
||
|
((((__HANDLE__)->Instance == ADC1) || \
|
||
|
((__HANDLE__)->Instance == ADC2)) && \
|
||
|
(((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T2_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC3) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T16_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_EXT_IT15))) || \
|
||
|
((((__HANDLE__)->Instance == ADC3)) && \
|
||
|
(((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_CC3) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T4_CC3) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T4_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_CC2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_EXT_IT3))) || \
|
||
|
((__INJTRIG__) == ADC_INJECTED_SOFTWARE_START) )
|
||
|
#elif defined(STM32G411xB) || defined(STM32G414xx) || defined(STM32GBK1CB) || defined(STM32G431xx) || defined(STM32G441xx)
|
||
|
#define IS_ADC_EXTTRIGINJEC(__HANDLE__, __INJTRIG__) (((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_TRGO2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T2_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T2_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC3) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T4_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T6_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T7_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_TRGO2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T15_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T16_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_EXT_IT15) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_LPTIM_OUT) || \
|
||
|
((__INJTRIG__) == ADC_INJECTED_SOFTWARE_START) )
|
||
|
#elif defined(STM32G491xx) || defined(STM32G4A1xx) || defined(STM32G411xC)
|
||
|
#define IS_ADC_EXTTRIGINJEC(__HANDLE__, __INJTRIG__) (((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_TRGO2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T2_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T4_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T6_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T7_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_TRGO2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T15_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T20_TRGO) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T20_TRGO2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_LPTIM_OUT) || \
|
||
|
((((__HANDLE__)->Instance == ADC1) || \
|
||
|
((__HANDLE__)->Instance == ADC2)) && \
|
||
|
(((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T2_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC3) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T3_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T16_CC1) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T20_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_EXT_IT15))) || \
|
||
|
(((__HANDLE__)->Instance == ADC3) && \
|
||
|
(((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T1_CC3) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T4_CC3) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T4_CC4) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T8_CC2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_T20_CC2) || \
|
||
|
((__INJTRIG__) == ADC_EXTERNALTRIGINJEC_EXT_IT3))) || \
|
||
|
((__INJTRIG__) == ADC_INJECTED_SOFTWARE_START) )
|
||
|
#endif /* STM32G4xx */
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC edge trigger setting for injected group.
|
||
|
* @param __EDGE__ programmed ADC edge trigger setting.
|
||
|
* @retval SET (__EDGE__ is a valid value) or RESET (__EDGE__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_EXTTRIGINJEC_EDGE(__EDGE__) (((__EDGE__) == ADC_EXTERNALTRIGINJECCONV_EDGE_NONE) || \
|
||
|
((__EDGE__) == ADC_EXTERNALTRIGINJECCONV_EDGE_RISING) || \
|
||
|
((__EDGE__) == ADC_EXTERNALTRIGINJECCONV_EDGE_FALLING) || \
|
||
|
((__EDGE__) == ADC_EXTERNALTRIGINJECCONV_EDGE_RISINGFALLING) )
|
||
|
|
||
|
#if defined(ADC_MULTIMODE_SUPPORT)
|
||
|
/**
|
||
|
* @brief Verify the ADC multimode setting.
|
||
|
* @param __MODE__ programmed ADC multimode setting.
|
||
|
* @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_MULTIMODE(__MODE__) (((__MODE__) == ADC_MODE_INDEPENDENT) || \
|
||
|
((__MODE__) == ADC_DUALMODE_REGSIMULT_INJECSIMULT) || \
|
||
|
((__MODE__) == ADC_DUALMODE_REGSIMULT_ALTERTRIG) || \
|
||
|
((__MODE__) == ADC_DUALMODE_REGINTERL_INJECSIMULT) || \
|
||
|
((__MODE__) == ADC_DUALMODE_INJECSIMULT) || \
|
||
|
((__MODE__) == ADC_DUALMODE_REGSIMULT) || \
|
||
|
((__MODE__) == ADC_DUALMODE_INTERL) || \
|
||
|
((__MODE__) == ADC_DUALMODE_ALTERTRIG) )
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC multimode DMA access setting.
|
||
|
* @param __MODE__ programmed ADC multimode DMA access setting.
|
||
|
* @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_DMA_ACCESS_MULTIMODE(__MODE__) (((__MODE__) == ADC_DMAACCESSMODE_DISABLED) || \
|
||
|
((__MODE__) == ADC_DMAACCESSMODE_12_10_BITS) || \
|
||
|
((__MODE__) == ADC_DMAACCESSMODE_8_6_BITS) )
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC multimode delay setting.
|
||
|
* @param __DELAY__ programmed ADC multimode delay setting.
|
||
|
* @retval SET (__DELAY__ is a valid value) or RESET (__DELAY__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_SAMPLING_DELAY(__DELAY__) (((__DELAY__) == ADC_TWOSAMPLINGDELAY_1CYCLE) || \
|
||
|
((__DELAY__) == ADC_TWOSAMPLINGDELAY_2CYCLES) || \
|
||
|
((__DELAY__) == ADC_TWOSAMPLINGDELAY_3CYCLES) || \
|
||
|
((__DELAY__) == ADC_TWOSAMPLINGDELAY_4CYCLES) || \
|
||
|
((__DELAY__) == ADC_TWOSAMPLINGDELAY_5CYCLES) || \
|
||
|
((__DELAY__) == ADC_TWOSAMPLINGDELAY_6CYCLES) || \
|
||
|
((__DELAY__) == ADC_TWOSAMPLINGDELAY_7CYCLES) || \
|
||
|
((__DELAY__) == ADC_TWOSAMPLINGDELAY_8CYCLES) || \
|
||
|
((__DELAY__) == ADC_TWOSAMPLINGDELAY_9CYCLES) || \
|
||
|
((__DELAY__) == ADC_TWOSAMPLINGDELAY_10CYCLES) || \
|
||
|
((__DELAY__) == ADC_TWOSAMPLINGDELAY_11CYCLES) || \
|
||
|
((__DELAY__) == ADC_TWOSAMPLINGDELAY_12CYCLES) )
|
||
|
#endif /* ADC_MULTIMODE_SUPPORT */
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC analog watchdog setting.
|
||
|
* @param __WATCHDOG__ programmed ADC analog watchdog setting.
|
||
|
* @retval SET (__WATCHDOG__ is valid) or RESET (__WATCHDOG__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_ANALOG_WATCHDOG_NUMBER(__WATCHDOG__) (((__WATCHDOG__) == ADC_ANALOGWATCHDOG_1) || \
|
||
|
((__WATCHDOG__) == ADC_ANALOGWATCHDOG_2) || \
|
||
|
((__WATCHDOG__) == ADC_ANALOGWATCHDOG_3) )
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC analog watchdog mode setting.
|
||
|
* @param __WATCHDOG_MODE__ programmed ADC analog watchdog mode setting.
|
||
|
* @retval SET (__WATCHDOG_MODE__ is valid) or RESET (__WATCHDOG_MODE__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_ANALOG_WATCHDOG_MODE(__WATCHDOG_MODE__) (((__WATCHDOG_MODE__) == ADC_ANALOGWATCHDOG_NONE) || \
|
||
|
((__WATCHDOG_MODE__) == ADC_ANALOGWATCHDOG_SINGLE_REG) || \
|
||
|
((__WATCHDOG_MODE__) == ADC_ANALOGWATCHDOG_SINGLE_INJEC) || \
|
||
|
((__WATCHDOG_MODE__) == ADC_ANALOGWATCHDOG_SINGLE_REGINJEC) || \
|
||
|
((__WATCHDOG_MODE__) == ADC_ANALOGWATCHDOG_ALL_REG) || \
|
||
|
((__WATCHDOG_MODE__) == ADC_ANALOGWATCHDOG_ALL_INJEC) || \
|
||
|
((__WATCHDOG_MODE__) == ADC_ANALOGWATCHDOG_ALL_REGINJEC) )
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC analog watchdog filtering setting.
|
||
|
* @param __FILTERING_MODE__ programmed ADC analog watchdog mode setting.
|
||
|
* @retval SET (__FILTERING_MODE__ is valid) or RESET (__FILTERING_MODE__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_ANALOG_WATCHDOG_FILTERING_MODE(__FILTERING_MODE__) \
|
||
|
(((__FILTERING_MODE__) == ADC_AWD_FILTERING_NONE) || \
|
||
|
((__FILTERING_MODE__) == ADC_AWD_FILTERING_2SAMPLES) || \
|
||
|
((__FILTERING_MODE__) == ADC_AWD_FILTERING_3SAMPLES) || \
|
||
|
((__FILTERING_MODE__) == ADC_AWD_FILTERING_4SAMPLES) || \
|
||
|
((__FILTERING_MODE__) == ADC_AWD_FILTERING_5SAMPLES) || \
|
||
|
((__FILTERING_MODE__) == ADC_AWD_FILTERING_6SAMPLES) || \
|
||
|
((__FILTERING_MODE__) == ADC_AWD_FILTERING_7SAMPLES) || \
|
||
|
((__FILTERING_MODE__) == ADC_AWD_FILTERING_8SAMPLES) )
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC conversion (regular or injected or both).
|
||
|
* @param __CONVERSION__ ADC conversion group.
|
||
|
* @retval SET (__CONVERSION__ is valid) or RESET (__CONVERSION__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_CONVERSION_GROUP(__CONVERSION__) (((__CONVERSION__) == ADC_REGULAR_GROUP) || \
|
||
|
((__CONVERSION__) == ADC_INJECTED_GROUP) || \
|
||
|
((__CONVERSION__) == ADC_REGULAR_INJECTED_GROUP) )
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC event type.
|
||
|
* @param __EVENT__ ADC event.
|
||
|
* @retval SET (__EVENT__ is valid) or RESET (__EVENT__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_EVENT_TYPE(__EVENT__) (((__EVENT__) == ADC_EOSMP_EVENT) || \
|
||
|
((__EVENT__) == ADC_AWD_EVENT) || \
|
||
|
((__EVENT__) == ADC_AWD2_EVENT) || \
|
||
|
((__EVENT__) == ADC_AWD3_EVENT) || \
|
||
|
((__EVENT__) == ADC_OVR_EVENT) || \
|
||
|
((__EVENT__) == ADC_JQOVF_EVENT) )
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC oversampling ratio.
|
||
|
* @param __RATIO__ programmed ADC oversampling ratio.
|
||
|
* @retval SET (__RATIO__ is a valid value) or RESET (__RATIO__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_OVERSAMPLING_RATIO(__RATIO__) (((__RATIO__) == ADC_OVERSAMPLING_RATIO_2 ) || \
|
||
|
((__RATIO__) == ADC_OVERSAMPLING_RATIO_4 ) || \
|
||
|
((__RATIO__) == ADC_OVERSAMPLING_RATIO_8 ) || \
|
||
|
((__RATIO__) == ADC_OVERSAMPLING_RATIO_16 ) || \
|
||
|
((__RATIO__) == ADC_OVERSAMPLING_RATIO_32 ) || \
|
||
|
((__RATIO__) == ADC_OVERSAMPLING_RATIO_64 ) || \
|
||
|
((__RATIO__) == ADC_OVERSAMPLING_RATIO_128 ) || \
|
||
|
((__RATIO__) == ADC_OVERSAMPLING_RATIO_256 ))
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC oversampling shift.
|
||
|
* @param __SHIFT__ programmed ADC oversampling shift.
|
||
|
* @retval SET (__SHIFT__ is a valid value) or RESET (__SHIFT__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_RIGHT_BIT_SHIFT(__SHIFT__) (((__SHIFT__) == ADC_RIGHTBITSHIFT_NONE) || \
|
||
|
((__SHIFT__) == ADC_RIGHTBITSHIFT_1 ) || \
|
||
|
((__SHIFT__) == ADC_RIGHTBITSHIFT_2 ) || \
|
||
|
((__SHIFT__) == ADC_RIGHTBITSHIFT_3 ) || \
|
||
|
((__SHIFT__) == ADC_RIGHTBITSHIFT_4 ) || \
|
||
|
((__SHIFT__) == ADC_RIGHTBITSHIFT_5 ) || \
|
||
|
((__SHIFT__) == ADC_RIGHTBITSHIFT_6 ) || \
|
||
|
((__SHIFT__) == ADC_RIGHTBITSHIFT_7 ) || \
|
||
|
((__SHIFT__) == ADC_RIGHTBITSHIFT_8 ))
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC oversampling triggered mode.
|
||
|
* @param __MODE__ programmed ADC oversampling triggered mode.
|
||
|
* @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_TRIGGERED_OVERSAMPLING_MODE(__MODE__) (((__MODE__) == ADC_TRIGGEREDMODE_SINGLE_TRIGGER) || \
|
||
|
((__MODE__) == ADC_TRIGGEREDMODE_MULTI_TRIGGER) )
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the ADC oversampling regular conversion resumed or continued mode.
|
||
|
* @param __MODE__ programmed ADC oversampling regular conversion resumed or continued mode.
|
||
|
* @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_REGOVERSAMPLING_MODE(__MODE__) (((__MODE__) == ADC_REGOVERSAMPLING_CONTINUED_MODE) || \
|
||
|
((__MODE__) == ADC_REGOVERSAMPLING_RESUMED_MODE) )
|
||
|
|
||
|
/**
|
||
|
* @brief Verify the DFSDM mode configuration.
|
||
|
* @param __HANDLE__ ADC handle.
|
||
|
* @note When DMSDFM configuration is not supported, the macro systematically reports SET. For
|
||
|
* this reason, the input parameter is the ADC handle and not the configuration parameter
|
||
|
* directly.
|
||
|
* @retval SET (DFSDM mode configuration is valid) or RESET (DFSDM mode configuration is invalid)
|
||
|
*/
|
||
|
#define IS_ADC_DFSDMCFG_MODE(__HANDLE__) (SET)
|
||
|
|
||
|
/**
|
||
|
* @brief Return the DFSDM configuration mode.
|
||
|
* @param __HANDLE__ ADC handle.
|
||
|
* @note When DMSDFM configuration is not supported, the macro systematically reports 0x0 (i.e disabled).
|
||
|
* For this reason, the input parameter is the ADC handle and not the configuration parameter
|
||
|
* directly.
|
||
|
* @retval DFSDM configuration mode
|
||
|
*/
|
||
|
#define ADC_CFGR_DFSDM(__HANDLE__) (0x0UL)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
|
||
|
/* Exported functions --------------------------------------------------------*/
|
||
|
/** @addtogroup ADCEx_Exported_Functions
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/** @addtogroup ADCEx_Exported_Functions_Group1
|
||
|
* @{
|
||
|
*/
|
||
|
/* IO operation functions *****************************************************/
|
||
|
|
||
|
/* ADC calibration */
|
||
|
HAL_StatusTypeDef HAL_ADCEx_Calibration_Start(ADC_HandleTypeDef *hadc, uint32_t SingleDiff);
|
||
|
uint32_t HAL_ADCEx_Calibration_GetValue(const ADC_HandleTypeDef *hadc, uint32_t SingleDiff);
|
||
|
HAL_StatusTypeDef HAL_ADCEx_Calibration_SetValue(ADC_HandleTypeDef *hadc, uint32_t SingleDiff,
|
||
|
uint32_t CalibrationFactor);
|
||
|
|
||
|
/* Blocking mode: Polling */
|
||
|
HAL_StatusTypeDef HAL_ADCEx_InjectedStart(ADC_HandleTypeDef *hadc);
|
||
|
HAL_StatusTypeDef HAL_ADCEx_InjectedStop(ADC_HandleTypeDef *hadc);
|
||
|
HAL_StatusTypeDef HAL_ADCEx_InjectedPollForConversion(ADC_HandleTypeDef *hadc, uint32_t Timeout);
|
||
|
|
||
|
/* Non-blocking mode: Interruption */
|
||
|
HAL_StatusTypeDef HAL_ADCEx_InjectedStart_IT(ADC_HandleTypeDef *hadc);
|
||
|
HAL_StatusTypeDef HAL_ADCEx_InjectedStop_IT(ADC_HandleTypeDef *hadc);
|
||
|
|
||
|
#if defined(ADC_MULTIMODE_SUPPORT)
|
||
|
/* ADC multimode */
|
||
|
HAL_StatusTypeDef HAL_ADCEx_MultiModeStart_DMA(ADC_HandleTypeDef *hadc, uint32_t *pData, uint32_t Length);
|
||
|
HAL_StatusTypeDef HAL_ADCEx_MultiModeStop_DMA(ADC_HandleTypeDef *hadc);
|
||
|
uint32_t HAL_ADCEx_MultiModeGetValue(const ADC_HandleTypeDef *hadc);
|
||
|
#endif /* ADC_MULTIMODE_SUPPORT */
|
||
|
|
||
|
/* ADC retrieve conversion value intended to be used with polling or interruption */
|
||
|
uint32_t HAL_ADCEx_InjectedGetValue(const ADC_HandleTypeDef *hadc, uint32_t InjectedRank);
|
||
|
|
||
|
/* ADC IRQHandler and Callbacks used in non-blocking modes (Interruption) */
|
||
|
void HAL_ADCEx_InjectedConvCpltCallback(ADC_HandleTypeDef *hadc);
|
||
|
void HAL_ADCEx_InjectedQueueOverflowCallback(ADC_HandleTypeDef *hadc);
|
||
|
void HAL_ADCEx_LevelOutOfWindow2Callback(ADC_HandleTypeDef *hadc);
|
||
|
void HAL_ADCEx_LevelOutOfWindow3Callback(ADC_HandleTypeDef *hadc);
|
||
|
void HAL_ADCEx_EndOfSamplingCallback(ADC_HandleTypeDef *hadc);
|
||
|
|
||
|
/* ADC group regular conversions stop */
|
||
|
HAL_StatusTypeDef HAL_ADCEx_RegularStop(ADC_HandleTypeDef *hadc);
|
||
|
HAL_StatusTypeDef HAL_ADCEx_RegularStop_IT(ADC_HandleTypeDef *hadc);
|
||
|
HAL_StatusTypeDef HAL_ADCEx_RegularStop_DMA(ADC_HandleTypeDef *hadc);
|
||
|
#if defined(ADC_MULTIMODE_SUPPORT)
|
||
|
HAL_StatusTypeDef HAL_ADCEx_RegularMultiModeStop_DMA(ADC_HandleTypeDef *hadc);
|
||
|
#endif /* ADC_MULTIMODE_SUPPORT */
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @addtogroup ADCEx_Exported_Functions_Group2
|
||
|
* @{
|
||
|
*/
|
||
|
/* Peripheral Control functions ***********************************************/
|
||
|
HAL_StatusTypeDef HAL_ADCEx_InjectedConfigChannel(ADC_HandleTypeDef *hadc,
|
||
|
const ADC_InjectionConfTypeDef *pConfigInjected);
|
||
|
#if defined(ADC_MULTIMODE_SUPPORT)
|
||
|
HAL_StatusTypeDef HAL_ADCEx_MultiModeConfigChannel(ADC_HandleTypeDef *hadc,
|
||
|
const ADC_MultiModeTypeDef *pMultimode);
|
||
|
#endif /* ADC_MULTIMODE_SUPPORT */
|
||
|
|
||
|
HAL_StatusTypeDef HAL_ADCEx_EnableInjectedQueue(ADC_HandleTypeDef *hadc);
|
||
|
HAL_StatusTypeDef HAL_ADCEx_DisableInjectedQueue(ADC_HandleTypeDef *hadc);
|
||
|
HAL_StatusTypeDef HAL_ADCEx_DisableVoltageRegulator(ADC_HandleTypeDef *hadc);
|
||
|
HAL_StatusTypeDef HAL_ADCEx_EnterADCDeepPowerDownMode(ADC_HandleTypeDef *hadc);
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* STM32G4xx_HAL_ADC_EX_H */
|