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

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

?? stm32l1xx_dac.c

?? STM32+Grlib
?? C
?? 第 1 頁 / 共 2 頁
字號:
  * @brief  Set the specified data holding register value for DAC channel1.
  * @param  DAC_Align: Specifies the data alignment for DAC channel1.
  *   This parameter can be one of the following values:
  *     @arg DAC_Align_8b_R: 8bit right data alignment selected
  *     @arg DAC_Align_12b_L: 12bit left data alignment selected
  *     @arg DAC_Align_12b_R: 12bit right data alignment selected
  * @param  Data : Data to be loaded in the selected data holding register.
  * @retval None
  */
void DAC_SetChannel1Data(uint32_t DAC_Align, uint16_t Data)
{  
  __IO uint32_t tmp = 0;
  
  /* Check the parameters */
  assert_param(IS_DAC_ALIGN(DAC_Align));
  assert_param(IS_DAC_DATA(Data));
  
  tmp = (uint32_t)DAC_BASE; 
  tmp += DHR12R1_OFFSET + DAC_Align;

  /* Set the DAC channel1 selected data holding register */
  *(__IO uint32_t *) tmp = Data;
}

/**
  * @brief  Set the specified data holding register value for DAC channel2.
  * @param  DAC_Align: Specifies the data alignment for DAC channel2.
  *   This parameter can be one of the following values:
  *     @arg DAC_Align_8b_R: 8bit right data alignment selected
  *     @arg DAC_Align_12b_L: 12bit left data alignment selected
  *     @arg DAC_Align_12b_R: 12bit right data alignment selected
  * @param  Data : Data to be loaded in the selected data holding register.
  * @retval None
  */
void DAC_SetChannel2Data(uint32_t DAC_Align, uint16_t Data)
{
  __IO uint32_t tmp = 0;

  /* Check the parameters */
  assert_param(IS_DAC_ALIGN(DAC_Align));
  assert_param(IS_DAC_DATA(Data));
  
  tmp = (uint32_t)DAC_BASE;
  tmp += DHR12R2_OFFSET + DAC_Align;

  /* Set the DAC channel2 selected data holding register */
  *(__IO uint32_t *)tmp = Data;
}

/**
  * @brief  Set the specified data holding register value for dual channel DAC.
  * @param  DAC_Align: Specifies the data alignment for dual channel DAC.
  *   This parameter can be one of the following values:
  *     @arg DAC_Align_8b_R: 8bit right data alignment selected
  *     @arg DAC_Align_12b_L: 12bit left data alignment selected
  *     @arg DAC_Align_12b_R: 12bit right data alignment selected
  * @param  Data2: Data for DAC Channel2 to be loaded in the selected data 
  *         holding register.
  * @param  Data1: Data for DAC Channel1 to be loaded in the selected data 
  *         holding register.
  * @note In dual mode, a unique register access is required to write in both
  *       DAC channels at the same time.
  * @retval None
  */
void DAC_SetDualChannelData(uint32_t DAC_Align, uint16_t Data2, uint16_t Data1)
{
  uint32_t data = 0, tmp = 0;
  
  /* Check the parameters */
  assert_param(IS_DAC_ALIGN(DAC_Align));
  assert_param(IS_DAC_DATA(Data1));
  assert_param(IS_DAC_DATA(Data2));
  
  /* Calculate and set dual DAC data holding register value */
  if (DAC_Align == DAC_Align_8b_R)
  {
    data = ((uint32_t)Data2 << 8) | Data1; 
  }
  else
  {
    data = ((uint32_t)Data2 << 16) | Data1;
  }
  
  tmp = (uint32_t)DAC_BASE;
  tmp += DHR12RD_OFFSET + DAC_Align;

  /* Set the dual DAC selected data holding register */
  *(__IO uint32_t *)tmp = data;
}

/**
  * @brief  Returns the last data output value of the selected DAC channel.
  * @param  DAC_Channel: the selected DAC channel. 
  *   This parameter can be one of the following values:
  *     @arg DAC_Channel_1: DAC Channel1 selected
  *     @arg DAC_Channel_2: DAC Channel2 selected
  * @retval The selected DAC channel data output value.
  */
