OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 6517|回复: 8

求助 STM32F103ZET6 DMA ADC 输出只有8位精度 最大值255

[复制链接]

1

主题

4

帖子

0

精华

新手上路

积分
35
金钱
35
注册时间
2016-2-26
在线时间
8 小时
发表于 2016-2-26 22:53:07 | 显示全部楼层 |阅读模式
1金钱
/*******************************************************************************

1¤3ìÎļtμÄ¿aê¼
&#203;ùóDí·&#206;&#196;&#188;tó&#195;<includes.h>°üo&#172;
&#214;÷oˉêy&#206;&#196;&#188;t&#189;&#248;DDê±&#214;óoí&#214;D&#182;&#207;μ&#196;&#197;&#228;&#214;&#195;

*******************************************************************************/

#include <includes.h>

/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/

#define ADC1_DR_Address    ((u32)0x4001244C)
int AD_value;

static unsigned long ticks;

int ExTick;

void RCC_Configuration(void);
void NVIC_Configuration(void);
void GPIO_Configuration(void);
void DMA_Configuration(void);
void ADC_Configuration(void);

int  main (void)
{
    RCC_Configuration();
    NVIC_Configuration();
    GPIO_Configuration();
       
    ili9320_Initializtion();
    ili9320_Clear(0xffff);
       
        DMA_Configuration();
    ADC_Configuration();
       

        GUI_Text(80,60,"ADC_DMA_TEST",12,0x0000,0xffff);
        GUI_Text(80,80,"Input-IOA0",12,0x0000,0xffff);
        GUI_Text(80,100,"ADC_Value:",10,0x0000,0xffff);
        GUI_Text(80,120,"Voltage_V:",10,0x0000,0xffff);
        GUI_Text(210,120,"V",1,0x0000,0xffff);

        //è&#231;Dèòa&#190;&#171;è·&#206;è&#182;¨μ&#196;2é&#188;ˉ£&#172;Dèòa×&#212;DD&#212;&#246;&#188;óèí&#188;t&#194;&#203;2¨3ìDò
        while(1)
        {
                ticks=ticks+1;
                if (ticks >= 400000)
                    {                  
                       ticks   = 0;
                                   //&#207;&#212;ê&#190;ADC&#214;μ
                                   GUI_Word(170,100,5,AD_value,0,0xffff,Magenta);       
                                   //&#207;&#212;ê&#190;μ&#231;&#209;1&#214;μ
                                   GUI_Word(170,120,4,((3.3/4096)*AD_value)*1000,3,0xffff,Magenta);       
                }     
         }                    
}



/*******************************************************************************
* Function Name  : RCC_Configuration
* Description    : Configures the different system clocks.
* Input          : None
* Output         : None
* Return         : None
*******************************************************************************/
void RCC_Configuration(void)
{   
  /* SYSCLK, HCLK, PCLK2 and PCLK1 configuration -----------------------------*/   
  /* RCC system reset(for debug purpose) */
  RCC_DeInit();

  /* Enable HSE */
  RCC_HSEConfig(RCC_HSE_ON);

  if(RCC_WaitForHSEStartUp() == SUCCESS)   /* Wait till HSE is ready μè′yía2&#191;&#190;§&#213;&#241;&#198;&#244;&#182;ˉ*/
  {
     /* Enable Prefetch Buffer */
     FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);

     /* Flash 2 wait state */
     FLASH_SetLatency(FLASH_Latency_2);

     /* HCLK = SYSCLK */
     RCC_HCLKConfig(RCC_SYSCLK_Div1);

     /* PCLK2 = HCLK */
     RCC_PCLK2Config(RCC_HCLK_Div1);

     /* PCLK1 = HCLK/2 */
     RCC_PCLK1Config(RCC_HCLK_Div2);

     /* PLLCLK = 8MHz * 9 = 72 MHz */
     RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);                 //9±&#182;&#198;μ  8M*9=72M

     /* Enable PLL */
     RCC_PLLCmd(ENABLE);

     /* Wait till PLL is ready */
     while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
     {
     }

     /* Select PLL as system clock source */
     RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);

     /* Wait till PLL is used as system clock source */
     while(RCC_GetSYSCLKSource() != 0x08)
     {
     }
   }
}



/*******************************************************************************
* Function Name  : NVIC_Configuration
* Description    : Configures Vector Table base location.
* Input          : None
* Output         : None
* Return         : None
*******************************************************************************/
void NVIC_Configuration(void)
{
                #ifdef  VECT_TAB_RAM  
                  /* Set the Vector Table base location at 0x20000000 */
                  NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0);
                #else  /* VECT_TAB_FLASH  */
                  /* Set the Vector Table base location at 0x08000000 */
                  NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);   
                #endif
}

