Caracteristicas:
En MODO de CONVERSIN CONTINUA, descarta el valor anterior una vez que haya
finalizado una conversin.
Hay conversiones de 12, 10, 8 y hasta 6 bit configurables.
Genera una INTERRUPCION al final de la conversin (FINAL DE LA INJECTED
CONVERSION).
MODOS:
o Una sola vez
o Continua
MODO ESCANEO tiene la particularidad de conversin automtica del canal 0 al canal
X.
Tiempo de muestreo Programable.
Tiene la opcin de activacin externa del perifrico con polaridad configurable, tanto
para conversin regular o configuracin inyectada.
Modo DOBLE/TRIPLE, esto es posible en dispositivos que cuenten con 2 o mas ADC`s
Almacenamiento configurable de datos DMA en DOBLE/TRIPLE modo de ADC.
Retardo configurable entre conversiones de modo entrelazado DOBLE/TRIPLE.
Rangos de entrada Vref(-)=Vin=Vref(+).
Peticin generada por DMA durante la conversin de canal regular.
================================================== ============================
[..]
(#) Inicialice los recursos ADC de bajo nivel mediante la implementacin de la HAL_ADC_MspInit ():
(##) Activar el reloj de la interfaz ADC utilizando __ADC_CLK_ENABLE ()
Configuracin (##) pines ADC
(+++) Habilitar el reloj para los GPIOs ADC con la siguiente funcin:
__GPIOx_CLK_ENABLE ()
(+++) Configure estos pines ADC en modo analgico utilizando HAL_GPIO_Init ()
(##) En el caso de la utilizacin de interrupciones (por ejemplo HAL_ADC_Start_IT ())
(+++) Configurar la prioridad de interrupcin ADC utilizando HAL_NVIC_SetPriority ()
(+++) Habilitar el manejador de IRQ ADC utilizando HAL_NVIC_EnableIRQ ()
(+++) En manejador de IRQ ADC, llame HAL_ADC_IRQHandler ()
(##) En caso de utilizar DMA para controlar la transferencia de datos (por ejemplo, HAL_ADC_Start_DMA ())
(+++) Habilitar el reloj de la interfaz DMAX usando __DMAx_CLK_ENABLE ()
(+++) Configurar y habilitar dos DMA arroyos corriente de la gestin de datos
transferir desde perifrica a la memoria (flujo de salida)
(+++) Asociar el initilalized DMA manejar al mango CRYP DMA
usando __HAL_LINKDMA ()
(+++) Configurar la prioridad y que el CNTV para la completa transferencia
interrumpir en las dos corrientes de DMA. El flujo de salida debera tener mayor
prioridad que el flujo de entrada.
(#) Configuracin de las caractersticas del grupo de canales regulares de ADC, utilice HAL_ADC_Init ()
y HAL_ADC_ConfigChannel () funciones.
POR SONDEO
Cada canal es una entrada
En CUBE:
/**Common config
*/
hadc2.Instance = ADC2;
hadc2.Init.ClockPrescaler = ADC_CLOCK_ASYNC;
hadc2.Init.Resolution = ADC_RESOLUTION12b;
hadc2.Init.ScanConvMode = ADC_SCAN_ENABLE;
hadc2.Init.ContinuousConvMode = ENABLE;
hadc2.Init.DiscontinuousConvMode = DISABLE;
hadc2.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
hadc2.Init.DataAlign = ADC_DATAALIGN_RIGHT;
hadc2.Init.NbrOfConversion = 1;
hadc2.Init.DMAContinuousRequests = DISABLE;
hadc2.Init.EOCSelection = EOC_SINGLE_CONV;
hadc2.Init.LowPowerAutoWait = DISABLE;
hadc2.Init.Overrun = OVR_DATA_OVERWRITTEN;
HAL_ADC_Init(&hadc2);
while (1)
{
/* USER CODE END WHILE */
HAL_ADC_Start( &hadc2 ); /*iniciamos conversion*/
HAL_ADC_PollForConversion( &hadc2, 100 );/*esperamos conversion con timeout de 100ms*/
valor = HAL_ADC_GetValue( &hadc2 ); /*leemos valor digital*/
if(valor>3000)
{
HAL_GPIO_WritePin(GPIOE, GPIO_PIN_8, GPIO_PIN_SET);
HAL_Delay(50);
HAL_GPIO_WritePin(GPIOE, GPIO_PIN_8, GPIO_PIN_RESET);
HAL_Delay(50);
}
else
{
HAL_GPIO_WritePin(GPIOE, GPIO_PIN_9, GPIO_PIN_SET);
HAL_Delay(50);
HAL_GPIO_WritePin(GPIOE, GPIO_PIN_9, GPIO_PIN_RESET);
HAL_Delay(50);
}
Se necesita declarar una variable de tipo vector en este caso de tres espacios los cuales se
asignara a cada canal (entrada) del ADC los cuales se actualizaran por medio del DMA sin que
el CPU se lo ordene.
HAL_ADC_Start_DMA(&hadc1, (uint32_t*)&ADC_Valores,3);
Las configuraciones para el ADC fueron:
void MX_ADC1_Init(void)
{
ADC_ChannelConfTypeDef sConfig;
/**Common config
*/
hadc1.Instance = ADC1;
hadc1.Init.ClockPrescaler = ADC_CLOCK_ASYNC;
hadc1.Init.Resolution = ADC_RESOLUTION12b;
hadc1.Init.ScanConvMode = ADC_SCAN_ENABLE;
hadc1.Init.ContinuousConvMode = ENABLE;
hadc1.Init.DiscontinuousConvMode = DISABLE;
hadc1.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
hadc1.Init.DataAlign = ADC_DATAALIGN_RIGHT;
hadc1.Init.NbrOfConversion = 3;
hadc1.Init.DMAContinuousRequests = ENABLE;
hadc1.Init.EOCSelection = EOC_SINGLE_CONV;
hadc1.Init.LowPowerAutoWait = DISABLE;
hadc1.Init.Overrun = OVR_DATA_OVERWRITTEN;
HAL_ADC_Init(&hadc1);
}
Las configuraciones para el DMA fueron:
void MX_DMA_Init(void)
{
/* DMA controller clock enable */
__DMA1_CLK_ENABLE();