Subversion Repositories NaviCtrl

Rev

Rev 196 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
196 killagreg 1
/******************** (C) COPYRIGHT 2008 STMicroelectronics ********************
1 ingob 2
* File Name          : 91x_wdg.c
3
* Author             : MCD Application Team
196 killagreg 4
* Version            : V2.1
5
* Date               : 12/22/2008
6
* Description        : This file provides all the WDG firmware functions.
1 ingob 7
********************************************************************************
8
* THE PRESENT SOFTWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
9
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME.
10
* AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT,
11
* INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE
12
* CONTENT OF SUCH SOFTWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING
13
* INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
14
*******************************************************************************/
15
 
16
/* Includes ------------------------------------------------------------------*/
17
#include "91x_wdg.h"
18
#include "91x_scu.h"
19
/* Private typedef -----------------------------------------------------------*/
20
/* Private define ------------------------------------------------------------*/
21
 
22
 
23
/* WDG End of Count interrupt Flag */
24
#define WDG_FLAG_EC  0x0001
25
 
26
 
27
/* WDG End of Count interrupt request */
28
#define WDG_IT_EC    0x0001
29
 
30
 
31
 
32
/* WDG Start/Stop counter */
33
#define WDG_Counter_Start  0x0002
34
#define WDG_Counter_Stop   0xFFFD
35
 
36
 
37
/* Private macro -------------------------------------------------------------*/
38
/* Private variables ---------------------------------------------------------*/
39
/* Registers reset value */
40
/* Private function prototypes -----------------------------------------------*/
41
/* Private functions ---------------------------------------------------------*/
42
 
43
/*******************************************************************************
44
* Function Name  : WDG_StructInit
45
* Description    : Fills the WDG_InitTypeDef structure member with its reset
46
*                  value.
47
* Input          : WDG_InitStruct : pointer to a WDG_InitTypeDef structure
48
*                  which will be initialized.
49
* Output         : None
50
* Return         : None
51
*******************************************************************************/
52
void WDG_StructInit(WDG_InitTypeDef *WDG_InitStruct)
53
{
54
 
55
  /* Select the source clock */
56
  WDG_InitStruct-> WDG_ClockSource = WDG_ClockSource_Apb;
57
 
58
   /* Initialize Prescaler */
59
  WDG_InitStruct->WDG_Prescaler =0xFF;
60
 
61
  /* Initialize Preload */
62
  WDG_InitStruct->WDG_Preload =0xFFFF;
63
 
64
 
65
}
66
 
67
/*******************************************************************************
68
* Function Name  : WDG_Init
69
* Description    : Initializes WDG  peripheral according to the specified
70
*                  parameters in the WDG_InitStruct.
71
* Input          : WDG_InitStruct: pointer to a WDG_InitTypeDef structure that
72
*                  contains the configuration information for the WDG peripheral.
73
* Output         : None
74
* Return         : None
75
*******************************************************************************/
76
void WDG_Init(WDG_InitTypeDef* WDG_InitStruct)
77
{
78
 
79
 
80
 if(WDG_InitStruct->WDG_ClockSource == WDG_ClockSource_Apb)
81
  {
82
    /* Select The APB clock as clock source */
83
    WDG->CR &= WDG_ClockSource_Apb;
84
  }
85
 
86
  else
87
  {
88
    /* Select the RTC clock as source */
89
    WDG->CR |= WDG_ClockSource_Rtc ;
90
  }
91
 
92
  /* Configure WDG Prescaler register value */
93
  WDG->PR = WDG_InitStruct->WDG_Prescaler;
94
 
95
  /* Configure WDG Pre-load register value */
96
  WDG->VR = WDG_InitStruct->WDG_Preload ;
97
 
98
}
99
 
100
/*******************************************************************************
196 killagreg 101
* Function Name  : WDG_TimerModeCmd
102
* Description    : Enables or disables the WDG timer mode
1 ingob 103
* Input          : NewState: new state of the WDG peripheral (Newstate can be
104
*                  ENABLE or DISABLE)
105
* Output         : None
106
* Return         : None
107
*******************************************************************************/
196 killagreg 108
void WDG_TimerModeCmd(FunctionalState NewState)
1 ingob 109
{
110
    if(NewState == ENABLE)
111
    {
112
      /* Start timer by setting SC bit in Control register */
113
      WDG->CR |= WDG_Counter_Start;
114
    }
115
    else
116
    {
117
      /* Stop timer by clearning SC bit in Control register */
118
      WDG->CR &= WDG_Counter_Stop;
119
    }
120
}
121
 