/*******************************************************************************
* Function Name  : GPIO_Configuration
* Description    : Configures the different GPIO ports.
* Input          : None
* Output         : None
* Return         : None
*******************************************************************************/
void GPIO_Configuration(void)
{
          GPIO_InitTypeDef GPIO_InitStructure;
          //&#189;&#171A0&#197;&#228;&#214;&#195;&#206;aADCê&#228;è&#235;&#182;&#203;&#191;ú   
          GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
          GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
          GPIO_Init(GPIOA, &GPIO_InitStructure);
}


void DMA_Configuration(void)
{
        DMA_InitTypeDef DMA_InitStructure;
        RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);                                 //ê1&#196;üDMA1ê±&#214;ó
        /* DMA channel1 configuration ----------------------------------------------*/
        //ê1&#196;üDMA
        DMA_DeInit(DMA1_Channel1);
        DMA_InitStructure.DMA_PeripheralBaseAddr = ADC1_DR_Address;
        DMA_InitStructure.DMA_MemoryBaseAddr = (u32)&AD_value;
        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);
        /* Enable DMA channel1 */
        DMA_Cmd(DMA1_Channel1, ENABLE);
}

void ADC_Configuration(void)
{
        ADC_InitTypeDef ADC_InitStructure;
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE);                        //ê1&#196;üADC1ê±&#214;ó
        /* ADC1 configuration ------------------------------------------------------*/
        //ADC&#197;&#228;&#214;&#195;
        ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; //ADC1oíADC21¤×÷&#212;ú&#182;àá¢&#196;£ê&#189;
        ADC_InitStructure.ADC_ScanConvMode = ENABLE;//&#196;£êy×a&#187;&#187;1¤×÷&#212;úé¨&#195;è&#196;£ê&#189;£¨&#182;àí¨μà£&#169;&#187;1ê&#199;μ¥′&#206;£¨μ¥í¨μà£&#169;&#196;£ê&#189;
        ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;//&#196;£êy×a&#187;&#187;1¤×÷&#212;úé¨&#195;è&#196;£ê&#189;£¨&#182;àí¨μà£&#169;&#187;1ê&#199;μ¥′&#206;£¨μ¥í¨μà£&#169;&#196;£ê&#189;
        ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;//×a&#187;&#187;óéèí&#188;t&#182;&#248;2&#187;ê&#199;ía2&#191;′¥·¢&#198;&#244;&#182;ˉ
        ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;//ADCêy&#190;Yóò&#182;&#212;&#198;&#235;
        ADC_InitStructure.ADC_NbrOfChannel = 1;//1&#230;&#182;¨&#189;&#248;DD1&#230;&#212;ò×a&#187;&#187;μ&#196;ADCí¨μàμ&#196;êy&#196;&#191;&#161;£&#213;a&#184;&#246;êy&#196;&#191;μ&#196;è&#161;&#214;μ·&#182;&#206;§ê&#199;1μ&#189;16
        ADC_Init(ADC1, &ADC_InitStructure);
       
        /* ADC1 regular channels configuration [1&#230;&#212;ò&#196;£ê&#189;í¨μà&#197;&#228;&#214;&#195;]*/
        ADC_RegularChannelConfig(ADC1, ADC_Channel_0 ,1, ADC_SampleTime_55Cycles5);

        /* Enable ADC1 DMA [ê1&#196;üADC1 DMA]*/
        ADC_DMACmd(ADC1, ENABLE);
        /* Enable ADC1 [ê1&#196;üADC1]*/
        ADC_Cmd(ADC1, ENABLE);       
        /* Enable ADC1 reset calibaration register */       
        ADC_ResetCalibration(ADC1);
        /* Check the end of ADC1 reset calibration register */
        while(ADC_GetResetCalibrationStatus(ADC1));
       
        /* Start ADC1 calibaration */
        ADC_StartCalibration(ADC1);
        /* Check the end of ADC1 calibration */
        while(ADC_GetCalibrationStatus(ADC1));
       
        /* Start ADC1 Software Conversion */
        ADC_SoftwareStartConvCmd(ADC1, ENABLE);
}


QQ图片20160226225227.png
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

1

主题

4

帖子

0

精华

新手上路

积分
35
金钱
35
注册时间
2016-2-26
在线时间
8 小时
 楼主| 发表于 2016-2-26 22:55:40 | 显示全部楼层
程序没注意贴错了,问题代码如下:
#include "stm32f10x.h"
#include "stm32f10x_usart.h"
#include "stm32f10x_dma.h"
#include "stm32f10x_adc.h"
//#include "misc.h"
#include <string.h>
#include <stdarg.h>
#include <stdio.h>
#define ADC1_DR_Address  ((u32)0x4001244C)
int ADC_ConvertedValue;

