亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? stm32f10x_adc.c

?? STM32手持式示波器源代碼
?? C
?? 第 1 頁 / 共 4 頁
字號:
/**
  ******************************************************************************
  * @file    stm32f10x_adc.c
  * @author  MCD Application Team
  * @version V3.1.2
  * @date    09/28/2009
  * @brief   This file provides all the ADC firmware functions.
  ******************************************************************************
  * @copy
  *
  * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
  * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
  * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
  * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
  * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
  * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
  *
  * <h2><center>&copy; COPYRIGHT 2009 STMicroelectronics</center></h2>
  */ 

/* Includes ------------------------------------------------------------------*/
#include "stm32f10x_adc.h"
#include "stm32f10x_rcc.h"

/** @addtogroup STM32F10x_StdPeriph_Driver
  * @{
  */

/** @defgroup ADC 
  * @brief ADC driver modules
  * @{
  */

/** @defgroup ADC_Private_TypesDefinitions
  * @{
  */

/**
  * @}
  */

/** @defgroup ADC_Private_Defines
  * @{
  */

/* ADC DISCNUM mask */
#define CR1_DISCNUM_Reset           ((uint32_t)0xFFFF1FFF)

/* ADC DISCEN mask */
#define CR1_DISCEN_Set              ((uint32_t)0x00000800)
#define CR1_DISCEN_Reset            ((uint32_t)0xFFFFF7FF)

/* ADC JAUTO mask */
#define CR1_JAUTO_Set               ((uint32_t)0x00000400)
#define CR1_JAUTO_Reset             ((uint32_t)0xFFFFFBFF)

/* ADC JDISCEN mask */
#define CR1_JDISCEN_Set             ((uint32_t)0x00001000)
#define CR1_JDISCEN_Reset           ((uint32_t)0xFFFFEFFF)

/* ADC AWDCH mask */
#define CR1_AWDCH_Reset             ((uint32_t)0xFFFFFFE0)

/* ADC Analog watchdog enable mode mask */
#define CR1_AWDMode_Reset           ((uint32_t)0xFF3FFDFF)

/* CR1 register Mask */
#define CR1_CLEAR_Mask              ((uint32_t)0xFFF0FEFF)

/* ADC ADON mask */
#define CR2_ADON_Set                ((uint32_t)0x00000001)
#define CR2_ADON_Reset              ((uint32_t)0xFFFFFFFE)

/* ADC DMA mask */
#define CR2_DMA_Set                 ((uint32_t)0x00000100)
#define CR2_DMA_Reset               ((uint32_t)0xFFFFFEFF)

/* ADC RSTCAL mask */
#define CR2_RSTCAL_Set              ((uint32_t)0x00000008)

/* ADC CAL mask */
#define CR2_CAL_Set                 ((uint32_t)0x00000004)

/* ADC SWSTART mask */
#define CR2_SWSTART_Set             ((uint32_t)0x00400000)

/* ADC EXTTRIG mask */
#define CR2_EXTTRIG_Set             ((uint32_t)0x00100000)
#define CR2_EXTTRIG_Reset           ((uint32_t)0xFFEFFFFF)

/* ADC Software start mask */
#define CR2_EXTTRIG_SWSTART_Set     ((uint32_t)0x00500000)
#define CR2_EXTTRIG_SWSTART_Reset   ((uint32_t)0xFFAFFFFF)

/* ADC JEXTSEL mask */
#define CR2_JEXTSEL_Reset           ((uint32_t)0xFFFF8FFF)

/* ADC JEXTTRIG mask */
#define CR2_JEXTTRIG_Set            ((uint32_t)0x00008000)
#define CR2_JEXTTRIG_Reset          ((uint32_t)0xFFFF7FFF)

/* ADC JSWSTART mask */
#define CR2_JSWSTART_Set            ((uint32_t)0x00200000)

/* ADC injected software start mask */
#define CR2_JEXTTRIG_JSWSTART_Set   ((uint32_t)0x00208000)
#define CR2_JEXTTRIG_JSWSTART_Reset ((uint32_t)0xFFDF7FFF)

