xref: /btstack/port/stm32-f4discovery-usb/Drivers/STM32F4xx_HAL_Driver/Src/stm32f4xx_ll_dac.c (revision a8f7f3fcbcd51f8d2e92aca076b6a9f812db358c)
1 /**
2   ******************************************************************************
3   * @file    stm32f4xx_ll_dac.c
4   * @author  MCD Application Team
5   * @brief   DAC LL module driver
6   ******************************************************************************
7   * @attention
8   *
9   * <h2><center>&copy; Copyright (c) 2017 STMicroelectronics.
10   * All rights reserved.</center></h2>
11   *
12   * This software component is licensed by ST under BSD 3-Clause license,
13   * the "License"; You may not use this file except in compliance with the
14   * License. You may obtain a copy of the License at:
15   *                        opensource.org/licenses/BSD-3-Clause
16   *
17   ******************************************************************************
18   */
19 #if defined(USE_FULL_LL_DRIVER)
20 
21 /* Includes ------------------------------------------------------------------*/
22 #include "stm32f4xx_ll_dac.h"
23 #include "stm32f4xx_ll_bus.h"
24 
25 #ifdef USE_FULL_ASSERT
26   #include "stm32_assert.h"
27 #else
28   #define assert_param(expr) ((void)0U)
29 #endif
30 
31 /** @addtogroup STM32F4xx_LL_Driver
32   * @{
33   */
34 
35 #if defined(DAC)
36 
37 /** @addtogroup DAC_LL DAC
38   * @{
39   */
40 
41 /* Private types -------------------------------------------------------------*/
42 /* Private variables ---------------------------------------------------------*/
43 /* Private constants ---------------------------------------------------------*/
44 /* Private macros ------------------------------------------------------------*/
45 
46 /** @addtogroup DAC_LL_Private_Macros
47   * @{
48   */
49 
50 #if defined(DAC_CHANNEL2_SUPPORT)
51 #define IS_LL_DAC_CHANNEL(__DACX__, __DAC_CHANNEL__)                           \
52   (                                                                            \
53       ((__DAC_CHANNEL__) == LL_DAC_CHANNEL_1)                                  \
54    || ((__DAC_CHANNEL__) == LL_DAC_CHANNEL_2)                                  \
55   )
56 #else
57 #define IS_LL_DAC_CHANNEL(__DACX__, __DAC_CHANNEL__)                           \
58   (                                                                            \
59    ((__DAC_CHANNEL__) == LL_DAC_CHANNEL_1)                                     \
60   )
61 #endif /* DAC_CHANNEL2_SUPPORT */
62 
63 #define IS_LL_DAC_TRIGGER_SOURCE(__TRIGGER_SOURCE__)                           \
64   (   ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_SOFTWARE)                           \
65    || ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_EXT_TIM2_TRGO)                      \
66    || ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_EXT_TIM4_TRGO)                      \
67    || ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_EXT_TIM5_TRGO)                      \
68    || ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_EXT_TIM6_TRGO)                      \
69    || ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_EXT_TIM7_TRGO)                      \
70    || ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_EXT_TIM8_TRGO)                      \
71    || ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_EXT_EXTI_LINE9)                     \
72   )
73 
74 #define IS_LL_DAC_WAVE_AUTO_GENER_MODE(__WAVE_AUTO_GENERATION_MODE__)           \
75   (   ((__WAVE_AUTO_GENERATION_MODE__) == LL_DAC_WAVE_AUTO_GENERATION_NONE)     \
76    || ((__WAVE_AUTO_GENERATION_MODE__) == LL_DAC_WAVE_AUTO_GENERATION_NOISE)    \
77    || ((__WAVE_AUTO_GENERATION_MODE__) == LL_DAC_WAVE_AUTO_GENERATION_TRIANGLE) \
78   )
79 
80 #define IS_LL_DAC_WAVE_AUTO_GENER_CONFIG(__WAVE_AUTO_GENERATION_CONFIG__)      \
81   (   ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BIT0)     \
82    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS1_0)  \
83    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS2_0)  \
84    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS3_0)  \
85    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS4_0)  \
86    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS5_0)  \
87    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS6_0)  \
88    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS7_0)  \
89    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS8_0)  \
90    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS9_0)  \
91    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS10_0) \
92    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS11_0) \
93    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_1)       \
94    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_3)       \
95    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_7)       \
96    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_15)      \
97    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_31)      \
98    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_63)      \
99    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_127)     \
100    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_255)     \
101    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_511)     \
102    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_1023)    \
103    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_2047)    \
104    || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_4095)    \
105   )
106 
107 #define IS_LL_DAC_OUTPUT_BUFFER(__OUTPUT_BUFFER__)                             \
108   (   ((__OUTPUT_BUFFER__) == LL_DAC_OUTPUT_BUFFER_ENABLE)                     \
109    || ((__OUTPUT_BUFFER__) == LL_DAC_OUTPUT_BUFFER_DISABLE)                    \
110   )
111 
112 /**
113   * @}
114   */
115 
116 
117 /* Private function prototypes -----------------------------------------------*/
118 
119 /* Exported functions --------------------------------------------------------*/
120 /** @addtogroup DAC_LL_Exported_Functions
121   * @{
122   */
123 
124 /** @addtogroup DAC_LL_EF_Init
125   * @{
126   */
127 
128 /**
129   * @brief  De-initialize registers of the selected DAC instance
130   *         to their default reset values.
131   * @param  DACx DAC instance
132   * @retval An ErrorStatus enumeration value:
133   *          - SUCCESS: DAC registers are de-initialized
134   *          - ERROR: not applicable
135   */
LL_DAC_DeInit(DAC_TypeDef * DACx)136 ErrorStatus LL_DAC_DeInit(DAC_TypeDef *DACx)
137 {
138   /* Check the parameters */
139   assert_param(IS_DAC_ALL_INSTANCE(DACx));
140 
141   /* Force reset of DAC1 clock */
142   LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_DAC1);
143 
144   /* Release reset of DAC1 clock */
145   LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_DAC1);
146   return SUCCESS;
147 }
148 
149 /**
150   * @brief  Initialize some features of DAC instance.
151   * @note   The setting of these parameters by function @ref LL_DAC_Init()
152   *         is conditioned to DAC state:
153   *         DAC instance must be disabled.
154   * @param  DACx DAC instance
155   * @param  DAC_Channel This parameter can be one of the following values:
156   *         @arg @ref LL_DAC_CHANNEL_1
157   *         @arg @ref LL_DAC_CHANNEL_2 (1)
158   *
159   *         (1) On this STM32 serie, parameter not available on all devices.
160   *             Refer to device datasheet for channels availability.
161   * @param  DAC_InitStruct Pointer to a @ref LL_DAC_InitTypeDef structure
162   * @retval An ErrorStatus enumeration value:
163   *          - SUCCESS: DAC registers are initialized
164   *          - ERROR: DAC registers are not initialized
165   */
LL_DAC_Init(DAC_TypeDef * DACx,uint32_t DAC_Channel,LL_DAC_InitTypeDef * DAC_InitStruct)166 ErrorStatus LL_DAC_Init(DAC_TypeDef *DACx, uint32_t DAC_Channel, LL_DAC_InitTypeDef *DAC_InitStruct)
167 {
168   ErrorStatus status = SUCCESS;
169 
170   /* Check the parameters */
171   assert_param(IS_DAC_ALL_INSTANCE(DACx));
172   assert_param(IS_LL_DAC_CHANNEL(DACx, DAC_Channel));
173   assert_param(IS_LL_DAC_TRIGGER_SOURCE(DAC_InitStruct->TriggerSource));
174   assert_param(IS_LL_DAC_OUTPUT_BUFFER(DAC_InitStruct->OutputBuffer));
175   assert_param(IS_LL_DAC_WAVE_AUTO_GENER_MODE(DAC_InitStruct->WaveAutoGeneration));
176   if (DAC_InitStruct->WaveAutoGeneration != LL_DAC_WAVE_AUTO_GENERATION_NONE)
177   {
178     assert_param(IS_LL_DAC_WAVE_AUTO_GENER_CONFIG(DAC_InitStruct->WaveAutoGenerationConfig));
179   }
180 
181   /* Note: Hardware constraint (refer to description of this function)        */
182   /*       DAC instance must be disabled.                                     */
183   if(LL_DAC_IsEnabled(DACx, DAC_Channel) == 0U)
184   {
185     /* Configuration of DAC channel:                                          */
186     /*  - TriggerSource                                                       */
187     /*  - WaveAutoGeneration                                                  */
188     /*  - OutputBuffer                                                        */
189     if (DAC_InitStruct->WaveAutoGeneration != LL_DAC_WAVE_AUTO_GENERATION_NONE)
190     {
191       MODIFY_REG(DACx->CR,
192                  (  DAC_CR_TSEL1
193                   | DAC_CR_WAVE1
194                   | DAC_CR_MAMP1
195                   | DAC_CR_BOFF1
196                  ) << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)
197                 ,
198                  (  DAC_InitStruct->TriggerSource
199                   | DAC_InitStruct->WaveAutoGeneration
200                   | DAC_InitStruct->WaveAutoGenerationConfig
201                   | DAC_InitStruct->OutputBuffer
202                  ) << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)
203                 );
204     }
205     else
206     {
207       MODIFY_REG(DACx->CR,
208                  (  DAC_CR_TSEL1
209                   | DAC_CR_WAVE1
210                   | DAC_CR_BOFF1
211                  ) << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)
212                 ,
213                  (  DAC_InitStruct->TriggerSource
214                   | LL_DAC_WAVE_AUTO_GENERATION_NONE
215                   | DAC_InitStruct->OutputBuffer
216                  ) << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)
217                 );
218     }
219   }
220   else
221   {
222     /* Initialization error: DAC instance is not disabled.                    */
223     status = ERROR;
224   }
225   return status;
226 }
227 
228 /**
229   * @brief Set each @ref LL_DAC_InitTypeDef field to default value.
230   * @param DAC_InitStruct pointer to a @ref LL_DAC_InitTypeDef structure
231   *                       whose fields will be set to default values.
232   * @retval None
233   */
LL_DAC_StructInit(LL_DAC_InitTypeDef * DAC_InitStruct)234 void LL_DAC_StructInit(LL_DAC_InitTypeDef *DAC_InitStruct)
235 {
236   /* Set DAC_InitStruct fields to default values */
237   DAC_InitStruct->TriggerSource            = LL_DAC_TRIG_SOFTWARE;
238   DAC_InitStruct->WaveAutoGeneration       = LL_DAC_WAVE_AUTO_GENERATION_NONE;
239   /* Note: Parameter discarded if wave auto generation is disabled,           */
240   /*       set anyway to its default value.                                   */
241   DAC_InitStruct->WaveAutoGenerationConfig = LL_DAC_NOISE_LFSR_UNMASK_BIT0;
242   DAC_InitStruct->OutputBuffer             = LL_DAC_OUTPUT_BUFFER_ENABLE;
243 }
244 
245 /**
246   * @}
247   */
248 
249 /**
250   * @}
251   */
252 
253 /**
254   * @}
255   */
256 
257 #endif /* DAC */
258 
259 /**
260   * @}
261   */
262 
263 #endif /* USE_FULL_LL_DRIVER */
264 
265 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
266