You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

480 lines
18 KiB

12 months ago
  1. /**
  2. ******************************************************************************
  3. * @file stm32f4xx_hal_dac.h
  4. * @author MCD Application Team
  5. * @brief Header file of DAC HAL module.
  6. ******************************************************************************
  7. * @attention
  8. *
  9. * Copyright (c) 2016 STMicroelectronics.
  10. * All rights reserved.
  11. *
  12. * This software is licensed under terms that can be found in the LICENSE file
  13. * in the root directory of this software component.
  14. * If no LICENSE file comes with this software, it is provided AS-IS.
  15. *
  16. ******************************************************************************
  17. */
  18. /* Define to prevent recursive inclusion -------------------------------------*/
  19. #ifndef STM32F4xx_HAL_DAC_H
  20. #define STM32F4xx_HAL_DAC_H
  21. #ifdef __cplusplus
  22. extern "C" {
  23. #endif
  24. /** @addtogroup STM32F4xx_HAL_Driver
  25. * @{
  26. */
  27. /* Includes ------------------------------------------------------------------*/
  28. #include "stm32f4xx_hal_def.h"
  29. #if defined(DAC)
  30. /** @addtogroup DAC
  31. * @{
  32. */
  33. /* Exported types ------------------------------------------------------------*/
  34. /** @defgroup DAC_Exported_Types DAC Exported Types
  35. * @{
  36. */
  37. /**
  38. * @brief HAL State structures definition
  39. */
  40. typedef enum
  41. {
  42. HAL_DAC_STATE_RESET = 0x00U, /*!< DAC not yet initialized or disabled */
  43. HAL_DAC_STATE_READY = 0x01U, /*!< DAC initialized and ready for use */
  44. HAL_DAC_STATE_BUSY = 0x02U, /*!< DAC internal processing is ongoing */
  45. HAL_DAC_STATE_TIMEOUT = 0x03U, /*!< DAC timeout state */
  46. HAL_DAC_STATE_ERROR = 0x04U /*!< DAC error state */
  47. } HAL_DAC_StateTypeDef;
  48. /**
  49. * @brief DAC handle Structure definition
  50. */
  51. #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1)
  52. typedef struct __DAC_HandleTypeDef
  53. #else
  54. typedef struct
  55. #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */
  56. {
  57. DAC_TypeDef *Instance; /*!< Register base address */
  58. __IO HAL_DAC_StateTypeDef State; /*!< DAC communication state */
  59. HAL_LockTypeDef Lock; /*!< DAC locking object */
  60. DMA_HandleTypeDef *DMA_Handle1; /*!< Pointer DMA handler for channel 1 */
  61. DMA_HandleTypeDef *DMA_Handle2; /*!< Pointer DMA handler for channel 2 */
  62. __IO uint32_t ErrorCode; /*!< DAC Error code */
  63. #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1)
  64. void (* ConvCpltCallbackCh1)(struct __DAC_HandleTypeDef *hdac);
  65. void (* ConvHalfCpltCallbackCh1)(struct __DAC_HandleTypeDef *hdac);
  66. void (* ErrorCallbackCh1)(struct __DAC_HandleTypeDef *hdac);
  67. void (* DMAUnderrunCallbackCh1)(struct __DAC_HandleTypeDef *hdac);
  68. #if defined(DAC_CHANNEL2_SUPPORT)
  69. void (* ConvCpltCallbackCh2)(struct __DAC_HandleTypeDef *hdac);
  70. void (* ConvHalfCpltCallbackCh2)(struct __DAC_HandleTypeDef *hdac);
  71. void (* ErrorCallbackCh2)(struct __DAC_HandleTypeDef *hdac);
  72. void (* DMAUnderrunCallbackCh2)(struct __DAC_HandleTypeDef *hdac);
  73. #endif /* DAC_CHANNEL2_SUPPORT */
  74. void (* MspInitCallback)(struct __DAC_HandleTypeDef *hdac);
  75. void (* MspDeInitCallback)(struct __DAC_HandleTypeDef *hdac);
  76. #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */
  77. } DAC_HandleTypeDef;
  78. /**
  79. * @brief DAC Configuration regular Channel structure definition
  80. */
  81. typedef struct
  82. {
  83. uint32_t DAC_Trigger; /*!< Specifies the external trigger for the selected DAC channel.
  84. This parameter can be a value of @ref DAC_trigger_selection */
  85. uint32_t DAC_OutputBuffer; /*!< Specifies whether the DAC channel output buffer is enabled or disabled.
  86. This parameter can be a value of @ref DAC_output_buffer */
  87. } DAC_ChannelConfTypeDef;
  88. #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1)
  89. /**
  90. * @brief HAL DAC Callback ID enumeration definition
  91. */
  92. typedef enum
  93. {
  94. HAL_DAC_CH1_COMPLETE_CB_ID = 0x00U, /*!< DAC CH1 Complete Callback ID */
  95. HAL_DAC_CH1_HALF_COMPLETE_CB_ID = 0x01U, /*!< DAC CH1 half Complete Callback ID */
  96. HAL_DAC_CH1_ERROR_ID = 0x02U, /*!< DAC CH1 error Callback ID */
  97. HAL_DAC_CH1_UNDERRUN_CB_ID = 0x03U, /*!< DAC CH1 underrun Callback ID */
  98. #if defined(DAC_CHANNEL2_SUPPORT)
  99. HAL_DAC_CH2_COMPLETE_CB_ID = 0x04U, /*!< DAC CH2 Complete Callback ID */
  100. HAL_DAC_CH2_HALF_COMPLETE_CB_ID = 0x05U, /*!< DAC CH2 half Complete Callback ID */
  101. HAL_DAC_CH2_ERROR_ID = 0x06U, /*!< DAC CH2 error Callback ID */
  102. HAL_DAC_CH2_UNDERRUN_CB_ID = 0x07U, /*!< DAC CH2 underrun Callback ID */
  103. #endif /* DAC_CHANNEL2_SUPPORT */
  104. HAL_DAC_MSPINIT_CB_ID = 0x08U, /*!< DAC MspInit Callback ID */
  105. HAL_DAC_MSPDEINIT_CB_ID = 0x09U, /*!< DAC MspDeInit Callback ID */
  106. HAL_DAC_ALL_CB_ID = 0x0AU /*!< DAC All ID */
  107. } HAL_DAC_CallbackIDTypeDef;
  108. /**
  109. * @brief HAL DAC Callback pointer definition
  110. */
  111. typedef void (*pDAC_CallbackTypeDef)(DAC_HandleTypeDef *hdac);
  112. #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */
  113. /**
  114. * @}
  115. */
  116. /* Exported constants --------------------------------------------------------*/
  117. /** @defgroup DAC_Exported_Constants DAC Exported Constants
  118. * @{
  119. */
  120. /** @defgroup DAC_Error_Code DAC Error Code
  121. * @{
  122. */
  123. #define HAL_DAC_ERROR_NONE 0x00U /*!< No error */
  124. #define HAL_DAC_ERROR_DMAUNDERRUNCH1 0x01U /*!< DAC channel1 DMA underrun error */
  125. #if defined(DAC_CHANNEL2_SUPPORT)
  126. #define HAL_DAC_ERROR_DMAUNDERRUNCH2 0x02U /*!< DAC channel2 DMA underrun error */
  127. #endif /* DAC_CHANNEL2_SUPPORT */
  128. #define HAL_DAC_ERROR_DMA 0x04U /*!< DMA error */
  129. #define HAL_DAC_ERROR_TIMEOUT 0x08U /*!< Timeout error */
  130. #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1)
  131. #define HAL_DAC_ERROR_INVALID_CALLBACK 0x10U /*!< Invalid callback error */
  132. #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */
  133. /**
  134. * @}
  135. */
  136. /** @defgroup DAC_trigger_selection DAC trigger selection
  137. * @{
  138. */
  139. #define DAC_TRIGGER_NONE 0x00000000UL /*!< Conversion is automatic once the DAC1_DHRxxxx register has been loaded, and not by external trigger */
  140. #define DAC_TRIGGER_T2_TRGO (DAC_CR_TSEL1_2 | DAC_CR_TEN1) /*!< TIM2 TRGO selected as external conversion trigger for DAC channel */
  141. #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 */
  142. #define DAC_TRIGGER_T5_TRGO ( DAC_CR_TSEL1_1 | DAC_CR_TSEL1_0 | DAC_CR_TEN1) /*!< TIM3 TRGO selected as external conversion trigger for DAC channel */
  143. #define DAC_TRIGGER_T6_TRGO ( DAC_CR_TEN1) /*!< Conversion started by software trigger for DAC channel */
  144. #define DAC_TRIGGER_T7_TRGO ( DAC_CR_TSEL1_1 | DAC_CR_TEN1) /*!< TIM7 TRGO selected as external conversion trigger for DAC channel */
  145. #define DAC_TRIGGER_T8_TRGO ( DAC_CR_TSEL1_0 | DAC_CR_TEN1) /*!< TIM8 TRGO selected as external conversion trigger for DAC channel */
  146. #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 */
  147. #define DAC_TRIGGER_SOFTWARE (DAC_CR_TSEL1 | DAC_CR_TEN1) /*!< Conversion started by software trigger for DAC channel */
  148. /**
  149. * @}
  150. */
  151. /** @defgroup DAC_output_buffer DAC output buffer
  152. * @{
  153. */
  154. #define DAC_OUTPUTBUFFER_ENABLE 0x00000000U
  155. #define DAC_OUTPUTBUFFER_DISABLE (DAC_CR_BOFF1)
  156. /**
  157. * @}
  158. */
  159. /** @defgroup DAC_Channel_selection DAC Channel selection
  160. * @{
  161. */
  162. #define DAC_CHANNEL_1 0x00000000U
  163. #if defined(DAC_CHANNEL2_SUPPORT)
  164. #define DAC_CHANNEL_2 0x00000010U
  165. #endif /* DAC_CHANNEL2_SUPPORT */
  166. /**
  167. * @}
  168. */
  169. /** @defgroup DAC_data_alignment DAC data alignment
  170. * @{
  171. */
  172. #define DAC_ALIGN_12B_R 0x00000000U
  173. #define DAC_ALIGN_12B_L 0x00000004U
  174. #define DAC_ALIGN_8B_R 0x00000008U
  175. /**
  176. * @}
  177. */
  178. /** @defgroup DAC_flags_definition DAC flags definition
  179. * @{
  180. */
  181. #define DAC_FLAG_DMAUDR1 (DAC_SR_DMAUDR1)
  182. #if defined(DAC_CHANNEL2_SUPPORT)
  183. #define DAC_FLAG_DMAUDR2 (DAC_SR_DMAUDR2)
  184. #endif /* DAC_CHANNEL2_SUPPORT */
  185. /**
  186. * @}
  187. */
  188. /** @defgroup DAC_IT_definition DAC IT definition
  189. * @{
  190. */
  191. #define DAC_IT_DMAUDR1 (DAC_SR_DMAUDR1)
  192. #if defined(DAC_CHANNEL2_SUPPORT)
  193. #define DAC_IT_DMAUDR2 (DAC_SR_DMAUDR2)
  194. #endif /* DAC_CHANNEL2_SUPPORT */
  195. /**
  196. * @}
  197. */
  198. /**
  199. * @}
  200. */
  201. /* Exported macro ------------------------------------------------------------*/
  202. /** @defgroup DAC_Exported_Macros DAC Exported Macros
  203. * @{
  204. */
  205. /** @brief Reset DAC handle state.
  206. * @param __HANDLE__ specifies the DAC handle.
  207. * @retval None
  208. */
  209. #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1)
  210. #define __HAL_DAC_RESET_HANDLE_STATE(__HANDLE__) do { \
  211. (__HANDLE__)->State = HAL_DAC_STATE_RESET; \
  212. (__HANDLE__)->MspInitCallback = NULL; \
  213. (__HANDLE__)->MspDeInitCallback = NULL; \
  214. } while(0)
  215. #else
  216. #define __HAL_DAC_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_DAC_STATE_RESET)
  217. #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */
  218. /** @brief Enable the DAC channel.
  219. * @param __HANDLE__ specifies the DAC handle.
  220. * @param __DAC_Channel__ specifies the DAC channel
  221. * @retval None
  222. */
  223. #define __HAL_DAC_ENABLE(__HANDLE__, __DAC_Channel__) \
  224. ((__HANDLE__)->Instance->CR |= (DAC_CR_EN1 << ((__DAC_Channel__) & 0x10UL)))
  225. /** @brief Disable the DAC channel.
  226. * @param __HANDLE__ specifies the DAC handle
  227. * @param __DAC_Channel__ specifies the DAC channel.
  228. * @retval None
  229. */
  230. #define __HAL_DAC_DISABLE(__HANDLE__, __DAC_Channel__) \
  231. ((__HANDLE__)->Instance->CR &= ~(DAC_CR_EN1 << ((__DAC_Channel__) & 0x10UL)))
  232. /** @brief Set DHR12R1 alignment.
  233. * @param __ALIGNMENT__ specifies the DAC alignment
  234. * @retval None
  235. */
  236. #define DAC_DHR12R1_ALIGNMENT(__ALIGNMENT__) (0x00000008UL + (__ALIGNMENT__))
  237. #if defined(DAC_CHANNEL2_SUPPORT)
  238. /** @brief Set DHR12R2 alignment.
  239. * @param __ALIGNMENT__ specifies the DAC alignment
  240. * @retval None
  241. */
  242. #define DAC_DHR12R2_ALIGNMENT(__ALIGNMENT__) (0x00000014UL + (__ALIGNMENT__))
  243. #endif /* DAC_CHANNEL2_SUPPORT */
  244. /** @brief Set DHR12RD alignment.
  245. * @param __ALIGNMENT__ specifies the DAC alignment
  246. * @retval None
  247. */
  248. #define DAC_DHR12RD_ALIGNMENT(__ALIGNMENT__) (0x00000020UL + (__ALIGNMENT__))
  249. /** @brief Enable the DAC interrupt.
  250. * @param __HANDLE__ specifies the DAC handle
  251. * @param __INTERRUPT__ specifies the DAC interrupt.
  252. * This parameter can be any combination of the following values:
  253. * @arg DAC_IT_DMAUDR1 DAC channel 1 DMA underrun interrupt
  254. * @arg DAC_IT_DMAUDR2 DAC channel 2 DMA underrun interrupt
  255. * @retval None
  256. */
  257. #define __HAL_DAC_ENABLE_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->CR) |= (__INTERRUPT__))
  258. /** @brief Disable the DAC interrupt.
  259. * @param __HANDLE__ specifies the DAC handle
  260. * @param __INTERRUPT__ specifies the DAC interrupt.
  261. * This parameter can be any combination of the following values:
  262. * @arg DAC_IT_DMAUDR1 DAC channel 1 DMA underrun interrupt
  263. * @arg DAC_IT_DMAUDR2 DAC channel 2 DMA underrun interrupt
  264. * @retval None
  265. */
  266. #define __HAL_DAC_DISABLE_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->CR) &= ~(__INTERRUPT__))
  267. /** @brief Check whether the specified DAC interrupt source is enabled or not.
  268. * @param __HANDLE__ DAC handle
  269. * @param __INTERRUPT__ DAC interrupt source to check
  270. * This parameter can be any combination of the following values:
  271. * @arg DAC_IT_DMAUDR1 DAC channel 1 DMA underrun interrupt
  272. * @arg DAC_IT_DMAUDR2 DAC channel 2 DMA underrun interrupt
  273. * @retval State of interruption (SET or RESET)
  274. */
  275. #define __HAL_DAC_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->CR\
  276. & (__INTERRUPT__)) == (__INTERRUPT__))
  277. /** @brief Get the selected DAC's flag status.
  278. * @param __HANDLE__ specifies the DAC handle.
  279. * @param __FLAG__ specifies the DAC flag to get.
  280. * This parameter can be any combination of the following values:
  281. * @arg DAC_FLAG_DMAUDR1 DAC channel 1 DMA underrun flag
  282. * @arg DAC_FLAG_DMAUDR2 DAC channel 2 DMA underrun flag
  283. * @retval None
  284. */
  285. #define __HAL_DAC_GET_FLAG(__HANDLE__, __FLAG__) ((((__HANDLE__)->Instance->SR) & (__FLAG__)) == (__FLAG__))
  286. /** @brief Clear the DAC's flag.
  287. * @param __HANDLE__ specifies the DAC handle.
  288. * @param __FLAG__ specifies the DAC flag to clear.
  289. * This parameter can be any combination of the following values:
  290. * @arg DAC_FLAG_DMAUDR1 DAC channel 1 DMA underrun flag
  291. * @arg DAC_FLAG_DMAUDR2 DAC channel 2 DMA underrun flag
  292. * @retval None
  293. */
  294. #define __HAL_DAC_CLEAR_FLAG(__HANDLE__, __FLAG__) (((__HANDLE__)->Instance->SR) = (__FLAG__))
  295. /**
  296. * @}
  297. */
  298. /* Private macro -------------------------------------------------------------*/
  299. /** @defgroup DAC_Private_Macros DAC Private Macros
  300. * @{
  301. */
  302. #define IS_DAC_OUTPUT_BUFFER_STATE(STATE) (((STATE) == DAC_OUTPUTBUFFER_ENABLE) || \
  303. ((STATE) == DAC_OUTPUTBUFFER_DISABLE))
  304. #if defined(DAC_CHANNEL2_SUPPORT)
  305. #define IS_DAC_CHANNEL(CHANNEL) (((CHANNEL) == DAC_CHANNEL_1) || \
  306. ((CHANNEL) == DAC_CHANNEL_2))
  307. #else
  308. #define IS_DAC_CHANNEL(CHANNEL) ((CHANNEL) == DAC_CHANNEL_1)
  309. #endif /* DAC_CHANNEL2_SUPPORT */
  310. #define IS_DAC_ALIGN(ALIGN) (((ALIGN) == DAC_ALIGN_12B_R) || \
  311. ((ALIGN) == DAC_ALIGN_12B_L) || \
  312. ((ALIGN) == DAC_ALIGN_8B_R))
  313. #define IS_DAC_DATA(DATA) ((DATA) <= 0xFFF0UL)
  314. /**
  315. * @}
  316. */
  317. /* Include DAC HAL Extended module */
  318. #include "stm32f4xx_hal_dac_ex.h"
  319. /* Exported functions --------------------------------------------------------*/
  320. /** @addtogroup DAC_Exported_Functions
  321. * @{
  322. */
  323. /** @addtogroup DAC_Exported_Functions_Group1
  324. * @{
  325. */
  326. /* Initialization and de-initialization functions *****************************/
  327. HAL_StatusTypeDef HAL_DAC_Init(DAC_HandleTypeDef *hdac);
  328. HAL_StatusTypeDef HAL_DAC_DeInit(DAC_HandleTypeDef *hdac);
  329. void HAL_DAC_MspInit(DAC_HandleTypeDef *hdac);
  330. void HAL_DAC_MspDeInit(DAC_HandleTypeDef *hdac);
  331. /**
  332. * @}
  333. */
  334. /** @addtogroup DAC_Exported_Functions_Group2
  335. * @{
  336. */
  337. /* IO operation functions *****************************************************/
  338. HAL_StatusTypeDef HAL_DAC_Start(DAC_HandleTypeDef *hdac, uint32_t Channel);
  339. HAL_StatusTypeDef HAL_DAC_Stop(DAC_HandleTypeDef *hdac, uint32_t Channel);
  340. HAL_StatusTypeDef HAL_DAC_Start_DMA(DAC_HandleTypeDef *hdac, uint32_t Channel, const uint32_t *pData, uint32_t Length,
  341. uint32_t Alignment);
  342. HAL_StatusTypeDef HAL_DAC_Stop_DMA(DAC_HandleTypeDef *hdac, uint32_t Channel);
  343. void HAL_DAC_IRQHandler(DAC_HandleTypeDef *hdac);
  344. HAL_StatusTypeDef HAL_DAC_SetValue(DAC_HandleTypeDef *hdac, uint32_t Channel, uint32_t Alignment, uint32_t Data);
  345. void HAL_DAC_ConvCpltCallbackCh1(DAC_HandleTypeDef *hdac);
  346. void HAL_DAC_ConvHalfCpltCallbackCh1(DAC_HandleTypeDef *hdac);
  347. void HAL_DAC_ErrorCallbackCh1(DAC_HandleTypeDef *hdac);
  348. void HAL_DAC_DMAUnderrunCallbackCh1(DAC_HandleTypeDef *hdac);
  349. #if (USE_HAL_DAC_REGISTER_CALLBACKS == 1)
  350. /* DAC callback registering/unregistering */
  351. HAL_StatusTypeDef HAL_DAC_RegisterCallback(DAC_HandleTypeDef *hdac, HAL_DAC_CallbackIDTypeDef CallbackID,
  352. pDAC_CallbackTypeDef pCallback);
  353. HAL_StatusTypeDef HAL_DAC_UnRegisterCallback(DAC_HandleTypeDef *hdac, HAL_DAC_CallbackIDTypeDef CallbackID);
  354. #endif /* USE_HAL_DAC_REGISTER_CALLBACKS */
  355. /**
  356. * @}
  357. */
  358. /** @addtogroup DAC_Exported_Functions_Group3
  359. * @{
  360. */
  361. /* Peripheral Control functions ***********************************************/
  362. uint32_t HAL_DAC_GetValue(const DAC_HandleTypeDef *hdac, uint32_t Channel);
  363. HAL_StatusTypeDef HAL_DAC_ConfigChannel(DAC_HandleTypeDef *hdac,
  364. const DAC_ChannelConfTypeDef *sConfig, uint32_t Channel);
  365. /**
  366. * @}
  367. */
  368. /** @addtogroup DAC_Exported_Functions_Group4
  369. * @{
  370. */
  371. /* Peripheral State and Error functions ***************************************/
  372. HAL_DAC_StateTypeDef HAL_DAC_GetState(const DAC_HandleTypeDef *hdac);
  373. uint32_t HAL_DAC_GetError(const DAC_HandleTypeDef *hdac);
  374. /**
  375. * @}
  376. */
  377. /**
  378. * @}
  379. */
  380. /** @defgroup DAC_Private_Functions DAC Private Functions
  381. * @{
  382. */
  383. void DAC_DMAConvCpltCh1(DMA_HandleTypeDef *hdma);
  384. void DAC_DMAErrorCh1(DMA_HandleTypeDef *hdma);
  385. void DAC_DMAHalfConvCpltCh1(DMA_HandleTypeDef *hdma);
  386. /**
  387. * @}
  388. */
  389. /**
  390. * @}
  391. */
  392. #endif /* DAC */
  393. /**
  394. * @}
  395. */
  396. #ifdef __cplusplus
  397. }
  398. #endif
  399. #endif /* STM32F4xx_HAL_DAC_H */