STM32L443xx HAL User Manual
|
00001 /** 00002 ****************************************************************************** 00003 * @file stm32l4xx_hal_dac.h 00004 * @author MCD Application Team 00005 * @brief Header file of DAC HAL module. 00006 ****************************************************************************** 00007 * @attention 00008 * 00009 * Copyright (c) 2017 STMicroelectronics. 00010 * All rights reserved. 00011 * 00012 * This software is licensed under terms that can be found in the LICENSE file 00013 * in the root directory of this software component. 00014 * If no LICENSE file comes with this software, it is provided AS-IS. 00015 * 00016 ****************************************************************************** 00017 */ 00018 00019 /* Define to prevent recursive inclusion -------------------------------------*/ 00020 #ifndef STM32L4xx_HAL_DAC_H 00021 #define STM32L4xx_HAL_DAC_H 00022 00023 #ifdef __cplusplus 00024 extern "C" { 00025 #endif 00026 00027 /** @addtogroup STM32L4xx_HAL_Driver 00028 * @{ 00029 */ 00030 00031 /* Includes ------------------------------------------------------------------*/ 00032 #include "stm32l4xx_hal_def.h" 00033 00034 #if defined(DAC1) 00035 00036 /** @addtogroup DAC 00037 * @{ 00038 */ 00039 00040 /* Exported types ------------------------------------------------------------*/ 00041 00042 /** @defgroup DAC_Exported_Types DAC Exported Types 00043 * @{ 00044 */ 00045 00046 /** 00047 * @brief HAL State structures definition 00048 */ 00049 typedef enum 00050 { 00051 HAL_DAC_STATE_RESET = 0x00U, /*!< DAC not yet initialized or disabled */ 00052 HAL_DAC_STATE_READY = 0x01U, /*!< DAC initialized and ready for use */ 00053 HAL_DAC_STATE_BUSY = 0x02U, /*!< DAC internal processing is ongoing */ 00054 HAL_DAC_STATE_TIMEOUT = 0x03U, /*!< DAC timeout state */ 00055 HAL_DAC_STATE_ERROR = 0x04U /*!< DAC error state */ 00056 00057 } HAL_DAC_StateTypeDef; 00058 00059 /** 00060 * @brief DAC handle Structure definition 00061 */ 00062 #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) 00063 typedef struct __DAC_HandleTypeDef 00064 #else 00065 typedef struct 00066 #endif 00067 { 00068 DAC_TypeDef *Instance; /*!< Register base address */ 00069 00070 __IO HAL_DAC_StateTypeDef State; /*!< DAC communication state */ 00071 00072 HAL_LockTypeDef Lock; /*!< DAC locking object */ 00073 00074 DMA_HandleTypeDef *DMA_Handle1; /*!< Pointer DMA handler for channel 1 */ 00075 00076 DMA_HandleTypeDef *DMA_Handle2; /*!< Pointer DMA handler for channel 2 */ 00077 00078 __IO uint32_t ErrorCode; /*!< DAC Error code */ 00079 00080 #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) 00081 void (* ConvCpltCallbackCh1) (struct __DAC_HandleTypeDef *hdac); 00082 void (* ConvHalfCpltCallbackCh1) (struct __DAC_HandleTypeDef *hdac); 00083 void (* ErrorCallbackCh1) (struct __DAC_HandleTypeDef *hdac); 00084 void (* DMAUnderrunCallbackCh1) (struct __DAC_HandleTypeDef *hdac); 00085 void (* ConvCpltCallbackCh2) (struct __DAC_HandleTypeDef *hdac); 00086 void (* ConvHalfCpltCallbackCh2) (struct __DAC_HandleTypeDef *hdac); 00087 void (* ErrorCallbackCh2) (struct __DAC_HandleTypeDef *hdac); 00088 void (* DMAUnderrunCallbackCh2) (struct __DAC_HandleTypeDef *hdac); 00089 00090 void (* MspInitCallback) (struct __DAC_HandleTypeDef *hdac); 00091 void (* MspDeInitCallback ) (struct __DAC_HandleTypeDef *hdac); 00092 #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */ 00093 00094 } DAC_HandleTypeDef; 00095 00096 /** 00097 * @brief DAC Configuration sample and hold Channel structure definition 00098 */ 00099 typedef struct 00100 { 00101 uint32_t DAC_SampleTime ; /*!< Specifies the Sample time for the selected channel. 00102 This parameter applies when DAC_SampleAndHold is DAC_SAMPLEANDHOLD_ENABLE. 00103 This parameter must be a number between Min_Data = 0 and Max_Data = 1023 */ 00104 00105 uint32_t DAC_HoldTime ; /*!< Specifies the hold time for the selected channel 00106 This parameter applies when DAC_SampleAndHold is DAC_SAMPLEANDHOLD_ENABLE. 00107 This parameter must be a number between Min_Data = 0 and Max_Data = 1023 */ 00108 00109 uint32_t DAC_RefreshTime ; /*!< Specifies the refresh time for the selected channel 00110 This parameter applies when DAC_SampleAndHold is DAC_SAMPLEANDHOLD_ENABLE. 00111 This parameter must be a number between Min_Data = 0 and Max_Data = 255 */ 00112 } DAC_SampleAndHoldConfTypeDef; 00113 00114 /** 00115 * @brief DAC Configuration regular Channel structure definition 00116 */ 00117 typedef struct 00118 { 00119 #if defined (STM32L4P5xx) || defined (STM32L4Q5xx) || defined (STM32L4R5xx) || defined (STM32L4R7xx) || defined (STM32L4R9xx) || defined (STM32L4S5xx) || defined (STM32L4S7xx) || defined(STM32L4S9xx) 00120 uint32_t DAC_HighFrequency; /*!< Specifies the frequency interface mode 00121 This parameter can be a value of @ref DAC_HighFrequency */ 00122 #endif /* STM32L4P5xx STM32L4Q5xx STM32L4R5xx STM32L4R7xx STM32L4R9xx STM32L4S5xx STM32L4S7xx STM32L4S9xx */ 00123 00124 uint32_t DAC_SampleAndHold; /*!< Specifies whether the DAC mode. 00125 This parameter can be a value of @ref DAC_SampleAndHold */ 00126 00127 uint32_t DAC_Trigger; /*!< Specifies the external trigger for the selected DAC channel. 00128 This parameter can be a value of @ref DAC_trigger_selection */ 00129 00130 uint32_t DAC_OutputBuffer; /*!< Specifies whether the DAC channel output buffer is enabled or disabled. 00131 This parameter can be a value of @ref DAC_output_buffer */ 00132 00133 uint32_t DAC_ConnectOnChipPeripheral ; /*!< Specifies whether the DAC output is connected or not to on chip peripheral . 00134 This parameter can be a value of @ref DAC_ConnectOnChipPeripheral */ 00135 00136 uint32_t DAC_UserTrimming; /*!< Specifies the trimming mode 00137 This parameter must be a value of @ref DAC_UserTrimming 00138 DAC_UserTrimming is either factory or user trimming */ 00139 00140 uint32_t DAC_TrimmingValue; /*!< Specifies the offset trimming value 00141 i.e. when DAC_SampleAndHold is DAC_TRIMMING_USER. 00142 This parameter must be a number between Min_Data = 1 and Max_Data = 31 */ 00143 00144 DAC_SampleAndHoldConfTypeDef DAC_SampleAndHoldConfig; /*!< Sample and Hold settings */ 00145 00146 } DAC_ChannelConfTypeDef; 00147 00148 #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) 00149 /** 00150 * @brief HAL DAC Callback ID enumeration definition 00151 */ 00152 typedef enum 00153 { 00154 HAL_DAC_CH1_COMPLETE_CB_ID = 0x00U, /*!< DAC CH1 Complete Callback ID */ 00155 HAL_DAC_CH1_HALF_COMPLETE_CB_ID = 0x01U, /*!< DAC CH1 half Complete Callback ID */ 00156 HAL_DAC_CH1_ERROR_ID = 0x02U, /*!< DAC CH1 error Callback ID */ 00157 HAL_DAC_CH1_UNDERRUN_CB_ID = 0x03U, /*!< DAC CH1 underrun Callback ID */ 00158 HAL_DAC_CH2_COMPLETE_CB_ID = 0x04U, /*!< DAC CH2 Complete Callback ID */ 00159 HAL_DAC_CH2_HALF_COMPLETE_CB_ID = 0x05U, /*!< DAC CH2 half Complete Callback ID */ 00160 HAL_DAC_CH2_ERROR_ID = 0x06U, /*!< DAC CH2 error Callback ID */ 00161 HAL_DAC_CH2_UNDERRUN_CB_ID = 0x07U, /*!< DAC CH2 underrun Callback ID */ 00162 HAL_DAC_MSPINIT_CB_ID = 0x08U, /*!< DAC MspInit Callback ID */ 00163 HAL_DAC_MSPDEINIT_CB_ID = 0x09U, /*!< DAC MspDeInit Callback ID */ 00164 HAL_DAC_ALL_CB_ID = 0x0AU /*!< DAC All ID */ 00165 } HAL_DAC_CallbackIDTypeDef; 00166 00167 /** 00168 * @brief HAL DAC Callback pointer definition 00169 */ 00170 typedef void (*pDAC_CallbackTypeDef)(DAC_HandleTypeDef *hdac); 00171 #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */ 00172 00173 /** 00174 * @} 00175 */ 00176 00177 /* Exported constants --------------------------------------------------------*/ 00178 00179 /** @defgroup DAC_Exported_Constants DAC Exported Constants 00180 * @{ 00181 */ 00182 00183 /** @defgroup DAC_Error_Code DAC Error Code 00184 * @{ 00185 */ 00186 #define HAL_DAC_ERROR_NONE 0x00U /*!< No error */ 00187 #define HAL_DAC_ERROR_DMAUNDERRUNCH1 0x01U /*!< DAC channel1 DMA underrun error */ 00188 #define HAL_DAC_ERROR_DMAUNDERRUNCH2 0x02U /*!< DAC channel2 DMA underrun error */ 00189 #define HAL_DAC_ERROR_DMA 0x04U /*!< DMA error */ 00190 #define HAL_DAC_ERROR_TIMEOUT 0x08U /*!< Timeout error */ 00191 #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) 00192 #define HAL_DAC_ERROR_INVALID_CALLBACK 0x10U /*!< Invalid callback error */ 00193 #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */ 00194 00195 /** 00196 * @} 00197 */ 00198 00199 /** @defgroup DAC_trigger_selection DAC trigger selection 00200 * @{ 00201 */ 00202 00203 #if defined (STM32L431xx) || defined (STM32L432xx) || defined (STM32L433xx) || defined (STM32L442xx) || defined (STM32L443xx) 00204 #define DAC_TRIGGER_NONE 0x00000000U /*!< Conversion is automatic once the DAC_DHRxxxx register 00205 has been loaded, and not by external trigger */ 00206 #define DAC_TRIGGER_T2_TRGO (DAC_CR_TSEL1_2 | DAC_CR_TEN1) /*!< TIM2 TRGO selected as external conversion trigger for DAC channel */ 00207 #define DAC_TRIGGER_T6_TRGO ( DAC_CR_TEN1) /*!< TIM6 TRGO selected as external conversion trigger for DAC channel */ 00208 #define DAC_TRIGGER_T7_TRGO ( DAC_CR_TSEL1_1 | DAC_CR_TEN1) /*!< TIM7 TRGO selected as external conversion trigger for DAC channel */ 00209 #define DAC_TRIGGER_EXT_IT9 (DAC_CR_TSEL1_2 | DAC_CR_TSEL1_1 | DAC_CR_TEN1) /*!< EXTI Line9 event selected as external conversion trigger for DAC channel */ 00210 #define DAC_TRIGGER_SOFTWARE ( DAC_CR_TSEL1 | DAC_CR_TEN1) /*!< Conversion started by software trigger for DAC channel */ 00211 #endif /* STM32L431xx STM32L432xx STM32L433xx STM32L442xx STM32L443xx */ 00212 00213 #if defined (STM32L451xx) || defined (STM32L452xx) || defined (STM32L462xx) 00214 #define DAC_TRIGGER_NONE 0x00000000U /*!< Conversion is automatic once the DAC_DHRxxxx register 00215 has been loaded, and not by external trigger */ 00216 #define DAC_TRIGGER_T2_TRGO (DAC_CR_TSEL1_2 | DAC_CR_TEN1) /*!< TIM2 TRGO selected as external conversion trigger for DAC channel */ 00217 #define DAC_TRIGGER_T6_TRGO ( DAC_CR_TEN1) /*!< TIM6 TRGO selected as external conversion trigger for DAC channel */ 00218 #define DAC_TRIGGER_EXT_IT9 (DAC_CR_TSEL1_2 | DAC_CR_TSEL1_1 | DAC_CR_TEN1) /*!< EXTI Line9 event selected as external conversion trigger for DAC channel */ 00219 #define DAC_TRIGGER_SOFTWARE ( DAC_CR_TSEL1 | DAC_CR_TEN1) /*!< Conversion started by software trigger for DAC channel */ 00220 #endif /* STM32L451xx STM32L452xx STM32L462xx */ 00221 00222 #if defined (STM32L471xx) || defined (STM32L475xx) || defined (STM32L476xx) || defined (STM32L485xx) || defined (STM32L486xx) || defined (STM32L496xx) || defined (STM32L4A6xx) 00223 #define DAC_TRIGGER_NONE 0x00000000U /*!< Conversion is automatic once the DAC_DHRxxxx register 00224 has been loaded, and not by external trigger */ 00225 #define DAC_TRIGGER_T2_TRGO (DAC_CR_TSEL1_2 | DAC_CR_TEN1) /*!< TIM2 TRGO selected as external conversion trigger for DAC channel */ 00226 #define DAC_TRIGGER_T4_TRGO (DAC_CR_TSEL1_2 | DAC_CR_TSEL1_0 | DAC_CR_TEN1) /*!< TIM4 TRGO selected as external conversion trigger for DAC channel */ 00227 #define DAC_TRIGGER_T5_TRGO ( DAC_CR_TSEL1_1 | DAC_CR_TSEL1_0 | DAC_CR_TEN1) /*!< TIM5 TRGO selected as external conversion trigger for DAC channel */ 00228 #define DAC_TRIGGER_T6_TRGO ( DAC_CR_TEN1) /*!< TIM6 TRGO selected as external conversion trigger for DAC channel */ 00229 #define DAC_TRIGGER_T7_TRGO ( DAC_CR_TSEL1_1 | DAC_CR_TEN1) /*!< TIM7 TRGO selected as external conversion trigger for DAC channel */ 00230 #define DAC_TRIGGER_T8_TRGO ( DAC_CR_TSEL1_0 | DAC_CR_TEN1) /*!< TIM8 TRGO selected as external conversion trigger for DAC channel */ 00231 #define DAC_TRIGGER_EXT_IT9 (DAC_CR_TSEL1_2 | DAC_CR_TSEL1_1 | DAC_CR_TEN1) /*!< EXTI Line9 event selected as external conversion trigger for DAC channel */ 00232 #define DAC_TRIGGER_SOFTWARE ( DAC_CR_TSEL1 | DAC_CR_TEN1) /*!< Conversion started by software trigger for DAC channel */ 00233 #endif /* STM32L471xx STM32L475xx STM32L476xx STM32L485xx STM32L486xx STM32L496xx STM32L4A6xx*/ 00234 00235 00236 #if defined (STM32L4P5xx) || defined (STM32L4Q5xx) || defined (STM32L4R5xx) || defined (STM32L4R7xx) || defined (STM32L4R9xx) || defined (STM32L4S5xx) || defined (STM32L4S7xx) || defined(STM32L4S9xx) 00237 #define DAC_TRIGGER_NONE 0x00000000U /*!< conversion is automatic once the DAC_DHRxxxx register has been loaded, and not by external trigger */ 00238 #define DAC_TRIGGER_SOFTWARE ( DAC_CR_TEN1) /*!< conversion started by software trigger for DAC channel */ 00239 #define DAC_TRIGGER_T1_TRGO ( DAC_CR_TSEL1_0 | DAC_CR_TEN1) /*!< TIM1 TRGO selected as external conversion trigger for DAC channel. */ 00240 #define DAC_TRIGGER_T2_TRGO ( DAC_CR_TSEL1_1 | DAC_CR_TEN1) /*!< TIM2 TRGO selected as external conversion trigger for DAC channel */ 00241 #define DAC_TRIGGER_T4_TRGO ( DAC_CR_TSEL1_1 | DAC_CR_TSEL1_0 | DAC_CR_TEN1) /*!< TIM4 TRGO selected as external conversion trigger for DAC channel */ 00242 #define DAC_TRIGGER_T5_TRGO ( DAC_CR_TSEL1_2 | DAC_CR_TEN1) /*!< TIM5 TRGO selected as external conversion trigger for DAC channel */ 00243 #define DAC_TRIGGER_T6_TRGO ( DAC_CR_TSEL1_2 | DAC_CR_TSEL1_0 | DAC_CR_TEN1) /*!< TIM6 TRGO selected as external conversion trigger for DAC channel */ 00244 #define DAC_TRIGGER_T7_TRGO ( DAC_CR_TSEL1_2 | DAC_CR_TSEL1_1 | DAC_CR_TEN1) /*!< TIM7 TRGO selected as external conversion trigger for DAC channel */ 00245 #define DAC_TRIGGER_T8_TRGO ( DAC_CR_TSEL1_2 | DAC_CR_TSEL1_1 | DAC_CR_TSEL1_0 | DAC_CR_TEN1) /*!< TIM8 TRGO selected as external conversion trigger for DAC channel */ 00246 #define DAC_TRIGGER_T15_TRGO (DAC_CR_TSEL1_3 | DAC_CR_TEN1) /*!< TIM15 TRGO selected as external conversion trigger for DAC channel */ 00247 #define DAC_TRIGGER_LPTIM1_OUT (DAC_CR_TSEL1_3 | DAC_CR_TSEL1_1 | DAC_CR_TSEL1_0 | DAC_CR_TEN1) /*!< LPTIM1 OUT TRGO selected as external conversion trigger for DAC channel */ 00248 #define DAC_TRIGGER_LPTIM2_OUT (DAC_CR_TSEL1_3 | DAC_CR_TSEL1_2 | DAC_CR_TEN1) /*!< LPTIM2 OUT TRGO selected as external conversion trigger for DAC channel */ 00249 #define DAC_TRIGGER_EXT_IT9 (DAC_CR_TSEL1_3 | DAC_CR_TSEL1_2 | DAC_CR_TSEL1_0 | DAC_CR_TEN1) /*!< EXTI Line9 event selected as external conversion trigger for DAC channel */ 00250 00251 #endif /* STM32L4P5xx STM32L4Q5xx STM32L4R5xx STM32L4R7xx STM32L4R9xx STM32L4S5xx STM32L4S7xx STM32L4S9xx */ 00252 00253 00254 /** 00255 * @} 00256 */ 00257 00258 /** @defgroup DAC_output_buffer DAC output buffer 00259 * @{ 00260 */ 00261 #define DAC_OUTPUTBUFFER_ENABLE 0x00000000U 00262 #define DAC_OUTPUTBUFFER_DISABLE (DAC_MCR_MODE1_1) 00263 00264 /** 00265 * @} 00266 */ 00267 00268 /** @defgroup DAC_Channel_selection DAC Channel selection 00269 * @{ 00270 */ 00271 #define DAC_CHANNEL_1 0x00000000U 00272 #if defined (STM32L431xx) || defined (STM32L432xx) || defined (STM32L433xx) || defined (STM32L442xx) || defined (STM32L443xx) || \ 00273 defined (STM32L471xx) || defined (STM32L475xx) || defined (STM32L476xx) || defined (STM32L485xx) || defined (STM32L486xx) || defined (STM32L496xx) || defined (STM32L4A6xx) || \ 00274 defined (STM32L4P5xx) || defined (STM32L4Q5xx) || \ 00275 defined (STM32L4R5xx) || defined (STM32L4R7xx) || defined (STM32L4R9xx) || defined (STM32L4S5xx) || defined (STM32L4S7xx) || defined(STM32L4S9xx) 00276 #define DAC_CHANNEL_2 0x00000010U 00277 #endif /* STM32L431xx STM32L432xx STM32L433xx STM32L442xx STM32L443xx */ 00278 /* STM32L471xx STM32L475xx STM32L476xx STM32L485xx STM32L486xx STM32L496xx STM32L4A6xx */ 00279 /* STM32L4P5xx STM32L4Q5xx */ 00280 /* STM32L4R5xx STM32L4R7xx STM32L4R9xx STM32L4S5xx STM32L4S7xx STM32L4S9xx */ 00281 00282 /** 00283 * @} 00284 */ 00285 00286 /** @defgroup DAC_data_alignment DAC data alignment 00287 * @{ 00288 */ 00289 #define DAC_ALIGN_12B_R 0x00000000U 00290 #define DAC_ALIGN_12B_L 0x00000004U 00291 #define DAC_ALIGN_8B_R 0x00000008U 00292 00293 /** 00294 * @} 00295 */ 00296 00297 /** @defgroup DAC_flags_definition DAC flags definition 00298 * @{ 00299 */ 00300 #define DAC_FLAG_DMAUDR1 (DAC_SR_DMAUDR1) 00301 #define DAC_FLAG_DMAUDR2 (DAC_SR_DMAUDR2) 00302 00303 /** 00304 * @} 00305 */ 00306 00307 /** @defgroup DAC_IT_definition DAC IT definition 00308 * @{ 00309 */ 00310 #define DAC_IT_DMAUDR1 (DAC_SR_DMAUDR1) 00311 #define DAC_IT_DMAUDR2 (DAC_SR_DMAUDR2) 00312 00313 /** 00314 * @} 00315 */ 00316 00317 /** @defgroup DAC_ConnectOnChipPeripheral DAC ConnectOnChipPeripheral 00318 * @{ 00319 */ 00320 #define DAC_CHIPCONNECT_DISABLE 0x00000000U 00321 #define DAC_CHIPCONNECT_ENABLE (DAC_MCR_MODE1_0) 00322 00323 /** 00324 * @} 00325 */ 00326 00327 /** @defgroup DAC_UserTrimming DAC User Trimming 00328 * @{ 00329 */ 00330 #define DAC_TRIMMING_FACTORY 0x00000000U /*!< Factory trimming */ 00331 #define DAC_TRIMMING_USER 0x00000001U /*!< User trimming */ 00332 00333 /** 00334 * @} 00335 */ 00336 00337 /** @defgroup DAC_SampleAndHold DAC power mode 00338 * @{ 00339 */ 00340 #define DAC_SAMPLEANDHOLD_DISABLE 0x00000000U 00341 #define DAC_SAMPLEANDHOLD_ENABLE (DAC_MCR_MODE1_2) 00342 00343 /** 00344 * @} 00345 */ 00346 #if defined (STM32L4P5xx) || defined (STM32L4Q5xx) || defined (STM32L4R5xx) || defined (STM32L4R7xx) || defined (STM32L4R9xx) || defined (STM32L4S5xx) || defined (STM32L4S7xx) || defined(STM32L4S9xx) 00347 /** @defgroup DAC_HighFrequency DAC high frequency interface mode 00348 * @{ 00349 */ 00350 #define DAC_HIGH_FREQUENCY_INTERFACE_MODE_DISABLE 0x00000000U /*!< High frequency interface mode disabled */ 00351 #define DAC_HIGH_FREQUENCY_INTERFACE_MODE_ABOVE_80MHZ (DAC_CR_HFSEL) /*!< High frequency interface mode compatible to AHB>80MHz enabled */ 00352 #define DAC_HIGH_FREQUENCY_INTERFACE_MODE_AUTOMATIC 0x00000002U /*!< High frequency interface mode automatic */ 00353 00354 /** 00355 * @} 00356 */ 00357 #endif /* STM32L4P5xx STM32L4Q5xx STM32L4R5xx STM32L4R7xx STM32L4R9xx STM32L4S5xx STM32L4S7xx STM32L4S9xx */ 00358 00359 /** 00360 * @} 00361 */ 00362 00363 /* Exported macro ------------------------------------------------------------*/ 00364 00365 /** @defgroup DAC_Exported_Macros DAC Exported Macros 00366 * @{ 00367 */ 00368 00369 /** @brief Reset DAC handle state. 00370 * @param __HANDLE__ specifies the DAC handle. 00371 * @retval None 00372 */ 00373 #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) 00374 #define __HAL_DAC_RESET_HANDLE_STATE(__HANDLE__) do { \ 00375 (__HANDLE__)->State = HAL_DAC_STATE_RESET; \ 00376 (__HANDLE__)->MspInitCallback = NULL; \ 00377 (__HANDLE__)->MspDeInitCallback = NULL; \ 00378 } while(0) 00379 #else 00380 #define __HAL_DAC_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_DAC_STATE_RESET) 00381 #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */ 00382 00383 /** @brief Enable the DAC channel. 00384 * @param __HANDLE__ specifies the DAC handle. 00385 * @param __DAC_Channel__ specifies the DAC channel 00386 * @retval None 00387 */ 00388 #define __HAL_DAC_ENABLE(__HANDLE__, __DAC_Channel__) \ 00389 ((__HANDLE__)->Instance->CR |= (DAC_CR_EN1 << ((__DAC_Channel__) & 0x10UL))) 00390 00391 /** @brief Disable the DAC channel. 00392 * @param __HANDLE__ specifies the DAC handle 00393 * @param __DAC_Channel__ specifies the DAC channel. 00394 * @retval None 00395 */ 00396 #define __HAL_DAC_DISABLE(__HANDLE__, __DAC_Channel__) \ 00397 ((__HANDLE__)->Instance->CR &= ~(DAC_CR_EN1 << ((__DAC_Channel__) & 0x10UL))) 00398 00399 /** @brief Set DHR12R1 alignment. 00400 * @param __ALIGNMENT__ specifies the DAC alignment 00401 * @retval None 00402 */ 00403 #define DAC_DHR12R1_ALIGNMENT(__ALIGNMENT__) (0x00000008U + (__ALIGNMENT__)) 00404 00405 /** @brief Set DHR12R2 alignment. 00406 * @param __ALIGNMENT__ specifies the DAC alignment 00407 * @retval None 00408 */ 00409 #define DAC_DHR12R2_ALIGNMENT(__ALIGNMENT__) (0x00000014U + (__ALIGNMENT__)) 00410 00411 /** @brief Set DHR12RD alignment. 00412 * @param __ALIGNMENT__ specifies the DAC alignment 00413 * @retval None 00414 */ 00415 #define DAC_DHR12RD_ALIGNMENT(__ALIGNMENT__) (0x00000020U + (__ALIGNMENT__)) 00416 00417 /** @brief Enable the DAC interrupt. 00418 * @param __HANDLE__ specifies the DAC handle 00419 * @param __INTERRUPT__ specifies the DAC interrupt. 00420 * This parameter can be any combination of the following values: 00421 * @arg DAC_IT_DMAUDR1: DAC channel 1 DMA underrun interrupt 00422 * @arg DAC_IT_DMAUDR2: DAC channel 2 DMA underrun interrupt 00423 * @retval None 00424 */ 00425 #define __HAL_DAC_ENABLE_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->CR) |= (__INTERRUPT__)) 00426 00427 /** @brief Disable the DAC interrupt. 00428 * @param __HANDLE__ specifies the DAC handle 00429 * @param __INTERRUPT__ specifies the DAC interrupt. 00430 * This parameter can be any combination of the following values: 00431 * @arg DAC_IT_DMAUDR1: DAC channel 1 DMA underrun interrupt 00432 * @arg DAC_IT_DMAUDR2: DAC channel 2 DMA underrun interrupt 00433 * @retval None 00434 */ 00435 #define __HAL_DAC_DISABLE_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->CR) &= ~(__INTERRUPT__)) 00436 00437 /** @brief Check whether the specified DAC interrupt source is enabled or not. 00438 * @param __HANDLE__ DAC handle 00439 * @param __INTERRUPT__ DAC interrupt source to check 00440 * This parameter can be any combination of the following values: 00441 * @arg DAC_IT_DMAUDR1: DAC channel 1 DMA underrun interrupt 00442 * @arg DAC_IT_DMAUDR2: DAC channel 2 DMA underrun interrupt 00443 * @retval State of interruption (SET or RESET) 00444 */ 00445 #define __HAL_DAC_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->CR & (__INTERRUPT__)) == (__INTERRUPT__)) 00446 00447 /** @brief Get the selected DAC's flag status. 00448 * @param __HANDLE__ specifies the DAC handle. 00449 * @param __FLAG__ specifies the DAC flag to get. 00450 * This parameter can be any combination of the following values: 00451 * @arg DAC_FLAG_DMAUDR1: DAC channel 1 DMA underrun flag 00452 * @arg DAC_FLAG_DMAUDR2: DAC channel 2 DMA underrun flag 00453 * @retval None 00454 */ 00455 #define __HAL_DAC_GET_FLAG(__HANDLE__, __FLAG__) ((((__HANDLE__)->Instance->SR) & (__FLAG__)) == (__FLAG__)) 00456 00457 /** @brief Clear the DAC's flag. 00458 * @param __HANDLE__ specifies the DAC handle. 00459 * @param __FLAG__ specifies the DAC flag to clear. 00460 * This parameter can be any combination of the following values: 00461 * @arg DAC_FLAG_DMAUDR1: DAC channel 1 DMA underrun flag 00462 * @arg DAC_FLAG_DMAUDR2: DAC channel 2 DMA underrun flag 00463 * @retval None 00464 */ 00465 #define __HAL_DAC_CLEAR_FLAG(__HANDLE__, __FLAG__) (((__HANDLE__)->Instance->SR) = (__FLAG__)) 00466 00467 /** 00468 * @} 00469 */ 00470 00471 /* Private macro -------------------------------------------------------------*/ 00472 00473 /** @defgroup DAC_Private_Macros DAC Private Macros 00474 * @{ 00475 */ 00476 #define IS_DAC_OUTPUT_BUFFER_STATE(STATE) (((STATE) == DAC_OUTPUTBUFFER_ENABLE) || \ 00477 ((STATE) == DAC_OUTPUTBUFFER_DISABLE)) 00478 00479 #if defined (STM32L431xx) || defined (STM32L432xx) || defined (STM32L433xx) || defined (STM32L442xx) || defined (STM32L443xx) || \ 00480 defined (STM32L471xx) || defined (STM32L475xx) || defined (STM32L476xx) || defined (STM32L485xx) || defined (STM32L486xx) || defined (STM32L496xx) || defined (STM32L4A6xx) || \ 00481 defined (STM32L4P5xx) || defined (STM32L4Q5xx) || \ 00482 defined (STM32L4R5xx) || defined (STM32L4R7xx) || defined (STM32L4R9xx) || defined (STM32L4S5xx) || defined (STM32L4S7xx) || defined(STM32L4S9xx) 00483 #define IS_DAC_CHANNEL(CHANNEL) (((CHANNEL) == DAC_CHANNEL_1) || \ 00484 ((CHANNEL) == DAC_CHANNEL_2)) 00485 #endif /* STM32L431xx STM32L432xx STM32L433xx STM32L442xx STM32L443xx */ 00486 /* STM32L471xx STM32L475xx STM32L476xx STM32L485xx STM32L486xx STM32L496xx STM32L4A6xx */ 00487 /* STM32L4P5xx STM32L4Q5xx */ 00488 /* STM32L4R5xx STM32L4R7xx STM32L4R9xx STM32L4S5xx STM32L4S7xx STM32L4S9xx */ 00489 00490 #if defined (STM32L451xx) || defined (STM32L452xx) || defined (STM32L462xx) 00491 #define IS_DAC_CHANNEL(CHANNEL) ((CHANNEL) == DAC_CHANNEL_1) 00492 #endif /* STM32L451xx STM32L452xx STM32L462xx */ 00493 00494 #define IS_DAC_ALIGN(ALIGN) (((ALIGN) == DAC_ALIGN_12B_R) || \ 00495 ((ALIGN) == DAC_ALIGN_12B_L) || \ 00496 ((ALIGN) == DAC_ALIGN_8B_R)) 00497 00498 #define IS_DAC_DATA(DATA) ((DATA) <= 0xFFF0U) 00499 00500 #define IS_DAC_REFRESHTIME(TIME) ((TIME) <= 0x000000FFU) 00501 00502 /** 00503 * @} 00504 */ 00505 00506 /* Include DAC HAL Extended module */ 00507 #include "stm32l4xx_hal_dac_ex.h" 00508 00509 /* Exported functions --------------------------------------------------------*/ 00510 00511 /** @addtogroup DAC_Exported_Functions 00512 * @{ 00513 */ 00514 00515 /** @addtogroup DAC_Exported_Functions_Group1 00516 * @{ 00517 */ 00518 /* Initialization and de-initialization functions *****************************/ 00519 HAL_StatusTypeDef HAL_DAC_Init(DAC_HandleTypeDef *hdac); 00520 HAL_StatusTypeDef HAL_DAC_DeInit(DAC_HandleTypeDef *hdac); 00521 void HAL_DAC_MspInit(DAC_HandleTypeDef *hdac); 00522 void HAL_DAC_MspDeInit(DAC_HandleTypeDef *hdac); 00523 00524 /** 00525 * @} 00526 */ 00527 00528 /** @addtogroup DAC_Exported_Functions_Group2 00529 * @{ 00530 */ 00531 /* IO operation functions *****************************************************/ 00532 HAL_StatusTypeDef HAL_DAC_Start(DAC_HandleTypeDef *hdac, uint32_t Channel); 00533 HAL_StatusTypeDef HAL_DAC_Stop(DAC_HandleTypeDef *hdac, uint32_t Channel); 00534 HAL_StatusTypeDef HAL_DAC_Start_DMA(DAC_HandleTypeDef *hdac, uint32_t Channel, uint32_t *pData, uint32_t Length, 00535 uint32_t Alignment); 00536 HAL_StatusTypeDef HAL_DAC_Stop_DMA(DAC_HandleTypeDef *hdac, uint32_t Channel); 00537 00538 void HAL_DAC_IRQHandler(DAC_HandleTypeDef *hdac); 00539 00540 HAL_StatusTypeDef HAL_DAC_SetValue(DAC_HandleTypeDef *hdac, uint32_t Channel, uint32_t Alignment, uint32_t Data); 00541 00542 void HAL_DAC_ConvCpltCallbackCh1(DAC_HandleTypeDef *hdac); 00543 void HAL_DAC_ConvHalfCpltCallbackCh1(DAC_HandleTypeDef *hdac); 00544 void HAL_DAC_ErrorCallbackCh1(DAC_HandleTypeDef *hdac); 00545 void HAL_DAC_DMAUnderrunCallbackCh1(DAC_HandleTypeDef *hdac); 00546 00547 #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) 00548 /* DAC callback registering/unregistering */ 00549 HAL_StatusTypeDef HAL_DAC_RegisterCallback(DAC_HandleTypeDef *hdac, HAL_DAC_CallbackIDTypeDef CallbackID, 00550 pDAC_CallbackTypeDef pCallback); 00551 HAL_StatusTypeDef HAL_DAC_UnRegisterCallback(DAC_HandleTypeDef *hdac, HAL_DAC_CallbackIDTypeDef CallbackID); 00552 #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */ 00553 00554 /** 00555 * @} 00556 */ 00557 00558 /** @addtogroup DAC_Exported_Functions_Group3 00559 * @{ 00560 */ 00561 /* Peripheral Control functions ***********************************************/ 00562 uint32_t HAL_DAC_GetValue(DAC_HandleTypeDef *hdac, uint32_t Channel); 00563 00564 HAL_StatusTypeDef HAL_DAC_ConfigChannel(DAC_HandleTypeDef *hdac, DAC_ChannelConfTypeDef *sConfig, uint32_t Channel); 00565 /** 00566 * @} 00567 */ 00568 00569 /** @addtogroup DAC_Exported_Functions_Group4 00570 * @{ 00571 */ 00572 /* Peripheral State and Error functions ***************************************/ 00573 HAL_DAC_StateTypeDef HAL_DAC_GetState(DAC_HandleTypeDef *hdac); 00574 uint32_t HAL_DAC_GetError(DAC_HandleTypeDef *hdac); 00575 00576 /** 00577 * @} 00578 */ 00579 00580 /** 00581 * @} 00582 */ 00583 00584 /** @defgroup DAC_Private_Functions DAC Private Functions 00585 * @{ 00586 */ 00587 void DAC_DMAConvCpltCh1(DMA_HandleTypeDef *hdma); 00588 void DAC_DMAErrorCh1(DMA_HandleTypeDef *hdma); 00589 void DAC_DMAHalfConvCpltCh1(DMA_HandleTypeDef *hdma); 00590 /** 00591 * @} 00592 */ 00593 00594 /** 00595 * @} 00596 */ 00597 00598 #endif /* DAC1 */ 00599 00600 /** 00601 * @} 00602 */ 00603 00604 #ifdef __cplusplus 00605 } 00606 #endif 00607 00608 00609 #endif /*STM32L4xx_HAL_DAC_H */ 00610 00611