diff options
author | Detlev Zundel <dzu@denx.de> | 2010-01-20 14:28:48 +0100 |
---|---|---|
committer | Wolfgang Denk <wd@denx.de> | 2010-01-25 23:57:39 +0100 |
commit | a21fb981d533ac6d323a01c7fa2cda20f2d36de5 (patch) | |
tree | 92830d96379035e980bb181f7b74fea91b0e15e4 /cpu/mpc5xxx/cpu.c | |
parent | 82826d5422331e9c99e5408dcf0348c8e0c257a6 (diff) | |
download | u-boot-imx-a21fb981d533ac6d323a01c7fa2cda20f2d36de5.zip u-boot-imx-a21fb981d533ac6d323a01c7fa2cda20f2d36de5.tar.gz u-boot-imx-a21fb981d533ac6d323a01c7fa2cda20f2d36de5.tar.bz2 |
mpc5xxx: Support CPU internal watchdog.
Signed-off-by: Detlev Zundel <dzu@denx.de>
Diffstat (limited to 'cpu/mpc5xxx/cpu.c')
-rw-r--r-- | cpu/mpc5xxx/cpu.c | 20 |
1 files changed, 19 insertions, 1 deletions
diff --git a/cpu/mpc5xxx/cpu.c b/cpu/mpc5xxx/cpu.c index 2a28df4..edfb828 100644 --- a/cpu/mpc5xxx/cpu.c +++ b/cpu/mpc5xxx/cpu.c @@ -1,5 +1,5 @@ /* - * (C) Copyright 2000-2003 + * (C) Copyright 2000-2010 * Wolfgang Denk, DENX Software Engineering, wd@denx.de. * * See file CREDITS for list of people who contributed to this @@ -192,3 +192,21 @@ int cpu_eth_init(bd_t *bis) return mpc5xxx_fec_initialize(bis); } #endif + +#if defined(CONFIG_WATCHDOG) +void watchdog_reset(void) +{ + int re_enable = disable_interrupts(); + reset_5xxx_watchdog(); + if (re_enable) enable_interrupts(); +} + +void reset_5xxx_watchdog(void) +{ + volatile struct mpc5xxx_gpt *gpt0 = + (struct mpc5xxx_gpt *) MPC5XXX_GPT; + + /* Trigger TIMER_0 by writing A5 to OCPW */ + clrsetbits_be32(&gpt0->emsr, 0xff000000, 0xa5000000); +} +#endif /* CONFIG_WATCHDOG */ |