stm32g4xx_hal_dac_ex.h 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345
  1. /**
  2. ******************************************************************************
  3. * @file stm32g4xx_hal_dac_ex.h
  4. * @author MCD Application Team
  5. * @brief Header file of DAC HAL Extended module.
  6. ******************************************************************************
  7. * @attention
  8. *
  9. * Copyright (c) 2019 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 STM32G4xx_HAL_DAC_EX_H
  20. #define STM32G4xx_HAL_DAC_EX_H
  21. #ifdef __cplusplus
  22. extern "C" {
  23. #endif
  24. /** @addtogroup STM32G4xx_HAL_Driver
  25. * @{
  26. */
  27. /* Includes ------------------------------------------------------------------*/
  28. #include "stm32g4xx_hal_def.h"
  29. #if defined(DAC1) || defined(DAC2) || defined(DAC3) ||defined (DAC4)
  30. /** @addtogroup DACEx
  31. * @{
  32. */
  33. /* Exported types ------------------------------------------------------------*/
  34. /**
  35. * @brief HAL State structures definition
  36. */
  37. /* Exported constants --------------------------------------------------------*/
  38. /** @defgroup DACEx_Exported_Constants DACEx Exported Constants
  39. * @{
  40. */
  41. /** @defgroup DACEx_lfsrunmask_triangleamplitude DACEx lfsrunmask triangle amplitude
  42. * @{
  43. */
  44. #define DAC_LFSRUNMASK_BIT0 0x00000000UL /*!< Unmask DAC channel LFSR bit0 for noise wave generation */
  45. #define DAC_LFSRUNMASK_BITS1_0 ( DAC_CR_MAMP1_0) /*!< Unmask DAC channel LFSR bit[1:0] for noise wave generation */
  46. #define DAC_LFSRUNMASK_BITS2_0 ( DAC_CR_MAMP1_1 ) /*!< Unmask DAC channel LFSR bit[2:0] for noise wave generation */
  47. #define DAC_LFSRUNMASK_BITS3_0 ( DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Unmask DAC channel LFSR bit[3:0] for noise wave generation */
  48. #define DAC_LFSRUNMASK_BITS4_0 ( DAC_CR_MAMP1_2 ) /*!< Unmask DAC channel LFSR bit[4:0] for noise wave generation */
  49. #define DAC_LFSRUNMASK_BITS5_0 ( DAC_CR_MAMP1_2 | DAC_CR_MAMP1_0) /*!< Unmask DAC channel LFSR bit[5:0] for noise wave generation */
  50. #define DAC_LFSRUNMASK_BITS6_0 ( DAC_CR_MAMP1_2 | DAC_CR_MAMP1_1 ) /*!< Unmask DAC channel LFSR bit[6:0] for noise wave generation */
  51. #define DAC_LFSRUNMASK_BITS7_0 ( DAC_CR_MAMP1_2 | DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Unmask DAC channel LFSR bit[7:0] for noise wave generation */
  52. #define DAC_LFSRUNMASK_BITS8_0 (DAC_CR_MAMP1_3 ) /*!< Unmask DAC channel LFSR bit[8:0] for noise wave generation */
  53. #define DAC_LFSRUNMASK_BITS9_0 (DAC_CR_MAMP1_3 | DAC_CR_MAMP1_0) /*!< Unmask DAC channel LFSR bit[9:0] for noise wave generation */
  54. #define DAC_LFSRUNMASK_BITS10_0 (DAC_CR_MAMP1_3 | DAC_CR_MAMP1_1 ) /*!< Unmask DAC channel LFSR bit[10:0] for noise wave generation */
  55. #define DAC_LFSRUNMASK_BITS11_0 (DAC_CR_MAMP1_3 | DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Unmask DAC channel LFSR bit[11:0] for noise wave generation */
  56. #define DAC_TRIANGLEAMPLITUDE_1 0x00000000UL /*!< Select max triangle amplitude of 1 */
  57. #define DAC_TRIANGLEAMPLITUDE_3 ( DAC_CR_MAMP1_0) /*!< Select max triangle amplitude of 3 */
  58. #define DAC_TRIANGLEAMPLITUDE_7 ( DAC_CR_MAMP1_1 ) /*!< Select max triangle amplitude of 7 */
  59. #define DAC_TRIANGLEAMPLITUDE_15 ( DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Select max triangle amplitude of 15 */
  60. #define DAC_TRIANGLEAMPLITUDE_31 ( DAC_CR_MAMP1_2 ) /*!< Select max triangle amplitude of 31 */
  61. #define DAC_TRIANGLEAMPLITUDE_63 ( DAC_CR_MAMP1_2 | DAC_CR_MAMP1_0) /*!< Select max triangle amplitude of 63 */
  62. #define DAC_TRIANGLEAMPLITUDE_127 ( DAC_CR_MAMP1_2 | DAC_CR_MAMP1_1 ) /*!< Select max triangle amplitude of 127 */
  63. #define DAC_TRIANGLEAMPLITUDE_255 ( DAC_CR_MAMP1_2 | DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Select max triangle amplitude of 255 */
  64. #define DAC_TRIANGLEAMPLITUDE_511 (DAC_CR_MAMP1_3 ) /*!< Select max triangle amplitude of 511 */
  65. #define DAC_TRIANGLEAMPLITUDE_1023 (DAC_CR_MAMP1_3 | DAC_CR_MAMP1_0) /*!< Select max triangle amplitude of 1023 */
  66. #define DAC_TRIANGLEAMPLITUDE_2047 (DAC_CR_MAMP1_3 | DAC_CR_MAMP1_1 ) /*!< Select max triangle amplitude of 2047 */
  67. #define DAC_TRIANGLEAMPLITUDE_4095 (DAC_CR_MAMP1_3 | DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Select max triangle amplitude of 4095 */
  68. /**
  69. * @}
  70. */
  71. /** @defgroup DACEx_SawtoothPolarityMode DAC Sawtooth polarity mode
  72. * @{
  73. */
  74. #define DAC_SAWTOOTH_POLARITY_DECREMENT 0x00000000UL /*!< Sawtooth wave generation, polarity is decrement */
  75. #define DAC_SAWTOOTH_POLARITY_INCREMENT (DAC_STR1_STDIR1) /*!< Sawtooth wave generation, polarity is increment */
  76. /**
  77. * @}
  78. */
  79. /**
  80. * @}
  81. */
  82. /* Exported macro ------------------------------------------------------------*/
  83. /* Private macro -------------------------------------------------------------*/
  84. /** @defgroup DACEx_Private_Macros DACEx Private Macros
  85. * @{
  86. */
  87. #if defined(STM32G414xx) || defined(STM32G474xx) || defined(STM32G484xx)
  88. #define IS_DAC_TRIGGER(DACX, TRIGGER) \
  89. (((TRIGGER) == DAC_TRIGGER_NONE) || \
  90. ((TRIGGER) == DAC_TRIGGER_SOFTWARE) || \
  91. ((TRIGGER) == DAC_TRIGGER_T7_TRGO) || \
  92. ((TRIGGER) == DAC_TRIGGER_T15_TRGO) || \
  93. ((TRIGGER) == DAC_TRIGGER_T2_TRGO) || \
  94. ((TRIGGER) == DAC_TRIGGER_T4_TRGO) || \
  95. ((TRIGGER) == DAC_TRIGGER_EXT_IT9) || \
  96. ((TRIGGER) == DAC_TRIGGER_T6_TRGO) || \
  97. ((TRIGGER) == DAC_TRIGGER_T3_TRGO) || \
  98. ((TRIGGER) == DAC_TRIGGER_HRTIM_RST_TRG1) || \
  99. ((TRIGGER) == DAC_TRIGGER_HRTIM_RST_TRG2) || \
  100. ((TRIGGER) == DAC_TRIGGER_HRTIM_RST_TRG3) || \
  101. ((TRIGGER) == DAC_TRIGGER_HRTIM_RST_TRG4) || \
  102. ((TRIGGER) == DAC_TRIGGER_HRTIM_RST_TRG5) || \
  103. ((TRIGGER) == DAC_TRIGGER_HRTIM_RST_TRG6) || \
  104. (((DACX) == DAC1) && \
  105. (((TRIGGER) == DAC_TRIGGER_T8_TRGO) || \
  106. ((TRIGGER) == DAC_TRIGGER_HRTIM_TRG01)) \
  107. ) || \
  108. (((DACX) == DAC2) && \
  109. (((TRIGGER) == DAC_TRIGGER_T8_TRGO) || \
  110. ((TRIGGER) == DAC_TRIGGER_HRTIM_TRG02)) \
  111. ) || \
  112. (((DACX) == DAC3) && \
  113. (((TRIGGER) == DAC_TRIGGER_T1_TRGO) || \
  114. ((TRIGGER) == DAC_TRIGGER_HRTIM_TRG03)) \
  115. ) || \
  116. (((DACX) == DAC4) && \
  117. (((TRIGGER) == DAC_TRIGGER_T8_TRGO) || \
  118. ((TRIGGER) == DAC_TRIGGER_HRTIM_TRG01)) \
  119. ) \
  120. )
  121. #else
  122. #define IS_DAC_TRIGGER(DACX, TRIGGER) \
  123. (((TRIGGER) == DAC_TRIGGER_NONE) || \
  124. ((TRIGGER) == DAC_TRIGGER_SOFTWARE) || \
  125. ((TRIGGER) == DAC_TRIGGER_T7_TRGO) || \
  126. ((TRIGGER) == DAC_TRIGGER_T15_TRGO) || \
  127. ((TRIGGER) == DAC_TRIGGER_T2_TRGO) || \
  128. ((TRIGGER) == DAC_TRIGGER_T4_TRGO) || \
  129. ((TRIGGER) == DAC_TRIGGER_EXT_IT9) || \
  130. ((TRIGGER) == DAC_TRIGGER_T6_TRGO) || \
  131. ((TRIGGER) == DAC_TRIGGER_T3_TRGO) || \
  132. (((DACX) == DAC3) ? \
  133. ((TRIGGER) == DAC_TRIGGER_T1_TRGO) \
  134. : ((TRIGGER) == DAC_TRIGGER_T8_TRGO) \
  135. ) \
  136. )
  137. #endif /* STM32G414xx || STM32G474xx || STM32G484xx */
  138. #if defined(STM32G414xx) || defined(STM32G474xx) || defined(STM32G484xx)
  139. #define IS_DAC_TRIGGER2(DACX, TRIGGER) \
  140. (((TRIGGER) == DAC_TRIGGER_NONE) || \
  141. ((TRIGGER) == DAC_TRIGGER_SOFTWARE) || \
  142. ((TRIGGER) == DAC_TRIGGER_T7_TRGO) || \
  143. ((TRIGGER) == DAC_TRIGGER_T15_TRGO) || \
  144. ((TRIGGER) == DAC_TRIGGER_T2_TRGO) || \
  145. ((TRIGGER) == DAC_TRIGGER_T4_TRGO) || \
  146. ((TRIGGER) == DAC_TRIGGER_EXT_IT10) || \
  147. ((TRIGGER) == DAC_TRIGGER_T6_TRGO) || \
  148. ((TRIGGER) == DAC_TRIGGER_T3_TRGO) || \
  149. ((TRIGGER) == DAC_TRIGGER_HRTIM_STEP_TRG1) || \
  150. ((TRIGGER) == DAC_TRIGGER_HRTIM_STEP_TRG2) || \
  151. ((TRIGGER) == DAC_TRIGGER_HRTIM_STEP_TRG3) || \
  152. ((TRIGGER) == DAC_TRIGGER_HRTIM_STEP_TRG4) || \
  153. ((TRIGGER) == DAC_TRIGGER_HRTIM_STEP_TRG5) || \
  154. ((TRIGGER) == DAC_TRIGGER_HRTIM_STEP_TRG6) || \
  155. (((DACX) == DAC1) && \
  156. ((TRIGGER) == DAC_TRIGGER_T8_TRGO) \
  157. ) || \
  158. (((DACX) == DAC2) && \
  159. ((TRIGGER) == DAC_TRIGGER_T8_TRGO) \
  160. ) || \
  161. (((DACX) == DAC3) && \
  162. ((TRIGGER) == DAC_TRIGGER_T1_TRGO) \
  163. ) || \
  164. (((DACX) == DAC4) && \
  165. ((TRIGGER) == DAC_TRIGGER_T8_TRGO) \
  166. ) \
  167. )
  168. #else
  169. #define IS_DAC_TRIGGER2(DACX, TRIGGER) \
  170. (((TRIGGER) == DAC_TRIGGER_NONE) || \
  171. ((TRIGGER) == DAC_TRIGGER_SOFTWARE) || \
  172. ((TRIGGER) == DAC_TRIGGER_T7_TRGO) || \
  173. ((TRIGGER) == DAC_TRIGGER_T15_TRGO) || \
  174. ((TRIGGER) == DAC_TRIGGER_T2_TRGO) || \
  175. ((TRIGGER) == DAC_TRIGGER_T4_TRGO) || \
  176. ((TRIGGER) == DAC_TRIGGER_EXT_IT10) || \
  177. ((TRIGGER) == DAC_TRIGGER_T6_TRGO) || \
  178. ((TRIGGER) == DAC_TRIGGER_T3_TRGO) || \
  179. (((DACX) == DAC3) ? \
  180. ((TRIGGER) == DAC_TRIGGER_T1_TRGO) \
  181. :((TRIGGER) == DAC_TRIGGER_T8_TRGO) \
  182. ) \
  183. )
  184. #endif /* STM32G414xx || STM32G474xx || STM32G484xx */
  185. #define IS_DAC_HIGH_FREQUENCY_MODE(MODE) (((MODE) == DAC_HIGH_FREQUENCY_INTERFACE_MODE_DISABLE) || \
  186. ((MODE) == DAC_HIGH_FREQUENCY_INTERFACE_MODE_ABOVE_80MHZ) || \
  187. ((MODE) == DAC_HIGH_FREQUENCY_INTERFACE_MODE_ABOVE_160MHZ) || \
  188. ((MODE) == DAC_HIGH_FREQUENCY_INTERFACE_MODE_AUTOMATIC))
  189. #define IS_DAC_SAMPLETIME(TIME) ((TIME) <= 0x000003FFU)
  190. #define IS_DAC_HOLDTIME(TIME) ((TIME) <= 0x000003FFU)
  191. #define IS_DAC_SAMPLEANDHOLD(MODE) (((MODE) == DAC_SAMPLEANDHOLD_DISABLE) || \
  192. ((MODE) == DAC_SAMPLEANDHOLD_ENABLE))
  193. #define IS_DAC_TRIMMINGVALUE(TRIMMINGVALUE) ((TRIMMINGVALUE) <= 0x1FU)
  194. #define IS_DAC_NEWTRIMMINGVALUE(TRIMMINGVALUE) ((TRIMMINGVALUE) <= 0x1FU)
  195. #define IS_DAC_CHIP_CONNECTION(CONNECT) (((CONNECT) == DAC_CHIPCONNECT_EXTERNAL) || \
  196. ((CONNECT) == DAC_CHIPCONNECT_INTERNAL) || \
  197. ((CONNECT) == DAC_CHIPCONNECT_BOTH))
  198. #define IS_DAC_TRIMMING(TRIMMING) (((TRIMMING) == DAC_TRIMMING_FACTORY) || \
  199. ((TRIMMING) == DAC_TRIMMING_USER))
  200. #define IS_DAC_LFSR_UNMASK_TRIANGLE_AMPLITUDE(VALUE) (((VALUE) == DAC_LFSRUNMASK_BIT0) || \
  201. ((VALUE) == DAC_LFSRUNMASK_BITS1_0) || \
  202. ((VALUE) == DAC_LFSRUNMASK_BITS2_0) || \
  203. ((VALUE) == DAC_LFSRUNMASK_BITS3_0) || \
  204. ((VALUE) == DAC_LFSRUNMASK_BITS4_0) || \
  205. ((VALUE) == DAC_LFSRUNMASK_BITS5_0) || \
  206. ((VALUE) == DAC_LFSRUNMASK_BITS6_0) || \
  207. ((VALUE) == DAC_LFSRUNMASK_BITS7_0) || \
  208. ((VALUE) == DAC_LFSRUNMASK_BITS8_0) || \
  209. ((VALUE) == DAC_LFSRUNMASK_BITS9_0) || \
  210. ((VALUE) == DAC_LFSRUNMASK_BITS10_0) || \
  211. ((VALUE) == DAC_LFSRUNMASK_BITS11_0) || \
  212. ((VALUE) == DAC_TRIANGLEAMPLITUDE_1) || \
  213. ((VALUE) == DAC_TRIANGLEAMPLITUDE_3) || \
  214. ((VALUE) == DAC_TRIANGLEAMPLITUDE_7) || \
  215. ((VALUE) == DAC_TRIANGLEAMPLITUDE_15) || \
  216. ((VALUE) == DAC_TRIANGLEAMPLITUDE_31) || \
  217. ((VALUE) == DAC_TRIANGLEAMPLITUDE_63) || \
  218. ((VALUE) == DAC_TRIANGLEAMPLITUDE_127) || \
  219. ((VALUE) == DAC_TRIANGLEAMPLITUDE_255) || \
  220. ((VALUE) == DAC_TRIANGLEAMPLITUDE_511) || \
  221. ((VALUE) == DAC_TRIANGLEAMPLITUDE_1023) || \
  222. ((VALUE) == DAC_TRIANGLEAMPLITUDE_2047) || \
  223. ((VALUE) == DAC_TRIANGLEAMPLITUDE_4095))
  224. #define IS_DAC_SAWTOOTH_POLARITY(POLARITY) (((POLARITY) == DAC_SAWTOOTH_POLARITY_DECREMENT) || \
  225. ((POLARITY) == DAC_SAWTOOTH_POLARITY_INCREMENT))
  226. #define IS_DAC_RESET_DATA(DATA) ((DATA) <= 0x00000FFFUL)
  227. #define IS_DAC_STEP_DATA(DATA) ((DATA) <= 0x0000FFFFUL)
  228. /**
  229. * @}
  230. */
  231. /* Exported functions --------------------------------------------------------*/
  232. /* Extended features functions ***********************************************/
  233. /** @addtogroup DACEx_Exported_Functions
  234. * @{
  235. */
  236. /** @addtogroup DACEx_Exported_Functions_Group2
  237. * @{
  238. */
  239. /* IO operation functions *****************************************************/
  240. HAL_StatusTypeDef HAL_DACEx_TriangleWaveGenerate(DAC_HandleTypeDef *hdac, uint32_t Channel, uint32_t Amplitude);
  241. HAL_StatusTypeDef HAL_DACEx_NoiseWaveGenerate(DAC_HandleTypeDef *hdac, uint32_t Channel, uint32_t Amplitude);
  242. HAL_StatusTypeDef HAL_DACEx_SawtoothWaveGenerate(DAC_HandleTypeDef *hdac, uint32_t Channel, uint32_t Polarity,
  243. uint32_t ResetData, uint32_t StepData);
  244. HAL_StatusTypeDef HAL_DACEx_SawtoothWaveDataReset(DAC_HandleTypeDef *hdac, uint32_t Channel);
  245. HAL_StatusTypeDef HAL_DACEx_SawtoothWaveDataStep(DAC_HandleTypeDef *hdac, uint32_t Channel);
  246. HAL_StatusTypeDef HAL_DACEx_DualStart(DAC_HandleTypeDef *hdac);
  247. HAL_StatusTypeDef HAL_DACEx_DualStop(DAC_HandleTypeDef *hdac);
  248. HAL_StatusTypeDef HAL_DACEx_DualStart_DMA(DAC_HandleTypeDef *hdac, uint32_t Channel,
  249. const uint32_t *pData, uint32_t Length, uint32_t Alignment);
  250. HAL_StatusTypeDef HAL_DACEx_DualStop_DMA(DAC_HandleTypeDef *hdac, uint32_t Channel);
  251. HAL_StatusTypeDef HAL_DACEx_DualSetValue(DAC_HandleTypeDef *hdac, uint32_t Alignment, uint32_t Data1, uint32_t Data2);
  252. uint32_t HAL_DACEx_DualGetValue(const DAC_HandleTypeDef *hdac);
  253. void HAL_DACEx_ConvCpltCallbackCh2(DAC_HandleTypeDef *hdac);
  254. void HAL_DACEx_ConvHalfCpltCallbackCh2(DAC_HandleTypeDef *hdac);
  255. void HAL_DACEx_ErrorCallbackCh2(DAC_HandleTypeDef *hdac);
  256. void HAL_DACEx_DMAUnderrunCallbackCh2(DAC_HandleTypeDef *hdac);
  257. /**
  258. * @}
  259. */
  260. /** @addtogroup DACEx_Exported_Functions_Group3
  261. * @{
  262. */
  263. /* Peripheral Control functions ***********************************************/
  264. HAL_StatusTypeDef HAL_DACEx_SelfCalibrate(DAC_HandleTypeDef *hdac, DAC_ChannelConfTypeDef *sConfig, uint32_t Channel);
  265. HAL_StatusTypeDef HAL_DACEx_SetUserTrimming(DAC_HandleTypeDef *hdac, DAC_ChannelConfTypeDef *sConfig, uint32_t Channel,
  266. uint32_t NewTrimmingValue);
  267. uint32_t HAL_DACEx_GetTrimOffset(const DAC_HandleTypeDef *hdac, uint32_t Channel);
  268. /**
  269. * @}
  270. */
  271. /**
  272. * @}
  273. */
  274. /** @addtogroup DACEx_Private_Functions
  275. * @{
  276. */
  277. /* DAC_DMAConvCpltCh2 / DAC_DMAErrorCh2 / DAC_DMAHalfConvCpltCh2 */
  278. /* are called by HAL_DAC_Start_DMA */
  279. void DAC_DMAConvCpltCh2(DMA_HandleTypeDef *hdma);
  280. void DAC_DMAErrorCh2(DMA_HandleTypeDef *hdma);
  281. void DAC_DMAHalfConvCpltCh2(DMA_HandleTypeDef *hdma);
  282. /**
  283. * @}
  284. */
  285. /**
  286. * @}
  287. */
  288. #endif /* DAC1 || DAC2 || DAC3 || DAC4 */
  289. /**
  290. * @}
  291. */
  292. #ifdef __cplusplus
  293. }
  294. #endif
  295. #endif /* STM32G4xx_HAL_DAC_EX_H */