/* ADC TSPD mask */
#define CR2_TSVREFE_Set             ((uint32_t)0x00800000)
#define CR2_TSVREFE_Reset           ((uint32_t)0xFF7FFFFF)

/* CR2 register Mask */
#define CR2_CLEAR_Mask              ((uint32_t)0xFFF1F7FD)

/* ADC SQx mask */
#define SQR3_SQ_Set                 ((uint32_t)0x0000001F)
#define SQR2_SQ_Set                 ((uint32_t)0x0000001F)
#define SQR1_SQ_Set                 ((uint32_t)0x0000001F)

/* SQR1 register Mask */
#define SQR1_CLEAR_Mask             ((uint32_t)0xFF0FFFFF)

/* ADC JSQx mask */
#define JSQR_JSQ_Set                ((uint32_t)0x0000001F)

/* ADC JL mask */
#define JSQR_JL_Set                 ((uint32_t)0x00300000)
#define JSQR_JL_Reset               ((uint32_t)0xFFCFFFFF)

/* ADC SMPx mask */
#define SMPR1_SMP_Set               ((uint32_t)0x00000007)
#define SMPR2_SMP_Set               ((uint32_t)0x00000007)

/* ADC JDRx registers offset */
#define JDR_Offset                  ((uint8_t)0x28)

/* ADC1 DR register base address */
#define DR_ADDRESS                  ((uint32_t)0x4001244C)

/**
  * @}
  */

/** @defgroup ADC_Private_Macros
  * @{
  */

/**
  * @}
  */

/** @defgroup ADC_Private_Variables
  * @{
  */

/**
  * @}
  */

/** @defgroup ADC_Private_FunctionPrototypes
  * @{
  */

/**
  * @}
  */

/** @defgroup ADC_Private_Functions
  * @{
  */

/**
  * @brief  Deinitializes the ADCx peripheral registers to their default reset values.
  * @param  ADCx: where x can be 1, 2 or 3 to select the ADC peripheral.
  * @retval None
  */
void ADC_DeInit(ADC_TypeDef* ADCx)
{
  /* Check the parameters */
  assert_param(IS_ADC_ALL_PERIPH(ADCx));
  
  if (ADCx == ADC1)
  {
    /* Enable ADC1 reset state */
    RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC1, ENABLE);
    /* Release ADC1 from reset state */
    RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC1, DISABLE);
  }
  else if (ADCx == ADC2)
  {
    /* Enable ADC2 reset state */
    RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC2, ENABLE);
    /* Release ADC2 from reset state */
    RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC2, DISABLE);
  }
  else
  {
    if (ADCx == ADC3)
    {
      /* Enable ADC3 reset state */
      RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC3, ENABLE);
      /* Release ADC3 from reset state */
      RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC3, DISABLE);
    }
  }
}

/**
  * @brief  Initializes the ADCx peripheral according to the specified parameters
  *   in the ADC_InitStruct.
  * @param  ADCx: where x can be 1, 2 or 3 to select the ADC peripheral.
  * @param  ADC_InitStruct: pointer to an ADC_InitTypeDef structure that contains
  *   the configuration information for the specified ADC peripheral.
  * @retval None
  */
