at91sam9_wdt.h 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. /*
  2. * drivers/watchdog/at91sam9_wdt.h
  3. *
  4. * Copyright (C) 2007 Andrew Victor
  5. * Copyright (C) 2007 Atmel Corporation.
  6. *
  7. * Watchdog Timer (WDT) - System peripherals regsters.
  8. * Based on AT91SAM9261 datasheet revision D.
  9. *
  10. * This program is free software; you can redistribute it and/or modify
  11. * it under the terms of the GNU General Public License as published by
  12. * the Free Software Foundation; either version 2 of the License, or
  13. * (at your option) any later version.
  14. */
  15. #ifndef AT91_WDT_H
  16. #define AT91_WDT_H
  17. #define AT91_WDT_CR 0x00 /* Watchdog Control Register */
  18. #define AT91_WDT_WDRSTT (1 << 0) /* Restart */
  19. #define AT91_WDT_KEY (0xa5 << 24) /* KEY Password */
  20. #define AT91_WDT_MR 0x04 /* Watchdog Mode Register */
  21. #define AT91_WDT_WDV (0xfff << 0) /* Counter Value */
  22. #define AT91_WDT_SET_WDV(x) ((x) & AT91_WDT_WDV)
  23. #define AT91_WDT_WDFIEN (1 << 12) /* Fault Interrupt Enable */
  24. #define AT91_WDT_WDRSTEN (1 << 13) /* Reset Processor */
  25. #define AT91_WDT_WDRPROC (1 << 14) /* Timer Restart */
  26. #define AT91_WDT_WDDIS (1 << 15) /* Watchdog Disable */
  27. #define AT91_WDT_WDD (0xfff << 16) /* Delta Value */
  28. #define AT91_WDT_SET_WDD(x) (((x) << 16) & AT91_WDT_WDD)
  29. #define AT91_WDT_WDDBGHLT (1 << 28) /* Debug Halt */
  30. #define AT91_WDT_WDIDLEHLT (1 << 29) /* Idle Halt */
  31. #define AT91_WDT_SR 0x08 /* Watchdog Status Register */
  32. #define AT91_WDT_WDUNF (1 << 0) /* Watchdog Underflow */
  33. #define AT91_WDT_WDERR (1 << 1) /* Watchdog Error */
  34. #endif