/** * \file * * * * \author Francesco Sacchi * * AT91 Watchdog. * This file is based on NUT/OS implementation. See license below. */ /* * Copyright (C) 2005-2006 by egnite Software GmbH. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. Neither the name of the copyright holders nor the names of * contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY EGNITE SOFTWARE GMBH AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL EGNITE * SOFTWARE GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * For additional information see http://www.ethernut.de/ */ #ifndef AT91_WDT_H #define AT91_WDT_H /** Watch Dog Control Register */ /*\{*/ #define WDT_CR_OFF 0x00000000 ///< Watchdog control register offset. #define WDT_CR (*((reg32_t *)(WDT_BASE + WDT_CR_OFF))) ///< Watchdog control register address. #define WDT_WDRSTT 0 ///< Watchdog restart. #define WDT_KEY 0xA5000000 ///< Watchdog password. /*\}*/ /** Watch Dog Mode Register */ /*\{*/ #define WDT_MR_OFF 0x00000004 ///< Mode register offset. #define WDT_MR (*((reg32_t *)(WDT_BASE + WDT_MR_OFF))) ///< Mode register address. #define WDT_WDV_MASK 0x00000FFF ///< Counter value mask. #define WDT_WDV_SHIFT 0 ///< Counter value LSB. #define WDT_WDFIEN 12 ///< Fault interrupt enable. #define WDT_WDRSTEN 13 ///< Reset enable. #define WDT_WDRPROC 14 ///< Eset processor enable. #define WDT_WDDIS 15 ///< Watchdog disable. #define WDT_WDD_MASK 0x0FFF0000 ///< Delta value mask. #define WDT_WDD_SHIFT 16 ///< Delta value LSB. #define WDT_WDDBGHLT 28 ///< Watchdog debug halt. #define WDT_WDIDLEHLT 29 ///< Watchdog idle halt. /*\}*/ /** Watch Dog Status Register */ /*\{*/ #define WDT_SR_OFF 0x00000008 ///< Status register offset. #define WDT_SR (*((reg32_t *)(WDT_BASE + WDT_SR_OFF))) ///< Status register address. #define WDT_WDUNF 0 ///< Watchdog underflow. #define WDT_WDERR 1 ///< Watchdog error. /*\}*/ #endif /* AT91_WDT_H */