reset-regs.h 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. /* MN10300 Reset controller and watchdog timer definitions
  2. *
  3. * Copyright (C) 2007 Red Hat, Inc. All Rights Reserved.
  4. * Written by David Howells (dhowells@redhat.com)
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU General Public Licence
  8. * as published by the Free Software Foundation; either version
  9. * 2 of the Licence, or (at your option) any later version.
  10. */
  11. #ifndef _ASM_RESET_REGS_H
  12. #define _ASM_RESET_REGS_H
  13. #include <asm/cpu-regs.h>
  14. #include <asm/exceptions.h>
  15. #ifdef __KERNEL__
  16. /*
  17. * watchdog timer registers
  18. */
  19. #define WDBC __SYSREGC(0xc0001000, u8) /* watchdog binary counter reg */
  20. #define WDCTR __SYSREG(0xc0001002, u8) /* watchdog timer control reg */
  21. #define WDCTR_WDCK 0x07 /* clock source selection */
  22. #define WDCTR_WDCK_256th 0x00 /* - OSCI/256 */
  23. #define WDCTR_WDCK_1024th 0x01 /* - OSCI/1024 */
  24. #define WDCTR_WDCK_2048th 0x02 /* - OSCI/2048 */
  25. #define WDCTR_WDCK_16384th 0x03 /* - OSCI/16384 */
  26. #define WDCTR_WDCK_65536th 0x04 /* - OSCI/65536 */
  27. #define WDCTR_WDRST 0x40 /* binary counter reset */
  28. #define WDCTR_WDCNE 0x80 /* watchdog timer enable */
  29. #define RSTCTR __SYSREG(0xc0001004, u8) /* reset control reg */
  30. #define RSTCTR_CHIPRST 0x01 /* chip reset */
  31. #define RSTCTR_DBFRST 0x02 /* double fault reset flag */
  32. #define RSTCTR_WDTRST 0x04 /* watchdog timer reset flag */
  33. #define RSTCTR_WDREN 0x08 /* watchdog timer reset enable */
  34. #ifndef __ASSEMBLY__
  35. static inline void mn10300_proc_hard_reset(void)
  36. {
  37. RSTCTR &= ~RSTCTR_CHIPRST;
  38. RSTCTR |= RSTCTR_CHIPRST;
  39. }
  40. extern unsigned int watchdog_alert_counter[];
  41. extern void watchdog_go(void);
  42. extern asmlinkage void watchdog_handler(void);
  43. extern asmlinkage
  44. void watchdog_interrupt(struct pt_regs *, enum exception_code);
  45. #endif
  46. #endif /* __KERNEL__ */
  47. #endif /* _ASM_RESET_REGS_H */