微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > STM32 八路AD转换用DMA传输调试成功,DMA传输不错位

STM32 八路AD转换用DMA传输调试成功,DMA传输不错位

时间:11-23 来源:互联网 点击:
//

//
#include"stm32f10x_conf.h" //把DMA.h和ADC.h 的注释去掉
#include "stm32f10x.h"
#include "stm32_eval.h"

#include

#define N 50 //每通道采50次
#define M 8 //为8个通道

#define ADC1_DR_Address ((u32)0x4001244C)

vu16 After_filter[M]; //用来存放求平均值之后的结果
vu16 AD_Value[N][M]; //用来存放ADC转换结果,也是DMA的目标地址
//这个变量存放ADC转换后的值,在后面DMA设置的时候取了这个变了的地址,将转

//换结果直接传输到这个地址。当需要多路AD转换时,定义此为一个数组后面

//DMA设置时取数组的基地址,依次传输

void IO_cfg(void);
void EXTI_cfg(void);
void NVIC_cfg(void);
void USART_cfg(void);
void ADC_cfg(void);
void DMA_cfg(void);

u16 GetVolt(u16 advalue);
void filter(void);

void SerialPutChar(uint8_t c);
void SerialReceivechar(uint8_t c);

void Delay(vu32 nCount)
{
for(; nCount != 0; nCount--);
}

void RCC_cfg()
{
//打开PA端口时钟,并且打开复用时钟
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB | RCC_APB2Periph_GPIOC | RCC_APB2Periph_AFIO, ENABLE);

RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE); //使能DMA时钟
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE); //使能ADC

}

////////////////////////////几乎没用,为了系统兼容/////////////////////////////////////
#ifdef __GNUC__

#define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
#else
#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
#endif
//////////////////////////////////////////////////////////////////////////////////////////////////

int main()
{
int i; //用于串口输出

u16 value[M]; //存放求完平均值之后再将结果扩大100倍

RCC_cfg();
EXTI_cfg();
IO_cfg();
NVIC_cfg();
USART_cfg();

DMA_cfg();
ADC_cfg();

while(1)
{
while(USART_GetFlagStatus(USART1,USART_FLAG_TXE)==RESET);//等待传输完成否则第一位数据容易失
filter();
for(i=0;i
{
value[i]= GetVolt(After_filter[i]);

printf("value[%d]:\t%d.%dv\n",i,value[i]/100,value[i]0) ;
Delay(0x80000);
}

}

}

//
void IO_cfg()
{
//八路AD输入

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
GPIO_Init(GPIOB, &GPIO_InitStructure);


GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
GPIO_Init(GPIOB, &GPIO_InitStructure);


GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
GPIO_Init(GPIOC, &GPIO_InitStructure);


GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
GPIO_Init(GPIOC, &GPIO_InitStructure);


GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
GPIO_Init(GPIOC, &GPIO_InitStructure);


GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
GPIO_Init(GPIOC, &GPIO_InitStructure);


GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
GPIO_Init(GPIOC, &GPIO_InitStructure);


GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
GPIO_Init(GPIOC, &GPIO_InitStructure);

}

// 配置串口参数

void USART_cfg()
{
USART_InitTypeDef USART_InitStructure;

USART_InitStructure.USART_BaudRate = 115200;
USART_InitStructure.USART_WordLength = USART_WordLength_8b;
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;

STM_EVAL_COMInit(COM1, &USART_InitStructure);

}

void SerialPutChar(uint8_t c)
{
USART_SendData(EVAL_COM1, c);
while (USART_GetFlagStatus(EVAL_COM1, USART_FLAG_TXE) == RESET)
{
}
}

void SerialReceivechar(uint8_t c)
{

USART_ReceiveData(EVAL_COM1);

while( USART_GetFlagStatus(EVAL_COM1, USART_FLAG_RXNE) != RESET)
{
}
}

void ADC_cfg(void)
{
ADC_InitTypeDef ADC_InitStructure;

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top