Received: by 2002:a25:d783:0:0:0:0:0 with SMTP id o125csp651645ybg; Thu, 19 Mar 2020 06:26:15 -0700 (PDT) X-Google-Smtp-Source: ADFU+vuPGhcGxoRFbwO6ET/Twpu6jp7+wjWCbwzo+/aCymWAFp5P/IcqeN9SN/YDr+OAjy85Dgy8 X-Received: by 2002:a9d:7696:: with SMTP id j22mr2435641otl.188.1584624375345; Thu, 19 Mar 2020 06:26:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1584624375; cv=none; d=google.com; s=arc-20160816; b=kXWr2M4z30oq+dvlUjDrZVKMHsTeMg6tJ+Wi3m9MXnCh5QbYHKAdWMkI7aFlbhenny 8eRFFG5u3wHnTCejUnDTUabTFqNYvn2u7bv13ipIhrxDS9ldD4vu0GxpPD/myKXZceL8 mOdfYpcO6Pp0aU1IINMMUFRaHDCpQLYBOYB1SqwfNfqNrH7BuqdFKPudSQb+6YgZ/Hyv Tlgb9AocYyUqj9n81wEE6lJuFwkBG+IUg1dSbTlJQyOog+W7N1FFtZ7AKoWLiplXZv2b Acb7h9wv5GnHrididimL9cSpW8iAjYOtvhjFAE7mCF0ECiu3HlFVHJ7D5Nq9lEwj6oy+ lGhQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=sxGaFDS5xBw2ajXX+/LzaXHOL1T64nsB0jzXoW4UVzM=; b=Iu5yZsxFzeAMzF7KevzUeI2QJ5Ls+Gaz3JqMmLKNGWSCy+egC4GbJdr/Fb2FHcuRBt +bZ2pplbT0BYGwWgLqwj/oaE1xDk0/dnPG8Xf/3UXFdn9XfqpIaXyJYIHbc2+30HvMDF dhpoAyk5ntzHMQE6yvZiitGQs9EdqqD0d8wsEdzyfWU2jDwBRT7zB5eNhwoH7XTbjqdr tb5M7VkN1wvx5/uu8XEYpX3HDR2Ntd51K3iliqr1H6ZGgR1I19hk/dYTsM/4jCmrcwL8 tCH5HWBNSqdIyfw5MpbnFnjwsTqEUggVtOBMWFND+C6zDE2CK5rJD4eejISAt2KFUrZR A9Uw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=sEQry4LT; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 23si950328oir.119.2020.03.19.06.26.01; Thu, 19 Mar 2020 06:26:15 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=sEQry4LT; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730683AbgCSNZs (ORCPT + 99 others); Thu, 19 Mar 2020 09:25:48 -0400 Received: from mail.kernel.org ([198.145.29.99]:53474 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730678AbgCSNZq (ORCPT ); Thu, 19 Mar 2020 09:25:46 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 4BA3C2080C; Thu, 19 Mar 2020 13:25:44 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1584624344; bh=WCE4+VYZhrwFUZKCCcqJqUTgAjKlW0Go2G+/HwLWmO4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=sEQry4LTZbBpP84r9eMQyQzlA3lZipjQJTzWgysMzVgD7wP7UeV5m0fT9aJm5yMFS Vw4utiKazRwC2WfZbhS3GyuASSEu5MTVIQFRAPKaMDwj/rk5rxNkY2UZ4fNeUKVLCy uRIc+p99Q4EYoiikeZHBFvlW3PslInvo7DqwzArc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jean Delvare , Mika Westerberg , "Rafael J. Wysocki" , Sasha Levin Subject: [PATCH 5.5 11/65] ACPI: watchdog: Set default timeout in probe Date: Thu, 19 Mar 2020 14:03:53 +0100 Message-Id: <20200319123929.806674971@linuxfoundation.org> X-Mailer: git-send-email 2.25.2 In-Reply-To: <20200319123926.466988514@linuxfoundation.org> References: <20200319123926.466988514@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Mika Westerberg [ Upstream commit cabe17d0173ab04bd3f87b8199ae75f43f1ea473 ] If the BIOS default timeout for the watchdog is too small userspace may not have enough time to configure new timeout after opening the device before the system is already reset. For this reason program default timeout of 30 seconds in the driver probe and allow userspace to change this from command line or through module parameter (wdat_wdt.timeout). Reported-by: Jean Delvare Signed-off-by: Mika Westerberg Reviewed-by: Jean Delvare Signed-off-by: Rafael J. Wysocki Signed-off-by: Sasha Levin --- drivers/watchdog/wdat_wdt.c | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/drivers/watchdog/wdat_wdt.c b/drivers/watchdog/wdat_wdt.c index e1b1fcfc02af8..3065dd670a182 100644 --- a/drivers/watchdog/wdat_wdt.c +++ b/drivers/watchdog/wdat_wdt.c @@ -54,6 +54,13 @@ module_param(nowayout, bool, 0); MODULE_PARM_DESC(nowayout, "Watchdog cannot be stopped once started (default=" __MODULE_STRING(WATCHDOG_NOWAYOUT) ")"); +#define WDAT_DEFAULT_TIMEOUT 30 + +static int timeout = WDAT_DEFAULT_TIMEOUT; +module_param(timeout, int, 0); +MODULE_PARM_DESC(timeout, "Watchdog timeout in seconds (default=" + __MODULE_STRING(WDAT_DEFAULT_TIMEOUT) ")"); + static int wdat_wdt_read(struct wdat_wdt *wdat, const struct wdat_instruction *instr, u32 *value) { @@ -438,6 +445,22 @@ static int wdat_wdt_probe(struct platform_device *pdev) platform_set_drvdata(pdev, wdat); + /* + * Set initial timeout so that userspace has time to configure the + * watchdog properly after it has opened the device. In some cases + * the BIOS default is too short and causes immediate reboot. + */ + if (timeout * 1000 < wdat->wdd.min_hw_heartbeat_ms || + timeout * 1000 > wdat->wdd.max_hw_heartbeat_ms) { + dev_warn(dev, "Invalid timeout %d given, using %d\n", + timeout, WDAT_DEFAULT_TIMEOUT); + timeout = WDAT_DEFAULT_TIMEOUT; + } + + ret = wdat_wdt_set_timeout(&wdat->wdd, timeout); + if (ret) + return ret; + watchdog_set_nowayout(&wdat->wdd, nowayout); return devm_watchdog_register_device(dev, &wdat->wdd); } -- 2.20.1