標題: STM32 ADC模擬量輸入實驗源碼 [打印本頁]

作者: 864063529    時間: 2022-10-8 14:33
標題: STM32 ADC模擬量輸入實驗源碼
找到一份資料,實現(xiàn)目的為:通過串口實時打印出模擬量通道PC0采集的電壓數(shù)值。
適用于初學者,親測可用,下載到開發(fā)板即可實現(xiàn)功能,代碼注解詳細,可快速理解ADC功能

  1. #include "pbdata.h"

  2. u8 dt=0;


  3. void RCC_HSE_Configuration(void) //HSE作為PLL時鐘,PLL作為SYSCLK
  4. {
  5.    RCC_DeInit(); /*將外設RCC寄存器重設為缺省值 */
  6.    RCC_HSEConfig(RCC_HSE_ON);          /*設置外部高速晶振(HSE) HSE晶振打開(ON)*/

  7.    if(RCC_WaitForHSEStartUp() == SUCCESS) {  /*等待HSE起振,  SUCCESS:HSE晶振穩(wěn)定且就緒*/  

  8.    RCC_HCLKConfig(RCC_SYSCLK_Div1);/*設置AHB時鐘(HCLK)RCC_SYSCLK_Div1——AHB時鐘 = 系統(tǒng)時*/  
  9.    RCC_PCLK2Config(RCC_HCLK_Div1); /*設置高速AHB時鐘(PCLK2)RCC_HCLK_Div1——APB2時鐘 = HCLK*/     
  10.    RCC_PCLK1Config(RCC_HCLK_Div2); /*設置低速AHB時鐘(PCLK1)RCC_HCLK_Div2——APB1時鐘 = HCLK / 2*/      

  11.    RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);/*設置PLL時鐘源及倍頻系數(shù)*/   
  12.    RCC_PLLCmd(ENABLE);          /*使能PLL */
  13.    while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET) ; /*檢查指定的RCC標志位(PLL準備好標志)設置與否*/
  14.    
  15.    RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);  /*設置系統(tǒng)時鐘(SYSCLK) */  
  16.    while(RCC_GetSYSCLKSource() != 0x08);     /*0x08:PLL作為系統(tǒng)時鐘 */            
  17. }
  18. }

  19. void delay(u32 nCount)
  20. {
  21.         for(;nCount!=0;nCount--);
  22. }

  23. /****************************************************************************
  24. * 名    稱:delay_us(u32 nus)
  25. * 功    能:微秒延時函數(shù)
  26. * 入口參數(shù):u32  nus
  27. * 出口參數(shù):無
  28. * 說    明:
  29. * 調(diào)用方法:無
  30. ****************************************************************************/
  31. void delay_us(u32 nus)
  32. {
  33.          u32 temp;
  34.          SysTick->LOAD = 9*nus;
  35.          SysTick->VAL=0X00;//清空計數(shù)器
  36.          SysTick->CTRL=0X01;//使能,減到零是無動作,采用外部時鐘源
  37.          do
  38.          {
  39.           temp=SysTick->CTRL;//讀取當前倒計數(shù)值
  40.          }while((temp&0x01)&&(!(temp&(1<<16))));//等待時間到達
  41.          
  42.          SysTick->CTRL=0x00; //關閉計數(shù)器
  43.          SysTick->VAL =0X00; //清空計數(shù)器
  44. }

  45. /****************************************************************************
  46. * 名    稱:delay_ms(u16 nms)
  47. * 功    能:毫秒延時函數(shù)
  48. * 入口參數(shù):u16 nms
  49. * 出口參數(shù):無
  50. * 說    明:
  51. * 調(diào)用方法:無
  52. ****************************************************************************/
  53. void delay_ms(u16 nms)
  54. {
  55.          u32 temp;
  56.          SysTick->LOAD = 9000*nms;
  57.          SysTick->VAL=0X00;//清空計數(shù)器
  58.          SysTick->CTRL=0X01;//使能,減到零是無動作,采用外部時鐘源
  59.          do
  60.          {
  61.           temp=SysTick->CTRL;//讀取當前倒計數(shù)值
  62.          }while((temp&0x01)&&(!(temp&(1<<16))));//等待時間到達
  63.          SysTick->CTRL=0x00; //關閉計數(shù)器
  64.          SysTick->VAL =0X00; //清空計數(shù)器
  65. }

