patch against linuxppc_2_4_devel: ppc405_wdt.c needs to be fixed
Kenneth Johansson
kenneth.johansson at etx.ericsson.se
Wed Jun 4 23:06:20 EST 2003
Dose the watchdog actually work ??
What happens when you get into a infinite loop when interrupts are
turned off?
On Wed, 2003-06-04 at 09:10, Matthias Fuchs wrote:
> Hi,
>
> I noticed that the 405 watchdog driver's ioctl() for GETPERIOD and SETPERIOD
> are not working correctly. The ioctls pass the watchdog timer period in microseconds.
> The variable wdt_period stores the current period in seconds.
>
> The attached patch fixes this behavior.
>
> Matthias
> ----
>
> --- drivers/char/ppc405_wdt.c Wed Jun 4 08:58:42 2003
> +++ /usr/src/linuxppc_2_4_devel/drivers/char/ppc405_wdt.c Tue Dec 24 06:00:15 2002
> @@ -190,8 +190,7 @@
> }
> case WDIOC_GETPERIOD:
> /* return watchdog period (units = microseconds) */
> - period = wdt_period * MICROSECBASE;
> -
> + period = (wdt_period / HZ) * MICROSECBASE;
> if (copy_to_user((unsigned long *)arg, &period,
> sizeof(period))) {
> return -EFAULT;
> @@ -234,7 +233,8 @@
> if (period == 0)
> period = MAXONEHOUR * MICROSECBASE;
>
> - wdt_period = period / MICROSECBASE;
> + heartbeat_count(0) = (period / TENMSBASE) +
> + (period % TENMSBASE ? 1 : 0);
> ppc405wd_update_timer();
>
> break;
--
Kenneth Johansson
Ericsson AB Tel: +46 8 719 70 20
Tellusborgsvägen 90 Fax: +46 8 719 29 45
126 25 Stockholm ken at switchboard.ericsson.se
** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/
More information about the Linuxppc-embedded
mailing list