2 ******************************************************************************
3 * @file stm32f10x_wwdg.c
4 * @author MCD Application Team
7 * @brief This file provides all the WWDG firmware functions.
8 ******************************************************************************
11 * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
12 * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
13 * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
14 * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
15 * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
16 * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
18 * <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
19 ******************************************************************************
22 /* Includes ------------------------------------------------------------------*/
23 #include "stm32f10x_wwdg.h"
24 #include "stm32f10x_rcc.h"
26 /** @addtogroup STM32F10x_StdPeriph_Driver
31 * @brief WWDG driver modules
35 /** @defgroup WWDG_Private_TypesDefinitions
43 /** @defgroup WWDG_Private_Defines
47 /* ----------- WWDG registers bit address in the alias region ----------- */
48 #define WWDG_OFFSET (WWDG_BASE - PERIPH_BASE)
50 /* Alias word address of EWI bit */
51 #define CFR_OFFSET (WWDG_OFFSET + 0x04)
52 #define EWI_BitNumber 0x09
53 #define CFR_EWI_BB (PERIPH_BB_BASE + (CFR_OFFSET * 32) + (EWI_BitNumber * 4))
55 /* --------------------- WWDG registers bit mask ------------------------ */
57 /* CR register bit mask */
58 #define CR_WDGA_Set ((uint32_t)0x00000080)
60 /* CFR register bit mask */
61 #define CFR_WDGTB_Mask ((uint32_t)0xFFFFFE7F)
62 #define CFR_W_Mask ((uint32_t)0xFFFFFF80)
63 #define BIT_Mask ((uint8_t)0x7F)
69 /** @defgroup WWDG_Private_Macros
77 /** @defgroup WWDG_Private_Variables
85 /** @defgroup WWDG_Private_FunctionPrototypes
93 /** @defgroup WWDG_Private_Functions
98 * @brief Deinitializes the WWDG peripheral registers to their default reset values.
102 void WWDG_DeInit(void)
104 RCC_APB1PeriphResetCmd(RCC_APB1Periph_WWDG
, ENABLE
);
105 RCC_APB1PeriphResetCmd(RCC_APB1Periph_WWDG
, DISABLE
);
109 * @brief Sets the WWDG Prescaler.
110 * @param WWDG_Prescaler: specifies the WWDG Prescaler.
111 * This parameter can be one of the following values:
112 * @arg WWDG_Prescaler_1: WWDG counter clock = (PCLK1/4096)/1
113 * @arg WWDG_Prescaler_2: WWDG counter clock = (PCLK1/4096)/2
114 * @arg WWDG_Prescaler_4: WWDG counter clock = (PCLK1/4096)/4
115 * @arg WWDG_Prescaler_8: WWDG counter clock = (PCLK1/4096)/8
118 void WWDG_SetPrescaler(uint32_t WWDG_Prescaler
)
121 /* Check the parameters */
122 assert_param(IS_WWDG_PRESCALER(WWDG_Prescaler
));
123 /* Clear WDGTB[1:0] bits */
124 tmpreg
= WWDG
->CFR
& CFR_WDGTB_Mask
;
125 /* Set WDGTB[1:0] bits according to WWDG_Prescaler value */
126 tmpreg
|= WWDG_Prescaler
;
127 /* Store the new value */
132 * @brief Sets the WWDG window value.
133 * @param WindowValue: specifies the window value to be compared to the downcounter.
134 * This parameter value must be lower than 0x80.
137 void WWDG_SetWindowValue(uint8_t WindowValue
)
139 __IO
uint32_t tmpreg
= 0;
141 /* Check the parameters */
142 assert_param(IS_WWDG_WINDOW_VALUE(WindowValue
));
143 /* Clear W[6:0] bits */
145 tmpreg
= WWDG
->CFR
& CFR_W_Mask
;
147 /* Set W[6:0] bits according to WindowValue value */
148 tmpreg
|= WindowValue
& (uint32_t) BIT_Mask
;
150 /* Store the new value */
155 * @brief Enables the WWDG Early Wakeup interrupt(EWI).
159 void WWDG_EnableIT(void)
161 *(__IO
uint32_t *) CFR_EWI_BB
= (uint32_t)ENABLE
;
165 * @brief Sets the WWDG counter value.
166 * @param Counter: specifies the watchdog counter value.
167 * This parameter must be a number between 0x40 and 0x7F.
170 void WWDG_SetCounter(uint8_t Counter
)
172 /* Check the parameters */
173 assert_param(IS_WWDG_COUNTER(Counter
));
174 /* Write to T[6:0] bits to configure the counter value, no need to do
175 a read-modify-write; writing a 0 to WDGA bit does nothing */
176 WWDG
->CR
= Counter
& BIT_Mask
;
180 * @brief Enables WWDG and load the counter value.
181 * @param Counter: specifies the watchdog counter value.
182 * This parameter must be a number between 0x40 and 0x7F.
185 void WWDG_Enable(uint8_t Counter
)
187 /* Check the parameters */
188 assert_param(IS_WWDG_COUNTER(Counter
));
189 WWDG
->CR
= CR_WDGA_Set
| Counter
;
193 * @brief Checks whether the Early Wakeup interrupt flag is set or not.
195 * @retval The new state of the Early Wakeup interrupt flag (SET or RESET)
197 FlagStatus
WWDG_GetFlagStatus(void)
199 return (FlagStatus
)(WWDG
->SR
);
203 * @brief Clears Early Wakeup interrupt flag.
207 void WWDG_ClearFlag(void)
209 WWDG
->SR
= (uint32_t)RESET
;
224 /******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/