void ADC_Init(ADC_TypeDef* ADCx, ADC_InitTypeDef* ADC_InitStruct)
{
  uint32_t tmpreg1 = 0;
  uint8_t tmpreg2 = 0;
  /* Check the parameters */
  assert_param(IS_ADC_ALL_PERIPH(ADCx));
  assert_param(IS_ADC_MODE(ADC_InitStruct->ADC_Mode));
  assert_param(IS_FUNCTIONAL_STATE(ADC_InitStruct->ADC_ScanConvMode));
  assert_param(IS_FUNCTIONAL_STATE(ADC_InitStruct->ADC_ContinuousConvMode));
  assert_param(IS_ADC_EXT_TRIG(ADC_InitStruct->ADC_ExternalTrigConv));   
  assert_param(IS_ADC_DATA_ALIGN(ADC_InitStruct->ADC_DataAlign)); 
  assert_param(IS_ADC_REGULAR_LENGTH(ADC_InitStruct->ADC_NbrOfChannel));

  /*---------------------------- ADCx CR1 Configuration -----------------*/
  /* Get the ADCx CR1 value */
  tmpreg1 = ADCx->CR1;
  /* Clear DUALMOD and SCAN bits */
  tmpreg1 &= CR1_CLEAR_Mask;
  /* Configure ADCx: Dual mode and scan conversion mode */
  /* Set DUALMOD bits according to ADC_Mode value */
  /* Set SCAN bit according to ADC_ScanConvMode value */
  tmpreg1 |= (uint32_t)(ADC_InitStruct->ADC_Mode | ((uint32_t)ADC_InitStruct->ADC_ScanConvMode << 8));
  /* Write to ADCx CR1 */
  ADCx->CR1 = tmpreg1;

  /*---------------------------- ADCx CR2 Configuration -----------------*/
  /* Get the ADCx CR2 value */
  tmpreg1 = ADCx->CR2;
  /* Clear CONT, ALIGN and EXTSEL bits */
  tmpreg1 &= CR2_CLEAR_Mask;
  /* Configure ADCx: external trigger event and continuous conversion mode */
  /* Set ALIGN bit according to ADC_DataAlign value */
  /* Set EXTSEL bits according to ADC_ExternalTrigConv value */
  /* Set CONT bit according to ADC_ContinuousConvMode value */
  tmpreg1 |= (uint32_t)(ADC_InitStruct->ADC_DataAlign | ADC_InitStruct->ADC_ExternalTrigConv |
            ((uint32_t)ADC_InitStruct->ADC_ContinuousConvMode << 1));
  /* Write to ADCx CR2 */
  ADCx->CR2 = tmpreg1;

  /*---------------------------- ADCx SQR1 Configuration -----------------*/
  /* Get the ADCx SQR1 value */
  tmpreg1 = ADCx->SQR1;
  /* Clear L bits */
  tmpreg1 &= SQR1_CLEAR_Mask;
  /* Configure ADCx: regular channel sequence length */
  /* Set L bits according to ADC_NbrOfChannel value */
  tmpreg2 |= (uint8_t) (ADC_InitStruct->ADC_NbrOfChannel - (uint8_t)1);
  tmpreg1 |= (uint32_t)tmpreg2 << 20;
  /* Write to ADCx SQR1 */
  ADCx->SQR1 = tmpreg1;
}

/**
  * @brief  Fills each ADC_InitStruct member with its default value.
  * @param  ADC_InitStruct : pointer to an ADC_InitTypeDef structure which will be initialized.
  * @retval None
  */
void ADC_StructInit(ADC_InitTypeDef* ADC_InitStruct)
{
  /* Reset ADC init structure parameters values */
  /* Initialize the ADC_Mode member */
  ADC_InitStruct->ADC_Mode = ADC_Mode_Independent;
  /* initialize the ADC_ScanConvMode member */
  ADC_InitStruct->ADC_ScanConvMode = DISABLE;
  /* Initialize the ADC_ContinuousConvMode member */
  ADC_InitStruct->ADC_ContinuousConvMode = DISABLE;
  /* Initialize the ADC_ExternalTrigConv member */
  ADC_InitStruct->ADC_ExternalTrigConv = ADC_ExternalTrigConv_T1_CC1;
  /* Initialize the ADC_DataAlign member */
  ADC_InitStruct->ADC_DataAlign = ADC_DataAlign_Right;
  /* Initialize the ADC_NbrOfChannel member */
  ADC_InitStruct->ADC_NbrOfChannel = 1;
}

/**
  * @brief  Enables or disables the specified ADC peripheral.
  * @param  ADCx: where x can be 1, 2 or 3 to select the ADC peripheral.
  * @param  NewState: new state of the ADCx peripheral.
  *   This parameter can be: ENABLE or DISABLE.
  * @retval None
  */
