中级会员
 
- 积分
- 206
- 金钱
- 206
- 注册时间
- 2014-5-12
- 在线时间
- 0 小时
|
5金钱
我用ADC对PB0,PB1采样,扫描+连续采样,再将数据给DMA,DMA是循环模式,但是这两个采样的结果都不对,PB0的大了很多,PB1一直是0,这是为什么?求教大神。
/* 头文件 ------------------------------------------------------------------*/
#include "stm32f10x_lib.h"
#include "stdio.h"
#include "stm32f10x_dma.h"
/* 自定义同义关键字 --------------------------------------------------------*/
/* 自定义参数宏 --------------------------------------------------------*/
/* 自定义函数宏 --------------------------------------------------------*/
/* 自定义全局变量 --------------------------------------------------------*/
u16 ADC_ConvertedValue[2];
/* 自定义函数声明 --------------------------------------------------------*/
void RCC_Configuration(void);
void GPIO_Configuration(void);
void USART_Configuration(void);
void ADC_Configuration(void);
void DMA_Configuration(void);
int main(void)
{
float VolValue1 = 0.00; /* 转换结果,双精度浮点数 */
float VolValue2 = 0.00;
u32 ticks = 0; /* ADC显示延时参数 */
RCC_Configuration();/* 设置系统时钟 */
GPIO_Configuration();/* 设置 GPIO 端口 */
USART_Configuration();/* 设置 USART */
DMA_Configuration();/*设置DMA*/
ADC_Configuration();/* 设置 ADC */
printf("\r\n The AD_value is:-------------------------- \r\n");
while(1)
{
if (ticks++ >= 2000000)
{
ticks = 0;
VolValue1 = 2.56 *ADC_ConvertedValue[0] / 0X0FFF;
VolValue2 = 2.56 *ADC_ConvertedValue[1] / 0X0FFF;
printf( "\r\nThe current VolValue111 = %.2fv\r\n", VolValue1);
printf( "\r\nThe current VolValue222 = %.2fv\r\n", VolValue2);
}
}
}
void DMA_Configuration(void)
{
DMA_InitTypeDef DMA_InitStructure;
DMA_DeInit(DMA1_Channel1);
DMA_InitStructure.DMA_PeripheralBaseAddr=(vu32)&ADC1->DR;
DMA_InitStructure.DMA_MemoryBaseAddr=(u32)&ADC_ConvertedValue;
DMA_InitStructure.DMA_DIR=DMA_DIR_PeripheralSRC;
DMA_InitStructure.DMA_BufferSize=1;
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);
DMA_Cmd(DMA1_Channel1,ENABLE);
}
void RCC_Configuration(void)
{
ErrorStatus HSEStartUpStatus;/* 定义枚举类型变量 HSEStartUpStatus */
RCC_DeInit();/* 复位系统时钟设置 */
RCC_HSEConfig(RCC_HSE_ON);/* 开启 HSE */
HSEStartUpStatus = RCC_WaitForHSEStartUp();/* 等待 HSE 起振并稳定 */
if(HSEStartUpStatus == SUCCESS)/* 判断 HSE 起是否振成功,是则进入if()内部 */
{
RCC_HCLKConfig(RCC_SYSCLK_Div1);/* 选择 HCLK(AHB)时钟源为SYSCLK 1分频 */
RCC_PCLK2Config(RCC_HCLK_Div1);/* 选择 PCLK2 时钟源为 HCLK(AHB)1分频 */
RCC_PCLK1Config(RCC_HCLK_Div2);/* 选择 PCLK1 时钟源为 HCLK(AHB)2分频 */
FLASH_SetLatency(FLASH_Latency_2);/* 设置 FLASH 延时周期数为2 */
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);/* 使能 FLASH 预取缓存 */
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);/* 选择锁相环(PLL)时钟源为 HSE 1分频,倍频数为9,则PLL输出频率为 8MHz * 9 = 72MHz */
RCC_PLLCmd(ENABLE);/* 使能 PLL */
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);/* 等待 PLL 输出稳定 */
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);/* 选择 SYSCLK 时钟源为 PLL */
while(RCC_GetSYSCLKSource() != 0x08);/* 等待 PLL 成为 SYSCLK 时钟源 */
}
/* 使能各个用到的外设时钟 */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA |
RCC_APB2Periph_ADC1 | RCC_APB2Periph_GPIOB, ENABLE);
RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1,ENABLE);
}
void GPIO_Configuration(void)
{
GPIO_InitTypeDef GPIO_InitStructure;/* 定义 GPIO 初始化结构体 GPIO_InitStructure */
/* 设置 USART1 的Tx脚(PA.9)为第二功能推挽输出功能 */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA , &GPIO_InitStructure);
/* 设置 USART1 的Rx脚(PA.10)为浮空输入脚 */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOA , &GPIO_InitStructure);
/* 将 PB.0 设置为模拟输入脚 */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
GPIO_Init(GPIOB , &GPIO_InitStructure);
/* 将 PB.1 设置为模拟输入脚 */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
GPIO_Init(GPIOB , &GPIO_InitStructure);
}
void ADC_Configuration(void)
{
ADC_InitTypeDef ADC_InitStructure;/* 定义 ADC 初始化结构体 ADC_InitStructure */
RCC_ADCCLKConfig(RCC_PCLK2_Div4);/* 配置ADC时钟分频 */
/* 独立工作模式;
多通道扫描模式;
连续模数转换模式;
转换触发方式:转换由软件触发启动;
ADC 数据右对齐 ;
进行规则转换的 ADC 通道的数目为1;*/
ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;
ADC_InitStructure.ADC_ScanConvMode = ENABLE;
ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;
ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;
ADC_InitStructure.ADC_NbrOfChannel = 2;
ADC_Init(ADC1, &ADC_InitStructure);
/* 设置 ADC1 使用8转换通道,转换顺序1,采样时间为 55.5 周期 */
ADC_RegularChannelConfig(ADC1, ADC_Channel_8, 1, ADC_SampleTime_55Cycles5);
ADC_RegularChannelConfig(ADC1, ADC_Channel_9, 1, ADC_SampleTime_55Cycles5);
ADC_DMACmd(ADC1,ENABLE);/*使能DMA功能*/
ADC_Cmd(ADC1, ENABLE);/* 使能 ADC1 */
ADC_ResetCalibration(ADC1);/* 复位 ADC1 的校准寄存器 */
while(ADC_GetResetCalibrationStatus(ADC1));/* 等待 ADC1 校准寄存器复位完成 */
ADC_StartCalibration(ADC1);/* 开始 ADC1 校准 */
while(ADC_GetCalibrationStatus(ADC1));/* 等待 ADC1 校准完成 */
ADC_SoftwareStartConvCmd(ADC1, ENABLE);/* 启动 ADC1 转换 */
}
void USART_Configuration(void)
{
USART_InitTypeDef USART_InitStructure;/* 定义 USART 初始化结构体 USART_InitStructure */
/* 波特率为115200bps;
8位数据长度;
1个停止位,无校验;
禁用硬件流控制;
禁止USART时钟;
时钟极性低;
在第2个边沿捕获数据
最后一位数据的时钟脉冲不从 SCLK 输出; */
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;
USART_Init(USART1 , &USART_InitStructure);
USART_Cmd(USART1 , ENABLE);/* 使能 USART1 */
}
int fputc(int ch, FILE *f)
{
USART_SendData(USART1, (u8) ch);
while(USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
return ch;
}
|
最佳答案
查看完整内容[请看2#楼]
两个顺序一样,到底先弄哪个啊?
ADC_RegularChannelConfig(ADC1, ADC_Channel_8, 1, ADC_SampleTime_55Cycles5);
ADC_RegularChannelConfig(ADC1, ADC_Channel_9, 1, ADC_SampleTime_55Cycles5);
改成不一样啊
|