uint16_t DAC_GetDataOutputValue(uint32_t DAC_Channel)
{
  __IO uint32_t tmp = 0;
  
  /* Check the parameters */
  assert_param(IS_DAC_CHANNEL(DAC_Channel));
  
  tmp = (uint32_t) DAC_BASE ;
  tmp += DOR_OFFSET + ((uint32_t)DAC_Channel >> 2);
  
  /* Returns the DAC channel data output register value */
  return (uint16_t) (*(__IO uint32_t*) tmp);
}

/**
  * @}
  */

/** @defgroup DAC_Group2 DMA management functions
 *  @brief   DMA management functions
 *
@verbatim   
 ===============================================================================
                          DMA management functions
 ===============================================================================  

@endverbatim
  * @{
  */

/**
  * @brief  Enables or disables the specified DAC channel DMA request.
  *         When enabled DMA1 is generated when an external trigger (EXTI Line9,
  *         TIM2, TIM4, TIM6, TIM7 or TIM9  but not a software trigger) occurs
  * @param  DAC_Channel: the selected DAC channel.
  *   This parameter can be one of the following values:
  *     @arg DAC_Channel_1: DAC Channel1 selected
  *     @arg DAC_Channel_2: DAC Channel2 selected
  * @param  NewState: new state of the selected DAC channel DMA request.
  *   This parameter can be: ENABLE or DISABLE.
  *  The DAC channel1 (channel2) is mapped on DMA1 channel3 (channel4) which 
  *  must be already configured. 
  * @retval None
  */
void DAC_DMACmd(uint32_t DAC_Channel, FunctionalState NewState)
{
  /* Check the parameters */
  assert_param(IS_DAC_CHANNEL(DAC_Channel));
  assert_param(IS_FUNCTIONAL_STATE(NewState));

  if (NewState != DISABLE)
  {
    /* Enable the selected DAC channel DMA request */
    DAC->CR |= (DAC_CR_DMAEN1 << DAC_Channel);
  }
  else
  {
    /* Disable the selected DAC channel DMA request */
    DAC->CR &= (~(DAC_CR_DMAEN1 << DAC_Channel));
  }
}

/**
  * @}
  */

/** @defgroup DAC_Group3 Interrupts and flags management functions
 *  @brief   Interrupts and flags management functions
 *
@verbatim   
 ===============================================================================
                   Interrupts and flags management functions
 ===============================================================================  

@endverbatim
  * @{
  */

/**
  * @brief  Enables or disables the specified DAC interrupts.
  * @param  DAC_Channel: the selected DAC channel. 
  *   This parameter can be one of the following values:
  *     @arg DAC_Channel_1: DAC Channel1 selected
  *     @arg DAC_Channel_2: DAC Channel2 selected
  * @param  DAC_IT: specifies the DAC interrupt sources to be enabled or disabled. 
  *   This parameter can be the following values:
  *     @arg DAC_IT_DMAUDR: DMA underrun interrupt mask
  * @note The DMA underrun occurs when a second external trigger arrives before
  *       the acknowledgement for the first external trigger is received (first request).
  * @param  NewState: new state of the specified DAC interrupts.
  *   This parameter can be: ENABLE or DISABLE.
  * @retval None
  */ 
void DAC_ITConfig(uint32_t DAC_Channel, uint32_t DAC_IT, FunctionalState NewState)  
{
  /* Check the parameters */
  assert_param(IS_DAC_CHANNEL(DAC_Channel));
  assert_param(IS_FUNCTIONAL_STATE(NewState));
  assert_param(IS_DAC_IT(DAC_IT)); 

  if (NewState != DISABLE)
  {
    /* Enable the selected DAC interrupts */
    DAC->CR |=  (DAC_IT << DAC_Channel);
  }
  else
  {
    /* Disable the selected DAC interrupts */
    DAC->CR &= (~(uint32_t)(DAC_IT << DAC_Channel));
  }
}