void ADC_Cmd(ADC_TypeDef* ADCx, FunctionalState NewState)
{
  /* Check the parameters */
  assert_param(IS_ADC_ALL_PERIPH(ADCx));
  assert_param(IS_FUNCTIONAL_STATE(NewState));
  if (NewState != DISABLE)
  {
    /* Set the ADON bit to wake up the ADC from power down mode */
    ADCx->CR2 |= CR2_ADON_Set;
  }
  else
  {
    /* Disable the selected ADC peripheral */
    ADCx->CR2 &= CR2_ADON_Reset;
  }
}

/**
  * @brief  Enables or disables the specified ADC DMA request.
  * @param  ADCx: where x can be 1 or 3 to select the ADC peripheral.
  *   Note: ADC2 hasn't a DMA capability.
  * @param  NewState: new state of the selected ADC DMA transfer.
  *   This parameter can be: ENABLE or DISABLE.
  * @retval None
  */
void ADC_DMACmd(ADC_TypeDef* ADCx, FunctionalState NewState)
{
  /* Check the parameters */
  assert_param(IS_ADC_DMA_PERIPH(ADCx));
  assert_param(IS_FUNCTIONAL_STATE(NewState));

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美人xxxx| 精品久久一区二区三区| 久久99在线观看| 一区二区三区中文字幕在线观看| 精品国产乱码久久久久久老虎| 一本大道久久a久久综合| 黄色资源网久久资源365| 亚洲成av人片一区二区三区| 国产精品久久久久精k8| 日韩亚洲欧美一区| 欧美日韩视频第一区| 在线亚洲欧美专区二区| 成人美女在线视频| 国内国产精品久久| 男人的天堂久久精品| 午夜视频在线观看一区二区三区| 亚洲同性同志一二三专区| 国产午夜精品久久久久久久 | 777亚洲妇女| 欧美在线观看视频在线| av午夜精品一区二区三区| 国产**成人网毛片九色| 国模娜娜一区二区三区| 捆绑调教美女网站视频一区| 日韩精品一二区| 日韩激情在线观看| 午夜电影一区二区三区| 日韩电影免费在线看| 亚洲国产成人高清精品| 亚洲成人福利片| 亚洲国产视频网站| 亚洲h在线观看| 日日夜夜免费精品| 午夜婷婷国产麻豆精品| 首页欧美精品中文字幕| 日日夜夜精品视频免费| 天堂蜜桃91精品| 日本vs亚洲vs韩国一区三区二区| 日本vs亚洲vs韩国一区三区二区| 日韩精品一级中文字幕精品视频免费观看 | 狠狠色狠狠色综合系列| 极品美女销魂一区二区三区免费| 狠狠色狠狠色综合日日91app| 黄色小说综合网站| 福利一区二区在线| 91碰在线视频| 欧洲精品一区二区三区在线观看| 欧美日韩午夜影院| 精品欧美乱码久久久久久| 久久久国产综合精品女国产盗摄| 国产日韩欧美高清在线| 中文字幕一区二区三区乱码在线 | 中文字幕中文在线不卡住| 亚洲天天做日日做天天谢日日欢| 亚洲欧美成人一区二区三区| 一区二区三区.www| 日本不卡一二三| 国精产品一区一区三区mba视频| 国产成人一级电影| 91在线国产福利| 欧美久久婷婷综合色| 精品免费国产一区二区三区四区| 国产无遮挡一区二区三区毛片日本| 国产精品高潮呻吟| 亚洲国产毛片aaaaa无费看| 奇米色777欧美一区二区| 国产成人欧美日韩在线电影| 色婷婷亚洲一区二区三区| 欧美一二三区在线观看| 日本一区二区久久| 午夜久久久久久| 国产伦理精品不卡| 色8久久人人97超碰香蕉987| 欧美不卡在线视频| 一区在线中文字幕| 日本成人在线电影网| 成人h动漫精品一区二| 3751色影院一区二区三区| 国产欧美日韩中文久久| 亚洲高清免费一级二级三级| 国产精品18久久久久久久久久久久| 91免费看视频| 日韩亚洲欧美中文三级| 亚洲欧美欧美一区二区三区| 久久精品国产免费看久久精品| 97精品视频在线观看自产线路二| 欧美一区二区成人| 国产精品夫妻自拍| 韩国av一区二区三区| 欧美自拍偷拍午夜视频| 国产午夜精品久久| 蜜臀久久99精品久久久久久9 | 奇米精品一区二区三区在线观看| 成人综合婷婷国产精品久久| 91精品在线麻豆| 亚洲欧美另类在线| 国产一区二区主播在线| 91麻豆精品国产自产在线观看一区| 国产精品理论在线观看| 国产一区999| 日韩一区二区三区视频| 亚洲成a人片在线不卡一二三区| 不卡的电影网站| 国产亚洲精品超碰| 精品一区二区在线观看| 欧美日本不卡视频| 一区二区国产视频| 91色.com| 国产精品国产三级国产普通话99| 国内成人自拍视频| 精品久久久久久久人人人人传媒| 日韩 欧美一区二区三区| 欧美在线不卡一区| 亚洲免费观看高清完整版在线观看熊| 国产精品一区专区| 制服丝袜亚洲精品中文字幕| 亚洲一二三区视频在线观看| 91蜜桃网址入口| 国产精品久久久久影院老司| 国产一区二区三区| 精品福利在线导航| 美女任你摸久久| 日韩精品一区二区三区蜜臀 | 国产精品久久久久影院| 国产a精品视频| 国产欧美日韩麻豆91| 国产成人综合在线播放| 欧美高清在线视频| 99天天综合性| 亚洲美女视频一区| 欧美综合色免费| 亚洲国产精品一区二区www在线| 色一情一伦一子一伦一区| 亚洲乱码国产乱码精品精可以看 | 美女网站一区二区| 日韩精品一区二区三区视频 | 一区二区成人在线视频| 欧美自拍丝袜亚洲| 日韩一区精品视频| 欧美大白屁股肥臀xxxxxx| 精品一区二区三区视频| 国产日韩成人精品| 99视频一区二区| 亚洲一区在线观看视频| 欧美二区乱c少妇| 国内国产精品久久| 国产精品不卡在线观看| 在线亚洲人成电影网站色www| 亚洲国产一区视频| 日韩女优视频免费观看| 国产成人亚洲精品青草天美| 亚洲欧洲在线观看av| 在线亚洲精品福利网址导航| 日韩高清欧美激情| 久久久另类综合| 一本一道综合狠狠老| 日韩国产一区二| 国产欧美日韩激情| 色屁屁一区二区| 另类的小说在线视频另类成人小视频在线 | 国产成人h网站| 亚洲三级在线看| 91麻豆精品国产自产在线 | 国产激情一区二区三区四区| 国产精品乱码一区二区三区软件| 色香蕉久久蜜桃| 久久精品72免费观看| 久久精品视频免费| 色94色欧美sute亚洲线路一久 | 国产精品久久久久aaaa| 欧美视频完全免费看| 久久99国产精品免费| 中文字幕中文字幕一区二区| 欧美日韩一级视频| 国产成人av一区二区三区在线观看| 一区二区三区免费观看| 精品乱码亚洲一区二区不卡| 99久久精品免费看国产| 日韩电影在线一区二区三区| 日本一区二区三区电影| 555夜色666亚洲国产免| 99免费精品在线| 久久国产剧场电影| 亚洲精品成人在线| 久久嫩草精品久久久久| 欧美日韩在线直播| 成人sese在线| 激情图区综合网| 亚洲成人免费电影| 综合中文字幕亚洲| 久久久久国产一区二区三区四区 | 国产精品美女久久久久aⅴ| 日韩三级高清在线| 91福利国产成人精品照片| 亚洲在线视频一区| 综合欧美亚洲日本| 国产欧美一区二区精品忘忧草| 日韩精品一区二| 欧洲精品在线观看| 成人av小说网|