stm32f411ceu6adc中断代码
时间: 2023-09-04 22:10:45 浏览: 48
下面是stm32f411ceu6_adc的中断代码,供参考:
```c
void ADC_IRQHandler(void)
{
if(ADC1->SR & ADC_SR_EOC) //判断转换是否完成
{
uint16_t adc_val = ADC1->DR; //获取转换结果
//TODO: 处理转换结果
ADC1->SR &= ~ADC_SR_EOC; //清除中断标志位
}
}
```
在中断服务函数中,首先通过判断ADC_SR寄存器的EOC位来判断转换是否完成,如果完成,则获取转换结果,并进行相应的处理。最后需要清除中断标志位,即将ADC_SR寄存器的EOC位清零。
相关问题
stm32f411ceu6adc自动校准代码
stm32f411ceu6是一款基于ARM Cortex-M4内核的微控制器,它内置了12位ADC模块,可以用于模拟信号采集。在使用ADC时,为了确保采集到的信号精度,需要进行ADC自动校准。
下面是stm32f411ceu6的ADC自动校准代码示例:
```c
#define ADC1_DR_ADDRESS ((uint32_t)0x4001204C)
void ADC1_Init(void)
{
ADC_InitTypeDef ADC_InitStructure;
ADC_CommonInitTypeDef ADC_CommonInitStructure;
GPIO_InitTypeDef GPIO_InitStructure;
/* Enable ADC1 and GPIOA clock */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE);
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);
/* Configure ADC1 Channel5 pin as analog input */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AN;
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
GPIO_Init(GPIOA, &GPIO_InitStructure);
/* ADC Common Init **********************************************************/
ADC_CommonInitStructure.ADC_Mode = ADC_Mode_Independent;
ADC_CommonInitStructure.ADC_Prescaler = ADC_Prescaler_Div2;
ADC_CommonInitStructure.ADC_DMAAccessMode = ADC_DMAAccessMode_Disabled;
ADC_CommonInitStructure.ADC_TwoSamplingDelay = ADC_TwoSamplingDelay_5Cycles;
ADC_CommonInit(&ADC_CommonInitStructure);
/* ADC1 Init ****************************************************************/
ADC_InitStructure.ADC_Resolution = ADC_Resolution_12b;
ADC_InitStructure.ADC_ScanConvMode = DISABLE;
ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;
ADC_InitStructure.ADC_ExternalTrigConvEdge = ADC_ExternalTrigConvEdge_None;
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;
ADC_InitStructure.ADC_NbrOfConversion = 1;
ADC_Init(ADC1, &ADC_InitStructure);
/* ADC1 regular channel5 configuration *************************************/
ADC_RegularChannelConfig(ADC1, ADC_Channel_5, 1, ADC_SampleTime_480Cycles);
/* Enable ADC1 */
ADC_Cmd(ADC1, ENABLE);
/* Wait for the ADC1 to be ready */
while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_ADONS));
/* ADC1 calibration *******************************************************/
ADC_SelectCalibrationMode(ADC1, ADC_CalibrationMode_Single);
ADC_StartCalibration(ADC1);
while(ADC_GetCalibrationStatus(ADC1) != RESET);
/* Start ADC1 Software Conversion */
ADC_SoftwareStartConv(ADC1);
}
uint16_t ADC1_GetValue(void)
{
/* Wait until the conversion is done */
while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC));
/* Return the ADC conversion value */
return ADC_GetConversionValue(ADC1);
}
```
在这个例子中,我们使用了ADC1的通道5,采样时间为480个时钟周期。在初始化时,我们首先启用了ADC1和GPIOA的时钟,然后将GPIOA的第5个引脚配置为模拟输入模式。接着,我们进行了ADC的通用初始化,设置了ADC的分频系数、DMA访问模式、转换延迟等参数,然后进行了ADC1的特定初始化,设置了分辨率、采样模式、转换触发边沿等参数。然后我们使用了ADC1的通道5进行了单次转换,并进行了校准。最后,我们通过软件触发ADC1的转换并获取了转换结果。
stm32f411ceu6adc电压校准代码
以下是一个基本的 STM32F411CEU6 ADC 电压校准代码例程,你可以根据自己的需求进行修改:
```c
#include "stm32f4xx.h"
ADC_HandleTypeDef hadc1; // 定义 ADC 句柄
void SystemClock_Config(void);
static void MX_GPIO_Init(void);
static void MX_ADC1_Init(void);
int main(void)
{
HAL_Init(); // 初始化 HAL 库
SystemClock_Config(); // 配置系统时钟
MX_GPIO_Init(); // 配置 GPIO
MX_ADC1_Init(); // 配置 ADC
HAL_ADC_Start(&hadc1); // 启动 ADC
while (1)
{
HAL_ADC_PollForConversion(&hadc1, 100); // 等待转换完成
uint16_t rawValue = HAL_ADC_GetValue(&hadc1); // 获取 ADC 原始值
float voltage = (float)rawValue / 4096 * 3.3; // 将原始值转换为电压值
voltage = voltage * 1.015 - 0.029; // 进行电压校准,根据实际情况进行修改
// 处理电压值
}
}
void SystemClock_Config(void)
{
RCC_OscInitTypeDef RCC_OscInitStruct = {0};
RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
/** Configure the main internal regulator output voltage
*/
__HAL_RCC_PWR_CLK_ENABLE();
__HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);
/** Initializes the CPU, AHB and APB busses clocks
*/
RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
RCC_OscInitStruct.HSIState = RCC_HSI_ON;
RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;
if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
{
Error_Handler();
}
/** Initializes the CPU, AHB and APB busses clocks
*/
RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
|RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_HSI;
RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_0) != HAL_OK)
{
Error_Handler();
}
}
static void MX_ADC1_Init(void)
{
ADC_ChannelConfTypeDef sConfig = {0};
/** Configure the global features of the ADC (Clock, Resolution, Data Alignment and number of conversion)
*/
hadc1.Instance = ADC1;
hadc1.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV2;
hadc1.Init.Resolution = ADC_RESOLUTION_12B;
hadc1.Init.ScanConvMode = DISABLE;
hadc1.Init.ContinuousConvMode = ENABLE;
hadc1.Init.DiscontinuousConvMode = DISABLE;
hadc1.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
hadc1.Init.ExternalTrigConv = ADC_SOFTWARE_START;
hadc1.Init.DataAlign = ADC_DATAALIGN_RIGHT;
hadc1.Init.NbrOfConversion = 1;
hadc1.Init.DMAContinuousRequests = DISABLE;
hadc1.Init.EOCSelection = ADC_EOC_SINGLE_CONV;
if (HAL_ADC_Init(&hadc1) != HAL_OK)
{
Error_Handler();
}
/** Configure for the selected ADC regular channel its corresponding rank in the sequencer and its sample time.
*/
sConfig.Channel = ADC_CHANNEL_0;
sConfig.Rank = 1;
sConfig.SamplingTime = ADC_SAMPLETIME_3CYCLES;
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
{
Error_Handler();
}
}
static void MX_GPIO_Init(void)
{
GPIO_InitTypeDef GPIO_InitStruct = {0};
/* GPIO Ports Clock Enable */
__HAL_RCC_GPIOC_CLK_ENABLE();
/*Configure GPIO pin : PC0 */
GPIO_InitStruct.Pin = GPIO_PIN_0;
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
GPIO_InitStruct.Pull = GPIO_NOPULL;
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
}
```
在上面的代码中,我们使用了 `HAL_ADC_Start` 启动了 ADC 的转换,并使用 `HAL_ADC_PollForConversion` 等待转换完成。然后,我们可以使用 `HAL_ADC_GetValue` 获取 ADC 的原始值,并将其转换为实际电压值。在这个例程中,我们也进行了一些电压校准,你可以根据自己的需要进行修改。