ADC采集信号DMA传输数据

ADCinit

adcinit大致流程:
打开相应io口时钟,GPIO时钟
配置io为模拟输入
ADC_DeInit(ADC1); //复位ADC1
初始化ADC_Init函数
ADC_RegularChannelConfig adc通道使能,参数为使能通道1,rank等级为第一接收 周期
ADC_Cmd(ADC1, ENABLE); 使能指定的ADC1
ADC_DMACmd 打开adc和dma链接通道
复位校准


void  Adc_Init(void)
{ 	
	ADC_InitTypeDef ADC_InitStructure; 
	GPIO_InitTypeDef GPIO_InitStructure;

	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA |RCC_APB2Periph_ADC1	, ENABLE );	  //使能ADC1通道时钟
 

	RCC_ADCCLKConfig(RCC_PCLK2_Div6);   //设置ADC分频因子6 72M/6=12,ADC最大时间不能超过14M

	//PA1 作为模拟通道输入引脚                         
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;		//模拟输入引脚
	GPIO_Init(GPIOA, &GPIO_InitStructure);	

	ADC_DeInit(ADC1);  //复位ADC1,将外设 ADC1 的全部寄存器重设为缺省值

	ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;	//ADC工作模式:ADC1和ADC2工作在独立模式
	ADC_InitStructure.ADC_ScanConvMode = DISABLE;	//模数转换工作在单通道模式
	ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;	//模数转换工作在单次转换模式
	ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;	//转换由软件而不是外部触发启动
	ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;	//ADC数据右对齐
	ADC_InitStructure.ADC_NbrOfChannel = 1;	//顺序进行规则转换的ADC通道的数目
	ADC_Init(ADC1, &ADC_InitStructure);	//根据ADC_InitStruct中指定的参数初始化外设ADCx的寄存器   

 
 ADC_RegularChannelConfig(ADC1, ADC_Channel_1, 1, ADC_SampleTime_239Cycles5);//配置ADC1,通道10等
	ADC_DMACmd(ADC1,ENABLE);	
	ADC_Cmd(ADC1, ENABLE);	//使能指定的ADC1
		
	
//	ADC_Cmd(ADC1, ENABLE);	//使能指定的ADC1
	
	/**************************************/
	printf("The curre value     b\n");

	ADC_ResetCalibration(ADC1);	//使能复位校准  
	 
	while(ADC_GetResetCalibrationStatus(ADC1));	//等待复位校准结束
	printf("The curre value     c\n");

	ADC_StartCalibration(ADC1);	 //开启AD校准
 
	while(ADC_GetCalibrationStatus(ADC1));	 //等待校准结束
	DMA_Configuration();

}				  

DMA_Configuration初始化

u16 ADC_ConVertedValue[N];
void DMA_Configuration(void)
{
	DMA_InitTypeDef DMA_InitStructure;
	RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);	//使能DMA传输	
	
  DMA_DeInit(DMA1_Channel1);   //将DMA的通道1寄存器重设为缺省值
	DMA_InitStructure.DMA_PeripheralBaseAddr =(u32)&ADC1->DR;  //DMA外设ADC基地址
//	DMA_InitStructure.DMA_MemoryBaseAddr = (u32)&Adc_RecBuff;  //DMA内存基地址
	DMA_InitStructure.DMA_MemoryBaseAddr = (u32)&ADC_ConVertedValue;
	DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;  //数据传输方向,从外设到内存
	DMA_InitStructure.DMA_BufferSize =N;// DMA1_MEM_LEN;  //DMA通道的DMA缓存的大小
	DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;  //外设地址寄存器不变
	DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;  //内存地址寄存器递增
	DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;  //数据宽度为16位
	DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord; //数据宽度为16位
	DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;  //工作在循环
	DMA_InitStructure.DMA_Priority = DMA_Priority_High; //DMA通道 x拥有高优先级 
	DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;  //DMA通道x没有设置为内存到内存传输
	
	DMA_Init(DMA1_Channel1, &DMA_InitStructure);  //根据DMA_InitStruct中指定的参数初始化DMA的通道USART1_Tx_DMA_Channel所标识的寄存器
	
//	DMA_Cmd(DMA1_Channel1,ENABLE);	//DMA使能
}
 u16 Get_Adc_Average(void)
{
	u8  count=0;
	u32 sum=0;
	for(count=0;count<N;count++)
	{	
		DMA_Cmd(DMA1_Channel1,DISABLE);
		ADC_SoftwareStartConvCmd(ADC1, ENABLE);		//使能指定的ADC1的软件转换启动功能	
			
    while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC ))

		
		DMA_Cmd(DMA1_Channel1,ENABLE);
		while( (DMA_GetFlagStatus(DMA1_FLAG_TC1)!=RESET) )	//等待通道4传输完成
		
			DMA_ClearFlag(DMA1_FLAG_TC1);//清除通道4传输完成标志
		sum+=ADC_ConVertedValue[count];
	}
	
	return sum/N;
} 	 


这边dma传输速率远大于adc,故需要先while接收adc的数据之后然后再用dma传送到CPU

  • 7
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值