復制代碼
  1. #include "pbdata.h"

  2. void RCC_Configuration(void);
  3. void GPIO_Configuration(void);
  4. void NVIC_Configuration(void);
  5. void USART_Configuration(void);
  6. void ADC_Configuration(void);

  7. int fputc(int ch,FILE *f)
  8. {
  9.         USART_SendData(USART1,(u8)ch);
  10.         while(USART_GetFlagStatus(USART1,USART_FLAG_TXE)==RESET);
  11.         return ch;
  12. }

  13. int main(void)
  14. {
  15.    u32 ad=0;
  16.    u8 i=0;

  17.    RCC_Configuration();        //系統(tǒng)時鐘初始化
  18.    GPIO_Configuration();//端口初始化
  19.    USART_Configuration();
  20.    NVIC_Configuration();
  21.    ADC_Configuration();
  22.    
  23.    while(1)
  24.    {
  25.      ad=0;
  26.          for(i=0;i<50;i++)
  27.          {
  28.                  ADC_SoftwareStartConvCmd(ADC1,ENABLE);
  29.                 while(!ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC));
  30.                 ad=ad+ADC_GetConversionValue(ADC1);
  31.          }
  32.           
  33.           ad=ad/50;
  34.           
  35.           printf("ad =%f\r\n",3.3/4095*ad);//實際電壓值

  36.           //注意 delay_ms函數(shù)輸入范圍是1-1863
  37.           //所以最大延時為1.8秒
  38.           delay_ms(1000);
  39.           delay_ms(1000);
  40.           delay_ms(1000);
  41.    }       
  42. }

  43. void RCC_Configuration(void)
  44. {
  45.     SystemInit();//72m
  46.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
  47.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);
  48.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);

  49.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC,ENABLE);
  50.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE);
  51.         RCC_ADCCLKConfig(RCC_PCLK2_Div6);//12M  最大14M

  52. }

  53. void GPIO_Configuration(void)
  54. {
  55.     GPIO_InitTypeDef GPIO_InitStructure;       
  56.         //LED
  57.         GPIO_InitStructure.GPIO_Pin=GPIO_Pin_9;//TX
  58.         GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
  59.         GPIO_InitStructure.GPIO_Mode=GPIO_Mode_AF_PP;
  60.         GPIO_Init(GPIOA,&GPIO_InitStructure);

  61.         GPIO_InitStructure.GPIO_Pin=GPIO_Pin_10;//RX
  62.         GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING;
  63.         GPIO_Init(GPIOA,&GPIO_InitStructure);

  64.         GPIO_InitStructure.GPIO_Pin=GPIO_Pin_0;//RX
  65.         GPIO_InitStructure.GPIO_Mode=GPIO_Mode_AIN;
  66.         GPIO_Init(GPIOC,&GPIO_InitStructure);
  67. }

  68. void NVIC_Configuration(void)
  69. {
  70.            NVIC_InitTypeDef NVIC_InitStructure;

  71.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);

  72.         NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
  73.         NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
  74.         NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
  75.         NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  76.         NVIC_Init(&NVIC_InitStructure);
  77. }

  78. void USART_Configuration(void)
  79. {
  80.     USART_InitTypeDef  USART_InitStructure;

  81.         USART_InitStructure.USART_BaudRate=9600;
  82.         USART_InitStructure.USART_WordLength=USART_WordLength_8b;
  83.         USART_InitStructure.USART_StopBits=USART_StopBits_1;
  84.         USART_InitStructure.USART_Parity=USART_Parity_No;
  85.         USART_InitStructure.USART_HardwareFlowControl=USART_HardwareFlowControl_None;
  86.         USART_InitStructure.USART_Mode=USART_Mode_Rx|USART_Mode_Tx;

  87.         USART_Init(USART1,&USART_InitStructure);
  88.         USART_ITConfig(USART1,USART_IT_RXNE,ENABLE);
  89.         USART_Cmd(USART1,ENABLE);
  90.         USART_ClearFlag(USART1,USART_FLAG_TC);
  91. }

  92. void ADC_Configuration(void)
  93. {
  94.         ADC_InitTypeDef ADC_InitStructure;

  95.         ADC_InitStructure.ADC_Mode=ADC_Mode_Independent;
  96.         ADC_InitStructure.ADC_ScanConvMode=DISABLE;
  97.         ADC_InitStructure.ADC_ContinuousConvMode=DISABLE;
  98.         ADC_InitStructure.ADC_ExternalTrigConv=ADC_ExternalTrigConv_None;
  99.         ADC_InitStructure.ADC_DataAlign=ADC_DataAlign_Right;
  100.         ADC_InitStructure.ADC_NbrOfChannel=1;

  101.         ADC_Init(ADC1,&ADC_InitStructure);

  102.         ADC_RegularChannelConfig(ADC1,ADC_Channel_10,1,ADC_SampleTime_239Cycles5);

  103.         ADC_Cmd(ADC1,ENABLE);


  104.         ADC_ResetCalibration(ADC1);
  105.         while(ADC_GetResetCalibrationStatus(ADC1));

  106.         ADC_StartCalibration(ADC1);
  107.         while(ADC_GetCalibrationStatus(ADC1));

  108.         ADC_SoftwareStartConvCmd(ADC1,ENABLE);

  109. }



復制代碼

Keil代碼下載: Keil代碼.7z (192.04 KB, 下載次數(shù): 22)





歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1