stm32adc配置问题应用到adc+dma+tim+usart

我将adc配置后读出的数一直为0,怀疑是否adc没有运作。下面是我写的程序,请大神们帮我指点一下,看看哪出了问题。
**********************************************************************************/
#include "adc.h"

vu16 AD_Value[N][M]; //用来存放ADC转换结果,也是DMA的目标地址
vu16 After_filter[M]; //用来存放求平均值之后的结果
u16 AD_Data_Ram[N];
u16 Get_RF_Data[N];
extern u16 RF_ADC1_Value_Count[ADRF_Arr_Count];
extern u16 V_ADC1_Value[ADRF_Arr_Count]; //存储采集电池电压缓存
/*

  • 函数名:ADC1_GPIO_Config
  • 描述 :使能ADC1和DMA1的时钟,初始化PC.01
  • 输入 : 无
  • 输出 :无
  • 调用 :内部调用
    /
    static void ADC1_GPIO_Config(void)
    {
    GPIO_InitTypeDef GPIO_InitStructure;
    /
    Enable ADC1 and GPIOC clock */
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 | RCC_APB2Periph_GPIOB, ENABLE);

    /*PB0-RF_AD输入 PB1-电压检测输入*/
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
    GPIO_Init(GPIOB, &GPIO_InitStructure);
    }

/* 函数名:ADC1_Mode_Config

  • 描述 :配置ADC1的工作模式为DMA模式
  • 输入 : 无
  • 输出 :无
  • 调用 :内部调用
    /
    static void ADC1_Mode_Config(void)
    {
    ADC_InitTypeDef ADC_InitStructure;
    // ADC_DMARequestModeConfig(ADC1, ADC_DMAMode_Circular);
    /
    ADC1 configuration */
    ADC_DeInit(ADC1); //复位ADC

    ADC_StructInit(&ADC_InitStructure); //初始化ADC结构体
    ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; //独立ADC模式
    ADC_InitStructure.ADC_ScanConvMode = ENABLE; //扫描模式用于多通道采集
    ADC_InitStructure.ADC_ContinuousConvMode = ENABLE; //ENABLE 开启连续转换模式,即不停地进行ADC转换
    ADC_InitStructure.ADC_ExternalTrigConv =ADC_ExternalTrigConv_None; //ADC_ExternalTrigConv_T2_CC2;//外部触发设置为TIM2
    //(ADC_ExternalTrigConv_None; //不使用外部触发转换 (ADC_ExternalTrigConv_Ext_IT11_TIM8_TRGO; )//使用外部中断线11作为转换外部触发

    ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right; //采集数据右对齐
    ADC_InitStructure.ADC_NbrOfChannel = M; //要转换的通道数目2
    ADC_Init(ADC1, &ADC_InitStructure);

    /*配置ADC时钟,为PCLK2的8分频,即9MHz*/
    RCC_ADCCLKConfig(RCC_PCLK2_Div8);
    /*配置ADC1的通道8为55.5个采样周期,序列为1 /
    /
    配置ADC1的通道9为55.5个采样周期,序列为2 /
    // ADC_SampleTime_55Cycles5
    ADC_RegularChannelConfig(ADC1, ADC_Channel_8, 1, ADC_SampleTime_7Cycles5);
    ADC_RegularChannelConfig(ADC1, ADC_Channel_9, 2, ADC_SampleTime_7Cycles5);
    // ADC_RegularChannelConfig(ADC1, ADC_Channel_8, 1, ADC_SampleTime_239Cycles5);
    // ADC_RegularChannelConfig(ADC1, ADC_Channel_9, 2, ADC_SampleTime_239Cycles5);
    /
    Enable ADC1 external trigger /
    // ADC_ExternalTrigConvCmd(ADC1, ENABLE);
    /
    Enable ADC1 DMA */
    ADC_DMACmd(ADC1, ENABLE);

    /* Enable ADC1 */
    ADC_Cmd(ADC1, ENABLE);

    /*复位校准寄存器 /

    ADC_ResetCalibration(ADC1);
    /
    等待校准寄存器复位完成 */
    while(ADC_GetResetCalibrationStatus(ADC1));

    /* ADC校准 /
    ADC_StartCalibration(ADC1);
    /
    等待校准完成*/
    while(ADC_GetCalibrationStatus(ADC1));

    /* 由于没有采用外部触发,所以使用软件触发ADC转换 */
    ADC_SoftwareStartConvCmd(ADC1, ENABLE);

