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

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

?? stm32l1xx_dac.c

?? VS1003_MP3_SPI_SDHC_FAT32
?? C
?? 第 1 頁 / 共 2 頁
字號:
  *     @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.
  * @note 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 value:
  *     @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 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's 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 2012 STMicroelectronics *****END OF FILE****/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩成人一区二区三区在线观看| 一区二区三区国产| 国产一区二区三区蝌蚪| 久久精品水蜜桃av综合天堂| 国产成人在线免费| 中文字幕一区二区三区精华液 | 另类小说综合欧美亚洲| 精品国产一区二区亚洲人成毛片 | 亚洲美女屁股眼交| 欧美视频在线观看一区| 日韩不卡一区二区三区| 国产亚洲一本大道中文在线| kk眼镜猥琐国模调教系列一区二区| 亚洲人成7777| 欧美一区二区在线观看| 国产综合久久久久久久久久久久| 国产精品午夜在线观看| 欧美亚洲动漫制服丝袜| 精品一区二区久久| 亚洲欧洲性图库| 91精品久久久久久久久99蜜臂| 激情五月激情综合网| 1区2区3区欧美| 欧美tickling网站挠脚心| 成人精品在线视频观看| 性欧美大战久久久久久久久| 国产人妖乱国产精品人妖| 91在线免费视频观看| 奇米精品一区二区三区在线观看| 久久精品视频一区| 在线播放日韩导航| 成人免费视频一区二区| 日产精品久久久久久久性色| 中文字幕日本不卡| 亚洲精品一区二区在线观看| 色久优优欧美色久优优| 国产一区二区免费视频| 夜夜夜精品看看| 久久精品视频一区二区三区| 欧美电影一区二区| 91色视频在线| 激情综合色综合久久| 午夜私人影院久久久久| 国产精品国产三级国产aⅴ中文 | 欧美福利一区二区| www.久久久久久久久| 国产制服丝袜一区| 日韩高清中文字幕一区| 亚洲麻豆国产自偷在线| 久久九九99视频| 日韩欧美国产不卡| 欧美午夜片在线观看| 99久久亚洲一区二区三区青草| 精品系列免费在线观看| 首页国产丝袜综合| 一区二区三区欧美激情| 中文欧美字幕免费| 久久精品免视看| 亚洲精品在线三区| 精品国产在天天线2019| 欧美一卡二卡在线观看| 欧美日韩黄视频| 色吊一区二区三区| 91久久精品一区二区三| 色哟哟欧美精品| 99视频精品在线| 99久久99久久综合| 99精品欧美一区二区三区小说| 成人免费电影视频| 成人性生交大片免费看视频在线| 国产一区二区调教| 国产精品自产自拍| 国产福利一区在线观看| 国产精品99久久久久久有的能看| 国产一区二区在线电影| 国产综合久久久久久鬼色| 狠狠色狠狠色合久久伊人| 国产一区在线视频| 国产91露脸合集magnet| 成人免费视频免费观看| 99在线热播精品免费| 一本色道久久综合亚洲91| 一本色道久久综合精品竹菊 | 3d动漫精品啪啪| 91精品国产欧美一区二区成人| 日韩一区二区三区四区| 2022国产精品视频| 欧美精彩视频一区二区三区| 中文字幕的久久| 亚洲精品美国一| 午夜亚洲国产au精品一区二区| 欧美aaaaaa午夜精品| 国产麻豆精品久久一二三| 成人黄色777网| 欧美色偷偷大香| 日韩欧美电影一二三| 久久久www成人免费无遮挡大片| 久久蜜桃香蕉精品一区二区三区| 中文字幕精品在线不卡| 亚洲精品大片www| 日本一区中文字幕| 成人性生交大片免费看中文网站| 91蜜桃在线观看| 91麻豆精品国产自产在线 | 精一区二区三区| 成人国产精品免费| 欧美日韩你懂得| 国产欧美一区视频| 亚洲一区二区三区国产| 免费看欧美女人艹b| 成人动漫av在线| 欧美疯狂性受xxxxx喷水图片| 欧美变态tickling挠脚心| 成人免费视频在线观看| 日韩av在线播放中文字幕| 国产成人午夜精品5599| 欧美性猛交一区二区三区精品 | 欧美激情一二三区| 亚洲国产精品一区二区久久恐怖片 | 欧美一级理论片| 国产精品污www在线观看| 亚洲va韩国va欧美va精品| 国产另类ts人妖一区二区| 91麻豆免费观看| 26uuu另类欧美亚洲曰本| 亚洲国产人成综合网站| 成人永久aaa| 精品国产凹凸成av人网站| 一区二区三区中文字幕精品精品| 激情伊人五月天久久综合| 欧美三日本三级三级在线播放| 久久亚洲影视婷婷| 三级不卡在线观看| 91激情五月电影| 国产精品妹子av| 国内不卡的二区三区中文字幕 | 久久成人18免费观看| 欧美在线观看视频一区二区三区| 久久久电影一区二区三区| 日韩电影在线观看一区| 在线看国产日韩| 国产精品久久久久三级| 国产美女视频一区| 日韩欧美国产综合一区 | 一二三区精品福利视频| 不卡一区二区在线| 中文字幕欧美日韩一区| 精品一区二区三区在线播放视频 | 欧美r级电影在线观看| 亚洲国产成人高清精品| 在线一区二区视频| 玉米视频成人免费看| 99久久久免费精品国产一区二区 | 久久亚区不卡日本| 琪琪久久久久日韩精品| 91精品国产91久久综合桃花| 婷婷成人综合网| 欧美久久久久久蜜桃| 视频一区二区欧美| 在线综合视频播放| 美女在线一区二区| 日韩免费在线观看| 久久99精品一区二区三区| 日韩欧美国产不卡| 九一久久久久久| 久久久久久综合| 成人免费高清视频| 亚洲视频在线一区观看| 91在线播放网址| 亚洲美女免费视频| 欧美日韩在线播放一区| 亚州成人在线电影| 91精品国产91久久综合桃花| 久久国产欧美日韩精品| 久久久国产午夜精品 | 欧美日韩成人在线一区| 天天做天天摸天天爽国产一区| 91精品国产品国语在线不卡| 久久国产精品99久久人人澡| 国产亚洲精品福利| 91在线你懂得| 午夜免费欧美电影| 亚洲精品在线电影| fc2成人免费人成在线观看播放 | 日韩制服丝袜av| 日韩美女主播在线视频一区二区三区| 久久99热99| 国产精品久久久久久久第一福利| 99精品视频在线免费观看| 亚洲国产成人av好男人在线观看| 91精品国产综合久久久久久| 国产精品一二三四| 亚洲三级免费观看| 欧美日韩国产片| 国产在线一区二区综合免费视频| 中文成人综合网| 欧美日本在线播放| 国产一区二区三区国产| 亚洲激情在线播放| 精品免费一区二区三区|