Received: by 10.223.185.116 with SMTP id b49csp2166155wrg; Thu, 15 Feb 2018 07:31:30 -0800 (PST) X-Google-Smtp-Source: AH8x227D3xXKpQgzVfknhp0fQXVKLK1n60Fow8Ba3Iqi8cm0KETHr61jqm7nqZLjZZKTGSUXGPcI X-Received: by 10.98.159.200 with SMTP id v69mr2990325pfk.236.1518708690226; Thu, 15 Feb 2018 07:31:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518708690; cv=none; d=google.com; s=arc-20160816; b=dDMjs1r0o1iKUVO0SEeEd8f3RxqdptGQmLPjkmezqDKR6DuIg3KgAQTmuIL1I91F3h GI9MwXLcOlzhDL/MCg4sa50NSNroQh8vP/dtYu2OEGg3NGWxv73QZEg3NAqsq0uTZtL6 Sdk5E1Btu/xIHPolZ8hwE/VaP0pOeeP7pgQ15TbQPE98ZbD1nw4zTS8QvY6IYbKubMZ/ IzPpRxvUFfgGAIC3/zVD6zuiIvZx4VxmZmU0Rk9zaMhQeM7hVXNlB0RY8Y2rrXM62ftX /Flp+/V9HEob0NeNE4QuhjmsDMh80yi9lKkbqFpZ/SuzYjj54ps8hZfb1E2GfL6lZK8N uFPw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=rrMWz/DhWg8YR/MU4MifNMWvkuCGBknKWDRql1ZRYTg=; b=x4zrSxjl/ctolBvRJCjwXGhBSlaOibF/h/sv/6CYKTEH0Z/6yaYAnT4ibAb+vpgiY9 ZnH+imZGbaZ8S6T1OcPLmqbQXG1eFvvc7XgP2ewe65rs4+UBkELEhWrwt4wZmCcO5hgC 20E2no/m3+ipyM3rKE7jC/78re8ceg6CsVsjLpdZ2hUifrBXP3BdKUpbw1NF361Er0Lx pVQudIwGMhRbO56sZkVnunnPyoUhhyvtWZqvN8z9BnNfuWidtFqbjCNJsmZNfJfqGu7T yEE86LWSLK2d/mlOdoLF/VFbZS3pTm273oR8cwLkYqIrsvL5BvTd2csRtYA5yraMFM5J Tg3w== ARC-Authentication-Results: i=1; mx.google.com; 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 70-v6si1182675pla.64.2018.02.15.07.31.15; Thu, 15 Feb 2018 07:31:30 -0800 (PST) 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; 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 S1164116AbeBOP3v (ORCPT + 99 others); Thu, 15 Feb 2018 10:29:51 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:54646 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1163658AbeBOP3s (ORCPT ); Thu, 15 Feb 2018 10:29:48 -0500 Received: from localhost (LFbn-1-12258-90.w90-92.abo.wanadoo.fr [90.92.71.90]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id B8B6610AC; Thu, 15 Feb 2018 15:29:46 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Martin Kaiser , Guenter Roeck , Wim Van Sebroeck Subject: [PATCH 4.9 57/88] watchdog: imx2_wdt: restore previous timeout after suspend+resume Date: Thu, 15 Feb 2018 16:17:24 +0100 Message-Id: <20180215151230.590362280@linuxfoundation.org> X-Mailer: git-send-email 2.16.1 In-Reply-To: <20180215151222.437136975@linuxfoundation.org> References: <20180215151222.437136975@linuxfoundation.org> User-Agent: quilt/0.65 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.9-stable review patch. If anyone has any objections, please let me know. ------------------ From: Martin Kaiser commit 0be267255cef64e1c58475baa7b25568355a3816 upstream. When the watchdog device is suspended, its timeout is set to the maximum value. During resume, the previously set timeout should be restored. This does not work at the moment. The suspend function calls imx2_wdt_set_timeout(wdog, IMX2_WDT_MAX_TIME); and resume reverts this by calling imx2_wdt_set_timeout(wdog, wdog->timeout); However, imx2_wdt_set_timeout() updates wdog->timeout. Therefore, wdog->timeout is set to IMX2_WDT_MAX_TIME when we enter the resume function. Fix this by adding a new function __imx2_wdt_set_timeout() which only updates the hardware settings. imx2_wdt_set_timeout() now calls __imx2_wdt_set_timeout() and then saves the new timeout to wdog->timeout. During suspend, we call __imx2_wdt_set_timeout() directly so that wdog->timeout won't be updated and we can restore the previous value during resume. This approach makes wdog->timeout different from the actual setting in the hardware which is usually not a good thing. However, the two differ only while we're suspended and no kernel code is running, so it should be ok in this case. Signed-off-by: Martin Kaiser Reviewed-by: Guenter Roeck Signed-off-by: Guenter Roeck Signed-off-by: Wim Van Sebroeck Signed-off-by: Greg Kroah-Hartman --- drivers/watchdog/imx2_wdt.c | 20 +++++++++++++++----- 1 file changed, 15 insertions(+), 5 deletions(-) --- a/drivers/watchdog/imx2_wdt.c +++ b/drivers/watchdog/imx2_wdt.c @@ -169,15 +169,21 @@ static int imx2_wdt_ping(struct watchdog return 0; } -static int imx2_wdt_set_timeout(struct watchdog_device *wdog, - unsigned int new_timeout) +static void __imx2_wdt_set_timeout(struct watchdog_device *wdog, + unsigned int new_timeout) { struct imx2_wdt_device *wdev = watchdog_get_drvdata(wdog); - wdog->timeout = new_timeout; - regmap_update_bits(wdev->regmap, IMX2_WDT_WCR, IMX2_WDT_WCR_WT, WDOG_SEC_TO_COUNT(new_timeout)); +} + +static int imx2_wdt_set_timeout(struct watchdog_device *wdog, + unsigned int new_timeout) +{ + __imx2_wdt_set_timeout(wdog, new_timeout); + + wdog->timeout = new_timeout; return 0; } @@ -371,7 +377,11 @@ static int imx2_wdt_suspend(struct devic /* The watchdog IP block is running */ if (imx2_wdt_is_running(wdev)) { - imx2_wdt_set_timeout(wdog, IMX2_WDT_MAX_TIME); + /* + * Don't update wdog->timeout, we'll restore the current value + * during resume. + */ + __imx2_wdt_set_timeout(wdog, IMX2_WDT_MAX_TIME); imx2_wdt_ping(wdog); }