ESOS32
ESOSOn32-bitProcessors
esos_wdog.c
Go to the documentation of this file.
1 /*
2  * "Copyright (c) 2019 J. W. Bruce ("AUTHOR(S)")"
3  * All rights reserved.
4  * (J. W. Bruce, jwbruce_AT_tntech.edu, Tennessee Tech University)
5  *
6  * Permission to use, copy, modify, and distribute this software and its
7  * documentation for any purpose, without fee, and without written agreement is
8  * hereby granted, provided that the above copyright notice, the following
9  * two paragraphs and the authors appear in all copies of this software.
10  *
11  * IN NO EVENT SHALL THE "AUTHORS" BE LIABLE TO ANY PARTY FOR
12  * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT
13  * OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF THE "AUTHORS"
14  * HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
15  *
16  * THE "AUTHORS" SPECIFICALLY DISCLAIMS ANY WARRANTIES,
17  * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
18  * AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
19  * ON AN "AS IS" BASIS, AND THE "AUTHORS" HAS NO OBLIGATION TO
20  * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS."
21  *
22  * Please maintain this header in its entirety when copying/modifying
23  * these files.
24  *
25  *
26  */
27 
41 /************************************************************************
42  * esos_wdog.c
43  ************************************************************************
44  * ES_OS file for (hardware independent) watchdog timer routines
45  */
46 
47 #include "esos_wdog.h"
48 
49 // ******** G L O B A L S ***************
50 volatile uint32_t __esos_wdog_ticksWatchdogPeriod;
51 volatile uint32_t __esos_wdog_ticksWatchdogLastFed;
52 
66 void _esos_wdog_initWatchdog(uint32_t u32_msBetweenWatchdogResets ) {
67  // record the watchdog period
68  __esos_wdog_ticksWatchdogPeriod = u32_msBetweenWatchdogResets * MILLISECONDS;
69  // call the HW-specific code to setup the watchdog timer
70  _esos_hw_wdog_initWatchdog( u32_msBetweenWatchdogResets );
71  // record the time we last "fed" the watchdog
72  __esos_wdog_ticksWatchdogLastFed = esos_GetSystemTick();
73 } // end esos_initWatchdog()
74 
87 void esos_wdog_feedWatchdog( void ) {
88  // record the time we last "fed" the watchdog
89  __esos_wdog_ticksWatchdogLastFed = esos_GetSystemTick();
90  // call the HW-specific code to setup the watchdog timer
92 } // end esos_feedWatchdog()
93 
105 inline uint32_t esos_wdog_getWatchdogFedTicks(void) {
106  return __esos_wdog_ticksWatchdogLastFed;
107 } // end esos_getWatchdogFedTicks(void)
108 
120 inline uint32_t esos_wdog_getTicksSinceWatchdogFed(void) {
121  return esos_GetSystemTick() - __esos_wdog_ticksWatchdogLastFed;
122 } // end esos_getTicksSinceWatchdogFed(void)
123 
140  return __esos_wdog_ticksWatchdogLastFed + __esos_wdog_ticksWatchdogPeriod - esos_GetSystemTick();
141 }
142 
159 inline uint32_t esos_wdog_getTicksWatchdogPeriod(void) {
160  return __esos_wdog_ticksWatchdogPeriod;
161 }
_esos_hw_wdog_feedWatchdog
void _esos_hw_wdog_feedWatchdog(void)
esos_GetSystemTick
#define esos_GetSystemTick()
Definition: esos.h:418
esos_wdog_getTicksSinceWatchdogFed
uint32_t esos_wdog_getTicksSinceWatchdogFed(void)
Definition: esos_wdog.c:120
esos_wdog_getWatchdogFedTicks
uint32_t esos_wdog_getWatchdogFedTicks(void)
Definition: esos_wdog.c:105
_esos_wdog_initWatchdog
void _esos_wdog_initWatchdog(uint32_t u32_msBetweenWatchdogResets)
Definition: esos_wdog.c:66
esos_wdog_getTicksWatchdogPeriod
uint32_t esos_wdog_getTicksWatchdogPeriod(void)
Definition: esos_wdog.c:159
esos_wdog_getTicksUntilWatchdogReset
uint32_t esos_wdog_getTicksUntilWatchdogReset(void)
Definition: esos_wdog.c:139
esos_wdog.h
_esos_hw_wdog_initWatchdog
void _esos_hw_wdog_initWatchdog(uint32_t u32_ticksBetweenWatchdogResets)
esos_wdog_feedWatchdog
void esos_wdog_feedWatchdog(void)
Definition: esos_wdog.c:87