1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 01:32:44 +01:00
RIOT/cpu/kinetis/periph/wdog.c

86 lines
2.2 KiB
C
Raw Normal View History

/*
* Copyright (C) 2015 PHYTEC Messtechnik GmbH
* Copyright (C) 2015 Eistec AB
*
* This file is subject to the terms and conditions of the GNU Lesser General
* Public License v2.1. See the file LICENSE in the top level directory for more
* details.
*/
/**
* @ingroup cpu_kinetis
2018-06-01 12:25:00 +02:00
* @ingroup cpu_kinetis_wdog
*
* @{
*
* @file
* @brief Low-level WDOG driver implementation
*
* @author Johann Fischer <j.fischer@phytec.de>
2015-09-20 13:47:39 +02:00
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
*
* @}
*/
#include <stdint.h>
#include "wdog.h"
#include "cpu_conf.h"
#include "periph_conf.h"
/**
* Attempts to determine the type of the WDOG,
* using the WDOG_STCTRLH_CLKSRC_MASK field.
*/
#ifndef KINETIS_WDOG_ADVANCED_MK
#ifdef WDOG_STCTRLH_CLKSRC_MASK
# define KINETIS_WDOG_ADVANCED_MK 1
#endif
#endif
#ifndef KINETIS_WDOG_ADVANCED_EA
#ifdef WDOG_CS1_STOP_MASK
# define KINETIS_WDOG_ADVANCED_EA 1
#endif
#endif
/**
* @brief Disable hardware watchdog.
*
* For advanced WDOG (mostly Kinetis MCUs with Cortex-M4 inside):
* The following unlock sequence must be completed within 256 bus cycles or
* the watchdog will reset the system. The watchdog is enabled by default at
* power on.
*
* The sequence is:
* 1. Write 0xC520 to the unlock register
* 2. Write 0xD928 to the unlock register
*
* Watchdog is now unlocked to allow us to change its settings
*
* 3. Clear the WDOGEN bit of the WDOG_STCTRLH register to completely disable
* the watchdog.
*
* It is now possible to single step through the code without the watchdog
* resetting the system.
*
* TODO: Only disable watchdog on debug builds.
*/
void wdog_disable(void)
{
#if KINETIS_WDOG_ADVANCED_MK
/* unlock and disable the WDOG */
WDOG->UNLOCK = (uint16_t)0xc520;
WDOG->UNLOCK = (uint16_t)0xd928;
WDOG->STCTRLH = (uint16_t)(WDOG_STCTRLH_WAITEN_MASK
| WDOG_STCTRLH_STOPEN_MASK
| WDOG_STCTRLH_ALLOWUPDATE_MASK
| WDOG_STCTRLH_CLKSRC_MASK);
#elif KINETIS_WDOG_ADVANCED_EA
extern void SystemDisableWatchdog(void);
SystemDisableWatchdog();
#else
/* disable the COP WDOG */
SIM->COPC = (uint32_t)0x00u;
#endif
}