u8 receive_flag;
static unsigned long ticks;

void delay_nus(u16 time)
{   
   u16 i=0;  
   while(time--)
   {
      i=10;  //????
      while(i--) ;   
   }
}
//??????
void delay_nms(u16 time)
{   
   u16 i=0;  
   while(time--)
   {
      i=12000;  //????
      while(i--) ;   
   }
}

int fputc(int ch,FILE*f) //êμ&#207;&#214;UART&#214;&#216;&#182;¨&#207;ò1|&#196;ü
{
if(ch=='\n')
{
  while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET);
        USART_SendData(USART1,'\r');
}
  while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET);
  USART_SendData(USART1,ch);
  return ch;
}

void GPIO_Configuration(void)
{
  GPIO_InitTypeDef GPIO_InitStructure;
        GPIO_StructInit(&GPIO_InitStructure);
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; //USARTT1 TX
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //&#184;′ó&#195;í&#198;íìê&#228;3&#246;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_Init(GPIOA,&GPIO_InitStructure);         
         
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;   //USARTT1 RX
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; //&#184;′ó&#195;&#191;a&#194;&#169;ê&#228;3&#246;
        GPIO_Init(GPIOA,&GPIO_InitStructure);         

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
        //GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_Init(GPIOC,&GPIO_InitStructure);         
}

void RCC_Configuration(void)
{
  SystemInit();
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
  RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1,ENABLE);       
        //RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC,ENABLE);
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1|RCC_APB2Periph_GPIOC,ENABLE);
  RCC_ADCCLKConfig(RCC_PCLK2_Div6);         
}

void USART_Config(void)
{
  USART_InitTypeDef USART_InitStructure;
        USART_InitStructure.USART_BaudRate = 115200; //2¨ì&#216;&#194;ê115200
  USART_InitStructure.USART_WordLength = USART_WordLength_8b;//8&#206;&#187;êy&#190;Y&#206;&#187;
        USART_InitStructure.USART_StopBits = USART_StopBits_1;//1&#184;&#246;í£&#214;1&#206;&#187;
  USART_InitStructure.USART_Parity = USART_Parity_No;//&#198;&#230;&#197;&#188;2&#187;ê1&#196;ü
        USART_InitStructure.USART_HardwareFlowControl =  USART_HardwareFlowControl_None;//ó2&#188;tá÷&#191;&#216;&#214;&#198;2&#187;ê1&#196;ü
        USART_InitStructure.USART_Mode = USART_Mode_Tx|USART_Mode_Rx;//·¢&#203;íê1&#196;ü
        USART_Init(USART1,&USART_InitStructure);//3&#245;ê&#188;&#187;ˉ&#189;á11ì&#229;
  USART_Cmd(USART1,ENABLE);         //ê1&#196;ü′&#174;&#191;ú1
}

void ADC_Configuration(void)
{
  ADC_InitTypeDef ADC_InitStructure;
        ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;
  ADC_InitStructure.ADC_ScanConvMode = DISABLE;//2&#187;ê1&#196;üé¨&#195;è
  ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;//ê1&#196;üá&#172;D&#248;×a&#187;&#187;
  ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;
  ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;
  ADC_InitStructure.ADC_NbrOfChannel = 1;
  ADC_Init(ADC1,&ADC_InitStructure);
  ADC_RegularChannelConfig(ADC1,ADC_Channel_11,1,ADC_SampleTime_55Cycles5);
  ADC_DMACmd(ADC1,ENABLE);
        ADC_Cmd(ADC1,ENABLE);
  ADC_ResetCalibration(ADC1);         
        while(ADC_GetResetCalibrationStatus(ADC1));
        ADC_StartCalibration(ADC1);
  while(ADC_GetCalibrationStatus(ADC1));         
        ADC_SoftwareStartConvCmd(ADC1,ENABLE);
}


