at91_wdt.h 4.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. #ifndef _ARCH_ARM_AT91_WDT_H_
  2. #define _ARCH_ARM_AT91_WDT_H_
  3. /*
  4. * Copyright (C) 2005-2006 by egnite Software GmbH. All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without
  7. * modification, are permitted provided that the following conditions
  8. * are met:
  9. *
  10. * 1. Redistributions of source code must retain the above copyright
  11. * notice, this list of conditions and the following disclaimer.
  12. * 2. Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in the
  14. * documentation and/or other materials provided with the distribution.
  15. * 3. Neither the name of the copyright holders nor the names of
  16. * contributors may be used to endorse or promote products derived
  17. * from this software without specific prior written permission.
  18. *
  19. * THIS SOFTWARE IS PROVIDED BY EGNITE SOFTWARE GMBH AND CONTRIBUTORS
  20. * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  21. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  22. * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL EGNITE
  23. * SOFTWARE GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
  24. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
  25. * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
  26. * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
  27. * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  28. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
  29. * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  30. * SUCH DAMAGE.
  31. *
  32. * For additional information see http://www.ethernut.de/
  33. */
  34. /*!
  35. * \file arch/arm/at91_wdt.h
  36. * \brief AT91 peripherals.
  37. *
  38. * \verbatim
  39. *
  40. * $Log: at91_wdt.h,v $
  41. * Revision 1.3 2006/08/31 19:13:44 haraldkipp
  42. * Added LSB definitions for counter and delta values.
  43. *
  44. * Revision 1.2 2006/07/18 14:06:18 haraldkipp
  45. * Changed coding style to follow existing headers.
  46. * Removed old lines, which had been derived from at91_wd.h.
  47. * Corrected register addresses, thanks to Jix.
  48. * Register names changed, now following the datasheet.
  49. *
  50. * Revision 1.1 2006/07/05 07:45:28 haraldkipp
  51. * Split on-chip interface definitions.
  52. *
  53. *
  54. * \endverbatim
  55. */
  56. /*!
  57. * \addtogroup xgNutArchArmAt91Wdt
  58. */
  59. /*@{*/
  60. /*! \name Watch Dog Control Register */
  61. /*@{*/
  62. #define WDT_CR_OFF 0x00000000 /*!< \brief Watchdog control register offset. */
  63. #define WDT_CR (WDT_BASE + WDT_CR_OFF) /*!< \brief Watchdog control register address. */
  64. #define WDT_WDRSTT 0x00000001 /*!< \brief Watchdog restart. */
  65. #define WDT_KEY 0xA5000000 /*!< \brief Watchdog password. */
  66. /*@}*/
  67. /*! \name Watch Dog Mode Register */
  68. /*@{*/
  69. #define WDT_MR_OFF 0x00000004 /*!< \brief Mode register offset. */
  70. #define WDT_MR (WDT_BASE + WDT_MR_OFF) /*!< \brief Mode register address. */
  71. #define WDT_WDV 0x00000FFF /*!< \brief Counter value mask. */
  72. #define WDT_WDV_LSB 0 /*!< \brief Counter value LSB. */
  73. #define WDT_WDFIEN 0x00001000 /*!< \brief Fault interrupt enable. */
  74. #define WDT_WDRSTEN 0x00002000 /*!< \brief Reset enable. */
  75. #define WDT_WDRPROC 0x00004000 /*!< \brief Eset processor enable. */
  76. #define WDT_WDDIS 0x00008000 /*!< \brief Watchdog disable. */
  77. #define WDT_WDD 0x0FFF0000 /*!< \brief Delta value mask. */
  78. #define WDT_WDD_LSB 16 /*!< \brief Delta value LSB. */
  79. #define WDT_WDDBGHLT 0x10000000 /*!< \brief Watchdog debug halt. */
  80. #define WDT_WDIDLEHLT 0x20000000 /*!< \brief Watchdog idle halt. */
  81. /*@}*/
  82. /*! \name Watch Dog Status Register */
  83. /*@{*/
  84. #define WDT_SR_OFF 0x00000008 /*!< \brief Status register offset. */
  85. #define WDT_SR (WDT_BASE + WDT_SR_OFF) /*!< \brief Status register address. */
  86. #define WDT_WDUNF 0x00000001 /*!< \brief Watchdog underflow. */
  87. #define WDT_WDERR 0x00000002 /*!< \brief Watchdog error. */
  88. /*@}*/
  89. /*@} xgNutArchArmAt91Wdt */
  90. #endif /* _ARCH_ARM_AT91_WDT_H_ */