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 | olio-uboot-2014.01-a21fb981d533ac6d323a01c7fa2cda20f2d36de5.tar.xz olio-uboot-2014.01-a21fb981d533ac6d323a01c7fa2cda20f2d36de5.zip | |
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 2a28df459..edfb8282b 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 */ |