Set blackbox file handler to NULL after closing file
[inav.git] / lib / main / STM32H7 / Drivers / STM32H7xx_HAL_Driver / Release_Notes.html
blobbc59796291aa2d8c244d3258674a80e1fe237360
1 <!DOCTYPE html>
2 <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
3 <head>
4 <meta charset="utf-8" />
5 <meta name="generator" content="pandoc" />
6 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
7 <title>Release Notes for STM32H7xx HAL Drivers</title>
8 <style type="text/css">
9 code{white-space: pre-wrap;}
10 span.smallcaps{font-variant: small-caps;}
11 span.underline{text-decoration: underline;}
12 div.column{display: inline-block; vertical-align: top; width: 50%;}
13 </style>
14 <link rel="stylesheet" href="_htmresc/mini-st.css" />
15 <!--[if lt IE 9]>
16 <script src="//cdnjs.cloudflare.com/ajax/libs/html5shiv/3.7.3/html5shiv-printshiv.min.js"></script>
17 <![endif]-->
18 </head>
19 <body>
20 <div class="row">
21 <div class="col-sm-12 col-lg-4">
22 <div class="card fluid">
23 <div class="sectione dark">
24 <center>
25 <h1 id="release-notes-for-stm32h7xx-hal-drivers"><strong>Release Notes for STM32H7xx HAL Drivers</strong></h1>
26 <p>Copyright © 2017 STMicroelectronics<br />
27 </p>
28 <a href="https://www.st.com" class="logo"><img src="_htmresc/st_logo.png" alt="ST logo" /></a>
29 </center>
30 </div>
31 </div>
32 <h1 id="license"><strong>License</strong></h1>
33 This software component is licensed by ST under BSD 3-Clause license, the “License”; You may not use this component except in compliance with the License. You may obtain a copy of the License at:
34 <center>
35 <a href="https://opensource.org/licenses/BSD-3-Clause">https://opensource.org/licenses/BSD-3-Clause</a>
36 </center>
37 </div>
38 <div class="col-sm-12 col-lg-8">
39 <h1 id="update-history"><strong>Update History</strong></h1>
40 <div class="collapse">
41 <input type="checkbox" id="collapse-section8" checked aria-hidden="true"> <label for="collapse-section8" aria-hidden="true"><strong>V1.7.0 / 06-December-2019</strong></label>
42 <div>
43 <h2 id="main-changes">Main Changes</h2>
44 <ul>
45 <li>Official release with support of STM32H7A3/B3xx/B0xx new devices<br />
46 </li>
47 <li>General updates to fix known defects and implementation enhancements</li>
48 <li><strong>HAL</strong>: generic
49 <ul>
50 <li>stm32h7xx_hal.h:
51 <ul>
52 <li>Add __HAL_SYSCFG_FASTMODEPLUS_ENABLE and __HAL_SYSCFG_FASTMODEPLUS_DISABLE macros allowing to enable/disable the I2C Fast-mode Plus driving capability
53 <ul>
54 <li>This feature is available on STM32H7A3/B3xx/B0xx devices only</li>
55 </ul></li>
56 <li>Add HAL_SYSCFG_VDDMMC_CompensationCodeConfig API allowing to configure the VDDMMC compensation<br />
57 </li>
58 </ul></li>
59 <li>stm32h7xx_hal_conf_template.h:
60 <ul>
61 <li>Add support for HAL DTS, GFXMMU, OSPI, PSSI (HAL modules enabling, header files inclusion and register callback activation)</li>
62 </ul></li>
63 <li>stm32h7xx_hal.c:
64 <ul>
65 <li>Update HAL_SetTickFreq API to restore current tick frequency when call to HAL_InitTick fails</li>
66 <li>Add HAL_SYSCFG_VDDMMC_CompensationCodeConfig API implementation</li>
67 <li>Fix HAL_EXTI_D1_ClearFlag and HAL_EXTI_D2_ClearFlag APIs implementation: using direct write operation (instead of read/modify/write)</li>
68 </ul></li>
69 </ul></li>
70 <li><strong>HAL/LL ADC</strong>:
71 <ul>
72 <li>stm32h7xx_hal_adc.h:
73 <ul>
74 <li>Add ADC_CHANNEL_DAC2CH1_ADC2 definition for DAC2 to ADC connection (DAC2 available on STM32H7A3/B3xx/B0xx devices only)</li>
75 <li>Update ADC_IS_SYNCHRONOUS_CLOCK_MODE macro implementation (ADC3 not available on STM32H7A3/B3xx/B0xx devices)</li>
76 </ul></li>
77 <li>stm32h7xx_hal_adc_ex.h:
78 <ul>
79 <li>ADC_IS_INDEPENDENT macro available only when device supports ADC3</li>
80 <li>Update ADC_OFFSET_SHIFT_RESOLUTION , ADC_AWD1THRESHOLD_SHIFT_RESOLUTION and ADC_AWD23THRESHOLD_SHIFT_RESOLUTION macros implemenation to support STM32H7A3/B3xx/B0xx new devices<br />
81 </li>
82 <li>ADC3_COMMON_REGISTER macro available only when device supports ADC3</li>
83 <li>Update ADC_MASTER_REGISTER macro to consider ADC3 when it is available only</li>
84 <li>ADC3_NONMULTIMODE_OR_MULTIMODEMASTER macro available only when device supports ADC3</li>
85 <li>Update ADC_INDEPENDENT_OR_NONMULTIMODEREGULAR_SLAVE and ADC_INDEPENDENT_OR_NONMULTIMODEINJECTED_SLAVE macro to consider ADC3 when it is available only</li>
86 <li>Update ADC_TEMPERATURE_SENSOR_INSTANCE, ADC_BATTERY_VOLTAGE_INSTANCE and ADC_VREFINT_INSTANCE to consider ADC3 when it is available and if not ADC2 (case of STM32H7A3/B3xx/B0xx devices)</li>
87 </ul></li>
88 <li>stm32h7xx_ll_adc.h:
89 <ul>
90 <li>Adapt definition of LL_ADC_RESOLUTION_8B for STM32H7A3/B3xx/B0xx devices</li>
91 <li>ADC3 definitions are conditionned by the ADC3 instance availability (according to CMSIS device mapping, ADC3 is not available on STM32H7A3/B3xx/B0xx devices)</li>
92 <li>Add DAC2 LL_ADC_CHANNEL_DAC2CH1_ADC2 definition</li>
93 </ul></li>
94 <li>stm32h7xx_hal_adc.c:
95 <ul>
96 <li>Update HAL_ADC_Init implementation to consider STM32H7A3/B3xx/B0xx devices (ADC_VER_V5_3)</li>
97 <li>Update HAL_ADC_Start_DMA to add configuration of Data transfer mode</li>
98 <li>Update HAL_ADC_ConfigChannel implemenation to consider ADC3 when it is available only</li>
99 <li>Update ADC_ConfigureBoostMode implemenation to consider frequency ranges for STM32H7A3/B3xx/B0xx devices (ADC_VER_V5_3)</li>
100 </ul></li>
101 <li>stm32h7xx_hal_adc_ex.c:
102 <ul>
103 <li>Update HAL_ADCEx_LinearCalibration_GetValue and HAL_ADCEx_LinearCalibration_SetValue APIs implementation to stop the Ongoing conversion, if any, before the calibration. In this case the convertion is retsored after the calibration</li>
104 <li>Update HAL_ADCEx_LinearCalibration_FactorLoad API implementation to consider ADC2 and ADC3 in addition to ADC1</li>
105 </ul></li>
106 </ul></li>
107 <li><strong>HAL/LL COMP</strong>:
108 <ul>
109 <li>stm32h7xx_hal_comp.h:
110 <ul>
111 <li>Add definition of COMP_INPUT_PLUS_DAC2_CH1 (DAC2 available on STM32H7A3/B3xx/B0xx devices only)</li>
112 <li>Add definition of COMP_INPUT_MINUS_TPSENS_DAC2CH1 and COMP_INPUT_MINUS_VBAT_VDDAP (available on STM32H7A3/B3xx/B0xx devices only)</li>
113 <li>Update IS_COMP_INPUT_PLUS and IS_COMP_INPUT_MINUS macros according to the new above defines</li>
114 </ul></li>
115 <li>stm32h7xx_hal_comp.c:
116 <ul>
117 <li>Update HAL_COMP_Init API implementation to
118 <ul>
119 <li>Support new inputs available on STM32H7A3/B3xx/B0xx devices</li>
120 <li>Add EXTI configuration for Coretx-M7 and Coretx-M4 (in case of Dual Core device)</li>
121 </ul></li>
122 </ul></li>
123 <li>stm32h7xx_ll_comp.h:
124 <ul>
125 <li>Add definition of LL_COMP_INPUT_MINUS_TPSENS_DAC2CH1 (DAC2 available on STM32H7A3/B3xx/B0xx devices only)<br />
126 </li>
127 <li>Add definition of LL_COMP_INPUT_MINUS_VBAT_VDDAP (DAC2 available on STM32H7A3/B3xx/B0xx devices only)</li>
128 <li>Add definition of LL_COMP_AF_PA6 to LL_COMP_AF_PK2 Comparator output definitions</li>
129 <li>Update LL_COMP_ConfigInputs, LL_COMP_SetInputPlus and LL_COMP_GetInputPlus APIs implementation with support of STM32H7A3/B3xx/B0xx devices</li>
130 <li>Add LL_COMP_SetOutputAlternateFunction and LL_COMP_GetOutputAlternateFunction allowing to Set/Get the output alternate function in the Option register</li>
131 </ul></li>
132 </ul></li>
133 <li><strong>HAL CRYP</strong>:
134 <ul>
135 <li>stm32h7xx_hal_cryp.h:
136 <ul>
137 <li>Add KeyIVConfigSkip parameter to CRYP_ConfigTypeDef structure: allowing user to skip IV and key setting when processing large buffers by chunks</li>
138 <li>Add definition of CRYP_KEYIVCONFIG_ALWAYS and CRYP_KEYIVCONFIG_ONCE used to fill KeyIVConfigSkip configuration parameter<br />
139 </li>
140 </ul></li>
141 <li>stm32h7xx_hal_cryp.c:
142 <ul>
143 <li>Update HAL_CRYP_Encrypt/HAL_CRYP_Decrypt HAL_CRYP_Encrypt_IT/HAL_CRYP_Decrypt_IT and HAL_CRYP_Encrypt_DMA/HAL_CRYP_Decrypt_DMA APIs to support large buffers encryption/decryption by chunks without reconfiguring the Key or the Initialization Vector between each API call</li>
144 <li>Update to support user input/output buffers size that is not multiple of 4 words (size of the CRYP peripheral FIFO)</li>
145 </ul></li>
146 </ul></li>
147 <li><strong>HAL/LL DAC</strong>:
148 <ul>
149 <li>stm32h7xx_hal_dac.h:
150 <ul>
151 <li>Add support for DAC2 instance (available on STM32H7A3/B3xx/B0xx devices only)</li>
152 <li>HAL_DAC_MSP_INIT_CB_ID and HAL_DAC_MSP_DEINIT_CB_ID callaback IDs respectively changed to HAL_DAC_MSPINIT_CB_ID and HAL_DAC_MSPDEINIT_CB_ID:
153 <ul>
154 <li>Backward compatibility ensured by the stm32_hal_legacy header file</li>
155 </ul></li>
156 <li>HRTIM tiggers definitions (DAC_TRIGGER_HR1_TRGO1 and DAC_TRIGGER_HR1_TRGO2) are available only for devices where the HRTIM peripheral is present
157 <ul>
158 <li>HRTIM peripheral not present on STM32H7A3/B3xx/B0xx devices</li>
159 </ul></li>
160 <li>DAC_TRIGGER_LP1_OUT and DAC_TRIGGER_LP2_OUT triggers defines renamed respectively to DAC_TRIGGER_LPTIM1_OUT and DAC_TRIGGER_LPTIM2_OUT
161 <ul>
162 <li>Backward compatibility ensured by the stm32_hal_legacy header file</li>
163 </ul></li>
164 <li>Add DAC_TRIGGER_LPTIM3_OUT trigger definition: available for DAC2 instance that is present on STM32H7A3/B3xx/B0xx devices only</li>
165 <li>DAC_CHIPCONNECT_DISABLE and DAC_CHIPCONNECT_ENABLE definitions respectively changed to DAC_CHIPCONNECT_EXTERNAL and DAC_CHIPCONNECT_INTERNAL
166 <ul>
167 <li>Backward compatibility ensured by the stm32_hal_legacy header file</li>
168 </ul></li>
169 </ul></li>
170 <li>stm32h7xx_hal_dac_ex.h:
171 <ul>
172 <li>Add support for DAC2 instance (available on STM32H7A3/B3xx/B0xx devices only)</li>
173 <li>Update IS_DAC_TRIGGER macro implementation to consider HRTIM and DAC2 triggers when it is available</li>
174 <li>Update IS_DAC_CHIP_CONNECTION macro implementation to consider new DAC_CHIPCONNECT_EXTERNAL and DAC_CHIPCONNECT_INTERNAL defines</li>
175 <li>Add HAL_DACEx_DualStart, HAL_DACEx_DualStop, HAL_DACEx_DualStart_DMA, HAL_DACEx_DualStop_DMA, HAL_DACEx_DualSetValue and HAL_DACEx_DualGetValue APIs</li>
176 </ul></li>
177 <li>stm32h7xx_hal_dac.c:
178 <ul>
179 <li>Update HAL_DAC_ConfigChannel implementation to consider DAC_CHIPCONNECT_EXTERNAL and DAC_CHIPCONNECT_INTERNAL defines</li>
180 </ul></li>
181 <li>stm32h7xx_hal_dac_ex.c:
182 <ul>
183 <li>Add implemenation of HAL_DACEx_DualStart, HAL_DACEx_DualStop, HAL_DACEx_DualStart_DMA, HAL_DACEx_DualStop_DMA, HAL_DACEx_DualSetValue and HAL_DACEx_DualGetValue APIs</li>
184 </ul></li>
185 <li>stm32h7xx_ll_dac.h: Update to support STM32H7A3/B3xx/B0xx devices New DAC triggers</li>
186 </ul></li>
187 <li><strong>HAL DCMI</strong>:
188 <ul>
189 <li>stm32h7xx_hal_dcmi.h:
190 <ul>
191 <li>Add definition of DCMI_SyncUnmaskTypeDef structure used with new HAL_DCMI_ConfigSyncUnmask API</li>
192 <li>Add HAL_DCMI_ConfigSyncUnmask API</li>
193 </ul></li>
194 <li>stm32h7xx_hal_dcmi.c:
195 <ul>
196 <li>Add implemenation HAL_DCMI_ConfigSyncUnmask API</li>
197 </ul></li>
198 </ul></li>
199 <li><strong>HAL DFSDM</strong>:
200 <ul>
201 <li>stm32h7xx_hal_dfsdm.h:
202 <ul>
203 <li>Add inclusion of stm32h7xx_hal_dfsdm_ex.h new file</li>
204 </ul></li>
205 <li>stm32h7xx_hal_dfsdm_ex.h:
206 <ul>
207 <li>New extension file with HAL_DFDSMEx_ChannelSetPulsesSkipping and HAL_DFDSMEx_ChannelGetPulsesSkipping APIs</li>
208 </ul></li>
209 <li>stm32h7xx_hal_dfsdm.c:
210 <ul>
211 <li>Add support of DFSDM2_Channel0 available on STM32H7A3/B3xx/B0xx devices</li>
212 </ul></li>
213 <li>stm32h7xx_hal_dfsdm_ex.c:
214 <ul>
215 <li>New extension file with HAL_DFDSMEx_ChannelSetPulsesSkipping and HAL_DFDSMEx_ChannelGetPulsesSkipping APIs implementation</li>
216 </ul></li>
217 </ul></li>
218 <li><strong>HAL/LL DMA</strong>:
219 <ul>
220 <li>stm32h7xx_hal_dma.h:
221 <ul>
222 <li>Add PSSI, DAC2, UART9 and USART10 requests (PSSI and DAC2 peripherals available on STM32H7A3/B3xx/B0xx devices only)</li>
223 <li>HRTIM, SAI3, SAI4, ADC3 requests are available only when these peripherals are present on the given device (through CMSIS device mapping)</li>
224 <li>Update to support BDMA1 and BDMA2 available on STM32H7A3/B3xx/B0xx devices</li>
225 </ul></li>
226 <li>stm32h7xx_hal_dma_ex.h:
227 <ul>
228 <li>DMAMUX request generator defines HAL_DMAMUX2_REQ_GEN_LPTIM4_WKUP, HAL_DMAMUX2_REQ_GEN_LPTIM5_WKUP and ADC3 are available when LPTIM4, LPTIM5 and ADC3 are respectively available</li>
229 </ul></li>
230 <li>stm32h7xx_hal_dma.c/stm32h7xx_hal_dma_ex.c:
231 <ul>
232 <li>Update to support BDMA1 and BDMA2 available on STM32H7A3/B3xx/B0xx devices</li>
233 </ul></li>
234 <li>stm32h7xx_ll_bdma.h:
235 <ul>
236 <li>Add support for BDMA1 and BDMA2 available on STM32H7A3/B3xx/B0xx devices</li>
237 </ul></li>
238 <li>stm32h7xx_ll_dmamux.h:
239 <ul>
240 <li>Add Add PSSI, DAC2, UART9 and USART10 requests (PSSI and DAC2 peripherals available on STM32H7A3/B3xx/B0xx devices only)</li>
241 <li>HRTIM, SAI3, SAI4, ADC3 requests are available only when these peripherals are present on the given device (through CMSIS device mapping)</li>
242 </ul></li>
243 </ul></li>
244 <li><strong>HAL/LL DMA2D</strong>:
245 <ul>
246 <li>stm32h7xx_hal_dma2d.h:
247 <ul>
248 <li>Update DMA2D_InitTypeDef initialization structure with BytesSwap and LineOffsetMode allowing respectively to support byte swap and line offset modes</li>
249 <li>Add DMA2D_M2M_BLEND_FG and DMA2D_M2M_BLEND_BG definitions allowing to support blending with fixed foreground/background colors</li>
250 <li>Add DMA2D_LOM_PIXELS and DMA2D_LOM_BYTES definitions allowing to support Line Offset mode feature</li>
251 <li>Add DMA2D_BYTES_REGULAR and DMA2D_BYTES_SWAP definitions allowing to support Byte Swap feature</li>
252 <li>Add HAL_DMA2D_CLUTStartLoad and HAL_DMA2D_CLUTStartLoad_IT APIs: same as HAL_DMA2D_CLUTStartLoad/HAL_DMA2D_CLUTStartLoad_IT APIs but with the parameter CLUTCfg passed by address instead of variable</li>
253 </ul></li>
254 <li>stm32h7xx_hal_dma2d.c:
255 <ul>
256 <li>Update HAL_DMA2D_Init implementation to support byte swap and line offset modes</li>
257 <li>Update HAL_DMA2D_BlendingStart and HAL_DMA2D_BlendingStart_IT to support blending with fixed foreground/background colors</li>
258 <li>Add implementation of HAL_DMA2D_CLUTStartLoad and HAL_DMA2D_CLUTStartLoad_IT APIs</li>
259 </ul></li>
260 <li>stm32h7xx_ll_dma2d.h:
261 <ul>
262 <li>Update LL_DMA2D_InitTypeDef initialization structure with OutputSwapMode and LineOffsetMode allowing respectively to support byte swap and line offset modes<br />
263 </li>
264 <li>Add LL_DMA2D_MODE_M2M_BLEND_FIXED_COLOR_FG and LL_DMA2D_MODE_M2M_BLEND_FIXED_COLOR_BG definitions allowing to support blending with fixed foreground/background colors</li>
265 <li>Add LL_DMA2D_SWAP_MODE_REGULAR and LL_DMA2D_SWAP_MODE_TWO_BY_TWO definitions allowing to support Byte Swap feature</li>
266 <li>Add LL_DMA2D_LINE_OFFSET_PIXELS and LL_DMA2D_LINE_OFFSET_BYTES definitions allowing to support Line Offset mode feature</li>
267 <li>Add LL_DMA2D_SetOutputSwapMode and LL_DMA2D_GetOutputSwapMode APIs</li>
268 <li>Add LL_DMA2D_SetLineOffsetMode and LL_DMA2D_GetLineOffsetMode APIs</li>
269 </ul></li>
270 <li>stm32h7xx_ll_dma2d.c:
271 <ul>
272 <li>Update LL_DMA2D_StructInit API implementation to support byte swap and line offset modes</li>
273 </ul></li>
274 </ul></li>
275 <li><strong>HAL DTS</strong>:
276 <ul>
277 <li>Add New HAL DTS driver stm32h7xx_hal_dts.h/stm32h7xx_hal_dts.c (Digital Temperature Sensor). This peripheral is available on STM32H7A3/B3xx/B0xx devices only</li>
278 </ul></li>
279 <li><strong>HAL/LL EXTI</strong>:
280 <ul>
281 <li>Update to consider STM32H7A3/B3xx/B0xx devices EXTI lines</li>
282 <li>Update EXTI Pend Clear Sources considering STM32H7A3/B3xx/B0xx devices: LPTIM2 and LPTIM3 used as SRD domain wakeup pend clear source versus LPTIM4/LPTIM5 in the legacy devices</li>
283 </ul></li>
284 <li><strong>HAL FLASH</strong>:
285 <ul>
286 <li>Update to consider Flash operations on STM32H7A3/B3xx/B0xx devices</li>
287 </ul></li>
288 <li><strong>HAL GFXMMU</strong>:
289 <ul>
290 <li>Add GFXMMU HAL driver stm32h7xx_hal_gfxmmu.h/stm32h7xx_hal_gfxmmu.c. This peripheral is available on STM32H7A3/B3xx/B0xx devices only</li>
291 </ul></li>
292 <li><strong>HAL GPIO</strong>:
293 <ul>
294 <li>Update GPIO Alternate functions definitions (in stm32h7xx_hal_gpio_ex.h file) for STM32H7A3/B3xx/B0xx devices</li>
295 </ul></li>
296 <li><strong>HAL HASH</strong>:
297 <ul>
298 <li>stm32h7xx_hal_hash.h:
299 <ul>
300 <li>Add IS_HASH_POLLING_MULTIBUFFER_SIZE macro to check that input data buffer size is valid for multi-buffer HASH</li>
301 <li>Add HAL_HASH_SHA1_Accmlt_IT/HAL_HASH_SHA1_Accmlt_End_IT and HAL_HASH_MD5_Accmlt_IT/HAL_HASH_MD5_Accmlt_End_IT APIs</li>
302 </ul></li>
303 <li>stm32h7xx_hal_hash_ex.h:
304 <ul>
305 <li>Add HAL_HASHEx_SHA224_Accmlt/HAL_HASHEx_SHA224_Accmlt_End, HAL_HASHEx_SHA256_Accmlt/HAL_HASHEx_SHA256_Accmlt_End APIs</li>
306 <li>Add HAL_HASHEx_SHA224_Accmlt_IT/HAL_HASHEx_SHA224_Accmlt_End_IT, HAL_HASHEx_SHA256_Accmlt_IT/HAL_HASHEx_SHA256_Accmlt_End_IT APIs</li>
307 </ul></li>
308 <li>stm32h7xx_hal_hash.c:
309 <ul>
310 <li>Add implementation of HAL_HASH_SHA1_Accmlt_IT/HAL_HASH_SHA1_Accmlt_End_IT and HAL_HASH_MD5_Accmlt_IT/HAL_HASH_MD5_Accmlt_End_IT APIs</li>
311 </ul></li>
312 <li>stm32h7xx_hal_hash_ex.c:
313 <ul>
314 <li>Add implementation of HAL_HASHEx_SHA224_Accmlt/HAL_HASHEx_SHA224_Accmlt_End, HAL_HASHEx_SHA256_Accmlt/HAL_HASHEx_SHA256_Accmlt_End APIs</li>
315 <li>Add implementation of HAL_HASHEx_SHA224_Accmlt_IT/HAL_HASHEx_SHA224_Accmlt_End_IT, HAL_HASHEx_SHA256_Accmlt_IT/HAL_HASHEx_SHA256_Accmlt_End_IT APIs</li>
316 </ul></li>
317 </ul></li>
318 <li><strong>HAL I2S</strong>:
319 <ul>
320 <li>stm32h7xx_hal_i2s.h:
321 <ul>
322 <li>Add definition of HAL_I2S_ERROR_NO_OGT and HAL_I2S_ERROR_NOT_SUPPORTED errors<br />
323 </li>
324 </ul></li>
325 <li>stm32h7xx_hal_i2s.c:
326 <ul>
327 <li>Add support of I2S mode on SPI6 peripheral (available on STM32H7A3/B3xx/B0xx devices only)</li>
328 <li>Fix GCC compilation warning on HAL_I2S_Transmit/HAL_I2S_Receive due to 16 bits access on TXDR/RXDR 32 bits registers</li>
329 <li>Update and fix HAL_I2S_DMAPause/HAL_I2S_DMAResume APIs</li>
330 <li>Update HAL_I2S_IRQHandler APIs to handle I2S_FLAG_OVR, I2S_FLAG_UDR and I2S_FLAG_FRE error flags</li>
331 </ul></li>
332 <li>stm32h7xx_hal_i2s_ex.h/stm32h7xx_hal_i2s_ex.c : These files are empty as full duplex feature is not available in this release</li>
333 </ul></li>
334 <li><strong>HAL/LL LPTIM</strong>:
335 <ul>
336 <li>stm32h7xx_hal_lptim.h:
337 <ul>
338 <li>LPTIM_INPUT1SOURCE_SAI1_FSA and LPTIM_INPUT1SOURCE_SAI1_FSB replaced respectively by LPTIM_INPUT1SOURCE_SAI4_FSA and LPTIM_INPUT1SOURCE_SAI4_FSB to be aligned with the Reference Manual (<strong>Compatibility break</strong>)</li>
339 </ul></li>
340 <li>stm32h7xx_ll_lptim.h:
341 <ul>
342 <li>Add definition of LL_LPTIM_TRIG_SOURCE_LPTIM2 to LL_LPTIM_TRIG_SOURCE_DFSDM2_BRK trigger sources</li>
343 </ul></li>
344 </ul></li>
345 <li><strong>HAL/LL MDMA</strong>:
346 <ul>
347 <li>stm32h7xx_hal_mdma.h:
348 <ul>
349 <li>Add definitions of OctoSPI peripheral requests when available (OctoSPI available on STM32H7A3/B3xx/B0xx devices only)</li>
350 <li>Add definitions of DSI peripheral requests when available (DSI available on STM32H747/757 devices only)</li>
351 <li>Add definitions of MDMA_REQUEST_SDMMC1_DMA_ENDBUFFER and MDMA_REQUEST_SDMMC1_COMMAND_END requests</li>
352 <li>Delimit definition of LTDC, QUADSPI and JPEG requests by the peripherals availability</li>
353 </ul></li>
354 <li>stm32h7xx_hal_mdma.c:
355 <ul>
356 <li>Update HAL_MDMA_DeInit APIs implementation to avoid returning error when the MDMA state is busy: the MDMA will be deinitialized in any case when calling HAL_MDMA_DeInit</li>
357 </ul></li>
358 <li>stm32h7xx_ll_mdma.h:
359 <ul>
360 <li>Add definitions of OctoSPI peripheral requests when available (OctoSPI available on STM32H7A3/B3xx/B0xx devices only)</li>
361 <li>Add definitions of DSI peripheral requests when available (DSI available on STM32H747/757 devices only)</li>
362 <li>Add definitions of MDMA_REQUEST_SDMMC1_DMA_ENDBUFFER and MDMA_REQUEST_SDMMC1_COMMAND_END requests</li>
363 <li>Delimit definition of LTDC, QUADSPI and JPEG requests by the peripherals availability</li>
364 </ul></li>
365 </ul></li>
366 <li><strong>HAL MMC</strong>:
367 <ul>
368 <li>stm32h7xx_hal_mmc_ex.h:
369 <ul>
370 <li>APIs HAL_MMCEx_Read_DMADoubleBuffer0CpltCallback, HAL_MMCEx_Read_DMADoubleBuffer1CpltCallback, HAL_MMCEx_Write_DMADoubleBuffer0CpltCallback and HAL_MMCEx_Write_DMADoubleBuffer1CpltCallback respectevely renamed to HAL_MMCEx_Read_DMADoubleBuf0CpltCallback, HAL_MMCEx_Read_DMADoubleBuf1CpltCallback, HAL_MMCEx_Write_DMADoubleBuf0CpltCallback and HAL_MMCEx_Write_DMADoubleBuf1CpltCallback:</li>
371 <li>Backward compatibility ensured by the stm32_hal_legacy header file</li>
372 </ul></li>
373 <li>stm32h7xx_hal_mmc.c:
374 <ul>
375 <li>Fix HAL_MMC_ReadBlocks/HAL_MMC_WriteBlocks, HAL_MMC_ReadBlocks_IT/HAL_MMC_WriteBlocks_IT and HAL_MMC_ReadBlocks_DMA/HAL_MMC_WriteBlocks_DMA APIs implementation for DDR mode</li>
376 </ul></li>
377 <li>stm32h7xx_hal_mmc_ex.c:
378 <ul>
379 <li>Fix HAL_MMCEx_ConfigDMAMultiBuffer API implementation regarding DMA block size</li>
380 </ul></li>
381 </ul></li>
382 <li><strong>HAL/LL OPAMP</strong>:
383 <ul>
384 <li>stm32h7xx_hal_opamp.h:
385 <ul>
386 <li>APIs HAL_OPAMP_MSP_INIT_CB_ID/HAL_OPAMP_MSP_DEINIT_CB_ID enumeration respectively renamed to HAL_OPAMP_MSPINIT_CB_ID/HAL_OPAMP_MSPDEINIT_CB_ID
387 <ul>
388 <li>Backward compatibility ensured by the stm32_hal_legacy header file</li>
389 </ul></li>
390 <li>Add definition of OPAMP_NONINVERTINGINPUT_DAC2_CH input trigger conditioned by the DAC2 peripheral availability (DAC2 peripheral available on STM32H7A3/B3xx/B0xx devices only)</li>
391 </ul></li>
392 <li>stm32h7xx_hal_opamp.c:
393 <ul>
394 <li>Update HAL_OPAMP_DeInit to disabled first the OPAMP before resetting the configuration</li>
395 </ul></li>
396 <li>stm32h7xx_ll_opamp.h:
397 <ul>
398 <li>Add definition of LL_OPAMP_INPUT_NONINVERT_DAC2 input trigger conditioned by the DAC2 peripheral availability (DAC2 peripheral available on STM32H7A3/B3xx/B0xx devices</li>
399 </ul></li>
400 </ul></li>
401 <li><p><strong>HAL OSPI</strong>: New HAL driver stm32h7xx_hal_ospi.h/stm32h7xx_hal_ospi.c to handle OctoSPI peripheral (available on STM32H7A3/B3xx/B0xx devices only)</p></li>
402 <li><p><strong>HAL OTFDEC</strong>: New HAL driver stm32h7xx_hal_otfdec.h/stm32h7xx_hal_otfdec.c to handle OTFDEC peripheral (available on STM32H7A3/B3xx/B0xx devices only)</p></li>
403 <li><p><strong>HAL PSSI</strong>: New HAL driver stm32h7xx_hal_pssi.h/stm32h7xx_hal_pssi.c to handle PSSI peripheral (available on STM32H7A3/B3xx/B0xx devices only)</p></li>
404 <li><strong>HAL/LL PWR</strong>: Update to handle STM32H7A3/B3xx/B0xx devices
405 <ul>
406 <li>2 power domains only (versus 3 in legacy STM32H7 devices)</li>
407 <li>VOS0 voltage scalling management</li>
408 <li>Wake up flag management</li>
409 <li>STOP2 Low Power mode management</li>
410 </ul></li>
411 <li><strong>HAL RAMECC</strong>:
412 <ul>
413 <li>stm32h7xx_hal_ramecc.h:
414 <ul>
415 <li>Add definition of RAMECC Error Codes</li>
416 <li>Add __HAL_RAMECC_GET_GLOBAL_IT_SOURCE, __HAL_RAMECC_GET_MONITOR_IT_SOURCE and __HAL_RAMECC_GET_IT_SOURCE macros</li>
417 <li>Add HAL_RAMECC_IsECCSingleErrorDetected, HAL_RAMECC_IsECCDoubleErrorDetected APIs</li>
418 </ul></li>
419 <li>stm32h7xx_hal_ramecc.c:
420 <ul>
421 <li>Add error codes management</li>
422 <li>Add HAL_RAMECC_IsECCSingleErrorDetected, HAL_RAMECC_IsECCDoubleErrorDetected APIs implementation</li>
423 </ul></li>
424 </ul></li>
425 <li><strong>HAL/LL RCC</strong>:
426 <ul>
427 <li>stm32h7xx_hal_rcc.h: Update to support STM32H7A3/B3xx/B0xx devices</li>
428 <li>Add OCTOSPI1/2, OCTOSPIM, OTFDEC1/2, GFXMMU peripherals clock enabling/disabling, force reset/release reset macros</li>
429 <li>Update other peripherals clock macros according to the number of instance on STM32H7A3/B3xx/B0xx devices and on the legacy STM32H7 devices</li>
430 <li>stm32h7xx_hal_rcc_ex.h: Update to support STM32H7A3/B3xx/B0xx devices
431 <ul>
432 <li>Update RCC_PeriphCLKInitTypeDef structure to handle OCTOSPI1/2, OCTOSPIM, OTFDEC1/2, GFXMMU peripherals clock settings</li>
433 </ul></li>
434 <li>Update other peripherals clock defines and macros according to the number of instance on STM32H7A3/B3xx/B0xx devices and on the legacy STM32H7 devices<br />
435 </li>
436 <li>stm32h7xx_hal_rcc.c:</li>
437 <li>General update to support STM32H7A3/B3xx/B0xx devices clock configurations<br />
438 </li>
439 <li>Update HAL_RCC_DeInit to handle flash latency configuration in both cases: when increasing and decreasing latency.</li>
440 <li>Update HAL_RCC_OscConfig to:
441 <ul>
442 <li>Allow only HSI calibration when HSI is used as system source clock (attempt to disable HSI will return error in this case)</li>
443 <li>Allow reconfiguring the system clock with the same current config without returning error (useful when reconfiguring the system clock after low power mode wakeup)<br />
444 </li>
445 </ul></li>
446 <li>stm32h7xx_hal_rcc_ex.c:</li>
447 <li>General update to support STM32H7A3/B3xx/B0xx devices peripherals clock configurations</li>
448 <li>Update HAL_RCCEx_GetPeriphCLKFreq to support SAI2/SAI3 and SPI6 peripherals</li>
449 <li>stm32h7xx_ll_rcc.h: Update to support STM32H7A3/B3xx/B0xx devices
450 <ul>
451 <li>Add OCTOSPI1/2, OCTOSPIM, OTFDEC1/2, GFXMMU peripherals clock source definitions</li>
452 </ul></li>
453 <li>Update other peripherals clock source definitions according to the number of instance on STM32H7A3/B3xx/B0xx devices and on the legacy STM32H7 devices</li>
454 </ul></li>
455 <li><strong>HAL/LL RNG</strong>:
456 <ul>
457 <li>stm32h7xx_hal_rng.h: Update to support STM32H7A3/B3xx/B0xx devices</li>
458 <li>Add definition of HAL_RNG_ERROR_BUSY, HAL_RNG_ERROR_SEED and HAL_RNG_ERROR_CLOCK error codes</li>
459 <li>Add inclusion of stm32h7xx_hal_rng_ex.h extended RNG HAL driver</li>
460 <li>stm32h7xx_hal_rng_ex.h:
461 <ul>
462 <li>New HAL extended HAL driver with support of support STM32H7A3/B3xx/B0xx devices RNG features</li>
463 </ul></li>
464 <li>stm32h7xx_hal_rng.c: Update to support STM32H7A3/B3xx/B0xx devices</li>
465 <li>Update HAL_RNG_Init and HAL_RNG_DeInit APIs implementation to support STM32H7A3/B3xx/B0xx devices RNG configuration</li>
466 <li>stm32h7xx_hal_rng_ex.c:
467 <ul>
468 <li>New HAL extended HAL RNG driver with support of support STM32H7A3/B3xx/B0xx devices RNG features</li>
469 </ul></li>
470 <li>stm32h7xx_ll_rng.h:
471 <ul>
472 <li>Add definition of LL_RNG_CLKDIV_BY_1 to LL_RNG_CLKDIV_BY_32768 RNG dividers</li>
473 <li>Add new APIs support features available on STM32H7A3/B3xx/B0xx devices:
474 <ul>
475 <li>LL_RNG_EnableCondReset, LL_RNG_DisableCondReset and LL_RNG_IsEnabledCondReset</li>
476 <li>LL_RNG_ConfigLock and LL_RNG_IsConfigLocked</li>
477 <li>LL_RNG_EnableNistCompliance, LL_RNG_DisableNistCompliance and LL_RNG_IsEnabledNistCompliance</li>
478 <li>LL_RNG_SetConfig1, LL_RNG_GetConfig1, LL_RNG_SetConfig2, LL_RNG_GetConfig2, LL_RNG_SetConfig3 and LL_RNG_GetConfig3</li>
479 <li>LL_RNG_SetClockDivider and LL_RNG_GetClockDivider</li>
480 <li>LL_RNG_SetHealthConfig and LL_RNG_GetHealthConfig</li>
481 </ul></li>
482 </ul></li>
483 </ul></li>
484 <li><p><strong>HAL/LL RTC</strong>: Update to support STM32H7A3/B3xx/B0xx devices new RTC features</p></li>
485 <li><strong>HAL SAI</strong>:
486 <ul>
487 <li>Update to support STM32H7A3/B3xx/B0xx devices SAI instances:
488 <ul>
489 <li>Only SAI2 and SAI3 instances are available on STM32H7A3/B3xx/B0xx devices</li>
490 <li>SAI1/2/3/4 are available for legacy STM32H7 devices</li>
491 <li>Usage of a giving SAI instance is conditioned with its presence on the given device (according to the CMSIS device memory mapping)</li>
492 </ul></li>
493 </ul></li>
494 <li><strong>HAL SAI</strong>:
495 <ul>
496 <li>Update to support STM32H7A3/B3xx/B0xx devices SAI instances:</li>
497 </ul></li>
498 <li><strong>HAL SD</strong>:
499 <ul>
500 <li>stm32h7xx_hal_sd_ex.h:
501 <ul>
502 <li>rename HAL_SDEx_Read_DMADoubleBuffer0CpltCallback, HAL_SDEx_Read_DMADoubleBuffer1CpltCallback, HAL_SDEx_Write_DMADoubleBuffer0CpltCallback and HAL_SDEx_Write_DMADoubleBuffer1CpltCallback respectevely to HAL_SDEx_Read_DMADoubleBuf0CpltCallback, HAL_SDEx_Read_DMADoubleBuf1CpltCallback, HAL_SDEx_Write_DMADoubleBuf0CpltCallback and HAL_SDEx_Write_DMADoubleBuf1CpltCallback</li>
503 <li>Backward compatibility ensured by the stm32_hal_legacy header file<br />
504 </li>
505 </ul></li>
506 <li>stm32h7xx_hal_sd.c:
507 <ul>
508 <li>Fix HAL_SD_ReadBlocks_IT/HAL_SD_WriteBlocks_IT HAL_SD_ReadBlocks_DMA/HAL_SD_WriteBlocks_DMA APIs implementation to avoid losing data in read and dead lock in write</li>
509 </ul></li>
510 <li>stm32h7xx_hal_sd_ex.c:
511 <ul>
512 <li>Fix HAL_SDEx_ReadBlocksDMAMultiBuffer/HAL_SDEx_WriteBlocksDMAMultiBuffer APIs implementation to avoid losing data in read and dead lock in write</li>
513 </ul></li>
514 </ul></li>
515 <li><strong>HAL/LL SPI</strong>:
516 <ul>
517 <li>stm32h7xx_hal_spi.c:
518 <ul>
519 <li>Fix GCC compilation warning on HAL_SPI_Transmit/HAL_SPI_Receive, HAL_SPI_Transmit_IT/HAL_SPI_Receive_IT and HAL_SPI_TransmitReceive/HAL_SPI_TransmitReceive_IT APIs due to 16 bits access on TXDR/RXDR 32 bits registers</li>
520 <li>stm32h7xx_ll_spi.h:
521 <ul>
522 <li>Rename LL_SPI_SR_CRCERR define to LL_SPI_SR_CRCE to be aligned with the Reference Manual</li>
523 <li>Update LL_SPI_TransmitData16 to fix GCC compilation warning</li>
524 </ul></li>
525 </ul></li>
526 </ul></li>
527 <li><strong>HAL SPI</strong>:
528 <ul>
529 <li>stm32h7xx_hal_spi.c:
530 <ul>
531 <li>Fix GCC compilation war</li>
532 </ul></li>
533 </ul></li>
534 <li><strong>HAL/LL TIM</strong>:
535 <ul>
536 <li>stm32h7xx_hal_tim.h:
537 <ul>
538 <li>Add definition of TIM_UIFREMAP_DISABLE and TIM_UIFREMAP_ENABLE Interrupt Flag Remap</li>
539 <li>Add definition of TIM_ENCODERINPUTPOLARITY_RISING and TIM_ENCODERINPUTPOLARITY_FALLING Encoder Input Polarity</li>
540 <li>Add definition of TIM_TS_ITR9 to TIM_TS_ITR13 Trigger Selection</li>
541 <li>Add __HAL_TIM_UIFREMAP_ENABLE, __HAL_TIM_UIFREMAP_DISABLE and __HAL_TIM_GET_UIFCPY macros</li>
542 </ul></li>
543 <li>stm32h7xx_hal_tim_ex.h:
544 <ul>
545 <li>Rename TIM_TIM1_ETR_ADC2_AWD1, TIM_TIM1_ETR_ADC2_AWD2 and TIM_TIM1_ETR_ADC2_AWD3 respectively to TIM_TIM1_ETR_ADC1_AWD1, TIM_TIM1_ETR_ADC1_AWD2 and TIM_TIM1_ETR_ADC1_AWD2 to be aligned with all STM32H7 devices Reference manuals (<strong>compatibility break</strong>)</li>
546 </ul></li>
547 <li>stm32h7xx_hal_tim.c:
548 <ul>
549 <li>Update TIM_SlaveTimer_SetConfig API implementation to handle TIM_TS_ITR9 to TIM_TS_ITR13 input triggers</li>
550 </ul></li>
551 </ul></li>
552 <li><strong>LL BUS</strong>:
553 <ul>
554 <li>stm32h7xx_ll_bus.h: Update to support STM32H7A3/B3xx/B0xx devices peripherals</li>
555 </ul></li>
556 <li><strong>LL CRS</strong>:
557 <ul>
558 <li>stm32h7xx_ll_crs.h/stm32h7xx_ll_crs.c: New LL driver allowing to handle CRS (Clock Recovery System) module</li>
559 </ul></li>
560 <li><strong>LL SDMMC</strong> (LL core driver for HAL SD/MMC):
561 <ul>
562 <li>stm32h7xx_ll_sdmmc.c: Fix SDMMC_CmdStopTransfer implementation to ignore address Out Of Range error that is not relevant at end of memory</li>
563 </ul></li>
564 <li><strong>LL SYSTEM</strong>:
565 <ul>
566 <li>stm32h7xx_ll_system.h:
567 <ul>
568 <li>Update LL_SYSCFG_SetTIMBreakInputs and LL_SYSCFG_GetTIMBreakInputs APIs to support STM32H7A3/B3xx/B0xx devices break inputs</li>
569 <li>Add LL_SYSCFG_EnableIOSpeedOptimization1/LL_SYSCFG_DisableIOSpeedOptimization1/LL_SYSCFG_IsEnabledIOSpeedOptimization1 APIs</li>
570 <li>Add LL_SYSCFG_EnableIOSpeedOptimization2/LL_SYSCFG_DisableIOSpeedOptimization2, LL_SYSCFG_IsEnabledIOSpeedOptimization1 APIs</li>
571 <li>Add LL_SYSCFG_EnableIOSpeedOptimization3/LL_SYSCFG_DisableIOSpeedOptimization3, LL_SYSCFG_IsEnabledIOSpeedOptimization3 APIs</li>
572 <li>Add LL_SYSCFG_MMCGetCellCompensationCode/LL_SYSCFG_MMCSetPMOSCompensationCode/LL_SYSCFG_MMCSetPMOSCompensationCode APIs</li>
573 <li>Add LL_SYSCFG_VDMMCSetNMOSCompensationCode/LL_SYSCFG_VDMMCGetNMOSCompensationCode APIs</li>
574 </ul></li>
575 </ul></li>
576 <li><strong>LL UTILS</strong>:
577 <ul>
578 <li>stm32h7xx_ll_utils.h:
579 <ul>
580 <li>Add definition of STM32H7A3/B3xx/B0xx devices package types: LL_UTILS_PACKAGETYPE_LQFP64 to LL_UTILS_PACKAGETYPE_TFBGA225</li>
581 <li>Update LL_GetPackageType API to support STM32H7A3/B3xx/B0xx devices package types</li>
582 </ul></li>
583 </ul></li>
584 <li><strong>LL DELAY BLOCK</strong> (LL core driver for HAL SD):
585 <ul>
586 <li>stm32h7xx_ll_delayblock.h:
587 <ul>
588 <li>Add DLYB_MAX_SELECT definition used for delay block tuning</li>
589 <li>Add DelayBlock_Configure use to configure the delay block</li>
590 </ul></li>
591 <li>stm32h7xx_ll_delayblock.c:
592 <ul>
593 <li>Add implemenation of DelayBlock_Configure function allowing to configure the delay block</li>
594 <li>Rework DelayBlock_Enable function (delay block calibration procedure)</li>
595 </ul></li>
596 </ul></li>
597 </ul>
598 <h2 id="known-limitations">Known Limitations</h2>
599 <ul>
600 <li><strong>HAL I2S</strong>:
601 <ul>
602 <li>Full duplex Transmit/receive feature not available
603 <ul>
604 <li>stm32h7xx_hal_i2s_ex.h/stm32h7xx_hal_i2s_ex.c: These files are empty as full duplex feature is not available in this release</li>
605 </ul></li>
606 </ul></li>
607 <li><strong>HAL PSSI</strong>:
608 <ul>
609 <li>New PSSI driver provided supporting both modes : DMA mode recommended/ polling mode has hardware limitation confirmed and mentioned in the STM32H7A3/B3xx/B0xx erratasheet.</li>
610 </ul></li>
611 </ul>
612 <h2 id="backward-compatibility">Backward compatibility</h2>
613 <ul>
614 <li><strong>HAL I2S</strong>:
615 <ul>
616 <li>stm32h7xx_hal_i2s_ex.h/stm32h7xx_hal_i2s_ex.c : These files are empty as full duplex feature is not available in this release</li>
617 </ul></li>
618 <li><strong>HAL LPTIM</strong>:
619 <ul>
620 <li>stm32h7xx_hal_lptim.h:
621 <ul>
622 <li>LPTIM_INPUT1SOURCE_SAI1_FSA and LPTIM_INPUT1SOURCE_SAI1_FSB replaced respectively by LPTIM_INPUT1SOURCE_SAI4_FSA and LPTIM_INPUT1SOURCE_SAI4_FSB to be aligned with the Reference manual</li>
623 </ul></li>
624 </ul></li>
625 <li><strong>HAL TIM</strong>:
626 <ul>
627 <li>stm32h7xx_hal_tim_ex.h:</li>
628 <li>TIM_TIM1_ETR_ADC2_AWD1, TIM_TIM1_ETR_ADC2_AWD2 and TIM_TIM1_ETR_ADC2_AWD3 respectively to TIM_TIM1_ETR_ADC1_AWD1, TIM_TIM1_ETR_ADC1_AWD2 and TIM_TIM1_ETR_ADC1_AWD2 to be aligned with all STM32H7 devices Reference manuals</li>
629 </ul></li>
630 </ul>
631 </div>
632 </div>
633 <div class="collapse">
634 <input type="checkbox" id="collapse-section7" aria-hidden="true"> <label for="collapse-section7" aria-hidden="true"><strong>V1.6.0 / 28-June-2019</strong></label>
635 <div>
636 <h2 id="main-changes-1">Main Changes</h2>
637 <ul>
638 <li>General updates to fix known defects and implementation enhancements</li>
639 <li><strong>HAL</strong>: generic
640 <ul>
641 <li>stm32h7xx_hal.h:
642 <ul>
643 <li>Add macros __HAL_ART_ENABLE, __HAL_ART_DISABLE and __HAL_ART_CONFIG_BASE_ADDRESS allowing to respectively enable/disable and configure the Cortex-M4 ART instruction cache</li>
644 <li>Add export of the variables uwTick, uwTickPrio and uwTickFreq</li>
645 <li>Add prototypes for utility APIs HAL_GetUIDw0, HAL_GetUIDw1 and HAL_GetUIDw2</li>
646 </ul></li>
647 <li>stm32h7xx_hal.c:
648 <ul>
649 <li>uwTick, uwTickPrio and uwTickFreq are no more static</li>
650 <li>Update HAL_Init API to configure and enable the Cortex-M4 ART instruction cache with default base address set to flash bank 2 (default boot address of the Cortex-M4). user can change this default configuration, if required, by calling macros __HAL_ART_ENABLE, __HAL_ART_DISABLE and __HAL_ART_CONFIG_BASE_ADDRESS after the HAL_Init</li>
651 <li>Add implementation of utility APIs HAL_GetUIDw0, HAL_GetUIDw1 and HAL_GetUIDw2<br />
652 </li>
653 </ul></li>
654 <li>stm32h7xx_hal_conf_template.h:
655 <ul>
656 <li>Add “USE_SPI_CRC” definition set to 1 by default and customizable by the HAL user</li>
657 </ul></li>
658 </ul></li>
659 <li><strong>HAL/LL ADC</strong>:
660 <ul>
661 <li>stm32h7xx_hal_adc.h:
662 <ul>
663 <li>Remove useless defines ADC_OVERSAMPLING_RATIO_2 to ADC_OVERSAMPLING_RATIO_1024. the oversampling ratio is filled in parameter “Ratio” of the structure “Oversampling” of the “ADC_InitTypeDef” structure with a value between 1 and 1024</li>
664 </ul></li>
665 <li>stm32h7xx_hal_adc_ex.h:
666 <ul>
667 <li>Fix macro “IS_ADC_OVERSAMPLING_RATIO”, the allowed oversampling ratio is a value between 1 and 1024</li>
668 <li>Add prototype of “HAL_ADCEx_LinearCalibration_FactorLoad” API allowing to automatically load the linear calibration factors from ADC engineering bytes (programmed during device production, specific to each device)<br />
669 </li>
670 </ul></li>
671 <li>stm32h7xx_ll_adc.h:
672 <ul>
673 <li>Add definitions of ADC_LINEAR_CALIB_REG_1_ADDR to ADC_LINEAR_CALIB_REG_6_ADDR: these are the addresses with ADC linearity calibration content (programmed during device production, specific to each device) the content of these addresses is then automatically loaded by the API “HAL_ADCEx_LinearCalibration_FactorLoad”</li>
674 </ul></li>
675 <li>stm32h7xx_hal_adc.c:
676 <ul>
677 <li>Update “HAL_ADC_ConfigChannel” implementation to set the ADC selected offset right shift</li>
678 </ul></li>
679 <li>stm32h7xx_hal_adc_ex.c:
680 <ul>
681 <li>Update definition of “ADC_CALIBRATION_TIMEOUT” to 633600000 according to the data-sheet update</li>
682 <li>Update “HAL_ADCEx_LinearCalibration_SetValue” implementation to:
683 <ul>
684 <li>Enable the ADC before applying the calibration factors</li>
685 <li>Respect the user linear calibration buffer order from calibration factor 0 to 5</li>
686 </ul></li>
687 <li>Update “HAL_ADCEx_LinearCalibration_GetValue” implementation to:
688 <ul>
689 <li>Respect the user linear calibration buffer order from calibration factor 0 to 5</li>
690 </ul></li>
691 <li>Add “HAL_ADCEx_LinearCalibration_FactorLoad” API allowing to automatically load the linear calibration factors from ADC engineering bytes (programmed during device production, specific to each device)</li>
692 <li>Update “HAL_ADCEx_InjectedConfigChannel” implementation to set the ADC selected offset right shift</li>
693 </ul></li>
694 </ul></li>
695 <li><strong>HAL CRYP</strong>:
696 <ul>
697 <li>stm32h7xx_hal_cryp.c:
698 <ul>
699 <li>Update “CRYP_GCMCCM_SetPayloadPhase_IT” implementation to improve data management in interrupt mode</li>
700 <li>Update “CRYP_Workaround” to fix the implementation of the authentication tags computation phase during a GCM encryption when the size of the last payload block is inferior to 128 bits</li>
701 </ul></li>
702 </ul></li>
703 <li><strong>HAL GPIO</strong>:
704 <ul>
705 <li>stm32h7xx_hal_gpio.c:
706 <ul>
707 <li>Fix implementation of “HAL_GPIO_DeInit” API in order to clear the correct external interrupt/event in SYSCFG EXTICR register</li>
708 </ul></li>
709 </ul></li>
710 <li><strong>HAL/LL HRTIM</strong>:
711 <ul>
712 <li>stm32h7xx_hal_hrtim.h:
713 <ul>
714 <li>Fix definitions of HRTIM Output Set Sources according the STM32H7 reference manual:
715 <ul>
716 <li>Remove definition HRTIM_OUTPUTSET_TIMAEV1_TIMBCMP1 to HRTIM_OUTPUTSET_TIMFEV9_TIMECMP3</li>
717 <li>Replaced by HRTIM_OUTPUTSET_TIMEV_1 to HRTIM_OUTPUTSET_TIMEV_9 definition</li>
718 <li>The stm32_hal_legacy.h file is also updated to avoid compatibility break versus the previous STM32H7 HAL version regarding the removed/replaced defines</li>
719 </ul></li>
720 </ul></li>
721 <li>stm32h7xx_hal_hrtim.c:
722 <ul>
723 <li>Update “HAL_HRTIM_WaveformCompareConfig” implementation to clear HRTIM_TIMCR_DELCMP2 bit field when required</li>
724 </ul></li>
725 <li>stm32h7xx_ll_hrtim.h:
726 <ul>
727 <li>Fix definitions of the output set sources (“LL_HRTIM_CROSSBAR_NONE” to “LL_HRTIM_CROSSBAR_UPDATE” replacing “LL_HRTIM_OUTPUTSET_NONE” to LL_HRTIM_OUTPUTSET_UPDATE) according to the reference manual (<strong>compatibility break</strong>)</li>
728 </ul></li>
729 </ul></li>
730 <li><strong>HAL/LL HSEM</strong>:
731 <ul>
732 <li>stm32h7xx_hal_hsem.c:
733 <ul>
734 <li>Update “HAL_HSEM_Release” implementation to support dynamic CPU ID detection useful when code is intended to be shared between the Cortex-M4 and Cortex-M7 in a dual core device</li>
735 </ul></li>
736 </ul></li>
737 <li><strong>HAL IRDA</strong>:
738 <ul>
739 <li>stm32h7xx_hal_irda.c:
740 <ul>
741 <li>Update description of “HAL_IRDA_Transmit_XXX”, “HAL_IRDA_Receive_XXX” APIs with more details about the data size management</li>
742 </ul></li>
743 </ul></li>
744 <li><strong>HAL LPTIM</strong>:
745 <ul>
746 <li>stm32h7xx_hal_lptim.c:
747 <ul>
748 <li>Update “HAL_LPTIM_XXX_Start/HAL_LPTIM_XXX_Stop” and “HAL_LPTIM_XXX_Start_IT/HAL_LPTIM_XXX_Stop_IT” implementations to handle “ARROK” and “CMPOK” flags</li>
749 </ul></li>
750 <li>stm32h7xx_hal_lptim.h:
751 <ul>
752 <li>Update "__HAL_LPTIM_AUTORELOAD_SET" and "__HAL_LPTIM_COMPARE_SET" macros description to add details about macro usage:
753 <ul>
754 <li>can only be used when the LPTIM instance is enabled</li>
755 </ul></li>
756 <li>Update "__HAL_LPTIM_ENABLE_IT" and "__HAL_LPTIM_DISABLE_IT" macros description to add details about macro usage:
757 <ul>
758 <li>can only be used when the LPTIM instance is disabled</li>
759 </ul></li>
760 </ul></li>
761 </ul></li>
762 <li><strong>HAL MMC</strong>:
763 <ul>
764 <li>stm32h7xx_hal_mmc.h:
765 <ul>
766 <li>Comments clean-up and updates of the APIs signatures</li>
767 <li>Add prototypes for “HAL_MMC_ConfigSpeedBusOperation” API allowing to configure the Bus speed mode in
768 <ul>
769 <li>Auto mode: SDMMC_SPEED_MODE_AUTO (maximum supported by the detected MMC memory)</li>
770 <li>Default speed: SDMMC_SPEED_MODE_DEFAULT<br />
771 </li>
772 <li>High Speed: SDMMC_SPEED_MODE_HIGH</li>
773 <li>High Speed DDR: SDMMC_SPEED_MODE_DDR</li>
774 </ul></li>
775 </ul></li>
776 <li>stm32h7xx_hal_mmc.c:
777 <ul>
778 <li>Update of the “How to use this driver” documentation section</li>
779 <li>Update “HAL_MMC_ReadBlocks” and “HAL_MMC_WriteBlocks” implementations to avoid overflow during data reading/writing into/from user buffer</li>
780 <li>Update “HAL_MMC_IRQHandler” implementation to consider the interrupts and flag when required(context corresponds to the given flag/interrupt)</li>
781 <li>Add “HAL_MMC_ConfigSpeedBusOperation” API allowing to configure the Bus speed mode</li>
782 </ul></li>
783 </ul></li>
784 <li><p><strong>HAL SD</strong>:</p>
785 <ul>
786 <li>Updates to handle 2 SD instances with different settings regarding the transceiver presence as follow:
787 <ul>
788 <li>If the define “USE_SD_TRANSCEIVER” is set to 1 then user can select different transceiver settings through the parameter “TranceiverPresent” of the Init structure (SDMMC_TRANSCEIVER_PRESENT/SDMMC_TRANSCEIVER_NOT_PRESENT)</li>
789 <li>If “USE_SD_TRANSCEIVER” is set to 1 and the parameter “TranceiverPresent” of the Init structure is not set (it takes the numerical value 0 which corresponds to SDMMC_TRANSCEIVER_UNKNOWN) then “TranceiverPresent” is forced to SDMMC_TRANSCEIVER_PRESENT in the “HAL_SD_Init” API:
790 <ul>
791 <li>This allows legacy user code that sets “USE_SD_TRANSCEIVER” to 1 and doesn’t fill the parameter “TranceiverPresent” to continue working as the previous HAL SD version (using a transceiver)</li>
792 </ul></li>
793 <li>If the define “USE_SD_TRANSCEIVER” is set to 0 then the parameter “TranceiverPresent” is not available and the HAL SD driver assumes no transceivers for both SD instances
794 <ul>
795 <li>This allows also legacy user code that sets “USE_SD_TRANSCEIVER” to 0 to continue working as the previous HAL SD version</li>
796 </ul></li>
797 </ul></li>
798 <li>stm32h7xx_hal_sd.h:
799 <ul>
800 <li>Rename “HAL_SD_CardStateType<strong>d</strong>ef” to “HAL_SD_CardStateType<strong>D</strong>ef” as per the STM32Cube coding and naming rules<br />
801 </li>
802 <li>Rename “HAL_SD_CardCSDType<strong>d</strong>ef” to “HAL_SD_CardCSDType<strong>D</strong>ef” as per the STM32Cube coding and naming rules</li>
803 <li>Rename “HAL_SD_CardCIDType<strong>d</strong>ef” to “HAL_SD_CardCIDType<strong>D</strong>ef” as per the STM32Cube coding and naming rules</li>
804 <li>Rename “HAL_SD_CardStatusType<strong>d</strong>ef” to “HAL_SD_CardStatusType<strong>D</strong>ef” as per the STM32Cube coding and naming rules</li>
805 <li><strong>Notes: backward compatibility ensured through the stm32_hal_legacy.h file</strong></li>
806 </ul></li>
807 <li>stm32h7xx_hal_sd.c:
808 <ul>
809 <li>Update “HAL_SD_InitCard” implementation to add 74 SD card clock cycles delay required for power up before starting the SD initialization</li>
810 <li>Update “HAL_SD_ReadBlocks” and “HAL_SD_WriteBlocks” implementations to avoid overflow during data reading/writing into/from user buffer</li>
811 <li>Update “HAL_SD_IRQHandler” implementation to consider the interrupts and flag when required(context corresponds to the given flag/interrupt)</li>
812 <li>Updates following renaming of “HAL_SD_CardStateType<strong>D</strong>ef”, “HAL_SD_CardCSDType<strong>D</strong>ef”, “HAL_SD_CardCIDType<strong>D</strong>ef”, and “HAL_SD_CardStatusType<strong>D</strong>ef”</li>
813 <li>Update “HAL_SD_ConfigSpeedBusOperation” implementation to handle “SDMMC_SPEED_MODE_AUTO” and “SDMMC_SPEED_MODE_HIGH” SD card speed modes in case of no transceiver present</li>
814 </ul></li>
815 </ul></li>
816 <li><strong>LL SDMMC</strong>:
817 <ul>
818 <li>Update “SDMMC_InitTypeDef” structure to add “TranceiverPresent” field in case of the define “USE_SD_TRANSCEIVER” is not zero:
819 <ul>
820 <li>This parameter allows to handle 2 SD instances with different settings regarding the transceiver presence as described above</li>
821 </ul></li>
822 </ul></li>
823 <li><strong>HAL/LL RCC</strong>:
824 <ul>
825 <li>stm32h7xx_ll_rcc.h:
826 <ul>
827 <li>Add suffix “LL_RCC” to private defines “REG_SHIFT”, “POS_SHIFT”, “CONFIG_SHIFT” and “MASK_SHIFT” according to the STM32Cube coding rules and to avoid clash with other modules defines if any</li>
828 </ul></li>
829 <li>stm32h7xx_hal_rcc.c:
830 <ul>
831 <li>Update “HAL_RCC_DeInit” API implementation to “uwTickPrio” variable when calling “HAL_InitTick” instead of the define “TICK_INT_PRIORITY” . The variable “uwTickPrio” maintains the last user Tick priority configuration where the “TICK_INT_PRIORITY” define is the initial Tick priority applied during the “HAL_Init”</li>
832 </ul></li>
833 <li>stm32h7xx_hal_rcc_ex.c:
834 <ul>
835 <li>Update “HAL_RCCEx_GetPeriphCLKFreq” API implementation to add support of the SDMMC peripheral clock frequency calculation</li>
836 </ul></li>
837 </ul></li>
838 <li><strong>HAL TIM</strong>:
839 <ul>
840 <li>stm32h7xx_hal_tim.h:
841 <ul>
842 <li>Add "__HAL_TIM_ENABLE_OCxFAST" and "__HAL_TIM_DISABLE_OCxFAST" macros allowing respectively to enable/disable the fast mode for a given channel</li>
843 </ul></li>
844 <li>stm32h7xx_hal_tim_ex.h:
845 <ul>
846 <li>Rename the timer remapping “TIM_TIM1_ETR_ADC1_AWD1” to “TIM_TIM1_ETR_ADC1_AWD3” defines respectively to “TIM_TIM1_ETR_ADC2_AWD1” to TIM_TIM1_ETR_ADC2_AWD3 according to the reference manual (<strong>compatibility break</strong>)<br />
847 </li>
848 <li>Rename the timer remapping “TIM_TIM8_ETR_ADC1_AWD1” to “TIM_TIM8_ETR_ADC1_AWD3” defines respectively to “TIM_TIM8_ETR_ADC2_AWD1” to “TIM_TIM8_ETR_ADC2_AWD3” according to the reference manual (<strong>compatibility break</strong>)</li>
849 </ul></li>
850 <li>stm32h7xx_hal_tim.c:
851 <ul>
852 <li>Update “HAL_TIM_OnePulse_ConfigChannel” description to add details about usage of "__HAL_TIM_ENABLE_OCxFAST" to output a waveform with a minimum delay</li>
853 </ul></li>
854 <li>stm32h7xx_hal_tim_ex.c:
855 <ul>
856 <li>Update “HAL_TIMEx_ConfigBreakDeadTime” description to add details about interrupts enabling and generation</li>
857 </ul></li>
858 </ul></li>
859 <li><strong>HAL UART</strong>:
860 <ul>
861 <li>Update to add UART Receiver timeout management (RTOF)</li>
862 <li>stm32h7xx_hal_uart.h:
863 <ul>
864 <li>Add definition of error code “HAL_UART_ERROR_RTO”</li>
865 <li>Add definition of “UART_FLAG_RTOF” flag</li>
866 <li>Add definition of “UART_IT_RTO” interrupt</li>
867 <li>Add definition of “UART_CLEAR_RTOF” clear flag</li>
868 <li>Add prototypes of APIs “HAL_UART_ReceiverTimeout_Config”, “HAL_UART_EnableReceiverTimeout” and “HAL_UART_DisableReceiverTimeout”</li>
869 </ul></li>
870 <li>stm32h7xx_hal_uart.c:
871 <ul>
872 <li>Update description of “HAL_UART_Transmit_XXX”, “HAL_UART_Receive_XXX” APIs with more details about the data size management</li>
873 <li>Update “HAL_UART_IRQHandler” to support RTOF flag</li>
874 <li>Add implementation of “HAL_UART_ReceiverTimeout_Config”, “HAL_UART_EnableReceiverTimeout” and “HAL_UART_DisableReceiverTimeout” APIs</li>
875 </ul></li>
876 </ul></li>
877 <li><strong>HAL USB</strong>:
878 <ul>
879 <li>stm32h7xx_hal_hcd.c
880 <ul>
881 <li>Update “HAL_HCD_HC_SubmitRequest” to avoid enabling do_ping during host setup</li>
882 <li>Update “HCD_Port_IRQHandler” implementation to fix fast host plug/inplug issue:
883 <ul>
884 <li>This update is to be used with rework done on the USB MW host process to fix process hangs during enumeration phase. The USB MW rework is part of the host USB library V3.3.3</li>
885 </ul></li>
886 </ul></li>
887 <li>stm32h7xx_hal_pcd.c
888 <ul>
889 <li>Update “HAL_PCD_IRQHandler” to remove useless initialization of epnum variable in HAL_PCD_IRQHandler() for OTG instance</li>
890 </ul></li>
891 </ul></li>
892 <li><strong>HAL/LL USART</strong>:
893 <ul>
894 <li>stm32h7xx_hal_usart.c:
895 <ul>
896 <li>Update description of “HAL_USART_Transmit_XXX”, “HAL_USART_Receive_XXX” APIs with more details about the data size management</li>
897 </ul></li>
898 <li>stm32h7xx_ll_usart.h:
899 <ul>
900 <li>Update “LL_USART_SetBaudRate” implementation to avoid overflow in “USART_PRESCALER_TAB” table</li>
901 </ul></li>
902 </ul></li>
903 <li><strong>LL SYSTEM</strong>:
904 <ul>
905 <li>stm32h7xx_ll_system.h:
906 <ul>
907 <li>Add APIs “LL_ART_Enable”, “LL_ART_Disable”, “LL_ART_IsEnabled” and “LL_ART_SetBaseAddress” allowing to enable/disable and configure the Cortex-M4 “ART” instruction cache</li>
908 </ul></li>
909 </ul></li>
910 </ul>
911 <h2 id="known-limitations-1">Known Limitations</h2>
912 <ul>
913 <li>None</li>
914 </ul>
915 <h2 id="backward-compatibility-1">Backward compatibility</h2>
916 <ul>
917 <li><strong>HAL TIM</strong>:
918 <ul>
919 <li>Rename the timer remapping “TIM_TIM1_ETR_ADC1_AWD1” to “TIM_TIM1_ETR_ADC1_AWD3” defines respectively to “TIM_TIM1_ETR_ADC2_AWD1” to TIM_TIM1_ETR_ADC2_AWD3 according to the reference manual<br />
920 </li>
921 <li>Rename the timer remapping “TIM_TIM8_ETR_ADC1_AWD1” to “TIM_TIM8_ETR_ADC1_AWD3” defines respectively to “TIM_TIM8_ETR_ADC2_AWD1” to “TIM_TIM8_ETR_ADC2_AWD3” according to the reference manual</li>
922 </ul></li>
923 <li><strong>LL HRTIM</strong>:
924 <ul>
925 <li>Replace “LL_HRTIM_OUTPUTSET_NONE” to LL_HRTIM_OUTPUTSET_UPDATE defines by “LL_HRTIM_CROSSBAR_NONE” to “LL_HRTIM_CROSSBAR_UPDATE”</li>
926 </ul></li>
927 </ul>
928 </div>
929 </div>
930 <div class="collapse">
931 <input type="checkbox" id="collapse-section6" aria-hidden="true"> <label for="collapse-section6" aria-hidden="true"><strong>V1.5.0 / 05-April-2019</strong></label>
932 <div>
933 <h2 id="main-changes-2">Main Changes</h2>
934 <ul>
935 <li>General updates to fix known defects and implementation enhancements</li>
936 <li>Add support for VOS0 power regulator voltage scaling with 480MHz over clock</li>
937 <li>Add support of STM32H7 <strong>Rev.V</strong> (All HAL and LL drivers remains compatible with STM32H7 <strong>Rev.Y</strong>)</li>
938 <li>Update HAL/LL drivers to be <strong>MISRA-C 2012</strong> compliant</li>
939 <li>Add <strong>DUAL CORE</strong> support/APIs for system peripherals HAL and LL drivers(COMP, CORTEX, ETH, EXTI, FLASH, GPIO, HSEM, MDIOS, PWR, RCC, RTC)
940 <ul>
941 <li><strong>DUAL CORE</strong> features are delimited by the define <strong>“DUAL_CORE”</strong>, this define is automatically available when using a <strong>DUAL CORE</strong> device through the stm32h7XYxx CMSIS device include files</li>
942 </ul></li>
943 <li>Update HAL/LL PWR driver to support Step Down Convector regulator (SMPS) available on <strong>DUAL CORE</strong> lines</li>
944 <li><strong>HAL</strong>: generic
945 <ul>
946 <li>stm32h7xx_hal.h :
947 <ul>
948 <li>Add support STM32H7 <strong>Rev.V</strong></li>
949 <li>Add support of <strong>DUAL CORE</strong> lines</li>
950 <li>Add SYSCFG break macros allowing to break TIM1/8/15/16/17 and HRTIMER following a given RAM or a FLASH double ECC error, or Cortex-M7/M4 lockup.</li>
951 </ul></li>
952 <li>stm32h7xx_hal_conf_template.h:
953 <ul>
954 <li>Add support of DSI peripheral(available on STM32H747xx and STM32H757xx lines)</li>
955 <li>Add definition of LSI oscillator value(LSI_VALUE)</li>
956 </ul></li>
957 <li>stm32h7xx_hal.c :
958 <ul>
959 <li>Update HAL_Init APIs to get the SystemCoreClock(Cortex-M7 clock) and SystemD2Clock(D2 domain clock) values:
960 <ul>
961 <li>Useful to update these values when the system clock settings are done but the other Cortex on a <strong>DUAL CORE</strong> device</li>
962 </ul></li>
963 <li>Update HAL_InitTick to support both Cortex-M7 and Cortex-M4 SYSTICK configuration</li>
964 <li>Add <strong>DUAL CORE</strong> APIs:
965 <ul>
966 <li>Boot address and configuration APIs: HAL_SYSCFG_CM4BootAddConfig, HAL_SYSCFG_EnableCM7BOOT, HAL_SYSCFG_DisableCM7BOOT, HAL_SYSCFG_EnableCM4BOOT and HAL_SYSCFG_DisableCM4BOOT</li>
967 <li>Debug APIs: HAL_EnableDomain2DBGSleepMode, HAL_DisableDomain2DBGSleepMode, HAL_EnableDomain2DBGStopMode, HAL_DisableDomain2DBGStopMode HAL_EnableDomain2DBGStandbyMode and HAL_DisableDomain2DBGStandbyMode</li>
968 <li>EXTI APIs: HAL_EXTI_D2_ClearFlag and HAL_EXTI_D2_EventInputConfig</li>
969 </ul></li>
970 </ul></li>
971 <li>Add stm32h7xx_hal_msp_template.c file: MSP template source file</li>
972 <li>Add HAL time base template files: stm32h7xx_hal_timebase_rtc_alarm_template.c, stm32h7xx_hal_timebase_rtc_wakeup_template.c and stm32h7xx_hal_timebase_tim_template.c</li>
973 </ul></li>
974 <li><strong>HAL ADC</strong>:
975 <ul>
976 <li>Update to support STM32H7 <strong>Rev.V</strong> : 8bits resolution settings.</li>
977 <li>Remove inconsistent definition of flags ADC_FLAG_AWD and ADC_FLAG_ALL</li>
978 </ul></li>
979 <li><strong>HAL COMP</strong>:
980 <ul>
981 <li>Update to support <strong>DUAL CORE</strong> lines:
982 <ul>
983 <li>Add __HAL_COMP_COMP1_EXTID2_ENABLE_IT/EVENT macros to enable an COMP1 EXTI IT/Event for Cortex-M4</li>
984 <li>Add __HAL_COMP_COMP1_EXTID2_DISABLE_IT/EVENT macros to disable an COMP1 EXTI IT/Event for Cortex-M4</li>
985 <li>Add __HAL_COMP_COMP1_EXTID2_GET_FLAG and __HAL_COMP_COMP1_EXTID2_CLEAR_FLAG macros to get/clear COMP1 EXTI flag for Cortex-M4</li>
986 <li>Add __HAL_COMP_COMP2_EXTID2_ENABLE_IT/EVENT macros to enable an COMP2 EXTI IT/Event for Cortex-M4</li>
987 <li>Add __HAL_COMP_COMP2_EXTID2_DISABLE_IT/EVENT macros to disable an COMP2 EXTI IT/Event for Cortex-M4</li>
988 <li>Add __HAL_COMP_COMP2_EXTID2_GET_FLAG and __HAL_COMP_COMP2_EXTID2_CLEAR_FLAG macros to get/clear COMP2 EXTI flag for Cortex-M4</li>
989 <li>Update HAL_COMP_Init function : don’t enable the EXTI IT and event in case of <strong>DUAL CORE</strong>. User may the use either __HAL_COMP_COMP1_EXTI_ENABLE_IT/EVENT or __HAL_COMP_COMP1_EXTID2_ENABLE_IT/EVENT to enable the IT/event for either Cortex-M7 or Cortex-M4</li>
990 </ul></li>
991 </ul></li>
992 <li><strong>HAL CORTEX</strong>:
993 <ul>
994 <li>Update “CORTEX MPU Region Number” define for <strong>DUAL CORE</strong> lines:
995 <ul>
996 <li>Cortex-M4: 8 MPU regions available</li>
997 <li>Cortex-M7 (or single core): 16 MPU regions available</li>
998 </ul></li>
999 <li>Add definition of Cortex-M5 CPU ID (CM4_CPUID)</li>
1000 <li>Update HAL_GetCurrentCPUID API to support Cortex-M7 and Cortex-M4</li>
1001 </ul></li>
1002 <li><strong>HAL DSI</strong>:
1003 <ul>
1004 <li>Introduce HAL DSI driver:stm32h7xx_hal_dsi.h and stm32h7xx_hal_dsi.c (DSI peripheral is available on STM32H747xx and STM32H757xx lines only)</li>
1005 </ul></li>
1006 <li><strong>HAL ETH</strong>:
1007 <ul>
1008 <li>stm32h7xx_hal_eth.h:
1009 <ul>
1010 <li>Update ETH_DMADescTypeDef definition: remove packing to avoid byte access(as all fields of this structure are UINT32)</li>
1011 </ul></li>
1012 <li>stm32h7xx_hal_eth.c:
1013 <ul>
1014 <li>Fix ETH_DMARxDescListInit function to support the case when Ethernet packet is split into more than one descriptor by:
1015 <ul>
1016 <li>Clearing the ETH_DMATXNDESCRF_LD bit of previous descriptor</li>
1017 <li>Clearing the ETH_DMATXNDESCRF_FD bit of new descriptor to indicate that this descriptor is not the first segment of the packet</li>
1018 </ul></li>
1019 <li>Fix HAL_ETH_GetRxDataBuffer and HAL_ETH_IRQHandler functions for better robustness when mass receiving UDP/TCPIP packets:
1020 <ul>
1021 <li>HAL_ETH_IRQHandler : Remove call to HAL_ETH_IsRxDataAvailable when RX Interrupt occurs as it may update the RX DMA descriptors while the last received data is being proceeded by TCPIP stack/Application: in this case data will be lost or corrupted</li>
1022 </ul></li>
1023 <li>HAL_ETH_GetRxDataLength: Update descriptor informations (descidx and dmarxdesc) with the last values returned by HAL_ETH_IsRxDataAvailable() when new data is available</li>
1024 </ul></li>
1025 <li>Update to support <strong>DUAL CORE</strong> lines:
1026 <ul>
1027 <li>Add __HAL_ETH_WAKEUP_EXTID2_ENABLE_IT macro to enable ETH wakeup EXTI for Cortex-M4</li>
1028 <li>Add __HAL_ETH_WAKEUP_EXTID2_GET_FLAG and __HAL_ETH_WAKEUP_EXTID2_CLEAR_FLAG macros to get/clear ETH wakeup EXTI flag for Cortex-M4</li>
1029 <li>Update HAL_ETH_IRQHandler function to get/clear ETH wakeup EXTI flag depending of the current CPU(Cortex-M4 or Cortex-M7)</li>
1030 </ul></li>
1031 </ul></li>
1032 <li><strong>HAL EXTI</strong>:
1033 <ul>
1034 <li>Update to support <strong>DUAL CORE</strong> lines:
1035 <ul>
1036 <li>stm32h7xx_hal_exti.h:
1037 <ul>
1038 <li>Add <strong>DUAL CORE</strong> EXTI lines definition</li>
1039 <li>Add EXTI_MODE_CORE1_INTERRUPT/EVENT, EXTI_MODE_CORE2_INTERRUPT/EVENT modes definition</li>
1040 </ul></li>
1041 <li>stm32h7xx_hal_exti.c:
1042 <ul>
1043 <li>Update to support EXTI lines on both Cortex-M7/Cortex-M4: APIs HAL_EXTI_SetConfigLine, HAL_EXTI_GetConfigLine, HAL_EXTI_ClearConfigLine, HAL_EXTI_IRQHandler, HAL_EXTI_GetPending and HAL_EXTI_ClearPending</li>
1044 </ul></li>
1045 </ul></li>
1046 </ul></li>
1047 <li><strong>HAL FLASH</strong>:
1048 <ul>
1049 <li>Update to support STM32H7 <strong>Rev.V</strong> devices</li>
1050 <li>Add support of CRC calculation feature</li>
1051 <li>Update to support <strong>DUAL CORE</strong> lines:
1052 <ul>
1053 <li>FLASH_OBProgramInitTypeDef structure: add CM4BootConfig, CM4BootAddr0 and CM4BootAddr1 for Cortex-M4 boot configuration</li>
1054 <li>Add definitions for <strong>DUAL CORE</strong> lines option bytes:
1055 <ul>
1056 <li>OPTIONBYTE_CM7_BOOTADD, OPTIONBYTE_CM4_BOOTADD, OB_BCM7_DISABLE, OB_BCM7_ENABLE, OB_BCM4_DISABLE, OB_BCM4_ENABLE, OB_IWDG2_SW, OB_IWDG2_HW, OB_STOP_RST_D2, OB_STOP_NO_RST_D2, OB_STDBY_RST_D2, OB_STDBY_NO_RST_D2</li>
1057 <li>Update HAL_FLASHEx_OBProgram, HAL_FLASHEx_OBGetConfig, FLASH_OB_UserConfig, FLASH_OB_BootAddConfig and FLASH_OB_GetBootAdd functions according to the new option bytes</li>
1058 <li>Add FLASH_OB_CM4BootAddConfig and FLASH_OB_GetCM4BootAdd functions for Cortex-M4 boot address configuration</li>
1059 </ul></li>
1060 </ul></li>
1061 <li>Enhance the HAL_FLASH_Program/HAL_FLASH_Program_IT implementation by adding Add ISB/DSB instructions:
1062 <ul>
1063 <li>Between programming enabling (Bit FLASH_CR_PG set to 1) and writing a flash word</li>
1064 <li>Between the flash word writing and the wait for the programming operation to end</li>
1065 </ul></li>
1066 <li>Fix FLASH_OB_GetRDP APIs to return the correct value in case of RDP level 1</li>
1067 </ul></li>
1068 <li><strong>HAL GPIO</strong>:
1069 <ul>
1070 <li>Add definition of new AF available in STM32H7 <strong>Rev.V</strong> devices:
1071 <ul>
1072 <li>GPIO_AF0_C1DSLEEP, GPIO_AF0_C1DSLEEP, GPIO_AF0_C1SLEEP, GPIO_AF0_D1PWREN, GPIO_AF0_D2PWREN, GPIO_AF0_C2DSLEEP, GPIO_AF0_C2SLEEP, GPIO_AF13_CRS_SYNC and GPIO_AF13_DSI</li>
1073 </ul></li>
1074 <li>Update to support <strong>DUAL CORE</strong> lines:
1075 <ul>
1076 <li>Update to support EXTI lines on both Cortex-M7/Cortex-M4 when a GPIO is configured in IT:EVENT mode : APIs HAL_GPIO_Init, HAL_GPIO_DeInit and HAL_GPIO_EXTI_IRQHandler</li>
1077 </ul></li>
1078 </ul></li>
1079 <li><strong>HAL HCD</strong>:
1080 <ul>
1081 <li>Fix HCD_HC_OUT_IRQHandler function to ensure setting the correct toggle for OUT interrupt during transfer complete</li>
1082 </ul></li>
1083 <li><strong>HAL I2S</strong>:
1084 <ul>
1085 <li>Fully reworked HAL I2S driver to fix issues and limitations and for MISRA-C 2012 compliance</li>
1086 </ul></li>
1087 <li><strong>HAL LPTIM</strong>:
1088 <ul>
1089 <li>Update LPTIM_Disable function to use RCC defines instead of hard coded zero values</li>
1090 </ul></li>
1091 <li><strong>HAL LTDC</strong>:
1092 <ul>
1093 <li>Add stm32h7xx_hal_ltdc_ex.c and stm32h7xx_hal_ltdc_ex.h files allowing to use the LTDC and DSI peripherals together</li>
1094 </ul></li>
1095 <li><strong>HAL MDIO</strong>:
1096 <ul>
1097 <li>Update to support <strong>DUAL CORE</strong> lines:
1098 <ul>
1099 <li>Add __HAL_MDIOS_WAKEUP_EXTID2_ENABLE_IT macro allowing to enable MDIO EXTI IT for Cortex-M4</li>
1100 <li>Add __HAL_MDIOS_WAKEUP_EXTID2_GET_FLAG and __HAL_MDIOS_WAKEUP_EXTID2_CLEAR_FLAG macros allowing to get:clear MDIO EXTI flag for Cortex-M4</li>
1101 <li>Update HAL_MDIOS_IRQHandler function to support MDIO EXTI flag clearing for Cortex-M7 or Cortex-M4 (depending of the current CPU)</li>
1102 </ul></li>
1103 </ul></li>
1104 <li><strong>HAL MMC</strong>:
1105 <ul>
1106 <li>Implementation enhancement of APIs HAL_MMC_ReadBlocks/_IT/_DMA, HAL_MMC_WriteBlocks/_IT/_DMA, HAL_MMC_IRQHandler and HAL_MMC_Abort</li>
1107 </ul></li>
1108 <li><strong>HAL PCD</strong>:
1109 <ul>
1110 <li>Cleanup and fix USB PCD interrupt handler to handle EP0OUT transfers in USB DMA mode</li>
1111 <li>Fix and enhancement of BCD (Battery Charging) feature</li>
1112 <li>Fix and enhancement to power-up the internal FS transceiver when the BCD discovery is completed</li>
1113 </ul></li>
1114 <li><strong>HAL PWR</strong>:
1115 <ul>
1116 <li>Update to support VOS0 power regulator voltage scaling :
1117 <ul>
1118 <li>Add definition of PWR_REGULATOR_VOLTAGE_SCALE0</li>
1119 <li>Update __HAL_PWR_VOLTAGESCALING_CONFIG macro for VOS0 support</li>
1120 </ul></li>
1121 <li>Update to support <strong>DUAL CORE</strong> lines:
1122 <ul>
1123 <li>File stm32h7xx_hal_pwr.h:
1124 <ul>
1125 <li>add definition of following flags:
1126 <ul>
1127 <li>PWR_FLAG_CPU_HOLD (Cortex-M7 hold boot flag), PWR_FLAG_CPU2_HOLD (Cortex-M4 hold boot flag), PWR_FLAG2_STOP (Cortex-M4 system stop flag), PWR_FLAG2_SB_D1 (Cortex-M4 D1 standby flag), PWR_FLAG2_SB_D2 (Cortex-M4 D2 standby flag), PWR_FLAG2_SB (Cortex-M4 system standby flag)</li>
1128 </ul></li>
1129 <li>Update __HAL_PWR_GET_FLAG and __HAL_PWR_CLEAR_FLAG macros implementation with new above flags</li>
1130 <li>Update __HAL_PWR_PVD_XXX macros for D2 domain (Cortex-M4)</li>
1131 </ul></li>
1132 <li>File stm32h7xx_hal_pwr_ex.h
1133 <ul>
1134 <li>Add PWR_CORE_CPU1 and PWR_CORE_CPU2: PWR cores definitions respectively relative to Cortex-M7 and Cortex-M4</li>
1135 <li>Add support for SMPS PWR supply regulator (note that SMPS regulator is available on <strong>DUAL CORE</strong> lines only)</li>
1136 <li>Update __HAL_PWR_AVD_XXX macros for D2 domain (Cortex-M4)</li>
1137 </ul></li>
1138 <li>File stm32h7xx_hal_pwr.c
1139 <ul>
1140 <li>Update functions HAL_PWR_ConfigPVD, HAL_PWR_EnterSTOPMode, HAL_PWR_EnterSTANDBYMode and HAL_PWR_PVD_IRQHandler
1141 <ul>
1142 <li>Add CPU2(Cortex-M4) domains power configuration</li>
1143 </ul></li>
1144 </ul></li>
1145 <li>File stm32h7xx_hal_pwr_ex.c
1146 <ul>
1147 <li>Update HAL_PWREx_EnterSTOPMode, HAL_PWREx_ClearPendingEvent, HAL_PWREx_EnterSTANDBYMode, HAL_PWREx_ConfigD3Domain, HAL_PWREx_EnableWakeUpPin, HAL_PWREx_ConfigAVD and HAL_PWREx_PVD_AVD_IRQHandler to consider <strong>DUAL CORE</strong> lines: Cortex-M4 versus power domains settings</li>
1148 <li>Introduce HAL_PWREx_HoldCore API: allowing to hold a CPU (Cortex-M7 or Cortex-M4) when exiting from STOP mode</li>
1149 <li>Introduce HAL_PWREx_ReleaseCore API: allowing to release a holden CPU(Cortex-M7 or Cortex-M4) after a wake-up from STOP</li>
1150 <li>Update HAL_PWREx_ConfigSupply function implementation to support SMPS power regulator</li>
1151 </ul></li>
1152 </ul></li>
1153 </ul></li>
1154 <li><strong>HAL RAMECC</strong>:
1155 <ul>
1156 <li>Fix typo in HAL_RAMECC_EnableNotification and HAL_RAMECC_DisableNotification APIs naming</li>
1157 </ul></li>
1158 <li><strong>HAL RCC</strong>:
1159 <ul>
1160 <li>Update to support <strong>DUAL CORE</strong> lines:
1161 <ul>
1162 <li>stm32h7xx_hal_rcc.h:
1163 <ul>
1164 <li>Add <strong>DUAL CORE</strong> reset flags: RCC_FLAG_C1RST, RCC_FLAG_C2RST, RCC_FLAG_SFTR1ST, RCC_FLAG_SFTR2ST, RCC_FLAG_WWDG2RST and RCC_FLAG_IWDG2RST</li>
1165 <li>Add Cortex-M4 ART clock enable/disable macros: __HAL_RCC_ART_CLK_ENABLE, __HAL_RCC_ART_CLK_DISABLE, and __HAL_RCC_ART_IS_CLK_ENABLED</li>
1166 <li>Add Cortex-M4 ART force/release reset macros: __HAL_RCC_ART_FORCE_RESET and __HAL_RCC_ART_RELEASE_RESET</li>
1167 <li>Add DSI clock enable/disable macros: __HAL_RCC_DSI_CLK_ENABLE, __HAL_RCC_DSI_CLK_DISABLE, __HAL_RCC_DSI_IS_CLK_ENABLED and __HAL_RCC_DSI_IS_CLK_DISABLED</li>
1168 <li>Add DSI force/release reset macros: __HAL_RCC_DSI_FORCE_RESET and __HAL_RCC_DSI_RELEASE_RESET</li>
1169 <li>Add DSI sleep clock enable/disable macros: __HAL_RCC_DSI_CLK_SLEEP_ENABLE, __HAL_RCC_DSI_CLK_SLEEP_DISABLE and __HAL_RCC_DSI_IS_CLK_SLEEP_ENABLED and __HAL_RCC_DSI_IS_CLK_SLEEP_DISABLED</li>
1170 <li>Add WWDG2 enable/disable macros: __HAL_RCC_WWDG2_CLK_ENABLE, __HAL_RCC_WWDG2_CLK_DISABLE, __HAL_RCC_WWDG2_IS_CLK_ENABLED and __HAL_RCC_WWDG2_IS_CLK_DISABLED</li>
1171 <li>Add WWDG2 sleep clock enable/disable macros : __HAL_RCC_WWDG2_CLK_SLEEP_ENABLE, __HAL_RCC_WWDG2_CLK_SLEEP_DISABLE, __HAL_RCC_WWDG2_IS_CLK_SLEEP_ENABLED and __HAL_RCC_WWDG2_IS_CLK_SLEEP_DISABLED</li>
1172 <li>Add peripherals _HAL_RCC_C1_PPP_CLK_ENABLE macros: allowing to enable/allocate a peripheral clock for Cortex-M7</li>
1173 <li>Add peripherals _HAL_RCC_C1_PPP_CLK_DISABLE macros: allowing to disable/deallocate a peripheral clock for Cortex-M7</li>
1174 <li>Add peripherals _HAL_RCC_C2_PPP_CLK_ENABLE macros: allowing to enable/allocate a peripheral clock for Cortex-M4</li>
1175 <li>Add peripherals _HAL_RCC_C2_PPP_CLK_DISABLE macros: allowing to disable/deallocate a peripheral clock for Cortex-M4</li>
1176 <li>Add peripherals _HAL_RCC_C2_PPP_CLK_DISABLE macros: allowing to disable/deallocate a peripheral clock for Cortex-M4</li>
1177 <li>Add peripherals __HAL_RCC_C1_PPP_CLK_SLEEP_ENABLE/DISABLE macros: allowing to enable/allocate or disable a peripheral sleep clock for Cortex-M7</li>
1178 <li>Add peripherals __HAL_RCC_C2_PPP_CLK_SLEEP_ENABLE/DISABLE macros: allowing to enable/allocate or disable a peripheral sleep clock for Cortex-M4</li>
1179 <li>Add __HAL_RCC_C1_CLEAR_RESET_FLAGS and __HAL_RCC_C1_GET_FLAG: allowing to get/reset an RCC flag for Cortex-M7</li>
1180 <li>Add __HAL_RCC_C2_CLEAR_RESET_FLAGS and __HAL_RCC_C2_GET_FLAG: allowing to get/reset an RCC flag for Cortex-M4</li>
1181 </ul></li>
1182 <li>stm32h7xx_hal_rcc_ex.h:
1183 <ul>
1184 <li>Add __HAL_RCC_DSI_CONFIG and __HAL_RCC_GET_DSI_SOURCE macros allowing to configure and get the DSI source clock</li>
1185 </ul></li>
1186 <li>stm32h7xx_hal_rcc_ex.c:
1187 <ul>
1188 <li>Update HAL_RCCEx_PeriphCLKConfig and HAL_RCCEx_GetPeriphCLKConfig functions to add DSI peripheral clock configuration</li>
1189 <li>Add HAL_RCCEx_EnableBootCore allowing to enable Cortex-M7 or Cortex-M4 boot independently from FLASH option bytes</li>
1190 <li>Update HAL_RCCEx_WWDGxSysResetConfig to generate system reset using WWDG1 or WWDG2</li>
1191 </ul></li>
1192 </ul></li>
1193 <li>Update __HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST macro to support STM32H7 <strong>Rev.V</strong> and <strong>Rev.Y</strong></li>
1194 <li>Update __HAL_RCC_CSI_CALIBRATIONVALUE_ADJUST macro to support STM32H7 <strong>Rev.V</strong> and <strong>Rev.Y</strong></li>
1195 <li>Update __HAL_RCC_LSEDRIVE_CONFIG macro to support STM32H7 <strong>Rev.V</strong> and <strong>Rev.Y</strong></li>
1196 <li>Update HAL_RCC_GetOscConfig function to support STM32H7 <strong>Rev.V</strong> and <strong>Rev.Y</strong></li>
1197 <li>Fix HSITRIM value reset value in HAL_RCC_DeInit function</li>
1198 <li>Update HAL_RCC_OscConfig to disable PLLFRACN before applying a new value</li>
1199 <li>Update HAL_RCCEx_CRSConfig to support STM32H7 <strong>Rev.V</strong> and <strong>Rev.Y</strong></li>
1200 <li>Add USB2 OTG FS ULPI macros: __HAL_RCC_USB2_OTG_FS_ULPI_CLK_ENABLE, __HAL_RCC_USB2_OTG_FS_ULPI_CLK_DISABLE, __HAL_RCC_USB2_OTG_FS_ULPI_IS_CLK_ENABLED, __HAL_RCC_USB2_OTG_FS_ULPI_IS_CLK_DISABLED __HAL_RCC_USB2_OTG_FS_ULPI_CLK_SLEEP_ENABLE, __HAL_RCC_USB2_OTG_FS_ULPI_CLK_SLEEP_DISABLE, __HAL_RCC_USB2_OTG_FS_ULPI_IS_CLK_SLEEP_ENABLED and __HAL_RCC_USB2_OTG_FS_ULPI_IS_CLK_SLEEP_DISABLED</li>
1201 </ul></li>
1202 <li><strong>HAL RTC</strong>:
1203 <ul>
1204 <li>Update to support <strong>DUAL CORE</strong> lines:
1205 <ul>
1206 <li>stm32h7xx_hal_rtc.h:
1207 <ul>
1208 <li>Add __HAL_RTC_ALARM_EXTID2_ENABLE_IT and __HAL_RTC_ALARM_EXTID2_DISABLE_IT macros : allowing to enable/disable generating EXTI IT for D2 Domain/Cortex-M4 upon an RTC ALARM</li>
1209 <li>Add __HAL_RTC_ALARM_EXTID2_ENABLE_EVENT and __HAL_RTC_ALARM_EXTID2_DISABLE_EVENT macros: allowing to enable/disable generating EXTI EVENT for D2 Domain/Cortex-M4 upon an RTC ALARM</li>
1210 <li>Add __HAL_RTC_ALARM_EXTID2_GET_FLAG and __HAL_RTC_ALARM_EXTID2_CLEAR_FLAG macros: allowing to get/clear EXTI RTC ALARM flag</li>
1211 </ul></li>
1212 <li>stm32h7xx_hal_rtc_ex.h:
1213 <ul>
1214 <li>Add __HAL_RTC_WAKEUPTIMER_EXTID2_ENABLE_IT and __HAL_RTC_WAKEUPTIMER_EXTID2_DISABLE_IT macros: allowing to enable/disable generating EXTI IT for D2 Domain/Cortex-M4 upon an RTC WakeUp</li>
1215 <li>Add __HAL_RTC_WAKEUPTIMER_EXTID2_ENABLE_EVENT and __HAL_RTC_WAKEUPTIMER_EXTID2_DISABLE_EVENT macros: allowing to enable/disable generating EXTI EVENT for D2 Domain/Cortex-M4 upon an RTC WakeUp</li>
1216 <li>Add __HAL_RTC_TAMPER_TIMESTAMP_EXTID2_GET_FLAG and __HAL_RTC_TAMPER_TIMESTAMP_EXTID2_CLEAR_FLAG macros: allowing to get/clear EXTI RTC TIMESTAMP flag</li>
1217 </ul></li>
1218 <li>stm32h7xx_hal_rtc.c:
1219 <ul>
1220 <li>Update HAL_RTC_AlarmIRQHandler function to support EXTI IT clearing for Cortex-M7 or Cortex-M4</li>
1221 </ul></li>
1222 <li>stm32h7xx_hal_rtc_ex.c:
1223 <ul>
1224 <li>Update HAL_RTCEx_SetTimeStamp_IT function : don’t enable the EXTI IT in case of <strong>DUAL CORE</strong>. User may the use either __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_IT or __HAL_RTC_ALARM_EXTID2_ENABLE_IT to enable the IT for either Cortex-M7 or Cortex-M4</li>
1225 <li>Update HAL_RTCEx_TamperTimeStampIRQHandler function to support EXTI IT clearing for Cortex-M7 or Cortex-M4</li>
1226 </ul></li>
1227 </ul></li>
1228 </ul></li>
1229 <li><strong>HAL SAI</strong>:
1230 <ul>
1231 <li>Update to support STM32H7 <strong>Rev.V</strong>:
1232 <ul>
1233 <li>SAI_InitTypeDef structure: Add filed MckOutput field (specific for STM32H7 <strong>Rev.V</strong> devices) allowing to select whether master clock output will be generated or not</li>
1234 <li>Update HAL_SAI_Init function in order to apply MckOutput field of the init structure for STM32H7 <strong>Rev.V</strong> devices (<strong>Rev.B</strong> and above)</li>
1235 </ul></li>
1236 <li>Fix register callback management for ErrorCallback in HAL_SAI_IRQHandler function</li>
1237 </ul></li>
1238 <li><strong>HAL SD</strong>:
1239 <ul>
1240 <li>Update to add support of DDR mode</li>
1241 <li>Update to fix behavior of uSD cards v1.x</li>
1242 </ul></li>
1243 <li><strong>HAL TIM</strong>:
1244 <ul>
1245 <li>Align DMA Burst defines with the reference manual: Remove TIM_DMABASE_OR definition Add TIM_DMABASE_TISEL definition</li>
1246 </ul></li>
1247 <li><strong>LL ADC</strong>:
1248 <ul>
1249 <li>Update to support STM32H7 <strong>Rev.V</strong> :
1250 <ul>
1251 <li>Add definition for boost mode ranges supported by the STM32H7 <strong>Rev.V</strong>:
1252 <ul>
1253 <li>LL_ADC_BOOST_MODE_6MHZ25, LL_ADC_BOOST_MODE_12MHZ5, LL_ADC_BOOST_MODE_20MHZ, LL_ADC_BOOST_MODE_25MHZ and LL_ADC_BOOST_MODE_50MHZ</li>
1254 </ul></li>
1255 <li>Update LL_ADC_SetResolution and LL_ADC_GetResolution APIs to support STM32H7 <strong>Rev.V</strong> and STM32H7 <strong>Rev.Y</strong> (8bits resolution settings)</li>
1256 <li>Update LL_ADC_SetBoostMode and LL_ADC_GetBoostMode APIs to support STM32H7 <strong>Rev.V</strong> and STM32H7 <strong>Rev.Y</strong></li>
1257 </ul></li>
1258 </ul></li>
1259 <li><strong>LL EXTI</strong>:
1260 <ul>
1261 <li>Update to support <strong>DUAL CORE</strong> lines:
1262 <ul>
1263 <li>stm32h7xx_ll_exti.c:
1264 <ul>
1265 <li>Update LL_EXTI_Init and LL_EXTI_DeInit APIs to support configuration of EXTI lines for Cortex-M7 and Cortex-M4 (C2)</li>
1266 </ul></li>
1267 <li>stm32h7xx_ll_exti.h:
1268 <ul>
1269 <li>Introduce definitions of LL_EXTI_MODE_C1_IT/EVENT/IT_EVENT and LL_EXTI_MODE_C2_IT/EVENT/IT_EVENT allowing to select EXTI modes for Cortex-M7(C1) or Cortex-M4(C2) or a combination of both</li>
1270 <li>Introduce APIs to handle EXTI events for Cortex-M4: LL_C2_EXTI_EnableEvent_x_y, LL_C2_EXTI_DisableEvent_x_y and LL_C2_EXTI_IsEnabledEvent_x_y</li>
1271 <li>Introduce APIs to handle EXTI interrupts for Cortex-M4: LL_C2_EXTI_EnableIT_x_y, LL_C2_EXTI_DisableIT_x_y and LL_C2_EXTI_IsEnabledIT_x_y</li>
1272 <li>Introduce APIs o handle EXTI flags for Cortex-M4: LL_C2_EXTI_IsActiveFlag_x_y, LL_C2_EXTI_ReadFlag_x_y and LL_C2_EXTI_ClearFlag_x_y</li>
1273 </ul></li>
1274 </ul></li>
1275 </ul></li>
1276 <li><strong>LL HSEM</strong>:
1277 <ul>
1278 <li>Update to support <strong>DUAL CORE</strong> lines:
1279 <ul>
1280 <li>stm32h7xx_ll_hsem.h:
1281 <ul>
1282 <li>Add definition of LL_HSEM_COREID_CPU2</li>
1283 <li>Add APIs to handle IT management for Cortex-M4: LL_HSEM_EnableIT_C2IER, LL_HSEM_DisableIT_C2IER and LL_HSEM_IsEnabledIT_C2IER</li>
1284 <li>Add APIs to handle flags management for Cortex-M4: LL_HSEM_ClearFlag_C2ICR, LL_HSEM_IsActiveFlag_C2ISR and LL_HSEM_IsActiveFlag_C2MISR</li>
1285 </ul></li>
1286 </ul></li>
1287 </ul></li>
1288 <li><strong>LL PWR</strong>:
1289 <ul>
1290 <li>Update to support <strong>DUAL CORE</strong> lines:
1291 <ul>
1292 <li>Add CPU1/2 low power flags:
1293 <ul>
1294 <li>Add LL_PWR_FLAG_CPU2_CSSF flag definition: for CPU2(Cortex-M4) STANDBY, STOP and HOLD flags</li>
1295 <li>Add LL_PWR_FLAG_SMPSEXTRDY flag definition: SMPS External supply ready flag</li>
1296 <li>Add LL_PWR_FLAG_CPU_HOLD2F flag definition: CPU1(Cortex-M7) in hold wakeup flag</li>
1297 <li>Add LL_PWR_FLAG_CPU2_SBF_D2 and LL_PWR_FLAG_CPU2_SBF_D1: respectively for D1/D2 CPU2(Cortex-M4) standby flags</li>
1298 <li>Add LL_PWR_FLAG_CPU2_SBF flag definition: CPU2(Cortex-M4) system standby flag</li>
1299 <li>Add LL_PWR_FLAG_CPU2_STOPF flag definition: CPU2(Cortex-M4) system stop flag</li>
1300 <li>Add LL_PWR_FLAG_CPU2_HOLD1F flag definition: CPU2(Cortex-M4) in hold wakeup flag</li>
1301 </ul></li>
1302 <li>Add CPU2 low power modes:
1303 <ul>
1304 <li>Add LL_PWR_CPU2_MODE_D1STOP definition: Enter D1 domain to Stop mode when the CPU2(Cortex-M4) enters deep sleep</li>
1305 <li>Add LL_PWR_CPU2_MODE_D1STANDBY definition: Enter D1 domain to Standby mode when the CPU2(Cortex-M4) enters deep sleep</li>
1306 <li>Add LL_PWR_CPU2_MODE_D2STOP definition: Enter D2 domain to Stop mode when the CPU2(Cortex-M4) enters deep sleep</li>
1307 <li>Add LL_PWR_CPU2_MODE_D2STANDBY definition: Enter D2 domain to Standby mode when the CPU2(Cortex-M4) enters deep sleep</li>
1308 <li>Add LL_PWR_CPU2_MODE_D3STOP definition: Enter D3 domain to Stop mode when the CPU2(Cortex-M4) enters deep sleep</li>
1309 <li>Add LL_PWR_CPU2_MODE_D3STANDBY definition: Enter D3 domain to Standby mode when the CPU2(Cortex-M4) enters deep sleep</li>
1310 <li>Add LL_PWR_CPU2_MODE_D3RUN definition: Keep system D3 domain in RUN mode when the CPU2 enter deep sleep</li>
1311 </ul></li>
1312 <li>Add definition for <strong>DUAL CORE</strong> lines new SMPS and LDO power supply source configuration:
1313 <ul>
1314 <li>LL_PWR_DIRECT_SMPS_SUPPLY: Core domains are supplied from the SMPS regulator</li>
1315 <li>LL_PWR_SMPS_1V8_SUPPLIES_LDO: The SMPS 1.8V output supplies the LDO which supplies the Core domains</li>
1316 <li>LL_PWR_SMPS_2V5_SUPPLIES_LDO: The SMPS 2.5V output supplies the LDO which supplies the Core domains</li>
1317 <li>LL_PWR_SMPS_1V8_SUPPLIES_EXT_AND_LDO: The SMPS 1.8V output supplies an external circuits and the LDO. The Core domains are supplied from the LDO</li>
1318 <li>LL_PWR_SMPS_2V5_SUPPLIES_EXT_AND_LDO: The SMPS 2.5V output supplies an external circuits and the LDO. The Core domains are supplied from the LDO</li>
1319 <li>LL_PWR_SMPS_1V8_SUPPLIES_EXT : The SMPS 1.8V output supplies an external source which supplies the Core domains</li>
1320 <li>LL_PWR_SMPS_2V5_SUPPLIES_EXT : The SMPS 2.5V output supplies an external source which supplies the Core domains</li>
1321 </ul></li>
1322 <li>Update LL_PWR_ConfigSupply and LL_PWR_GetSupply APIs implementation to support new power supply sources on <strong>DUAL CORE</strong> lines</li>
1323 <li>Add LL_PWR_CPU2_SetD1PowerMode and LL_PWR_CPU2_GetD1PowerMode APIs: allowing to Set/Get D1 domain low power mode when CPU2(Cortex-M4) goes to deep sleep mode</li>
1324 <li>Add LL_PWR_CPU2_SetD2PowerMode and LL_PWR_CPU2_GetD2PowerMode APIs: allowing to Set/Get D2 domain low power mode when CPU2(Cortex-M4) goes to deep sleep mode</li>
1325 <li>Add LL_PWR_CPU2_SetD3PowerMode and LL_PWR_CPU2_GetD3PowerMode APIs: allowing to Set/Get D3 domain low power mode when CPU2(Cortex-M4) goes to deep sleep mode</li>
1326 <li>Add LL_PWR_HoldCPU1 , LL_PWR_ReleaseCPU1 and LL_PWR_IsCPU1Held APIs : allowing to Hold/Release CPU1(CoretxM7) when exiting from STOP mode</li>
1327 <li>Add LL_PWR_HoldCPU2 , LL_PWR_ReleaseCPU2 and LL_PWR_IsCPU2Held APIs : allowing to Hold/Release CPU2(CoretxM4) when exiting from STOP mode</li>
1328 <li>Add LL_PWR_CPU2_EnableD3RunInLowPowerMode LL_PWR_CPU2_DisableD3RunInLowPowerMode and LL_PWR_CPU2_IsEnabledD3RunInLowPowerMode APIs: allowing to Set/Get D3 domain low power mode when CPU2(Cortex-M4) goes to deep sleep mode</li>
1329 <li>Add LL_PWR_IsActiveFlag_SMPSEXT API: allowing to check the external SMPS supply ready flag</li>
1330 <li>Add LL_PWR_IsActiveFlag_HOLD2 and LL_PWR_IsActiveFlag_HOLD1: allowing to get CPU2(Cortex-M4) and CPU1(Cortex-M7) HOLD flags</li>
1331 <li>Add LL_PWR_CPU2_IsActiveFlag_STOP and LL_PWR_CPU2_IsActiveFlag_SB: allowing to get CPU2(Cortex-M4) Stop and standby flags</li>
1332 <li>Add LL_PWR_CPU2_IsActiveFlag_SB_D1 API: allowing to get CPU2(Cortex-M4) D1 domain standby flag</li>
1333 <li>Add LL_PWR_CPU2_IsActiveFlag_SB_D2 API: allowing to get CPU2(Cortex-M4) D2 domain standby flag</li>
1334 <li>Add LL_PWR_ClearFlag_CPU2 API: allowing to clear CPU2(Cortex-M4) low power flags</li>
1335 </ul></li>
1336 </ul></li>
1337 <li><strong>LL LPTIM</strong>:
1338 <ul>
1339 <li>Update LL_LPTIM_Init function to configure the LPTIM only when it is disabled, return ERROR if not</li>
1340 </ul></li>
1341 <li><strong>LL RCC</strong>:
1342 <ul>
1343 <li>Fix RCC registers reset values in LL_RCC_DeInit API</li>
1344 <li>Add LL_RCC_GetDSIClockFreq, LL_RCC_SetDSIClockSource and LL_RCC_GetDSIClockSource APIs and LL_RCC_DSI_CLKSOURCE_PHY/LL_RCC_DSI_CLKSOURCE_PLL2Q/LL_RCC_DSI_CLKSOURCE defines for DSI peripheral</li>
1345 <li>Update LL_RCC_HSI_GetCalibration, LL_RCC_HSI_SetCalibTrimming and LL_RCC_HSI_GetCalibTrimming to support HSI trimming on STM32H7 <strong>Rev.V</strong> and STM32H7 <strong>Rev.Y</strong></li>
1346 <li>Update LL_RCC_CSI_GetCalibration, LL_RCC_CSI_SetCalibTrimming and LL_RCC_CSI_GetCalibTrimming to support CSI trimming and calibration on STM32H7 <strong>Rev.V</strong> and STM32H7 <strong>Rev.Y</strong></li>
1347 <li>Update to support <strong>DUAL CORE</strong> lines:
1348 <ul>
1349 <li>Add WWDG2 APIs: LL_RCC_WWDG2_EnableSystemReset and LL_RCC_WWDG2_IsSystemReset</li>
1350 <li>Add LL_RCC_ForceCM4Boot and LL_RCC_IsCM4BootForced APIs: to enable/check Cortex-M4 boot if hold by FLASH option byte BCM4</li>
1351 <li>Add LL_RCC_ForceCM7Boot and LL_RCC_IsCM7BootForced APIs: to enable/check Cortex-M7 boot if hold by FLASH option byte BCM7</li>
1352 <li>Update implementation of LL_RCC_IsActiveFlag_LPWRRST for <strong>DUAL CORE</strong> lines</li>
1353 <li>Add API LL_RCC_IsActiveFlag_LPWR2RST to check D2 domain low power reset flag</li>
1354 <li>Add LL_RCC_IsActiveFlag_WWDG2RST and LL_RCC_IsActiveFlag_IWDG2RST allowing to check WWD2 and IWDG2 reset flag</li>
1355 <li>Update LL_RCC_IsActiveFlag_SFTRST implementation for <strong>DUAL CORE</strong> lines</li>
1356 <li>Add LL_RCC_IsActiveFlag_SFT2RST API allowing to check SW reset flag for Cortex-M4</li>
1357 <li>Update LL_RCC_IsActiveFlag_CPURST implementation for <strong>DUAL CORE</strong> lines</li>
1358 <li>Add LL_RCC_IsActiveFlag_CPU2RST API allowing to check CPU2(Cortex-M4) reset flag</li>
1359 <li>Add LL_C1/2_RCC_IsActiveFlag_LPWRRST and LL_C1/2_RCC_IsActiveFlag_LPWR2RST APIs: allowing to check D1 and D2 domain low power reset respectively for CoretxM7/M4</li>
1360 <li>Add LL_C1/2_RCC_IsActiveFlag_WWDG1RST and LL_C1/2_RCC_IsActiveFlag_WWDG2RST APIs: allowing to check WWDG1 and WWDG2 reset flag respectively for CoretxM7/M4</li>
1361 <li>Add LL_C1/2_RCC_IsActiveFlag_IWDG1RST and LL_C1/2_RCC_IsActiveFlag_IWDG2RST APIs: allowing to check IWDG1 and IWDG2 reset flag respectively for CoretxM7/M4</li>
1362 <li>Add LL_C1/C2_RCC_IsActiveFlag_SFTRST APIs: allowing to check SW reset flag for respectively for Cortex-M7/M4</li>
1363 <li>Add LL_C1/C2_RCC_IsActiveFlag_SFT2RST APIs: allowing to check SW reset flag 2 for respectively for Cortex-M7/M4</li>
1364 <li>Add LL_C1/C2_RCC_IsActiveFlag_PORRST APIs: allowing to check POR/PDR reset flag for respectively for Cortex-M7/M4</li>
1365 <li>Add LL_C1/C2_RCC_IsActiveFlag_PINRST APIs: allowing to check Pin reset flag for respectively for Cortex-M7/M4</li>
1366 <li>Add LL_C1/C2_RCC_IsActiveFlag_D1RST APIs: allowing to check D1 domain reset flag for respectively for Cortex-M7/M4</li>
1367 <li>Add LL_C1/C2_RCC_IsActiveFlag_D2RST APIs: allowing to check D2 domain reset flag for respectively for Cortex-M7/M4</li>
1368 <li>Add LL_C1/C2_RCC_IsActiveFlag_CPURST APIs: allowing to check Cortex-M7 reset</li>
1369 <li>Add LL_C1/C2_RCC_IsActiveFlag_CPU2RST APIs: allowing to check Cortex-M4 reset</li>
1370 <li>Add LL_C1/C2_RCC_ClearResetFlags APIs: allowing to clear respectively Cortex-M7/M4 reset flags</li>
1371 </ul></li>
1372 </ul></li>
1373 <li><strong>LL SDMMC</strong>:
1374 <ul>
1375 <li>Update to support DDR mode</li>
1376 </ul></li>
1377 <li><strong>LL SYSTEM</strong>:
1378 <ul>
1379 <li>Add new APIs to allow timers break source selection (new feature of STM32H7 devices <strong>Rev.V</strong>)</li>
1380 <li>Update to support <strong>DUAL CORE</strong> lines:
1381 <ul>
1382 <li>Add LL_SYSCFG_IWDG2_SW_CONTROL_MODE and LL_SYSCFG_IWDG2_HW_CONTROL_MODE definition: for IWDG2 control mode</li>
1383 <li>Add LL_SYSCFG_GetIWDG2ControlMode API allowing to select IWDG2 control mode at SYSCFG level</li>
1384 <li>Update LL_SYSCFG_SetCM7BootAddress0/1 and LL_SYSCFG_GetCM7BootAddress0/1 APIs implementation for <strong>DUAL CORE</strong> : register bit naming change</li>
1385 <li>Add LL_SYSCFG_SetCM4BootAddress0/1 and LL_SYSCFG_GetCM4BootAddress0/1 APIs for Cortex-M4 SYSCFG boot address setting</li>
1386 <li>Add LL_SYSCFG_IsD2StandbyGenerateReset and LL_SYSCFG_IsD2StopGenerateReset APIs: allowing to check D2 domain SYSCFG Stop/Standby reset flag</li>
1387 <li>Add LL_DBGMCU_EnableD2DebugInSleepMode and LL_DBGMCU_DisableD2DebugInSleepMode APIs: allowing to enable/disable D2 domain debug in sleep mode</li>
1388 <li>Add LL_DBGMCU_EnableD2DebugInStopMode and LL_DBGMCU_DisableD2DebugInStopMode APIs: allowing to enable/disable D2 domain debug in stop mode</li>
1389 <li>Add LL_DBGMCU_EnableD2DebugInStandbyMode and LL_DBGMCU_DisableD2DebugInStandbyMode APIs: allowing to enable/disable D2 domain debug in standby mode</li>
1390 </ul></li>
1391 </ul></li>
1392 <li><strong>LL USB</strong>:
1393 <ul>
1394 <li>Cleanup and fix USB PCD to handle EP0OUT transfers in USB DMA mode</li>
1395 <li>Fix and enhancement of BCD (Battery Charging) feature</li>
1396 <li>Fix and enhancement to power-up the internal FS transceiver when the BCD discovery is completed</li>
1397 </ul></li>
1398 <li><strong>LL UTILS</strong>:
1399 <ul>
1400 <li>Update LL_Init1msTick and LL_SetSystemCoreClock description for <strong>DUAL CORE</strong> lines</li>
1401 </ul></li>
1402 </ul>
1403 <h2 id="known-limitations-2">Known Limitations</h2>
1404 <ul>
1405 <li><strong>HAL SD</strong>:
1406 <ul>
1407 <li>The STM32H7xx devices provide two instances of the SDMMC peripheral, each instance could be configured with or without an external 1.8V/3.3V transceiver:
1408 <ul>
1409 <li>The STM32H7 HAL SD driver doesn’t support Mix configuration: i.e one instance with transceiver and the other one without</li>
1410 </ul></li>
1411 </ul></li>
1412 <li><strong>HAL I2S</strong>:
1413 <ul>
1414 <li>Full duplex Transmit/receive feature not available</li>
1415 </ul></li>
1416 </ul>
1417 <h2 id="backward-compatibility-2">Backward compatibility</h2>
1418 <ul>
1419 <li><strong>HAL ADC</strong>:
1420 <ul>
1421 <li>Backward compatibility break introduced since <strong>v1.4.0</strong> versus <strong>v1.3.x</strong> versions: In ADC_InitTypeDef structure, filed BoostMode is removed.</li>
1422 </ul></li>
1423 <li><strong>HAL IRDA</strong>:
1424 <ul>
1425 <li>Backward compatibility break introduced since <strong>v1.4.0</strong> versus <strong>v1.3.x</strong> versions:
1426 <ul>
1427 <li>Alignment with STM32F7/L4/G0 (for inter STM32 families portability)</li>
1428 <li>Add new field “ClockPrescaler” to “IRDA_InitTypeDef” structure"</li>
1429 </ul></li>
1430 </ul></li>
1431 <li><strong>HAL SMARTCARD</strong>:
1432 <ul>
1433 <li>Backward compatibility break introduced since <strong>v1.4.0</strong> versus <strong>v1.3.x</strong> versions:
1434 <ul>
1435 <li>Alignment with STM32F7/L4/G0 (for inter STM32 families portability)</li>
1436 <li>Remove fields “FIFOMode”, “TXFIFOThreshold” and “RXFIFOThreshold” from “SMARTCARD_InitTypeDef” structure</li>
1437 <li>Add new field “ClockPrescaler” to “SMARTCARD_InitTypeDef” structure"</li>
1438 <li>SMARTCARD RXFIFO and TXFIFO threshold level defines moved to “stm32h7xx_hal_smartcard_ex.h”</li>
1439 </ul></li>
1440 </ul></li>
1441 <li><strong>HAL UART</strong>:
1442 <ul>
1443 <li>Backward compatibility break introduced since <strong>v1.4.0</strong> versus <strong>v1.3.x</strong> versions:
1444 <ul>
1445 <li>Alignment with STM32F7/L4/G0 (for inter STM32 families portability)</li>
1446 <li>Field “Prescaler” of structure “UART_InitTypeDef” renamed to ClockPrescaler</li>
1447 <li>remove fields “FIFOMode”, “TXFIFOThreshold” and “RXFIFOThreshold” from “UART_InitTypeDef” structure</li>
1448 <li>UART RXFIFO and TXFIFO threshold level defines moved to “stm32h7xx_hal_uart_ex.h”</li>
1449 </ul></li>
1450 </ul></li>
1451 <li><strong>HAL USART</strong>:
1452 <ul>
1453 <li>Backward compatibility break introduced since <strong>v1.4.0</strong> versus <strong>v1.3.x</strong> versions:
1454 <ul>
1455 <li>Alignment with STM32F7/L4/G0 (for inter STM32 families portability)</li>
1456 <li>Introduce “stm32h7xx_hal_usart_ex.c” file with new Tx/Rx FIFO management APIs</li>
1457 <li>Field “Prescaler” of structure “USART_InitTypeDef” renamed to ClockPrescaler</li>
1458 <li>remove fields “NSS”, “SlaveMode”, “FIFOMode”, “TXFIFOThreshold” and “RXFIFOThreshold” from “USART_InitTypeDef” structure</li>
1459 <li>USART RXFIFO and TXFIFO threshold level defines moved to “stm32h7xx_hal_usart_ex.h”</li>
1460 <li>USART Salve Mode defines moved to “stm32h7xx_hal_usart_ex.h”</li>
1461 </ul></li>
1462 </ul></li>
1463 </ul>
1464 </div>
1465 </div>
1466 <div class="collapse">
1467 <input type="checkbox" id="collapse-section5" aria-hidden="true"> <label for="collapse-section5" aria-hidden="true"><strong>V1.4.0 / 30-November-2018</strong></label>
1468 <div>
1469 <h2 id="main-changes-3">Main Changes</h2>
1470 <ul>
1471 <li>General updates to fix known defects and implementation enhancements</li>
1472 <li>Add LL drivers : LL_ADC, LL_BDMA, LL_BUS, LL_COMP, LL_CORTEX, LL_CRC, LL_DAC, LL_DMA, LL_DMA2D, LL_DMAMUX, LL_EXTI, LL_GPIO, LL_HRTIM, LL_HSEM, LL_I2C, LL_IWDG, LL_LPTIM, LL_LPUART, LL_MDMA, LL_OPAMP,LL_PWR, LL_RCC, LL_RNG, LL_RTC, LL_SPI, LL_SWPMI, LL_SYSTEM, LL_TIM, LL_USART, LL_UTILS, LL_WWDG</li>
1473 <li>Introduce the register callback mechanism. It permits the user to configure dynamically the interrupt callbacks:
1474 <ul>
1475 <li>hal_conf_template.h is updated to embed the required new define to activate the feature : one define per HAL driver, example: USE_HAL_I2C_REGISTER_CALLBACKS</li>
1476 </ul></li>
1477 <li>Add HAL <strong>EXTI</strong> driver</li>
1478 <li>Add HAL <strong>RAMECC</strong> driver</li>
1479 <li><strong>HAL</strong> : stm32h7xx_hal.c and stm32h7xx_hal.h and stm32h7xx_hal_conf_template.h files
1480 <ul>
1481 <li>Fix register bit field “SYSCFG_PMCR_EPIS_SEL” naming in function “HAL_SYSCFG_ETHInterfaceSelect” in stm32h7xx_hal.c:
1482 <ul>
1483 <li>Alignment with the cmsis device include files</li>
1484 </ul></li>
1485 <li>Rename internal private macro “IS_EXTI_CONFIG_LINE” to IS_HAL_EXTI_CONFIG_LINE in stm32h7xx_hal.h: to avoid conflict with HAL EXTI driver</li>
1486 <li>Update stm32h7xx_hal_conf_template.h to add HAL EXTI and HAL RAMECC</li>
1487 <li>Update stm32h7xx_hal_conf_template.h to to put the include of the MDMA HAL header file before the include of the JPEG and QSPI HAL header files (as JPEG and QSPI HAL drivers are using the MDMA)</li>
1488 <li>File stm32h7xx_hal.c, update HAL_SetFMCMemorySwappingConfig and HAL_GetFMCMemorySwappingConfig to align with Reference Manual regarding registers and bit definition naming</li>
1489 <li>Update stm32h7xx_hal.c with Driver version number set to V1.4.0</li>
1490 </ul></li>
1491 <li><strong>HAL ADC</strong>:
1492 <ul>
1493 <li>Remove BoostMode from Init structure, this settings is automatically handled by HAL_ADC_Init() function depending of the ADC Clock value
1494 <ul>
1495 <li><strong>Caution : compatibility break with previous version regarding ADC init parameters (ADC_InitTypeDef structure)</strong></li>
1496 </ul></li>
1497 </ul></li>
1498 <li><strong>HAL_CRYP</strong>:
1499 <ul>
1500 <li>Improve error detection in function “CRYP_GCMCCM_SetPayloadPhase_IT”</li>
1501 <li>Improve padding management in function “CRYP_GCMCCM_SetPayloadPhase_IT”</li>
1502 <li>Fix data counter issue in function “CRYP_AESCCM_Process”</li>
1503 </ul></li>
1504 <li><strong>HAL DFSDM</strong>:
1505 <ul>
1506 <li>Rename DFSDM_FILTER_EXT_TRIG_LPTIMx with DFSDM_FILTER_EXT_TRIG_LPTIMx_OUT</li>
1507 </ul></li>
1508 <li><strong>HAL DMA</strong>:
1509 <ul>
1510 <li>Add double buffering feature support for BDMA</li>
1511 <li>Fix DMA_FLAG_FEIF0_4 and DMA_FLAG_DMEIF0_4 numerical values (no impact on the functional behavior)</li>
1512 <li>Add a Clean/Reset of callbacks in HAL_DMA_DeInit()</li>
1513 <li>Remove FIFO error enabling in “HAL_DMA_Start_IT”. when FIFO error monitoring is requested in IT model, the macro __HAL_DMA_ENABLE_IT can be used to enable the FIFO error IT at the user Msp function</li>
1514 <li>Remove check on busy state within “HAL_DMA_DeInit” function : to allow forcing a de-initialization even in busy state</li>
1515 </ul></li>
1516 <li><strong>HAL ETH</strong>:
1517 <ul>
1518 <li>Add check for input buffer against NULL in function HAL_ETH_GetRxDataBuffer</li>
1519 </ul></li>
1520 <li><strong>HAL FDCAN</strong>:
1521 <ul>
1522 <li>Fix counter increment in API HAL_FDCAN_ConfigFilter</li>
1523 <li>Fix comment description of parameter “RxFDFflag” in “FDCAN_ProtocolStatusTypeDef” structure</li>
1524 <li>Fix comment description of defines FDCAN_FRAME_FD_NO_BRS and FDCAN_FRAME_FD_BRS</li>
1525 <li>Add a reset of FDCAN operation mode in the “HAL_FDCAN_Init” function</li>
1526 <li>Add Error Status callback support:
1527 <ul>
1528 <li>Add parameter “ErrorStatusCallback” in FDCAN_HandleTypeDef structure in stm32h7xx_hal_fdcan.h</li>
1529 <li>Add typedef “pFDCAN_ErrorStatusCallbackTypeDef” in stm32h7xx_hal_fdcan.h</li>
1530 <li>Add APIs “HAL_FDCAN_RegisterErrorStatusCallback” and “HAL_FDCAN_UnRegisterErrorStatusCallback”</li>
1531 <li>Add weak callback “HAL_FDCAN_ErrorStatusCallback”</li>
1532 <li>Update “HAL_FDCAN_IRQHandler” function to call the ErrorStatusCallback in case of an error status interrupt</li>
1533 </ul></li>
1534 <li>Improve error management by adding error codes “HAL_FDCAN_ERROR_FIFO_EMPTY” and “HAL_FDCAN_ERROR_FIFO_FULL” used in case of FIFO full in “HAL_FDCAN_AddMessageToTxFifoQ” and FIFO empty in “HAL_FDCAN_GetRxMessage” functions</li>
1535 <li>Fix implementation issue in “HAL_FDCAN_ResetTimeoutCounter” function</li>
1536 <li>Improve behavior of “HAL_FDCAN_GetRxMessage” and “HAL_FDCAN_GetTxEvent” functions : operation not allowed in HAL_FDCAN_STATE_READY state</li>
1537 </ul></li>
1538 <li><strong>HAL FLASH</strong>:
1539 <ul>
1540 <li>Align driver with the Reference Manual regarding registers and bit definition naming</li>
1541 </ul></li>
1542 <li><strong>HAL GPIO</strong>:
1543 <ul>
1544 <li>Add assert check of parameter GPIO_Pin in function “HAL_GPIO_DeInit”</li>
1545 <li>Add assert check against alternate function availability for parameter “GPIOx” in function “HAL_GPIO_Init”</li>
1546 <li>Improve “HAL_GPIO_TogglePin” function against reentrancy</li>
1547 <li>Move GPIO clearing to default values in “HAL_GPIO_DeInit” function after EXTI clearing to avoid unexpected pending interrupts issues</li>
1548 </ul></li>
1549 <li><strong>HAL HRTIM</strong>:
1550 <ul>
1551 <li>Fix “HAL_HRTIM_FaultConfig” function regarding FLTINR1 and FLTINR2 registers settings</li>
1552 <li>Update “HAL_HRTIM_SimpleBaseStop_DMA”, “HAL_HRTIM_SimpleOCStop_DMA” and “HAL_HRTIM_SimplePWMStop_DMA” functions to add a check for the DMA handle against NULL pointer</li>
1553 <li>Fix HAL_HRTIM_SimpleOCChannelConfig,, “HAL_HRTIM_SimpleCaptureChannelConfig”, HAL_HRTIM_SimplePWMChannelConfig and “HAL_HRTIM_SimpleOnePulseChannelConfig” functions : considering parameters “pSimpleOCChannelCfg-&gt;Polarity” , “pSimpleOCChannelCfg-&gt;IdleLevel” and “pSimpleCaptureChannelCfg-&gt;EventSensitivity”</li>
1554 </ul></li>
1555 <li><strong>HAL IRDA (compatibility break)</strong>: alignment with STM32L4 (for inter STM32 families portability)
1556 <ul>
1557 <li>Add new field “ClockPrescaler” to “IRDA_InitTypeDef” structure"</li>
1558 </ul></li>
1559 <li><strong>HAL I2C</strong>:
1560 <ul>
1561 <li>ErrorCode is set to HAL_I2C_ERROR_INVALID_PARAM in all APIs when I2C handle is NULL</li>
1562 <li>Add and I2C restart condition for each call of HAL_I2C_Master_Sequential_xxxx_IT</li>
1563 <li>Rename APIs “HAL_I2C_Master_Sequential_Transmit_IT” and “HAL_I2C_Master_Seq_Receive_IT” respectively to “HAL_I2C_Master_Seq_Transmit_IT” and “HAL_I2C_Master_Seq_Receive_IT” for MISRA-C 2012 compliance</li>
1564 <li>Rename APIs “HAL_I2C_Slave_Sequential_Transmit_IT” and “HAL_I2C_Slave_Sequential_Receive_IT” respectively to “HAL_I2C_Slave_Seq_Transmit_IT” and “HAL_I2C_Slave_Seq_Receive_IT” for MISRA-C 2012 compliance</li>
1565 <li>Rename APIs “HAL_I2C_Master_Sequential_Transmit_DMA” and “HAL_I2C_Master_Seq_Receive_DMA” respectively to “HAL_I2C_Master_Seq_Transmit_DMA” and “HAL_I2C_Master_Seq_Receive_DMA” for MISRA-C 2012 compliance</li>
1566 <li>Rename APIs “HAL_I2C_Slave_Sequential_Transmit_DMA” and “HAL_I2C_Slave_Sequential_Receive_DMA” respectively to “HAL_I2C_Slave_Seq_Transmit_DMA” and “HAL_I2C_Slave_Seq_Receive_DMA” for MISRA-C 2012 compliance</li>
1567 </ul></li>
1568 <li><strong>HAL I2S</strong>:
1569 <ul>
1570 <li>Align driver with the Reference Manual regarding registers and bit definition naming</li>
1571 <li>Fix HAL_I2S_DMAPause and HAL_I2S_DMAResume management</li>
1572 <li>HAL_I2S_DMAStop is no more supported (return HAL_I2S_ERROR_NOT_SUPPORTED when called)</li>
1573 <li>Fix FifoThreshold affectation into HAL_I2S_Init</li>
1574 <li>Update several defines into stm32h7xx_hal_i2s.h</li>
1575 <li>Add macro __HAL_I2S_CLEAR_SUSPFLAG</li>
1576 <li>Fix compilation issue when SPI driver is not included in the project (Due to the use of some HAL SPI define, use appropriate I2S defines instead)</li>
1577 <li>Fix Tx and RX buffers increment to avoid memory overflow (functions HAL_I2S_Transmit, HAL_I2S_Receive, I2S_RxISR_16BIT, I2S_RxISR_32BIT, I2S_TxISR_16BIT and I2S_TxISR_32BIT)</li>
1578 <li><strong>Known limitations:</strong>
1579 <ul>
1580 <li><strong>Driver not fully tested, some features may not be working as expected</strong></li>
1581 <li><strong>A new version of this driver will be available in next release with full features tested</strong></li>
1582 </ul></li>
1583 </ul></li>
1584 <li><strong>HAL JPEG</strong>:
1585 <ul>
1586 <li>Remove include of MDMA HAL driver as it is already done through the stm32h7xx_hal_conf.h header file
1587 <ul>
1588 <li>Note : in the stm32h7xx_hal_conf.h the include of the MDMA HAL header file must be done before the include of the JPEG HAL header file (stm32h7xx_hal_conf_template.h updated accordingly)</li>
1589 </ul></li>
1590 </ul></li>
1591 <li><strong>HAL LPTIM</strong>:
1592 <ul>
1593 <li>Update “HAL_LPTIM_Init” function to add a clock polarity reset</li>
1594 <li>Update "__HAL_LPTIM_DISABLE" macro implementation</li>
1595 <li>Replace usage of global variables “tmpclksource”, “tmpIER”, “tmpCFGR”, “tmpCMP”, “tmpARR” and “tmpCFGR2” by local ones</li>
1596 </ul></li>
1597 <li><strong>HAL MDMA</strong>:
1598 <ul>
1599 <li>Remove check on busy state within “HAL_MDMA_DeInit” function : to allow forcing a de-initialization even in busy state</li>
1600 </ul></li>
1601 <li><strong>HAL MMC</strong>:
1602 <ul>
1603 <li>Rename “BLOCKSIZE” define to “MMC_BLOCKSIZE” to avoid conflict with HAL SD definition</li>
1604 </ul></li>
1605 <li><strong>HAL PWR</strong>:
1606 <ul>
1607 <li>Update “HAL_PWR_DisableWakeUpPin” function to disable the Wakeup for the given wakeup pin only</li>
1608 <li>Fix “HAL_PWR_EnterSLEEPMode” and “HAL_PWR_EnterSTOPMode” using one single __WFE instruction in case low power mode with wait for event</li>
1609 <li>Fix “HAL_PWREx_EnterSTOPMode” using one single using one single __WFE instruction in case low power mode with wait for event</li>
1610 <li>Add API “HAL_PWREx_ClearPendingEvent” to clear pending events if any</li>
1611 </ul></li>
1612 <li><strong>HAL QSPI</strong>:
1613 <ul>
1614 <li>Remove include of MDMA HAL driver as it is already done through the stm32h7xx_hal_conf.h header file
1615 <ul>
1616 <li>Note : in the stm32h7xx_hal_conf.h the include of the MDMA HAL header file must be done before the include of the QSPI HAL header file (stm32h7xx_hal_conf_template.h updated accordingly)</li>
1617 </ul></li>
1618 <li>Add description of MDMA required settings in the “How to use this driver” section</li>
1619 <li>Fix the “HAL_QSPI_Transmit_DMA” function:
1620 <ul>
1621 <li>Add check for MDMA settings : Data size and increment mode
1622 <ul>
1623 <li>Support of BYTE, HALF WORD and WORD modes</li>
1624 </ul></li>
1625 <li>Enable the QSPI Transfer complete and errors interrupt before starting the MDMA transfer to avoid race condition</li>
1626 </ul></li>
1627 <li>Fix the “HAL_QSPI_Receive_DMA” function :
1628 <ul>
1629 <li>Add check for MDMA settings : Data size and increment mode
1630 <ul>
1631 <li>Support of BYTE, HALF WORD and WORD modes</li>
1632 </ul></li>
1633 </ul></li>
1634 </ul></li>
1635 <li><strong>HAL RCC</strong>:
1636 <ul>
1637 <li>Add management for “Frac” parameter in PLL2 and PLL3</li>
1638 <li>Add macros __HAL_RCC_MCO1_CONFIG and __HAL_RCC_MCO2_CONFIG</li>
1639 <li>Rework HAL_RCC_DeInit function to reset RCC registers</li>
1640 <li>Rework HAL_RCC_ClockConfig function to use the correct divider settings order according to the Reference Manual</li>
1641 <li>Fix PCLK1 Configuration in HAL_RCC_ClockConfig function : use correct register RCC-&gt;D2CFGR instead of RCC-&gt;D1CFGR.</li>
1642 <li>Add definitions of “RCC_SYSCLKSOURCE_STATUS_CSI”, “RCC_SYSCLKSOURCE_STATUS_HSI”, “RCC_SYSCLKSOURCE_STATUS_HSE” and “RCC_SYSCLKSOURCE_STATUS_PLLCLK”</li>
1643 <li>Fix “HAL_RCC_ClockConfig” implementation:
1644 <ul>
1645 <li>Null pointer check</li>
1646 <li>use "__HAL_FLASH_GET_LATENCY" macro instead of direct register access</li>
1647 <li>Optimize the wait for clock source switching</li>
1648 </ul></li>
1649 </ul></li>
1650 <li><strong>HAL RTC</strong>:
1651 <ul>
1652 <li>Add new macro IS_RTC_TAMPER_FILTER_CONFIG_CORRECT() to check filter is enabled only in case of high or low level</li>
1653 <li>Align driver with the Reference Manual regarding registers and bit definition naming</li>
1654 </ul></li>
1655 <li><strong>HAL SAI</strong>:
1656 <ul>
1657 <li>PDM feature is available on SAI1 and SAI4 only</li>
1658 <li>Improve and fix HAL_SAI_DMAStop and HAL_SAI_Abort APIs</li>
1659 <li>Expend external synchronization feature to SAI3 and SAI4</li>
1660 </ul></li>
1661 <li><strong>HAL SD</strong>:
1662 <ul>
1663 <li>Fix and improve High speed and ultra-high speed behavior</li>
1664 <li>Add APIs “HAL_SD_ConfigSpeedBusOperation” to configure the SD card speed bus mode:
1665 <ul>
1666 <li>SDMMC_SPEED_MODE_AUTO: Max speed mode supported by the card</li>
1667 <li>SDMMC_SPEED_MODE_DEFAULT: Default Speed/SDR12 mode</li>
1668 <li>SDMMC_SPEED_MODE_HIGH: High Speed/SDR25 mode</li>
1669 <li>SDMMC_SPEED_MODE_ULTRA: Ultra high speed mode</li>
1670 </ul></li>
1671 <li>Remove extra function prototype “HAL_SD_SendSDStatus” from stm32h7xx_hal_sd.h</li>
1672 <li>Fix multi-buffering feature implementation</li>
1673 </ul></li>
1674 <li><strong>HAL SPI</strong>:
1675 <ul>
1676 <li>Update HAL_SPI_Transmit_DMA : checking hmdtx instead of hdmrx.</li>
1677 <li>Update to add Reload Feature and Duplex Packet DXP
1678 <ul>
1679 <li>Add APIs : “HAL_SPI_Reload_Transmit_IT”, “HAL_SPI_Reload_Receive_IT” and “HAL_SPI_Reload_TransmitReceive_IT”</li>
1680 </ul></li>
1681 <li>Align driver with the Reference Manual regarding registers and bit definition naming</li>
1682 </ul></li>
1683 <li><strong>HAL SMARTCARD(compatibility break)</strong>: Alignment with STM32L4 (for inter STM32 families portability)
1684 <ul>
1685 <li>Remove fields “FIFOMode”, “TXFIFOThreshold” and “RXFIFOThreshold” from “SMARTCARD_InitTypeDef” structure</li>
1686 <li>Add new field “ClockPrescaler” to “SMARTCARD_InitTypeDef” structure"</li>
1687 <li>SMARTCARD RXFIFO and TXFIFO threshold level defines moved to “stm32h7xx_hal_smartcard_ex.h”</li>
1688 <li>Introduce new APIs to manage the Tx and Rx FIFO:
1689 <ul>
1690 <li>HAL_SMARTCARDEx_EnableFifoMode, HAL_SMARTCARDEx_DisableFifoMode, HAL_SMARTCARDEx_SetTxFifoThreshold and HAL_SMARTCARDEx_SetRxFifoThreshold</li>
1691 <li>Introduce “HAL_SMARTCARDEx_RxFifoFullCallback” and “HAL_SMARTCARDEx_TxFifoEmptyCallback”</li>
1692 <li>Fix Linux compilation warning in function “HAL_SMARTCARD_Receive”</li>
1693 </ul></li>
1694 </ul></li>
1695 <li><strong>HAL SRAM, HAL SDRAM , HAL NOR and HAL NAND</strong>:
1696 <ul>
1697 <li>Align driver with the Reference Manual regarding registers and bit definition naming</li>
1698 <li>Fix and improve state and error management</li>
1699 </ul></li>
1700 <li><strong>HAL TIM</strong>:
1701 <ul>
1702 <li>Add a call to HAL_DMA_Abort_IT from HAL_TIM_XXX_Stop_DMA</li>
1703 <li>Add APIs “HAL_TIM_DMABurst_MultiWriteStart” and “HAL_TIM_DMABurst_MultiReadStart”</li>
1704 </ul></li>
1705 <li><strong>HAL UART(compatibility break)</strong>: Alignment with STM32L4 (for inter STM32 families portability)
1706 <ul>
1707 <li>Field “Prescaler” of structure “UART_InitTypeDef” renamed to ClockPrescaler</li>
1708 <li>remove fields “FIFOMode”, “TXFIFOThreshold” and “RXFIFOThreshold” from “UART_InitTypeDef” structure</li>
1709 <li>UART RXFIFO and TXFIFO threshold level defines moved to “stm32h7xx_hal_uart_ex.h”</li>
1710 <li>Introduce new APIs to manage the Tx and Rx FIFO:
1711 <ul>
1712 <li>HAL_UARTEx_EnableFifoMode, HAL_UARTEx_DisableFifoMode, HAL_UARTEx_SetTxFifoThreshold and HAL_UARTEx_SetRxFifoThreshold</li>
1713 </ul></li>
1714 <li>Introduce “HAL_UARTEx_RxFifoFullCallback” and “HAL_UARTEx_TxFifoEmptyCallback”</li>
1715 </ul></li>
1716 <li><strong>HAL USART(compatibility break)</strong>: Alignment with STM32L4 (for inter STM32 families portability)
1717 <ul>
1718 <li>Introduce “stm32h7xx_hal_usart_ex.c” file with new Tx/Rx FIFO management APIs</li>
1719 <li>Field “Prescaler” of structure “USART_InitTypeDef” renamed to ClockPrescaler</li>
1720 <li>remove fields “NSS”, “SlaveMode”, “FIFOMode”, “TXFIFOThreshold” and “RXFIFOThreshold” from “USART_InitTypeDef” structure</li>
1721 <li>USART RXFIFO and TXFIFO threshold level defines moved to “stm32h7xx_hal_usart_ex.h”</li>
1722 <li>USART Salve Mode defines moved to “stm32h7xx_hal_usart_ex.h”</li>
1723 <li>Introduce new APIs to manage the Tx and Rx FIFO:
1724 <ul>
1725 <li>HAL_USARTEx_EnableFifoMode, HAL_USARTEx_DisableFifoMode, HAL_USARTEx_SetTxFifoThreshold and HAL_USARTEx_SetRxFifoThreshold</li>
1726 </ul></li>
1727 <li>Introduce new APIs to manage SPI slave mode:
1728 <ul>
1729 <li>HAL_USARTEx_EnableSlaveMode, HAL_USARTEx_DisableSlaveMode and HAL_USARTEx_ConfigNSS</li>
1730 </ul></li>
1731 </ul></li>
1732 <li><strong>HAL USB</strong>:
1733 <ul>
1734 <li>Fix condition check for EmptyTX FIFO</li>
1735 <li>Protect the hcd driver to be used only if the USB_OTG_FS, USB_OTG_HS are enabled</li>
1736 </ul></li>
1737 </ul>
1738 <h2 id="known-limitations-3">Known Limitations</h2>
1739 <ul>
1740 <li><strong>HAL I2S</strong>:
1741 <ul>
1742 <li>Driver not fully tested, some features may not be working as expected</li>
1743 <li>A new version of this driver will be available in next release with full features tested</li>
1744 </ul></li>
1745 </ul>
1746 <h2 id="backward-compatibility-3">Backward compatibility</h2>
1747 <ul>
1748 <li><strong>HAL ADC</strong>:
1749 <ul>
1750 <li>ADC_InitTypeDef structure: remove filed BoostMode.</li>
1751 </ul></li>
1752 <li><strong>HAL IRDA</strong>:
1753 <ul>
1754 <li>Alignment with STM32F7/L4/G0 (for inter STM32 families portability)</li>
1755 <li>Add new field “ClockPrescaler” to “IRDA_InitTypeDef” structure"</li>
1756 </ul></li>
1757 <li><strong>HAL SMARTCARD</strong>:
1758 <ul>
1759 <li>Alignment with STM32F7/L4/G0 (for inter STM32 families portability)</li>
1760 <li>Remove fields “FIFOMode”, “TXFIFOThreshold” and “RXFIFOThreshold” from “SMARTCARD_InitTypeDef” structure</li>
1761 <li>Add new field “ClockPrescaler” to “SMARTCARD_InitTypeDef” structure"</li>
1762 <li>SMARTCARD RXFIFO and TXFIFO threshold level defines moved to “stm32h7xx_hal_smartcard_ex.h”</li>
1763 </ul></li>
1764 <li><strong>HAL UART</strong>:
1765 <ul>
1766 <li>Alignment with STM32F7/L4/G0 (for inter STM32 families portability)</li>
1767 <li>Field “Prescaler” of structure “UART_InitTypeDef” renamed to ClockPrescaler</li>
1768 <li>remove fields “FIFOMode”, “TXFIFOThreshold” and “RXFIFOThreshold” from “UART_InitTypeDef” structure</li>
1769 <li>UART RXFIFO and TXFIFO threshold level defines moved to “stm32h7xx_hal_uart_ex.h”</li>
1770 </ul></li>
1771 <li><strong>HAL USART</strong>:
1772 <ul>
1773 <li>Alignment with STM32F7/L4/G0 (for inter STM32 families portability)</li>
1774 <li>Introduce “stm32h7xx_hal_usart_ex.c” file with new Tx/Rx FIFO management APIs</li>
1775 <li>Field “Prescaler” of structure “USART_InitTypeDef” renamed to ClockPrescaler</li>
1776 <li>remove fields “NSS”, “SlaveMode”, “FIFOMode”, “TXFIFOThreshold” and “RXFIFOThreshold” from “USART_InitTypeDef” structure</li>
1777 <li>USART RXFIFO and TXFIFO threshold level defines moved to “stm32h7xx_hal_usart_ex.h”</li>
1778 <li>USART Salve Mode defines moved to “stm32h7xx_hal_usart_ex.h”</li>
1779 </ul></li>
1780 </ul>
1781 </div>
1782 </div>
1783 <div class="collapse">
1784 <input type="checkbox" id="collapse-section4" aria-hidden="true"> <label for="collapse-section4" aria-hidden="true"><strong>V1.3.0 / 29-June-2018</strong></label>
1785 <div>
1786 <h2 id="main-changes-4">Main Changes</h2>
1787 <ul>
1788 <li>Updates to fix known defects on HAL Cortex, HAL RCC and HAL SDMMC drivers</li>
1789 <li><strong>HAL Cortex</strong>: Driver update to support 16 MPU regions instead of 8. User can now select an MPU regions from MPU_REGION_NUMBER0 to MPU_REGION_NUMBER15</li>
1790 <li><strong>HAL RCC</strong> : Update and rework HAL_RCC_PeriphCLKConfig function in order to support consecutive configurations for several peripherals using PLL2 and PLL3. To do so first the given PLL is stopped, then the given divider is updated, the given PLL clock output divider is enabled and finally the given PLL is enabled</li>
1791 <li><strong>HAL SDMMC</strong>: Fix and enhancements to support high speed mode</li>
1792 </ul>
1793 </div>
1794 </div>
1795 <div class="collapse">
1796 <input type="checkbox" id="collapse-section3" aria-hidden="true"> <label for="collapse-section3" aria-hidden="true"><strong>V1.2.0 / 29-December-2017</strong></label>
1797 <div>
1798 <h2 id="main-changes-5">Main Changes</h2>
1799 <ul>
1800 <li>General updates to fix known defects and enhancements implementation</li>
1801 <li><strong>HAL SPI</strong>: Driver reworked to fix critical issues</li>
1802 <li>HAL: Update HAL Tick implementation</li>
1803 </ul>
1804 </div>
1805 </div>
1806 <div class="collapse">
1807 <input type="checkbox" id="collapse-section2" aria-hidden="true"> <label for="collapse-section2" aria-hidden="true"><strong>V1.1.0 / 31-August-2017</strong></label>
1808 <div>
1809 <h2 id="main-changes-6">Main Changes</h2>
1810 <ul>
1811 <li>General updates to fix known defects and enhancements implementation</li>
1812 <li><strong>HAL FLASH</strong>: Add Mass Erase for both banks</li>
1813 <li><strong>HAL RCC</strong>:
1814 <ul>
1815 <li>Update <strong>RCC_PeriphCLKInitTypeDef</strong> structure for more IP clock selection flexibility</li>
1816 </ul></li>
1817 <li><strong>HAL SPDIFRX</strong>: Add symbol clock generation</li>
1818 </ul>
1819 </div>
1820 </div>
1821 <div class="collapse">
1822 <input type="checkbox" id="collapse-section1" aria-hidden="true"> <label for="collapse-section1" aria-hidden="true"><strong>V1.0.0 / 21-April-2017</strong></label>
1823 <div>
1824 <h2 id="main-changes-7">Main Changes</h2>
1825 <ul>
1826 <li>First official release for STM32H743xx/753xx devices</li>
1827 </ul>
1828 </div>
1829 </div>
1830 </div>
1831 </div>
1832 <footer class="sticky">
1833 For complete documentation on STM32 Microcontrollers </mark> , visit: <span style="font-color: blue;"><a href="http://www.st.com/stm32">www.st.com/stm32</a></span>
1834 </footer>
1835 </body>
1836 </html>