void DMA_Configuration()
{
        DMA_InitTypeDef DMA_InitStructure;//&#182;¨ò&#229;&#189;á11ì&#229;±&#228;á&#191;
  DMA_DeInit(DMA1_Channel1);//&#184;′&#206;&#187;DMA1
        DMA_InitStructure.DMA_PeripheralBaseAddr = ADC1_DR_Address;//&#212;′í·BUF
        DMA_InitStructure.DMA_MemoryBaseAddr = (u32)&ADC_ConvertedValue;//&#196;&#191;±êBUF
        DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;                        //íaéè×÷&#212;′í·
        DMA_InitStructure.DMA_BufferSize = 1;                                    //BUF′óD&#161;
        DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;//íaéèμ&#216;&#214;·&#188;&#196;′&#230;&#198;÷2&#187;μY&#212;&#246;
        DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Disable;                //&#196;ú′&#230;μ&#216;&#214;·μY&#212;&#246;
        DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;//íaéè×&#214;&#189;ú&#206;aμ¥&#206;&#187;
        DMA_InitStructure.DMA_MemoryDataSize = DMA_PeripheralDataSize_HalfWord;//&#196;ú′&#230;×&#214;&#189;ú&#206;aμ¥&#206;&#187;
        DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;                //&#209;-&#187;·&#196;£ê&#189;
        DMA_InitStructure.DMA_Priority = DMA_Priority_High;        //4ó&#197;&#207;è&#188;&#182;&#214;&#174;ò&#187;μ&#196;(&#184;&#223;ó&#197;&#207;è)
        DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;        //·&#199;&#196;ú′&#230;μ&#189;&#196;ú′&#230;
        DMA_Init(DMA1_Channel1, &DMA_InitStructure);
//  DMA_ITConfig(DMA1_Channel1,DMA_IT_TC,ENABLE);//DMA1&#189;óê&#213;ADC1,DMAêy&#190;Y
  DMA_Cmd(DMA1_Channel1,ENABLE);//ê1&#196;ü
}


int main(void)
{
        float voltage;
        float temp;
        RCC_Configuration();
  GPIO_Configuration();
  USART_Config();
  DMA_Configuration();
//        NVIC_Configuration();
  ADC_Configuration();
  USART_ClearFlag(USART1,USART_FLAG_TC);
// printf("hello world\n");
while(1)
{
  voltage = (float) ADC_ConvertedValue/ 4096*3.3;
        printf("%d\r\n",ADC_ConvertedValue);
  printf("%f\r\n ",voltage);
  delay_nms(10);
        }
}













回复

使用道具 举报

1

主题

4

帖子

0

精华

新手上路

积分
35
金钱
35
注册时间
2016-2-26
在线时间
8 小时
 楼主| 发表于 2016-2-27 20:18:44 | 显示全部楼层
有没有大神指点一下?谢谢!
回复

使用道具 举报

1

主题

4

帖子

0

精华

新手上路

积分
35
金钱
35
注册时间
2016-2-26
在线时间
8 小时
 楼主| 发表于 2016-3-2 00:05:07 | 显示全部楼层
没有大神回复吗?
回复

使用道具 举报

8

主题

31

帖子

0

精华

初级会员

Rank: 2

积分
89
金钱
89
注册时间
2016-3-1
在线时间
17 小时
发表于 2016-3-2 07:56:10 | 显示全部楼层
欧来看看
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2016-3-2 23:11:45 | 显示全部楼层
参考我们的例程。
回复

使用道具 举报

0

主题

3

帖子

0

精华

新手入门

积分
12
金钱
12
注册时间
2016-8-17
在线时间
2 小时
发表于 2016-8-17 20:23:49 | 显示全部楼层
正点原子 发表于 2016-3-2 23:11
参考我们的例程。

我也遇到同样的现象,代码参考的就是光盘里面的,费解
回复

使用道具 举报

0

主题

35

帖子

0

精华

初级会员

Rank: 2

积分
92
金钱
92
注册时间
2016-8-11
在线时间
40 小时
发表于 2016-8-17 22:59:39 | 显示全部楼层
USART_InitStructure.USART_WordLength = USART_WordLength_8b

就该要分2次传一个完整数据。采样是对的,传送没传完。(我乱猜的,我也不懂)
回复

使用道具 举报

0

主题

3

帖子

0

精华

新手入门

积分
12
金钱
12
注册时间
2016-8-17
在线时间
2 小时
发表于 2016-8-18 00:19:48 | 显示全部楼层
怀疑这里的配置有问题
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;//íaéè×&Ouml;&frac12;ú&Icirc;aμ¥&Icirc;&raquo;
DMA_InitStructure.DMA_MemoryDataSize = DMA_PeripheralDataSize_HalfWord;//&Auml;ú′&aelig;×&Ouml;&frac12;ú&Icirc;aμ¥&Icirc;&raquo;



DMA_InitStructure.DMA_MemoryDataSize = DMA_PeripheralDataSize_HalfWord;//
应该改为
DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;//

头文件中 定不一样的

#define DMA_MemoryDataSize_HalfWord        ((uint32_t)0x00000400)
#define DMA_PeripheralDataSize_HalfWord    ((uint32_t)0x00000100)

明天试一试
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-2 20:21

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表