122
/*******************************************************************************
196 killagreg 123
* Function Name  : WDG_StartWatchdogMode
124
* Description    : Starts the watchdog mode
125
* Input          : None
126
* Output         : None
127
* Return         : None
128
*******************************************************************************/
129
void WDG_StartWatchdogMode(void)
130
{
131
   /*reload watchdog*/
132
   WDG->KR = WDG_KeyValue1;
133
   WDG->KR = WDG_KeyValue2;
134
 
135
   /*start watchdog*/
136
   WDG->CR |= WDG_Mode_Wdg;
137
}
138
 
139
/*******************************************************************************
1 ingob 140
* Function Name  : WDG_ITConfig
141
* Description    : Enables or disables the WDG End of Count(EC) interrupt.
142
* Input          : Newstate:  new state of the End of Count(EC) WDG interrupt.
143
*                  This parameter can be: ENABLE or DISABLE.
144
* Output         : None
145
* Return         : None
146
*******************************************************************************/
147
void WDG_ITConfig(FunctionalState NewState)
148
{
149
  if(NewState == ENABLE)
150
  {
151
    /* Enable the End of Count interrupt */
152
    WDG->MR |= WDG_IT_EC;
153
  }
154
  else
155
  {
156
    /* Disable the End of Count interrupt */
157
    WDG->MR &= ~WDG_IT_EC;
158
  }
159
}
160
 
161
/*******************************************************************************
162
* Function Name  : WDG_GetCounter
163
* Description    : Gets the WDG’s current counter value.
164
* Input          : None
165
* Output         : None
166
* Return         : The WDG current counter value
167
*******************************************************************************/
168
u16 WDG_GetCounter(void)
169
{
170
   return WDG->CNT;
171
}
172
 
173
/*******************************************************************************
174
* Function Name  : WDG_GetITStatus
175
* Description    : Checks whether the WDG End of Count(EC) interrupt is occured or not.
176
* Input          : None
177
* Output         : None
178
* Return         : The new state of WDG_IT (SET or RESET).
179
*******************************************************************************/
180
ITStatus WDG_GetITStatus(void)
181
{
182
  if(((WDG->SR & WDG_IT_EC) != RESET )&&((WDG->MR & WDG_IT_EC) != RESET ))
183
  {
184
    return SET;
185
  }
186
  else
187
  {
188
    return RESET;
189
  }
190
}
191
 
192
/*******************************************************************************
193
* Function Name  : WDG_ClearITPendingBit
194
* Description    : Clears the WDG's End of Count(EC) interrupt pending bit.
195
* Input          : None
196
* Output         : None
197
* Return         : None
198
*******************************************************************************/
199
void WDG_ClearITPendingBit(void)
200
{
201
 /* Clear the EC pending bit */
202
  WDG->SR &= ~WDG_IT_EC;
203
 
204
}
205
 
206
/*******************************************************************************
207
* Function Name  : WDG_ClearFlag
208
* Description    : Clears the WDG's End of Count(EC) Flag.
209
* Input          : None
210
* Output         : None
211
* Return         : None
212
*******************************************************************************/
213
void WDG_ClearFlag(void)
214
{
215
 /* Clear the EC Flag */
216
 
217
  WDG->SR &= ~WDG_FLAG_EC;
218
}
219
 
220
/*******************************************************************************
221
* Function Name  : WDG_GetFlagStatus
222
* Description    : Checks whether the WDG End of Count(EC) flag is set or not.
223
* Input          : None
224
* Output         : None
225
* Return         : The new state of the WDG_FLAG (SET or RESET).
226
*******************************************************************************/
227
FlagStatus WDG_GetFlagStatus(void)
228
{
229
  if((WDG->SR & WDG_FLAG_EC) != RESET )
230
  {
231
    return SET;
232
  }
233
  else
234
  {
235
    return RESET;
236
  }
237
}
238
 
196 killagreg 239
/*******************************************************************************
240
* Function Name  : WDG_Reload
241
* Description    : reloads the watchdog counter in watchdog mode
242
* Input          : None
243
* Output         : None
244
* Return         : none
245
*******************************************************************************/
246
void WDG_Reload(void)
247
{
248
  WDG->KR = WDG_KeyValue1;
249
  WDG->KR = WDG_KeyValue2;
250
}
1 ingob 251
 
252
 
196 killagreg 253
/******************* (C) COPYRIGHT 2008 STMicroelectronics *****END OF FILE****/