初级会员

- 积分
- 92
- 金钱
- 92
- 注册时间
- 2015-6-7
- 在线时间
- 2 小时
|
5金钱
看了 ALIENTEK MINISTM32 实验16 内部温度传感器实验,改程序介绍了多通道ADC的用法,但是该实验中给ADC的
配置为单通道、单次转换模式,通道个数为1,也没有使用DMA。
我想使用3个ADC通道,并使用DMA,将ADC配置为单通道、连续转换模式,通道个数为1,并为ADC转换数据开辟
一个长度为500的数组。在编译时程序没错,就是不能得到采样结果,我的程序如下,请帮忙看看,谢谢!
// ADC、DMA配置
#include "adc.h"
#include "delay.h"
#define ADC1_DR_Address ((u32)0x40012400+0x4c)
vu16 ADC_ConvertedValue[Sample_Num]; //Sample_Num 为500
static void ADC1_GPIO_Config(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
/* Enable DMA clock */
RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
/* Enable ADC1 and GPIOC clock */
//RCC_AHB2PeriphClockCmd(RCC_AHB2Periph_ADC1 | RCC_AHB2Periph_GPIOA, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA |RCC_APB2Periph_GPIOC |RCC_APB2Periph_ADC1 , ENABLE );
/* Configure PA.01 as analog input */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 ;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
GPIO_Init(GPIOA, &GPIO_InitStructure);
/* Configure PC.00 PC.02 as analog input */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_2 ;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
GPIO_Init(GPIOC, &GPIO_InitStructure);
}
static void ADC1_Mode_Config(void)
{
DMA_InitTypeDef DMA_InitStructure;
ADC_InitTypeDef ADC_InitStructure;
/* DMA channel1 configuration */
DMA_DeInit(DMA1_Channel1);
DMA_InitStructure.DMA_PeripheralBaseAddr = ADC1_DR_Address;
DMA_InitStructure.DMA_MemoryBaseAddr = (u32)&ADC_ConvertedValue;
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;
DMA_InitStructure.DMA_BufferSize = Sample_Num ;
DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;
DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;
DMA_InitStructure.DMA_Priority = DMA_Priority_High;
DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;
DMA_Init(DMA1_Channel1, &DMA_InitStructure);
/* Enable DMA channel1 */
DMA_Cmd(DMA1_Channel1, ENABLE);
/* ADC1 configuration */
ADC_DeInit(ADC1);
ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;
ADC_InitStructure.ADC_ScanConvMode = DISABLE;
ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;
ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;
ADC_InitStructure.ADC_NbrOfChannel = 1;
ADC_Init(ADC1, &ADC_InitStructure);
RCC_ADCCLKConfig(RCC_PCLK2_Div6);
// ADC_RegularChannelConfig(ADC1, ADC_Channel_1, 1, ADC_SampleTime_55Cycles5);
// ADC_RegularChannelConfig(ADC1, ADC_Channel_10, 2, ADC_SampleTime_55Cycles5);
// ADC_RegularChannelConfig(ADC1, ADC_Channel_12, 3, ADC_SampleTime_55Cycles5);
/* Enable ADC1 DMA */
// ADC_DMACmd(ADC1, ENABLE);
/* Enable ADC1 */
// ADC_Cmd(ADC1, ENABLE);
ADC_ResetCalibration(ADC1);
while(ADC_GetResetCalibrationStatus(ADC1));
ADC_StartCalibration(ADC1);
while(ADC_GetCalibrationStatus(ADC1));
// ADC_SoftwareStartConvCmd(ADC1, ENABLE);
}
// uint16_t ReadADCAverageValue(u8 ch, uint16_t Channel )
uint16_t ReadADCAverageValue( uint16_t Channel )
{
uint16_t i;
uint32_t sum = 0;
ADC_Cmd(ADC1, ENABLE);
ADC_DMACmd(ADC1, ENABLE);
switch (Channel)
{
case 0:
{
ADC_RegularChannelConfig(ADC1, ADC_Channel_1, 1, ADC_SampleTime_55Cycles5);
break;
}
case 1:
{
ADC_RegularChannelConfig(ADC1, ADC_Channel_10, 1, ADC_SampleTime_55Cycles5);
break;
}
case 2:
{
ADC_RegularChannelConfig(ADC1, ADC_Channel_12, 1, ADC_SampleTime_55Cycles5);
break;
}
}
ADC_SoftwareStartConvCmd(ADC1, ENABLE);
while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC ));
for(i=0; i<Sample_Num; i++)
sum+=ADC_ConvertedValue;
ADC_Cmd(ADC1, DISABLE);
ADC_DMACmd(ADC1, DISABLE);
return (sum/Sample_Num);
}
void Adc_Init(void)
{
ADC1_GPIO_Config();
ADC1_Mode_Config();
}
//main函数
int main(void)
{
u16 i;
u16 adcx;
float temp;
delay_init();
uart_init(9600);
LED_Init();
LCD_Init();
Adc_Init();
POINT_COLOR=RED;
LCD_ShowString(40,50,200,16,16,"LD&TEC driver control system");
LCD_ShowString(40,70,200,16,16,"Status monitor");
LCD_ShowString(40,90,200,16,16,"Chinaoptoplex");
LCD_ShowString(40,110,200,16,16,"2015/6/6");
POINT_COLOR=BLUE;
LCD_ShowString(60,130,200,16,16,"ADC_CH1_VAL:");
LCD_ShowString(60,150,200,16,16,"ADC_CH1_VOL:0.000V");
LCD_ShowString(60,170,200,16,16,"ADC_CH2_VAL:");
LCD_ShowString(60,190,200,16,16,"ADC_CH2_VOL:0.000V");
LCD_ShowString(60,210,200,16,16,"ADC_CH5_VAL:");
LCD_ShowString(60,230,200,16,16,"ADC_CH5_VOL:0.000V");
while(USART_GetFlagStatus(USART1,USART_FLAG_TXE)==RESET);
while(1)
{
for (i= 0; i < 3; i++)
{
adcx= ReadADCAverageValue(i);
LCD_ShowxNum(156,(130+i*40),adcx,4,16,0);
temp=(float)adcx*(3.3/4096);
adcx=temp;
LCD_ShowxNum(156,(150+i*40),adcx,1,16,0);
}
temp-=adcx;
temp*=1000;
LCD_ShowxNum(172,150,temp,3,16,0X80);
LED0=!LED0;
LED1=!LED1;
delay_ms(250);
}
}
|
|