/**
  * @brief  Checks whether the specified DAC flag is set or not.
  * @param  DAC_Channel: thee selected DAC channel. 
  *   This parameter can be one of the following values:
  *     @arg DAC_Channel_1: DAC Channel1 selected
  *     @arg DAC_Channel_2: DAC Channel2 selected
  * @param  DAC_FLAG: specifies the flag to check. 
  *   This parameter can be only of the following value:
  *     @arg DAC_FLAG_DMAUDR: DMA underrun flag
  * @note The DMA underrun occurs when a second external trigger arrives before
  *       the acknowledgement for the first external trigger is received (first request).
  * @retval The new state of DAC_FLAG (SET or RESET).
  */
FlagStatus DAC_GetFlagStatus(uint32_t DAC_Channel, uint32_t DAC_FLAG)
{
  FlagStatus bitstatus = RESET;
  /* Check the parameters */
  assert_param(IS_DAC_CHANNEL(DAC_Channel));
  assert_param(IS_DAC_FLAG(DAC_FLAG));

  /* Check the status of the specified DAC flag */
  if ((DAC->SR & (DAC_FLAG << DAC_Channel)) != (uint8_t)RESET)
  {
    /* DAC_FLAG is set */
    bitstatus = SET;
  }
  else
  {
    /* DAC_FLAG is reset */
    bitstatus = RESET;
  }
  /* Return the DAC_FLAG status */
  return  bitstatus;
}

/**
  * @brief  Clears the DAC channel's pending flags.
  * @param  DAC_Channel: the selected DAC channel. 
  *   This parameter can be one of the following values:
  *     @arg DAC_Channel_1: DAC Channel1 selected
  *     @arg DAC_Channel_2: DAC Channel2 selected
  * @param  DAC_FLAG: specifies the flag to clear. 
  *   This parameter can be of the following value:
  *     @arg DAC_FLAG_DMAUDR: DMA underrun flag                          
  * @retval None
  */
void DAC_ClearFlag(uint32_t DAC_Channel, uint32_t DAC_FLAG)
{
  /* Check the parameters */
  assert_param(IS_DAC_CHANNEL(DAC_Channel));
  assert_param(IS_DAC_FLAG(DAC_FLAG));

  /* Clear the selected DAC flags */
  DAC->SR = (DAC_FLAG << DAC_Channel);
}

/**
  * @brief  Checks whether the specified DAC interrupt has occurred or not.
  * @param  DAC_Channel: the selected DAC channel. 
  *   This parameter can be one of the following values:
  *     @arg DAC_Channel_1: DAC Channel1 selected
  *     @arg DAC_Channel_2: DAC Channel2 selected
  * @param  DAC_IT: specifies the DAC interrupt source to check. 
  *   This parameter can be the following values:
  *     @arg DAC_IT_DMAUDR: DMA underrun interrupt mask
  * @note The DMA underrun occurs when a second external trigger arrives before
  *       the acknowledgement for the first external trigger is received (first request).
  * @retval The new state of DAC_IT (SET or RESET).
  */
ITStatus DAC_GetITStatus(uint32_t DAC_Channel, uint32_t DAC_IT)
{
  ITStatus bitstatus = RESET;
  uint32_t enablestatus = 0;
  
  /* Check the parameters */
  assert_param(IS_DAC_CHANNEL(DAC_Channel));
  assert_param(IS_DAC_IT(DAC_IT));

  /* Get the DAC_IT enable bit status */
  enablestatus = (DAC->CR & (DAC_IT << DAC_Channel)) ;
  
  /* Check the status of the specified DAC interrupt */
  if (((DAC->SR & (DAC_IT << DAC_Channel)) != (uint32_t)RESET) && enablestatus)
  {
    /* DAC_IT is set */
    bitstatus = SET;
  }
  else
  {
    /* DAC_IT is reset */
    bitstatus = RESET;
  }
  /* Return the DAC_IT status */
  return  bitstatus;
}

