mbed library sources

Dependents:   Encrypted my_mbed lklk CyaSSL_DTLS_Cellular ... more

Superseded

This library was superseded by mbed-dev - https://os.mbed.com/users/mbed_official/code/mbed-dev/.

Development branch of the mbed library sources. This library is kept in synch with the latest changes from the mbed SDK and it is not guaranteed to work.

If you are looking for a stable and tested release, please import one of the official mbed library releases:

Import librarymbed

The official Mbed 2 C/C++ SDK provides the software platform and libraries to build your applications.

Committer:
mbed_official
Date:
Mon Nov 03 10:45:07 2014 +0000
Revision:
382:ee426a420dbb
Parent:
targets/cmsis/TARGET_STM/TARGET_DISCO_L053C8/stm32l0xx_hal_wwdg.c@376:cb4d9db17537
Child:
387:643a59b3dbac
Synchronized with git revision d54467eb07f62efd9ccdf44f1ede7fe1c1b0cf83

Full URL: https://github.com/mbedmicro/mbed/commit/d54467eb07f62efd9ccdf44f1ede7fe1c1b0cf83/

Who changed what in which revision?

UserRevisionLine numberNew contents of line
mbed_official 376:cb4d9db17537 1 /**
mbed_official 376:cb4d9db17537 2 ******************************************************************************
mbed_official 376:cb4d9db17537 3 * @file stm32l0xx_hal_wwdg.c
mbed_official 376:cb4d9db17537 4 * @author MCD Application Team
mbed_official 376:cb4d9db17537 5 * @version V1.1.0
mbed_official 376:cb4d9db17537 6 * @date 18-June-2014
mbed_official 376:cb4d9db17537 7 * @brief WWDG HAL module driver.
mbed_official 376:cb4d9db17537 8 * This file provides firmware functions to manage the following
mbed_official 376:cb4d9db17537 9 * functionalities of the Window Watchdog (WWDG) peripheral:
mbed_official 376:cb4d9db17537 10 * + Initialization and de-initialization functions
mbed_official 376:cb4d9db17537 11 * + IO operation functions
mbed_official 376:cb4d9db17537 12 * + Peripheral State functions
mbed_official 376:cb4d9db17537 13 @verbatim
mbed_official 376:cb4d9db17537 14 ==============================================================================
mbed_official 376:cb4d9db17537 15 ##### WWDG specific features #####
mbed_official 376:cb4d9db17537 16 ==============================================================================
mbed_official 376:cb4d9db17537 17 [..]
mbed_official 376:cb4d9db17537 18 Once enabled the WWDG generates a system reset on expiry of a programmed
mbed_official 376:cb4d9db17537 19 time period, unless the program refreshes the counter (downcounter)
mbed_official 376:cb4d9db17537 20 before reaching 0x3F value (i.e. a reset is generated when the counter
mbed_official 376:cb4d9db17537 21 value rolls over from 0x40 to 0x3F).
mbed_official 376:cb4d9db17537 22
mbed_official 376:cb4d9db17537 23 (+) An MCU reset is also generated if the counter value is refreshed
mbed_official 376:cb4d9db17537 24 before the counter has reached the refresh window value. This
mbed_official 376:cb4d9db17537 25 implies that the counter must be refreshed in a limited window.
mbed_official 376:cb4d9db17537 26 (+) Once enabled the WWDG cannot be disabled except by a system reset.
mbed_official 376:cb4d9db17537 27 (+) WWDGRST flag in RCC_CSR register can be used to inform when a WWDG
mbed_official 376:cb4d9db17537 28 reset occurs.
mbed_official 376:cb4d9db17537 29 (+) The WWDG counter input clock is derived from the APB clock divided
mbed_official 376:cb4d9db17537 30 by a programmable prescaler.
mbed_official 376:cb4d9db17537 31 (+) WWDG counter clock = PCLK1 / Prescaler
mbed_official 376:cb4d9db17537 32 WWDG timeout = (WWDG counter clock) * (counter value)
mbed_official 376:cb4d9db17537 33 (+) Min-max timeout value @32 MHz(PCLK1): ~128.0 us / ~65.54 ms
mbed_official 376:cb4d9db17537 34
mbed_official 376:cb4d9db17537 35
mbed_official 376:cb4d9db17537 36 ##### How to use this driver #####
mbed_official 376:cb4d9db17537 37 ==============================================================================
mbed_official 376:cb4d9db17537 38 [..]
mbed_official 376:cb4d9db17537 39 (+) Enable WWDG APB1 clock using __WWDG_CLK_ENABLE().
mbed_official 376:cb4d9db17537 40 (+) Set the WWDG prescaler, refresh window and counter value
mbed_official 376:cb4d9db17537 41 using HAL_WWDG_Init() function.
mbed_official 376:cb4d9db17537 42 (+) Start the WWDG using HAL_WWDG_Start() function.
mbed_official 376:cb4d9db17537 43 When the WWDG is enabled the counter value should be configured to
mbed_official 376:cb4d9db17537 44 a value greater than 0x40 to prevent generating an immediate reset.
mbed_official 376:cb4d9db17537 45 (+) Optionally you can enable the Early Wakeup Interrupt (EWI) which is
mbed_official 376:cb4d9db17537 46 generated when the counter reaches 0x40, and then start the WWDG using
mbed_official 376:cb4d9db17537 47 HAL_WWDG_Start_IT().
mbed_official 376:cb4d9db17537 48 Once enabled, EWI interrupt cannot be disabled except by a system reset.
mbed_official 376:cb4d9db17537 49 (+) Then the application program must refresh the WWDG counter at regular
mbed_official 376:cb4d9db17537 50 intervals during normal operation to prevent an MCU reset, using
mbed_official 376:cb4d9db17537 51 HAL_WWDG_Refresh() function. This operation must occur only when
mbed_official 376:cb4d9db17537 52 the counter is lower than the refresh window value already programmed.
mbed_official 376:cb4d9db17537 53
mbed_official 376:cb4d9db17537 54 *** WWDG HAL driver macros list ***
mbed_official 376:cb4d9db17537 55 ==================================
mbed_official 376:cb4d9db17537 56 [..]
mbed_official 376:cb4d9db17537 57 Below the list of most used macros in WWDG HAL driver.
mbed_official 376:cb4d9db17537 58
mbed_official 376:cb4d9db17537 59 (+) __HAL_WWDG_ENABLE: Enable the WWDG peripheral
mbed_official 376:cb4d9db17537 60 (+) __HAL_WWDG_GET_FLAG: Get the selected WWDG's flag status
mbed_official 376:cb4d9db17537 61 (+) __HAL_WWDG_CLEAR_FLAG: Clear the WWDG's pending flags
mbed_official 376:cb4d9db17537 62 (+) __HAL_WWDG_ENABLE_IT: Enables the WWDG early wakeup interrupt
mbed_official 376:cb4d9db17537 63
mbed_official 376:cb4d9db17537 64 @endverbatim
mbed_official 376:cb4d9db17537 65 ******************************************************************************
mbed_official 376:cb4d9db17537 66 * @attention
mbed_official 376:cb4d9db17537 67 *
mbed_official 376:cb4d9db17537 68 * <h2><center>&copy; COPYRIGHT(c) 2014 STMicroelectronics</center></h2>
mbed_official 376:cb4d9db17537 69 *
mbed_official 376:cb4d9db17537 70 * Redistribution and use in source and binary forms, with or without modification,
mbed_official 376:cb4d9db17537 71 * are permitted provided that the following conditions are met:
mbed_official 376:cb4d9db17537 72 * 1. Redistributions of source code must retain the above copyright notice,
mbed_official 376:cb4d9db17537 73 * this list of conditions and the following disclaimer.
mbed_official 376:cb4d9db17537 74 * 2. Redistributions in binary form must reproduce the above copyright notice,
mbed_official 376:cb4d9db17537 75 * this list of conditions and the following disclaimer in the documentation
mbed_official 376:cb4d9db17537 76 * and/or other materials provided with the distribution.
mbed_official 376:cb4d9db17537 77 * 3. Neither the name of STMicroelectronics nor the names of its contributors
mbed_official 376:cb4d9db17537 78 * may be used to endorse or promote products derived from this software
mbed_official 376:cb4d9db17537 79 * without specific prior written permission.
mbed_official 376:cb4d9db17537 80 *
mbed_official 376:cb4d9db17537 81 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
mbed_official 376:cb4d9db17537 82 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
mbed_official 376:cb4d9db17537 83 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
mbed_official 376:cb4d9db17537 84 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
mbed_official 376:cb4d9db17537 85 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
mbed_official 376:cb4d9db17537 86 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
mbed_official 376:cb4d9db17537 87 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
mbed_official 376:cb4d9db17537 88 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
mbed_official 376:cb4d9db17537 89 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
mbed_official 376:cb4d9db17537 90 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
mbed_official 376:cb4d9db17537 91 *
mbed_official 376:cb4d9db17537 92 ******************************************************************************
mbed_official 376:cb4d9db17537 93 */
mbed_official 376:cb4d9db17537 94
mbed_official 376:cb4d9db17537 95 /* Includes ------------------------------------------------------------------*/
mbed_official 376:cb4d9db17537 96 #include "stm32l0xx_hal.h"
mbed_official 376:cb4d9db17537 97
mbed_official 376:cb4d9db17537 98 /** @addtogroup STM32L0xx_HAL_Driver
mbed_official 376:cb4d9db17537 99 * @{
mbed_official 376:cb4d9db17537 100 */
mbed_official 376:cb4d9db17537 101
mbed_official 376:cb4d9db17537 102 /** @defgroup WWDG
mbed_official 376:cb4d9db17537 103 * @brief WWDG HAL module driver.
mbed_official 376:cb4d9db17537 104 * @{
mbed_official 376:cb4d9db17537 105 */
mbed_official 376:cb4d9db17537 106
mbed_official 376:cb4d9db17537 107 #ifdef HAL_WWDG_MODULE_ENABLED
mbed_official 376:cb4d9db17537 108
mbed_official 376:cb4d9db17537 109 /* Private typedef -----------------------------------------------------------*/
mbed_official 376:cb4d9db17537 110 /* Private define ------------------------------------------------------------*/
mbed_official 376:cb4d9db17537 111 /* Private macro -------------------------------------------------------------*/
mbed_official 376:cb4d9db17537 112 /* Private variables ---------------------------------------------------------*/
mbed_official 376:cb4d9db17537 113 /* Private function prototypes -----------------------------------------------*/
mbed_official 376:cb4d9db17537 114 /* Private functions ---------------------------------------------------------*/
mbed_official 376:cb4d9db17537 115
mbed_official 376:cb4d9db17537 116 /** @defgroup WWDG_Private_Functions
mbed_official 376:cb4d9db17537 117 * @{
mbed_official 376:cb4d9db17537 118 */
mbed_official 376:cb4d9db17537 119
mbed_official 376:cb4d9db17537 120 /** @defgroup WWDG_Group1 Initialization and de-initialization functions
mbed_official 376:cb4d9db17537 121 * @brief Initialization and Configuration functions.
mbed_official 376:cb4d9db17537 122 *
mbed_official 376:cb4d9db17537 123 @verbatim
mbed_official 376:cb4d9db17537 124 ==============================================================================
mbed_official 376:cb4d9db17537 125 ##### Initialization and de-initialization functions #####
mbed_official 376:cb4d9db17537 126 ==============================================================================
mbed_official 376:cb4d9db17537 127 [..]
mbed_official 376:cb4d9db17537 128 This section provides functions allowing to:
mbed_official 376:cb4d9db17537 129 (+) Initialize the WWDG according to the specified parameters
mbed_official 376:cb4d9db17537 130 in the WWDG_InitTypeDef and create the associated handle
mbed_official 376:cb4d9db17537 131 (+) DeInitialize the WWDG peripheral
mbed_official 376:cb4d9db17537 132 (+) Initialize the WWDG MSP
mbed_official 376:cb4d9db17537 133 (+) DeInitialize the WWDG MSP
mbed_official 376:cb4d9db17537 134
mbed_official 376:cb4d9db17537 135 @endverbatim
mbed_official 376:cb4d9db17537 136 * @{
mbed_official 376:cb4d9db17537 137 */
mbed_official 376:cb4d9db17537 138
mbed_official 376:cb4d9db17537 139 /**
mbed_official 376:cb4d9db17537 140 * @brief Initializes the WWDG according to the specified
mbed_official 376:cb4d9db17537 141 * parameters in the WWDG_InitTypeDef and creates the associated handle.
mbed_official 376:cb4d9db17537 142 * @param hwwdg: pointer to a WWDG_HandleTypeDef structure that contains
mbed_official 376:cb4d9db17537 143 * the configuration information for the specified WWDG module.
mbed_official 376:cb4d9db17537 144 * @retval HAL status
mbed_official 376:cb4d9db17537 145 */
mbed_official 376:cb4d9db17537 146 HAL_StatusTypeDef HAL_WWDG_Init(WWDG_HandleTypeDef *hwwdg)
mbed_official 376:cb4d9db17537 147 {
mbed_official 376:cb4d9db17537 148 uint32_t tmp = 0;
mbed_official 376:cb4d9db17537 149
mbed_official 376:cb4d9db17537 150 /* Check the WWDG handle allocation */
mbed_official 376:cb4d9db17537 151 if(hwwdg == NULL)
mbed_official 376:cb4d9db17537 152 {
mbed_official 376:cb4d9db17537 153 return HAL_ERROR;
mbed_official 376:cb4d9db17537 154 }
mbed_official 376:cb4d9db17537 155
mbed_official 376:cb4d9db17537 156 /* Check the parameters */
mbed_official 376:cb4d9db17537 157 assert_param(IS_WWDG_ALL_INSTANCE(hwwdg->Instance));
mbed_official 376:cb4d9db17537 158 assert_param(IS_WWDG_PRESCALER(hwwdg->Init.Prescaler));
mbed_official 376:cb4d9db17537 159 assert_param(IS_WWDG_WINDOW(hwwdg->Init.Window));
mbed_official 376:cb4d9db17537 160 assert_param(IS_WWDG_COUNTER(hwwdg->Init.Counter));
mbed_official 376:cb4d9db17537 161
mbed_official 376:cb4d9db17537 162 if(hwwdg->State == HAL_WWDG_STATE_RESET)
mbed_official 376:cb4d9db17537 163 {
mbed_official 376:cb4d9db17537 164 /* Init the low level hardware */
mbed_official 376:cb4d9db17537 165 HAL_WWDG_MspInit(hwwdg);
mbed_official 376:cb4d9db17537 166 }
mbed_official 376:cb4d9db17537 167
mbed_official 376:cb4d9db17537 168 /* Change WWDG peripheral state */
mbed_official 376:cb4d9db17537 169 hwwdg->State = HAL_WWDG_STATE_BUSY;
mbed_official 376:cb4d9db17537 170
mbed_official 376:cb4d9db17537 171 /* Set WWDG Prescaler and Window */
mbed_official 376:cb4d9db17537 172 /* Get the CFR register value */
mbed_official 376:cb4d9db17537 173 tmp = hwwdg->Instance->CFR;
mbed_official 376:cb4d9db17537 174
mbed_official 376:cb4d9db17537 175 /* Clear WDGTB[1:0] and W[6:0] bits */
mbed_official 376:cb4d9db17537 176 tmp &= ((uint32_t)~(WWDG_CFR_WDGTB | WWDG_CFR_W));
mbed_official 376:cb4d9db17537 177
mbed_official 376:cb4d9db17537 178 /* Prepare the WWDG Prescaler and Window parameters */
mbed_official 376:cb4d9db17537 179 tmp |= hwwdg->Init.Prescaler | hwwdg->Init.Window;
mbed_official 376:cb4d9db17537 180
mbed_official 376:cb4d9db17537 181 /* Write to WWDG CFR */
mbed_official 376:cb4d9db17537 182 hwwdg->Instance->CFR = tmp;
mbed_official 376:cb4d9db17537 183
mbed_official 376:cb4d9db17537 184 /* Set WWDG Counter */
mbed_official 376:cb4d9db17537 185 /* Get the CR register value */
mbed_official 376:cb4d9db17537 186 tmp = hwwdg->Instance->CR;
mbed_official 376:cb4d9db17537 187
mbed_official 376:cb4d9db17537 188 /* Clear T[6:0] bits */
mbed_official 376:cb4d9db17537 189 tmp &= (uint32_t)~((uint32_t)WWDG_CR_T);
mbed_official 376:cb4d9db17537 190
mbed_official 376:cb4d9db17537 191 /* Prepare the WWDG Counter parameter */
mbed_official 376:cb4d9db17537 192 tmp |= (hwwdg->Init.Counter);
mbed_official 376:cb4d9db17537 193
mbed_official 376:cb4d9db17537 194 /* Write to WWDG CR */
mbed_official 376:cb4d9db17537 195 hwwdg->Instance->CR = tmp;
mbed_official 376:cb4d9db17537 196
mbed_official 376:cb4d9db17537 197 /* Change WWDG peripheral state */
mbed_official 376:cb4d9db17537 198 hwwdg->State = HAL_WWDG_STATE_READY;
mbed_official 376:cb4d9db17537 199
mbed_official 376:cb4d9db17537 200 /* Return function status */
mbed_official 376:cb4d9db17537 201 return HAL_OK;
mbed_official 376:cb4d9db17537 202 }
mbed_official 376:cb4d9db17537 203
mbed_official 376:cb4d9db17537 204 /**
mbed_official 376:cb4d9db17537 205 * @brief DeInitializes the WWDG peripheral.
mbed_official 376:cb4d9db17537 206 * @param hwwdg: pointer to a WWDG_HandleTypeDef structure that contains
mbed_official 376:cb4d9db17537 207 * the configuration information for the specified WWDG module.
mbed_official 376:cb4d9db17537 208 * @retval HAL status
mbed_official 376:cb4d9db17537 209 */
mbed_official 376:cb4d9db17537 210 HAL_StatusTypeDef HAL_WWDG_DeInit(WWDG_HandleTypeDef *hwwdg)
mbed_official 376:cb4d9db17537 211 {
mbed_official 376:cb4d9db17537 212 /* Check the parameters */
mbed_official 376:cb4d9db17537 213 assert_param(IS_WWDG_ALL_INSTANCE(hwwdg->Instance));
mbed_official 376:cb4d9db17537 214
mbed_official 376:cb4d9db17537 215 /* Change WWDG peripheral state */
mbed_official 376:cb4d9db17537 216 hwwdg->State = HAL_WWDG_STATE_BUSY;
mbed_official 376:cb4d9db17537 217
mbed_official 376:cb4d9db17537 218 /* DeInit the low level hardware */
mbed_official 376:cb4d9db17537 219 HAL_WWDG_MspDeInit(hwwdg);
mbed_official 376:cb4d9db17537 220
mbed_official 376:cb4d9db17537 221 /* Reset WWDG Control register */
mbed_official 376:cb4d9db17537 222 hwwdg->Instance->CR = (uint32_t)0x0000007F;
mbed_official 376:cb4d9db17537 223
mbed_official 376:cb4d9db17537 224 /* Reset WWDG Configuration register */
mbed_official 376:cb4d9db17537 225 hwwdg->Instance->CFR = (uint32_t)0x0000007F;
mbed_official 376:cb4d9db17537 226
mbed_official 376:cb4d9db17537 227 /* Reset WWDG Status register */
mbed_official 376:cb4d9db17537 228 hwwdg->Instance->SR = 0;
mbed_official 376:cb4d9db17537 229
mbed_official 376:cb4d9db17537 230 /* Change WWDG peripheral state */
mbed_official 376:cb4d9db17537 231 hwwdg->State = HAL_WWDG_STATE_RESET;
mbed_official 376:cb4d9db17537 232
mbed_official 376:cb4d9db17537 233 /* Release Lock */
mbed_official 376:cb4d9db17537 234 __HAL_UNLOCK(hwwdg);
mbed_official 376:cb4d9db17537 235
mbed_official 376:cb4d9db17537 236 /* Return function status */
mbed_official 376:cb4d9db17537 237 return HAL_OK;
mbed_official 376:cb4d9db17537 238 }
mbed_official 376:cb4d9db17537 239
mbed_official 376:cb4d9db17537 240 /**
mbed_official 376:cb4d9db17537 241 * @brief Initializes the WWDG MSP.
mbed_official 376:cb4d9db17537 242 * @param hwwdg: pointer to a WWDG_HandleTypeDef structure that contains
mbed_official 376:cb4d9db17537 243 * the configuration information for the specified WWDG module.
mbed_official 376:cb4d9db17537 244 * @retval None
mbed_official 376:cb4d9db17537 245 */
mbed_official 376:cb4d9db17537 246 __weak void HAL_WWDG_MspInit(WWDG_HandleTypeDef *hwwdg)
mbed_official 376:cb4d9db17537 247 {
mbed_official 376:cb4d9db17537 248 /* NOTE: This function Should not be modified, when the callback is needed,
mbed_official 376:cb4d9db17537 249 the HAL_WWDG_MspInit could be implemented in the user file
mbed_official 376:cb4d9db17537 250 */
mbed_official 376:cb4d9db17537 251 }
mbed_official 376:cb4d9db17537 252
mbed_official 376:cb4d9db17537 253 /**
mbed_official 376:cb4d9db17537 254 * @brief DeInitializes the WWDG MSP.
mbed_official 376:cb4d9db17537 255 * @param hwwdg: pointer to a WWDG_HandleTypeDef structure that contains
mbed_official 376:cb4d9db17537 256 * the configuration information for the specified WWDG module.
mbed_official 376:cb4d9db17537 257 * @retval None
mbed_official 376:cb4d9db17537 258 */
mbed_official 376:cb4d9db17537 259 __weak void HAL_WWDG_MspDeInit(WWDG_HandleTypeDef *hwwdg)
mbed_official 376:cb4d9db17537 260 {
mbed_official 376:cb4d9db17537 261 /* NOTE: This function Should not be modified, when the callback is needed,
mbed_official 376:cb4d9db17537 262 the HAL_WWDG_MspDeInit could be implemented in the user file
mbed_official 376:cb4d9db17537 263 */
mbed_official 376:cb4d9db17537 264 }
mbed_official 376:cb4d9db17537 265
mbed_official 376:cb4d9db17537 266 /**
mbed_official 376:cb4d9db17537 267 * @}
mbed_official 376:cb4d9db17537 268 */
mbed_official 376:cb4d9db17537 269
mbed_official 376:cb4d9db17537 270 /** @defgroup WWDG_Group2 IO operation functions
mbed_official 376:cb4d9db17537 271 * @brief IO operation functions
mbed_official 376:cb4d9db17537 272 *
mbed_official 376:cb4d9db17537 273 @verbatim
mbed_official 376:cb4d9db17537 274 ==============================================================================
mbed_official 376:cb4d9db17537 275 ##### IO operation functions #####
mbed_official 376:cb4d9db17537 276 ==============================================================================
mbed_official 376:cb4d9db17537 277 [..]
mbed_official 376:cb4d9db17537 278 This section provides functions allowing to:
mbed_official 376:cb4d9db17537 279 (+) Start the WWDG.
mbed_official 376:cb4d9db17537 280 (+) Refresh the WWDG.
mbed_official 376:cb4d9db17537 281 (+) Handle WWDG interrupt request.
mbed_official 376:cb4d9db17537 282
mbed_official 376:cb4d9db17537 283 @endverbatim
mbed_official 376:cb4d9db17537 284 * @{
mbed_official 376:cb4d9db17537 285 */
mbed_official 376:cb4d9db17537 286
mbed_official 376:cb4d9db17537 287 /**
mbed_official 376:cb4d9db17537 288 * @brief Starts the WWDG.
mbed_official 376:cb4d9db17537 289 * @param hwwdg: pointer to a WWDG_HandleTypeDef structure that contains
mbed_official 376:cb4d9db17537 290 * the configuration information for the specified WWDG module.
mbed_official 376:cb4d9db17537 291 * @retval HAL status
mbed_official 376:cb4d9db17537 292 */
mbed_official 376:cb4d9db17537 293 HAL_StatusTypeDef HAL_WWDG_Start(WWDG_HandleTypeDef *hwwdg)
mbed_official 376:cb4d9db17537 294 {
mbed_official 376:cb4d9db17537 295 /* Process Locked */
mbed_official 376:cb4d9db17537 296 __HAL_LOCK(hwwdg);
mbed_official 376:cb4d9db17537 297
mbed_official 376:cb4d9db17537 298 /* Change WWDG peripheral state */
mbed_official 376:cb4d9db17537 299 hwwdg->State = HAL_WWDG_STATE_BUSY;
mbed_official 376:cb4d9db17537 300
mbed_official 376:cb4d9db17537 301 /* Enable the peripheral */
mbed_official 376:cb4d9db17537 302 __HAL_WWDG_ENABLE(hwwdg);
mbed_official 376:cb4d9db17537 303
mbed_official 376:cb4d9db17537 304 /* Change WWDG peripheral state */
mbed_official 376:cb4d9db17537 305 hwwdg->State = HAL_WWDG_STATE_READY;
mbed_official 376:cb4d9db17537 306
mbed_official 376:cb4d9db17537 307 /* Process Unlocked */
mbed_official 376:cb4d9db17537 308 __HAL_UNLOCK(hwwdg);
mbed_official 376:cb4d9db17537 309
mbed_official 376:cb4d9db17537 310 /* Return function status */
mbed_official 376:cb4d9db17537 311 return HAL_OK;
mbed_official 376:cb4d9db17537 312 }
mbed_official 376:cb4d9db17537 313
mbed_official 376:cb4d9db17537 314 /**
mbed_official 376:cb4d9db17537 315 * @brief Starts the WWDG with interrupt enabled.
mbed_official 376:cb4d9db17537 316 * @param hwwdg: pointer to a WWDG_HandleTypeDef structure that contains
mbed_official 376:cb4d9db17537 317 * the configuration information for the specified WWDG module.
mbed_official 376:cb4d9db17537 318 * @retval HAL status
mbed_official 376:cb4d9db17537 319 */
mbed_official 376:cb4d9db17537 320 HAL_StatusTypeDef HAL_WWDG_Start_IT(WWDG_HandleTypeDef *hwwdg)
mbed_official 376:cb4d9db17537 321 {
mbed_official 376:cb4d9db17537 322 /* Process Locked */
mbed_official 376:cb4d9db17537 323 __HAL_LOCK(hwwdg);
mbed_official 376:cb4d9db17537 324
mbed_official 376:cb4d9db17537 325 /* Change WWDG peripheral state */
mbed_official 376:cb4d9db17537 326 hwwdg->State = HAL_WWDG_STATE_BUSY;
mbed_official 376:cb4d9db17537 327
mbed_official 376:cb4d9db17537 328 /* Enable the Early Wakeup Interrupt */
mbed_official 376:cb4d9db17537 329 __HAL_WWDG_ENABLE_IT(WWDG_IT_EWI);
mbed_official 376:cb4d9db17537 330
mbed_official 376:cb4d9db17537 331 /* Enable the peripheral */
mbed_official 376:cb4d9db17537 332 __HAL_WWDG_ENABLE(hwwdg);
mbed_official 376:cb4d9db17537 333
mbed_official 376:cb4d9db17537 334 /* Return function status */
mbed_official 376:cb4d9db17537 335 return HAL_OK;
mbed_official 376:cb4d9db17537 336 }
mbed_official 376:cb4d9db17537 337
mbed_official 376:cb4d9db17537 338 /**
mbed_official 376:cb4d9db17537 339 * @brief Refreshes the WWDG.
mbed_official 376:cb4d9db17537 340 * @param hwwdg: pointer to a WWDG_HandleTypeDef structure that contains
mbed_official 376:cb4d9db17537 341 * the configuration information for the specified WWDG module.
mbed_official 376:cb4d9db17537 342 * @param Counter: value of counter to put in WWDG counter
mbed_official 376:cb4d9db17537 343 * @retval HAL status
mbed_official 376:cb4d9db17537 344 */
mbed_official 376:cb4d9db17537 345 HAL_StatusTypeDef HAL_WWDG_Refresh(WWDG_HandleTypeDef *hwwdg, uint32_t Counter)
mbed_official 376:cb4d9db17537 346 {
mbed_official 376:cb4d9db17537 347 /* Process Locked */
mbed_official 376:cb4d9db17537 348 __HAL_LOCK(hwwdg);
mbed_official 376:cb4d9db17537 349
mbed_official 376:cb4d9db17537 350 /* Change WWDG peripheral state */
mbed_official 376:cb4d9db17537 351 hwwdg->State = HAL_WWDG_STATE_BUSY;
mbed_official 376:cb4d9db17537 352
mbed_official 376:cb4d9db17537 353 /* Check the parameters */
mbed_official 376:cb4d9db17537 354 assert_param(IS_WWDG_COUNTER(Counter));
mbed_official 376:cb4d9db17537 355
mbed_official 376:cb4d9db17537 356 /* Write to WWDG CR the WWDG Counter value to refresh with */
mbed_official 376:cb4d9db17537 357 MODIFY_REG(hwwdg->Instance->CR, (uint32_t)WWDG_CR_T, Counter);
mbed_official 376:cb4d9db17537 358
mbed_official 376:cb4d9db17537 359 /* Change WWDG peripheral state */
mbed_official 376:cb4d9db17537 360 hwwdg->State = HAL_WWDG_STATE_READY;
mbed_official 376:cb4d9db17537 361
mbed_official 376:cb4d9db17537 362 /* Process Unlocked */
mbed_official 376:cb4d9db17537 363 __HAL_UNLOCK(hwwdg);
mbed_official 376:cb4d9db17537 364
mbed_official 376:cb4d9db17537 365 /* Return function status */
mbed_official 376:cb4d9db17537 366 return HAL_OK;
mbed_official 376:cb4d9db17537 367 }
mbed_official 376:cb4d9db17537 368
mbed_official 376:cb4d9db17537 369 /**
mbed_official 376:cb4d9db17537 370 * @brief Handles WWDG interrupt request.
mbed_official 376:cb4d9db17537 371 * @note The Early Wakeup Interrupt (EWI) can be used if specific safety operations
mbed_official 376:cb4d9db17537 372 * or data logging must be performed before the actual reset is generated.
mbed_official 376:cb4d9db17537 373 * The EWI interrupt is enabled using __HAL_WWDG_ENABLE_IT() macro.
mbed_official 376:cb4d9db17537 374 * When the downcounter reaches the value 0x40, and EWI interrupt is
mbed_official 376:cb4d9db17537 375 * generated and the corresponding Interrupt Service Routine (ISR) can
mbed_official 376:cb4d9db17537 376 * be used to trigger specific actions (such as communications or data
mbed_official 376:cb4d9db17537 377 * logging), before resetting the device.
mbed_official 376:cb4d9db17537 378 * @param hwwdg: pointer to a WWDG_HandleTypeDef structure that contains
mbed_official 376:cb4d9db17537 379 * the configuration information for the specified WWDG module.
mbed_official 376:cb4d9db17537 380 * @retval None
mbed_official 376:cb4d9db17537 381 */
mbed_official 376:cb4d9db17537 382 void HAL_WWDG_IRQHandler(WWDG_HandleTypeDef *hwwdg)
mbed_official 376:cb4d9db17537 383 {
mbed_official 376:cb4d9db17537 384 /* WWDG Early Wakeup Interrupt occurred */
mbed_official 376:cb4d9db17537 385 if(__HAL_WWDG_GET_FLAG(hwwdg, WWDG_FLAG_EWIF) != RESET)
mbed_official 376:cb4d9db17537 386 {
mbed_official 376:cb4d9db17537 387 /* Early Wakeup callback */
mbed_official 376:cb4d9db17537 388 HAL_WWDG_WakeupCallback(hwwdg);
mbed_official 376:cb4d9db17537 389
mbed_official 376:cb4d9db17537 390 /* Change WWDG peripheral state */
mbed_official 376:cb4d9db17537 391 hwwdg->State = HAL_WWDG_STATE_READY;
mbed_official 376:cb4d9db17537 392
mbed_official 376:cb4d9db17537 393 /* Clear the WWDG Data Ready flag */
mbed_official 376:cb4d9db17537 394 __HAL_WWDG_CLEAR_IT(hwwdg, WWDG_FLAG_EWIF);
mbed_official 376:cb4d9db17537 395
mbed_official 376:cb4d9db17537 396 /* Process Unlocked */
mbed_official 376:cb4d9db17537 397 __HAL_UNLOCK(hwwdg);
mbed_official 376:cb4d9db17537 398 }
mbed_official 376:cb4d9db17537 399 }
mbed_official 376:cb4d9db17537 400
mbed_official 376:cb4d9db17537 401 /**
mbed_official 376:cb4d9db17537 402 * @brief Early Wakeup WWDG callback.
mbed_official 376:cb4d9db17537 403 * @param hwwdg: pointer to a WWDG_HandleTypeDef structure that contains
mbed_official 376:cb4d9db17537 404 * the configuration information for the specified WWDG module.
mbed_official 376:cb4d9db17537 405 * @retval None
mbed_official 376:cb4d9db17537 406 */
mbed_official 376:cb4d9db17537 407 __weak void HAL_WWDG_WakeupCallback(WWDG_HandleTypeDef* hwwdg)
mbed_official 376:cb4d9db17537 408 {
mbed_official 376:cb4d9db17537 409 /* NOTE: This function Should not be modified, when the callback is needed,
mbed_official 376:cb4d9db17537 410 the HAL_WWDG_WakeupCallback could be implemented in the user file
mbed_official 376:cb4d9db17537 411 */
mbed_official 376:cb4d9db17537 412 }
mbed_official 376:cb4d9db17537 413
mbed_official 376:cb4d9db17537 414 /**
mbed_official 376:cb4d9db17537 415 * @}
mbed_official 376:cb4d9db17537 416 */
mbed_official 376:cb4d9db17537 417
mbed_official 376:cb4d9db17537 418 /** @defgroup WWDG_Group3 Peripheral State functions
mbed_official 376:cb4d9db17537 419 * @brief Peripheral State functions.
mbed_official 376:cb4d9db17537 420 *
mbed_official 376:cb4d9db17537 421 @verbatim
mbed_official 376:cb4d9db17537 422 ==============================================================================
mbed_official 376:cb4d9db17537 423 ##### Peripheral State functions #####
mbed_official 376:cb4d9db17537 424 ==============================================================================
mbed_official 376:cb4d9db17537 425 [..]
mbed_official 376:cb4d9db17537 426 This subsection permits to get in run-time the status of the peripheral
mbed_official 376:cb4d9db17537 427 and the data flow.
mbed_official 376:cb4d9db17537 428
mbed_official 376:cb4d9db17537 429 @endverbatim
mbed_official 376:cb4d9db17537 430 * @{
mbed_official 376:cb4d9db17537 431 */
mbed_official 376:cb4d9db17537 432
mbed_official 376:cb4d9db17537 433 /**
mbed_official 376:cb4d9db17537 434 * @brief Returns the WWDG state.
mbed_official 376:cb4d9db17537 435 * @param hwwdg: pointer to a WWDG_HandleTypeDef structure that contains
mbed_official 376:cb4d9db17537 436 * the configuration information for the specified WWDG module.
mbed_official 376:cb4d9db17537 437 * @retval HAL state
mbed_official 376:cb4d9db17537 438 */
mbed_official 376:cb4d9db17537 439 HAL_WWDG_StateTypeDef HAL_WWDG_GetState(WWDG_HandleTypeDef *hwwdg)
mbed_official 376:cb4d9db17537 440 {
mbed_official 376:cb4d9db17537 441 return hwwdg->State;
mbed_official 376:cb4d9db17537 442 }
mbed_official 376:cb4d9db17537 443
mbed_official 376:cb4d9db17537 444 /**
mbed_official 376:cb4d9db17537 445 * @}
mbed_official 376:cb4d9db17537 446 */
mbed_official 376:cb4d9db17537 447
mbed_official 376:cb4d9db17537 448 /**
mbed_official 376:cb4d9db17537 449 * @}
mbed_official 376:cb4d9db17537 450 */
mbed_official 376:cb4d9db17537 451
mbed_official 376:cb4d9db17537 452 #endif /* HAL_WWDG_MODULE_ENABLED */
mbed_official 376:cb4d9db17537 453 /**
mbed_official 376:cb4d9db17537 454 * @}
mbed_official 376:cb4d9db17537 455 */
mbed_official 376:cb4d9db17537 456
mbed_official 376:cb4d9db17537 457 /**
mbed_official 376:cb4d9db17537 458 * @}
mbed_official 376:cb4d9db17537 459 */
mbed_official 376:cb4d9db17537 460
mbed_official 376:cb4d9db17537 461 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/