// DMA_Cmd(DMA1_Channel1, ENABLE);//使能DMA

}
void DMA_AD_Init(void)
{
DMA_InitTypeDef DMA_InitStructure;
/* Enable DMA clock /
RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
/
DMA channel1 configuration */
DMA_DeInit(DMA1_Channel1);
DMA_InitStructure.DMA_PeripheralBaseAddr = ADC1_DR_Address; //ADC地址
DMA_InitStructure.DMA_MemoryBaseAddr = (u32)&AD_Value;//内存地址
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC; //内存作为数据传输的目的地
DMA_InitStructure.DMA_BufferSize = N*M; //DMA通道的DMA缓存的大小
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通道拥有高优先级
DMA_InitStructure.DMA_M2M = DMA_M2M_Disable; //DMA通道没有设置为内存到内存传输
DMA_Init(DMA1_Channel1, &DMA_InitStructure);

//开启DMA传输完成中断

// DMA_ITConfig(DMA1_Channel1,DMA_IT_TC,ENABLE);
// DMA_ClearITPendingBit(DMA_IT_TC); //清除一次DMA中断标志

DMA_Cmd(DMA1_Channel1, ENABLE); //Enable DMA channel1

}
/*

  • 函数名:ADC1_Init
  • 描述 :无
  • 输入 :无
  • 输出 :无
  • 调用 :外部调用 */ void ADC1_Init(void) { ADC1_GPIO_Config(); DMA_AD_Init(); ADC1_Mode_Config(); }

http://blog.csdn.net/zhnn610735528/article/details/45690111

我就是按这个配置的,结果还是不行。你帮我查看一下,我这个程序有问题吗,在哪

//USART 初始化设置
USART_InitStructure.USART_BaudRate = bound;//一般设置为9600;
USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字长为8位数据格式
USART_InitStructure.USART_StopBits = USART_StopBits_1;//一个停止位
USART_InitStructure.USART_Parity = USART_Parity_No;//无奇偶校验位
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//无硬件数据流控制
USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; //收发模式
USART_Init(USART1, &USART_InitStructure); //初始化串口

// USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);//开启中断
//使用DMA检测串口空闲中断初始化配置
// USART_ITConfig(USART1,USART_IT_IDLE,ENABLE); //开启空闲中断
/*开启串口DMA接收*/
USART_DMACmd(USART1,USART_DMAReq_Rx,ENABLE);

USART_Cmd(USART1, ENABLE);                    //使能串口 
USART1_Flag=0;

}

//发送一个字节
void TransByte(USART_TypeDef* USARTx , u8 byte)
{
while(USART_GetFlagStatus(USARTx,USART_FLAG_TC)!=SET);//等待 发送结束
USART_SendData(USARTx, byte);//向串口 1 发送数据
LED4=!LED4;
// Delay_ms(5); //这个时间由接收的器件决定,如果过快接收不了
}
//发送一个字符串
void TransStr(USART_TypeDef* USARTx , u8 *Str)
{
u8 i=0;
while(Str[i]!='\0')//空字符
{
TransByte(USARTx,Str[i]);
i++;

}
}
//串口1接收函数
void USART1_IRQHandler(void) //串口1中断服务程序
{

volatile u16 IIR;
u8 ch;
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) //是否为接收中断
{
USART_ClearITPendingBit(USART1,USART_IT_RXNE); //清除标志位
ch=USART_ReceiveData(USART1);
if(ch!=0x0A) //接收字符不是换行符
{
USART1_RX_BUF[USART1_RX_Count]=ch;
USART1_RX_Count++;
}
else
{
if(USART1_RX_BUF[USART1_RX_Count-1]==0x0D) //接收到前一个字符为回车符
{
USART1_Flag=1;
USART1_RX_Count=0;
}
}
LED4=!LED4;

}

}
void USART11_IRQHandler(void) //串口1空闲中断服务程序
{
unsigned char num=0;
if(USART_GetITStatus(USART1,USART_IT_IDLE) == SET)
{
num = USART1->SR;
num = USART1->DR; //清USART_IT_IDLE标志
DMA_Cmd(DMA1_Channel5,DISABLE); //关闭DMA
num = USART_REC_LEN - DMA_GetCurrDataCounter(DMA1_Channel5); //得到真正接收数据个数

//USART1_RX_BUF[num] = '\0';
DMA1_Channel5->CNDTR=USART_REC_LEN; //重新设置接收数据个数

DMA_Cmd(DMA1_Channel5,ENABLE); //开启DMA
USART1_Flag = 1; //接收数据标志位置1
LED3=!LED3;
}
}