On Thu, May 13, 2021 at 02:26:36PM +0200, Petr Pavlu wrote:
> When an IPMI watchdog timer is being stopped in ipmi_close() or
> ipmi_ioctl(WDIOS_DISABLECARD), the current watchdog action is updated to
> WDOG_TIMEOUT_NONE and _ipmi_set_timeout(IPMI_SET_TIMEOUT_NO_HB) is called
> to install this action. The latter function ends up invoking
> __ipmi_set_timeout() which makes the actual 'Set Watchdog Timer' IPMI
> request.
> 
> For IPMI 1.0, this operation results in fully stopping the watchdog timer.
> For IPMI >= 1.5, function __ipmi_set_timeout() always specifies the "don't
> stop" flag in the prepared 'Set Watchdog Timer' IPMI request. This causes
> that the watchdog timer has its action correctly updated to 'none' but the
> timer continues to run. A problem is that IPMI firmware can then still log
> an expiration event when the configured timeout is reached, which is
> unexpected because the watchdog timer was requested to be stopped.
> 
> The patch fixes this problem by not setting the "don't stop" flag in
> __ipmi_set_timeout() when the current action is WDOG_TIMEOUT_NONE which
> results in stopping the watchdog timer. This makes the behaviour for
> IPMI >= 1.5 consistent with IPMI 1.0. It also matches the logic in
> __ipmi_heartbeat() which does not allow to reset the watchdog if the
> current action is WDOG_TIMEOUT_NONE as that would start the timer.

Yes, I believe this is correct, though it took a bit to be sure :).
Applied for linux-next.  I'm also requesting backport to stable kernels.

-corey

> 
> Signed-off-by: Petr Pavlu <petr.pa...@suse.com>
> ---
>  drivers/char/ipmi/ipmi_watchdog.c | 22 ++++++++++++----------
>  1 file changed, 12 insertions(+), 10 deletions(-)
> 
> diff --git a/drivers/char/ipmi/ipmi_watchdog.c 
> b/drivers/char/ipmi/ipmi_watchdog.c
> index 32c334e34d55..e4ff3b50de7f 100644
> --- a/drivers/char/ipmi/ipmi_watchdog.c
> +++ b/drivers/char/ipmi/ipmi_watchdog.c
> @@ -371,16 +371,18 @@ static int __ipmi_set_timeout(struct ipmi_smi_msg  
> *smi_msg,
>       data[0] = 0;
>       WDOG_SET_TIMER_USE(data[0], WDOG_TIMER_USE_SMS_OS);
>  
> -     if ((ipmi_version_major > 1)
> -         || ((ipmi_version_major == 1) && (ipmi_version_minor >= 5))) {
> -             /* This is an IPMI 1.5-only feature. */
> -             data[0] |= WDOG_DONT_STOP_ON_SET;
> -     } else if (ipmi_watchdog_state != WDOG_TIMEOUT_NONE) {
> -             /*
> -              * In ipmi 1.0, setting the timer stops the watchdog, we
> -              * need to start it back up again.
> -              */
> -             hbnow = 1;
> +     if (ipmi_watchdog_state != WDOG_TIMEOUT_NONE) {
> +             if ((ipmi_version_major > 1) ||
> +                 ((ipmi_version_major == 1) && (ipmi_version_minor >= 5))) {
> +                     /* This is an IPMI 1.5-only feature. */
> +                     data[0] |= WDOG_DONT_STOP_ON_SET;
> +             } else {
> +                     /*
> +                      * In ipmi 1.0, setting the timer stops the watchdog, we
> +                      * need to start it back up again.
> +                      */
> +                     hbnow = 1;
> +             }
>       }
>  
>       data[1] = 0;
> -- 
> 2.26.2
> 


_______________________________________________
Openipmi-developer mailing list
Openipmi-developer@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/openipmi-developer

Reply via email to