/**
  * @brief  Clears the DAC channel抯 interrupt pending bits.
  * @param  DAC_Channel: the selected DAC channel. 
  *   This parameter can be one of the following values:
  *     @arg DAC_Channel_1: DAC Channel1 selected
  *     @arg DAC_Channel_2: DAC Channel2 selected
  * @param  DAC_IT: specifies the DAC interrupt pending bit to clear.
  *   This parameter can be the following values:
  *     @arg DAC_IT_DMAUDR: DMA underrun interrupt mask                         
  * @retval None
  */
void DAC_ClearITPendingBit(uint32_t DAC_Channel, uint32_t DAC_IT)
{
  /* Check the parameters */
  assert_param(IS_DAC_CHANNEL(DAC_Channel));
  assert_param(IS_DAC_IT(DAC_IT)); 

  /* Clear the selected DAC interrupt pending bits */
  DAC->SR = (DAC_IT << DAC_Channel);
}

/**
  * @}
  */

/**
  * @}
  */ 

/**
  * @}
  */ 

/**
  * @}
  */ 

/******************* (C) COPYRIGHT 2010 STMicroelectronics *****END OF FILE****/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
va亚洲va日韩不卡在线观看| 午夜精品一区二区三区免费视频| 在线观看日韩毛片| 精品一区二区在线播放| 亚洲欧美电影院| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 国产色综合一区| 5月丁香婷婷综合| 99久久精品国产一区| 久久草av在线| 亚洲成人综合网站| 中文字幕佐山爱一区二区免费| 日韩一级片网址| 精品视频在线免费看| 成人h动漫精品一区二| 美女一区二区视频| 亚洲va欧美va天堂v国产综合| 国产精品成人免费| 久久久国产精品午夜一区ai换脸| 日韩一区二区三免费高清| 91美女在线看| 99精品视频中文字幕| 国产精品自拍网站| 国内一区二区视频| 秋霞av亚洲一区二区三| 天使萌一区二区三区免费观看| 亚洲欧美激情插| 亚洲精品乱码久久久久久| 中文字幕在线播放不卡一区| 国产精品视频第一区| 久久女同性恋中文字幕| 日韩欧美一级精品久久| 制服丝袜亚洲精品中文字幕| 欧美日韩在线精品一区二区三区激情| a4yy欧美一区二区三区| 成人午夜短视频| 国产夫妻精品视频| 成人综合日日夜夜| 成人av电影免费在线播放| 成人午夜免费av| 91在线视频免费观看| 99久久精品国产精品久久| 波多野结衣亚洲一区| yourporn久久国产精品| 99精品久久免费看蜜臀剧情介绍| 不卡的电影网站| 91在线一区二区三区| 在线观看中文字幕不卡| 欧美日韩免费不卡视频一区二区三区 | 国产拍欧美日韩视频二区| 国产亚洲精品久| 中文字幕一区二区视频| 亚洲欧美日韩综合aⅴ视频| 亚洲精品一二三四区| 亚洲成av人在线观看| 全国精品久久少妇| 国产一区二区三区不卡在线观看 | 91丝袜国产在线播放| 色成年激情久久综合| 欧美日韩一卡二卡| 欧美xxxx老人做受| 国产精品免费久久| 亚洲一区自拍偷拍| 蜜臀av性久久久久蜜臀aⅴ四虎 | 亚洲最大成人综合| 天堂影院一区二区| 国产乱码字幕精品高清av| 北岛玲一区二区三区四区| 在线观看一区不卡| 日韩女优电影在线观看| 欧美国产精品v| 五月婷婷欧美视频| 国产美女在线精品| 色先锋aa成人| 日韩精品一区二区三区在线播放| 中文一区一区三区高中清不卡| 夜夜嗨av一区二区三区网页| 美日韩一区二区| 99vv1com这只有精品| 欧美精品丝袜中出| 国产精品情趣视频| 丝袜美腿高跟呻吟高潮一区| 风间由美一区二区av101| 在线看国产一区| 久久嫩草精品久久久精品| 综合av第一页| 麻豆精品一区二区| 色狠狠桃花综合| 久久久不卡网国产精品一区| 亚洲在线免费播放| 福利一区在线观看| 日韩午夜三级在线| 亚洲精品成人少妇| 国产美女精品一区二区三区| 欧美午夜精品电影| 亚洲国产精品精华液2区45| 天天综合天天综合色| 成人白浆超碰人人人人| 日韩欧美亚洲国产精品字幕久久久| 亚洲日韩欧美一区二区在线| 国产在线看一区| 欧美精品电影在线播放| 亚洲女性喷水在线观看一区| 国产黄色精品视频| 日韩一区二区精品| 亚洲一区免费视频| 不卡一区二区在线| 国产色产综合产在线视频| 日韩精品电影在线观看| 91精品办公室少妇高潮对白| 国产清纯美女被跳蛋高潮一区二区久久w| 亚洲国产乱码最新视频 | 中文字幕五月欧美| 久久99精品国产.久久久久久| 色偷偷成人一区二区三区91| 欧美国产在线观看| 国产麻豆精品久久一二三| 欧美va亚洲va香蕉在线| 日日摸夜夜添夜夜添精品视频| 在线视频观看一区| 亚洲精品中文在线观看| 91玉足脚交白嫩脚丫在线播放| 久久久高清一区二区三区| 国产一区二区毛片| 久久影院电视剧免费观看| 激情偷乱视频一区二区三区| 日韩欧美黄色影院| 青娱乐精品在线视频| 欧美一区二区三区视频免费| 亚洲gay无套男同| 欧美日韩亚洲综合一区| 亚洲国产精品嫩草影院| 欧美在线观看视频在线| 一卡二卡欧美日韩| 欧美色男人天堂| 日韩精品免费视频人成| 欧美一区二区视频观看视频| 日韩极品在线观看| 欧美成人性战久久| 国产一区二区影院| 国产人伦精品一区二区| 成人精品视频网站| 1区2区3区欧美| 日本道免费精品一区二区三区| 亚洲老司机在线| 欧美日本视频在线| 日日夜夜精品视频天天综合网| 欧美大黄免费观看| 国产高清无密码一区二区三区| 欧美国产一区二区在线观看| 99re在线视频这里只有精品| 亚洲人被黑人高潮完整版| 欧洲一区在线电影| 日精品一区二区三区| 欧美v国产在线一区二区三区| 国产在线播放一区| 中文字幕亚洲电影| 欧美精品亚洲一区二区在线播放| 蜜臀av性久久久久蜜臀aⅴ流畅| 久久久蜜桃精品| 99精品黄色片免费大全| 一区二区三区波多野结衣在线观看| 欧美视频一区二区三区四区| 日本va欧美va精品发布| 精品国产乱码久久久久久浪潮 | 欧美色精品天天在线观看视频| 日韩电影在线免费| 久久久国产综合精品女国产盗摄| 91一区一区三区| 日韩av一区二区三区| 欧美激情一区二区三区蜜桃视频| 色欧美片视频在线观看在线视频| 日本亚洲欧美天堂免费| 久久久久高清精品| 欧美综合色免费| 久久99国产精品久久99果冻传媒 | 韩国v欧美v日本v亚洲v| 一色屋精品亚洲香蕉网站| 欧美色综合网站| 国产一区美女在线| 亚洲一区二区av在线| 精品久久五月天| 91久久精品一区二区三区| 久久国产福利国产秒拍| 亚洲精品免费在线观看| 久久视频一区二区| 欧洲精品一区二区| 国产电影精品久久禁18| 调教+趴+乳夹+国产+精品| 亚洲国产经典视频| 日韩欧美三级在线| 欧美亚洲一区二区在线| 国产精品一二三四区| 香蕉影视欧美成人| 亚洲手机成人高清视频| 久久这里只有精品首页| 欧美日韩成人综合在线一区二区| 成人小视频免费在线观看| 午夜精品久久久久久久久| 中文字幕制服丝袜一区二区三区|