STM32F103xB HAL User Manual
stm32f1xx_hal_dac.h
Go to the documentation of this file.
00001 /**
00002   ******************************************************************************
00003   * @file    stm32f1xx_hal_dac.h
00004   * @author  MCD Application Team
00005   * @brief   Header file of DAC HAL module.
00006   ******************************************************************************
00007   * @attention
00008   *
00009   * <h2><center>&copy; Copyright (c) 2016 STMicroelectronics.
00010   * All rights reserved.</center></h2>
00011   *
00012   * This software component is licensed by ST under BSD 3-Clause license,
00013   * the "License"; You may not use this file except in compliance with the
00014   * License. You may obtain a copy of the License at:
00015   *                        opensource.org/licenses/BSD-3-Clause
00016   *
00017   ******************************************************************************
00018   */
00019 
00020 /* Define to prevent recursive inclusion -------------------------------------*/
00021 #ifndef STM32F1xx_HAL_DAC_H
00022 #define STM32F1xx_HAL_DAC_H
00023 
00024 #ifdef __cplusplus
00025 extern "C" {
00026 #endif
00027 
00028 /** @addtogroup STM32F1xx_HAL_Driver
00029   * @{
00030   */
00031 
00032 /* Includes ------------------------------------------------------------------*/
00033 #include "stm32f1xx_hal_def.h"
00034 
00035 #if defined(DAC)
00036 
00037 /** @addtogroup DAC
00038   * @{
00039   */
00040 
00041 /* Exported types ------------------------------------------------------------*/
00042 
00043 /** @defgroup DAC_Exported_Types DAC Exported Types
00044   * @{
00045   */
00046 
00047 /**
00048   * @brief  HAL State structures definition
00049   */
00050 typedef enum
00051 {
00052   HAL_DAC_STATE_RESET             = 0x00U,  /*!< DAC not yet initialized or disabled  */
00053   HAL_DAC_STATE_READY             = 0x01U,  /*!< DAC initialized and ready for use    */
00054   HAL_DAC_STATE_BUSY              = 0x02U,  /*!< DAC internal processing is ongoing   */
00055   HAL_DAC_STATE_TIMEOUT           = 0x03U,  /*!< DAC timeout state                    */
00056   HAL_DAC_STATE_ERROR             = 0x04U   /*!< DAC error state                      */
00057 
00058 } HAL_DAC_StateTypeDef;
00059 
00060 /**
00061   * @brief  DAC handle Structure definition
00062   */
00063 #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1)
00064 typedef struct __DAC_HandleTypeDef
00065 #else
00066 typedef struct
00067 #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */
00068 {
00069   DAC_TypeDef                 *Instance;     /*!< Register base address             */
00070 
00071   __IO HAL_DAC_StateTypeDef   State;         /*!< DAC communication state           */
00072 
00073   HAL_LockTypeDef             Lock;          /*!< DAC locking object                */
00074 
00075   DMA_HandleTypeDef           *DMA_Handle1;  /*!< Pointer DMA handler for channel 1 */
00076 
00077   DMA_HandleTypeDef           *DMA_Handle2;  /*!< Pointer DMA handler for channel 2 */
00078 
00079   __IO uint32_t               ErrorCode;     /*!< DAC Error code                    */
00080 
00081 #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1)
00082   void (* ConvCpltCallbackCh1)            (struct __DAC_HandleTypeDef *hdac);
00083   void (* ConvHalfCpltCallbackCh1)        (struct __DAC_HandleTypeDef *hdac);
00084   void (* ErrorCallbackCh1)               (struct __DAC_HandleTypeDef *hdac);
00085   void (* DMAUnderrunCallbackCh1)         (struct __DAC_HandleTypeDef *hdac);
00086 
00087   void (* ConvCpltCallbackCh2)            (struct __DAC_HandleTypeDef *hdac);
00088   void (* ConvHalfCpltCallbackCh2)        (struct __DAC_HandleTypeDef *hdac);
00089   void (* ErrorCallbackCh2)               (struct __DAC_HandleTypeDef *hdac);
00090   void (* DMAUnderrunCallbackCh2)         (struct __DAC_HandleTypeDef *hdac);
00091 
00092 
00093   void (* MspInitCallback)                (struct __DAC_HandleTypeDef *hdac);
00094   void (* MspDeInitCallback)              (struct __DAC_HandleTypeDef *hdac);
00095 #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */
00096 
00097 } DAC_HandleTypeDef;
00098 
00099 /**
00100   * @brief   DAC Configuration regular Channel structure definition
00101   */
00102 typedef struct
00103 {
00104   uint32_t DAC_Trigger;                  /*!< Specifies the external trigger for the selected DAC channel.
00105                                               This parameter can be a value of @ref DAC_trigger_selection */
00106 
00107   uint32_t DAC_OutputBuffer;             /*!< Specifies whether the DAC channel output buffer is enabled or disabled.
00108                                                This parameter can be a value of @ref DAC_output_buffer */
00109 
00110 } DAC_ChannelConfTypeDef;
00111 
00112 #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1)
00113 /**
00114   * @brief  HAL DAC Callback ID enumeration definition
00115   */
00116 typedef enum
00117 {
00118   HAL_DAC_CH1_COMPLETE_CB_ID                 = 0x00U,  /*!< DAC CH1 Complete Callback ID      */
00119   HAL_DAC_CH1_HALF_COMPLETE_CB_ID            = 0x01U,  /*!< DAC CH1 half Complete Callback ID */
00120   HAL_DAC_CH1_ERROR_ID                       = 0x02U,  /*!< DAC CH1 error Callback ID         */
00121   HAL_DAC_CH1_UNDERRUN_CB_ID                 = 0x03U,  /*!< DAC CH1 underrun Callback ID      */
00122 
00123   HAL_DAC_CH2_COMPLETE_CB_ID                 = 0x04U,  /*!< DAC CH2 Complete Callback ID      */
00124   HAL_DAC_CH2_HALF_COMPLETE_CB_ID            = 0x05U,  /*!< DAC CH2 half Complete Callback ID */
00125   HAL_DAC_CH2_ERROR_ID                       = 0x06U,  /*!< DAC CH2 error Callback ID         */
00126   HAL_DAC_CH2_UNDERRUN_CB_ID                 = 0x07U,  /*!< DAC CH2 underrun Callback ID      */
00127 
00128   HAL_DAC_MSPINIT_CB_ID                      = 0x08U,  /*!< DAC MspInit Callback ID           */
00129   HAL_DAC_MSPDEINIT_CB_ID                    = 0x09U,  /*!< DAC MspDeInit Callback ID         */
00130   HAL_DAC_ALL_CB_ID                          = 0x0AU   /*!< DAC All ID                        */
00131 } HAL_DAC_CallbackIDTypeDef;
00132 
00133 /**
00134   * @brief  HAL DAC Callback pointer definition
00135   */
00136 typedef void (*pDAC_CallbackTypeDef)(DAC_HandleTypeDef *hdac);
00137 #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */
00138 
00139 /**
00140   * @}
00141   */
00142 
00143 /* Exported constants --------------------------------------------------------*/
00144 
00145 /** @defgroup DAC_Exported_Constants DAC Exported Constants
00146   * @{
00147   */
00148 
00149 /** @defgroup DAC_Error_Code DAC Error Code
00150   * @{
00151   */
00152 #define  HAL_DAC_ERROR_NONE              0x00U    /*!< No error                          */
00153 #define  HAL_DAC_ERROR_DMAUNDERRUNCH1    0x01U    /*!< DAC channel1 DMA underrun error   */
00154 #define  HAL_DAC_ERROR_DMAUNDERRUNCH2    0x02U    /*!< DAC channel2 DMA underrun error   */
00155 #define  HAL_DAC_ERROR_DMA               0x04U    /*!< DMA error                         */
00156 #define  HAL_DAC_ERROR_TIMEOUT           0x08U    /*!< Timeout error                     */
00157 #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1)
00158 #define HAL_DAC_ERROR_INVALID_CALLBACK   0x10U    /*!< Invalid callback error            */
00159 #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */
00160 
00161 /**
00162   * @}
00163   */
00164 
00165 /** @defgroup DAC_output_buffer DAC output buffer
00166   * @{
00167   */
00168 #define DAC_OUTPUTBUFFER_ENABLE            0x00000000U
00169 #define DAC_OUTPUTBUFFER_DISABLE           (DAC_CR_BOFF1)
00170 
00171 /**
00172   * @}
00173   */
00174 
00175 /** @defgroup DAC_Channel_selection DAC Channel selection
00176   * @{
00177   */
00178 #define DAC_CHANNEL_1                      0x00000000U
00179 
00180 #define DAC_CHANNEL_2                      0x00000010U
00181 
00182 /**
00183   * @}
00184   */
00185 
00186 /** @defgroup DAC_data_alignment DAC data alignment
00187   * @{
00188   */
00189 #define DAC_ALIGN_12B_R                    0x00000000U
00190 #define DAC_ALIGN_12B_L                    0x00000004U
00191 #define DAC_ALIGN_8B_R                     0x00000008U
00192 
00193 /**
00194   * @}
00195   */
00196 
00197 /** @defgroup DAC_flags_definition DAC flags definition
00198   * @{
00199   */
00200 #define DAC_FLAG_DMAUDR1                   (DAC_SR_DMAUDR1)
00201 
00202 #define DAC_FLAG_DMAUDR2                   (DAC_SR_DMAUDR2)
00203 
00204 
00205 /**
00206   * @}
00207   */
00208 
00209 /** @defgroup DAC_IT_definition  DAC IT definition
00210   * @{
00211   */
00212 #define DAC_IT_DMAUDR1                   (DAC_SR_DMAUDR1)
00213 
00214 #define DAC_IT_DMAUDR2                   (DAC_SR_DMAUDR2)
00215 
00216 
00217 /**
00218   * @}
00219   */
00220 
00221 /**
00222   * @}
00223   */
00224 
00225 /* Exported macro ------------------------------------------------------------*/
00226 
00227 /** @defgroup DAC_Exported_Macros DAC Exported Macros
00228   * @{
00229   */
00230 
00231 /** @brief Reset DAC handle state.
00232   * @param  __HANDLE__ specifies the DAC handle.
00233   * @retval None
00234   */
00235 #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1)
00236 #define __HAL_DAC_RESET_HANDLE_STATE(__HANDLE__) do {                                                        \
00237                                                       (__HANDLE__)->State             = HAL_DAC_STATE_RESET; \
00238                                                       (__HANDLE__)->MspInitCallback   = NULL;                \
00239                                                       (__HANDLE__)->MspDeInitCallback = NULL;                \
00240                                                      } while(0)
00241 #else
00242 #define __HAL_DAC_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_DAC_STATE_RESET)
00243 #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */
00244 
00245 /** @brief Enable the DAC channel.
00246   * @param  __HANDLE__ specifies the DAC handle.
00247   * @param  __DAC_Channel__ specifies the DAC channel
00248   * @retval None
00249   */
00250 #define __HAL_DAC_ENABLE(__HANDLE__, __DAC_Channel__) \
00251   ((__HANDLE__)->Instance->CR |=  (DAC_CR_EN1 << ((__DAC_Channel__) & 0x10UL)))
00252 
00253 /** @brief Disable the DAC channel.
00254   * @param  __HANDLE__ specifies the DAC handle
00255   * @param  __DAC_Channel__ specifies the DAC channel.
00256   * @retval None
00257   */
00258 #define __HAL_DAC_DISABLE(__HANDLE__, __DAC_Channel__) \
00259   ((__HANDLE__)->Instance->CR &=  ~(DAC_CR_EN1 << ((__DAC_Channel__) & 0x10UL)))
00260 
00261 /** @brief Set DHR12R1 alignment.
00262   * @param  __ALIGNMENT__ specifies the DAC alignment
00263   * @retval None
00264   */
00265 #define DAC_DHR12R1_ALIGNMENT(__ALIGNMENT__) (0x00000008UL + (__ALIGNMENT__))
00266 
00267 
00268 /** @brief  Set DHR12R2 alignment.
00269   * @param  __ALIGNMENT__ specifies the DAC alignment
00270   * @retval None
00271   */
00272 #define DAC_DHR12R2_ALIGNMENT(__ALIGNMENT__) (0x00000014UL + (__ALIGNMENT__))
00273 
00274 
00275 /** @brief  Set DHR12RD alignment.
00276   * @param  __ALIGNMENT__ specifies the DAC alignment
00277   * @retval None
00278   */
00279 #define DAC_DHR12RD_ALIGNMENT(__ALIGNMENT__) (0x00000020UL + (__ALIGNMENT__))
00280 
00281 /** @brief Enable the DAC interrupt.
00282   * @param  __HANDLE__ specifies the DAC handle
00283   * @param  __INTERRUPT__ specifies the DAC interrupt.
00284   *          This parameter can be any combination of the following values:
00285   *            @arg DAC_IT_DMAUDR1 DAC channel 1 DMA underrun interrupt
00286   *            @arg DAC_IT_DMAUDR2 DAC channel 2 DMA underrun interrupt
00287   * @retval None
00288   */
00289 #define __HAL_DAC_ENABLE_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->CR) |= (__INTERRUPT__))
00290 
00291 /** @brief Disable the DAC interrupt.
00292   * @param  __HANDLE__ specifies the DAC handle
00293   * @param  __INTERRUPT__ specifies the DAC interrupt.
00294   *          This parameter can be any combination of the following values:
00295   *            @arg DAC_IT_DMAUDR1 DAC channel 1 DMA underrun interrupt
00296   *            @arg DAC_IT_DMAUDR2 DAC channel 2 DMA underrun interrupt
00297   * @retval None
00298   */
00299 #define __HAL_DAC_DISABLE_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->CR) &= ~(__INTERRUPT__))
00300 
00301 /** @brief  Check whether the specified DAC interrupt source is enabled or not.
00302   * @param __HANDLE__ DAC handle
00303   * @param __INTERRUPT__ DAC interrupt source to check
00304   *          This parameter can be any combination of the following values:
00305   *            @arg DAC_IT_DMAUDR1 DAC channel 1 DMA underrun interrupt
00306   *            @arg DAC_IT_DMAUDR2 DAC channel 2 DMA underrun interrupt
00307   * @retval State of interruption (SET or RESET)
00308   */
00309 #define __HAL_DAC_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->CR\
00310                                                              & (__INTERRUPT__)) == (__INTERRUPT__))
00311 
00312 /** @brief  Get the selected DAC's flag status.
00313   * @param  __HANDLE__ specifies the DAC handle.
00314   * @param  __FLAG__ specifies the DAC flag to get.
00315   *          This parameter can be any combination of the following values:
00316   *            @arg DAC_FLAG_DMAUDR1 DAC channel 1 DMA underrun flag
00317   *            @arg DAC_FLAG_DMAUDR2 DAC channel 2 DMA underrun flag
00318   * @retval None
00319   */
00320 #define __HAL_DAC_GET_FLAG(__HANDLE__, __FLAG__) ((((__HANDLE__)->Instance->SR) & (__FLAG__)) == (__FLAG__))
00321 
00322 /** @brief  Clear the DAC's flag.
00323   * @param  __HANDLE__ specifies the DAC handle.
00324   * @param  __FLAG__ specifies the DAC flag to clear.
00325   *          This parameter can be any combination of the following values:
00326   *            @arg DAC_FLAG_DMAUDR1 DAC channel 1 DMA underrun flag
00327   *            @arg DAC_FLAG_DMAUDR2 DAC channel 2 DMA underrun flag
00328   * @retval None
00329   */
00330 #define __HAL_DAC_CLEAR_FLAG(__HANDLE__, __FLAG__) (((__HANDLE__)->Instance->SR) = (__FLAG__))
00331 
00332 /**
00333   * @}
00334   */
00335 
00336 /* Private macro -------------------------------------------------------------*/
00337 
00338 /** @defgroup DAC_Private_Macros DAC Private Macros
00339   * @{
00340   */
00341 #define IS_DAC_OUTPUT_BUFFER_STATE(STATE) (((STATE) == DAC_OUTPUTBUFFER_ENABLE) || \
00342                                            ((STATE) == DAC_OUTPUTBUFFER_DISABLE))
00343 
00344 #define IS_DAC_CHANNEL(CHANNEL) (((CHANNEL) == DAC_CHANNEL_1) || \
00345                                  ((CHANNEL) == DAC_CHANNEL_2))
00346 
00347 #define IS_DAC_ALIGN(ALIGN) (((ALIGN) == DAC_ALIGN_12B_R) || \
00348                              ((ALIGN) == DAC_ALIGN_12B_L) || \
00349                              ((ALIGN) == DAC_ALIGN_8B_R))
00350 
00351 #define IS_DAC_DATA(DATA) ((DATA) <= 0xFFF0UL)
00352 
00353 /**
00354   * @}
00355   */
00356 
00357 /* Include DAC HAL Extended module */
00358 #include "stm32f1xx_hal_dac_ex.h"
00359 
00360 /* Exported functions --------------------------------------------------------*/
00361 
00362 /** @addtogroup DAC_Exported_Functions
00363   * @{
00364   */
00365 
00366 /** @addtogroup DAC_Exported_Functions_Group1
00367   * @{
00368   */
00369 /* Initialization and de-initialization functions *****************************/
00370 HAL_StatusTypeDef HAL_DAC_Init(DAC_HandleTypeDef *hdac);
00371 HAL_StatusTypeDef HAL_DAC_DeInit(DAC_HandleTypeDef *hdac);
00372 void HAL_DAC_MspInit(DAC_HandleTypeDef *hdac);
00373 void HAL_DAC_MspDeInit(DAC_HandleTypeDef *hdac);
00374 
00375 /**
00376   * @}
00377   */
00378 
00379 /** @addtogroup DAC_Exported_Functions_Group2
00380   * @{
00381   */
00382 /* IO operation functions *****************************************************/
00383 HAL_StatusTypeDef HAL_DAC_Start(DAC_HandleTypeDef *hdac, uint32_t Channel);
00384 HAL_StatusTypeDef HAL_DAC_Stop(DAC_HandleTypeDef *hdac, uint32_t Channel);
00385 HAL_StatusTypeDef HAL_DAC_Start_DMA(DAC_HandleTypeDef *hdac, uint32_t Channel, uint32_t *pData, uint32_t Length,
00386                                     uint32_t Alignment);
00387 HAL_StatusTypeDef HAL_DAC_Stop_DMA(DAC_HandleTypeDef *hdac, uint32_t Channel);
00388 void HAL_DAC_IRQHandler(DAC_HandleTypeDef *hdac);
00389 HAL_StatusTypeDef HAL_DAC_SetValue(DAC_HandleTypeDef *hdac, uint32_t Channel, uint32_t Alignment, uint32_t Data);
00390 
00391 void HAL_DAC_ConvCpltCallbackCh1(DAC_HandleTypeDef *hdac);
00392 void HAL_DAC_ConvHalfCpltCallbackCh1(DAC_HandleTypeDef *hdac);
00393 void HAL_DAC_ErrorCallbackCh1(DAC_HandleTypeDef *hdac);
00394 void HAL_DAC_DMAUnderrunCallbackCh1(DAC_HandleTypeDef *hdac);
00395 
00396 #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1)
00397 /* DAC callback registering/unregistering */
00398 HAL_StatusTypeDef     HAL_DAC_RegisterCallback(DAC_HandleTypeDef *hdac, HAL_DAC_CallbackIDTypeDef CallbackID,
00399                                                pDAC_CallbackTypeDef pCallback);
00400 HAL_StatusTypeDef     HAL_DAC_UnRegisterCallback(DAC_HandleTypeDef *hdac, HAL_DAC_CallbackIDTypeDef CallbackID);
00401 #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */
00402 
00403 /**
00404   * @}
00405   */
00406 
00407 /** @addtogroup DAC_Exported_Functions_Group3
00408   * @{
00409   */
00410 /* Peripheral Control functions ***********************************************/
00411 uint32_t HAL_DAC_GetValue(DAC_HandleTypeDef *hdac, uint32_t Channel);
00412 HAL_StatusTypeDef HAL_DAC_ConfigChannel(DAC_HandleTypeDef *hdac, DAC_ChannelConfTypeDef *sConfig, uint32_t Channel);
00413 /**
00414   * @}
00415   */
00416 
00417 /** @addtogroup DAC_Exported_Functions_Group4
00418   * @{
00419   */
00420 /* Peripheral State and Error functions ***************************************/
00421 HAL_DAC_StateTypeDef HAL_DAC_GetState(DAC_HandleTypeDef *hdac);
00422 uint32_t HAL_DAC_GetError(DAC_HandleTypeDef *hdac);
00423 
00424 /**
00425   * @}
00426   */
00427 
00428 /**
00429   * @}
00430   */
00431 
00432 /** @defgroup DAC_Private_Functions DAC Private Functions
00433   * @{
00434   */
00435 void DAC_DMAConvCpltCh1(DMA_HandleTypeDef *hdma);
00436 void DAC_DMAErrorCh1(DMA_HandleTypeDef *hdma);
00437 void DAC_DMAHalfConvCpltCh1(DMA_HandleTypeDef *hdma);
00438 /**
00439   * @}
00440   */
00441 
00442 /**
00443   * @}
00444   */
00445 
00446 #endif /* DAC */
00447 
00448 /**
00449   * @}
00450   */
00451 
00452 #ifdef __cplusplus
00453 }
00454 #endif
00455 
00456 
00457 #endif /* STM32F1xx_HAL_DAC_H */
00458 
00459 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/