Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp54683imm; Tue, 22 May 2018 13:55:38 -0700 (PDT) X-Google-Smtp-Source: AB8JxZpzR8GKN5vU0aZYbkROSr3lpI1IOivXZLPtlPuzB8hAXMZg2EOKQ5I8H9aSaiGamFDNtvJn X-Received: by 2002:a63:3d0a:: with SMTP id k10-v6mr24900pga.255.1527022538686; Tue, 22 May 2018 13:55:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527022538; cv=none; d=google.com; s=arc-20160816; b=PAOg/hEnIY1GfiivxtXRWZ7LuKcK0GUkZvlB81YVudwXny84TVdnL8GsS6PvTnOi9c W1bcI5hM8Pwuy033ycab5WlmtaTdHMbnoXfu4ilFm/WpMBmu2EBYSGeaWv3g6QVJpkwL lt2+8xGHOO5TAoNNe5IbVMoxjCnMZpW6Rv5x1MTRCIVqt4PcwPaqZ2rDTY5JDydDxLnP EGAAW8Rz8HkKPjPrIQV5rCqYydux5RuIzBx9fZm5o0asMuMb8LAqwkmsv9JWDfKORQ2R X1hiHy50ihBh8nr7Oo4IHnYfrshY3TDmIXeFsT/gGbgt0ZBRjTKTHMtLJ7fv9Dro/KL/ J2qQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature:arc-authentication-results; bh=hEo6apuM0LatiGQ0tAGJb3V+bf1Yy/khUqHQGa5qplk=; b=fN6YlAh8xu5ERrf2NVTONTuwS9ZY3b8x+R35gYA7p2lp+W/W8AZL7kyhaDpgDeWoQj 6gz+2JSwN/sYK0DvOyP1woZkVYev2vJjwDyyn8GQwGMVVq4P/DFJSdNej2C+uhykLL3m JfJguWGgcoFF6w6zKYwIX0+JEQN3s8kIT0DzzB2tXIuNGF1KPTLjmESoD6WmcVU6wrsj rziiFpmppd1fSJbfh5+DSCbnimZEy5RRAt0dIlmPZ68tXTyQuJc+dFBzeJ8P4SOZSuL9 kh5OeiXRGHf6UFp9Tph9awhbUHgYUZy4nA1ZUe+Yhbd/krwyAT/DDOgryVaAw3bGlEW3 /A0Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@roeck-us.net header.s=default header.b=kEWk2+Vq; 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 a12-v6si17153024plp.225.2018.05.22.13.55.23; Tue, 22 May 2018 13:55:38 -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=fail header.i=@roeck-us.net header.s=default header.b=kEWk2+Vq; 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 S1753016AbeEVUzF (ORCPT + 99 others); Tue, 22 May 2018 16:55:05 -0400 Received: from bh-25.webhostbox.net ([208.91.199.152]:52103 "EHLO bh-25.webhostbox.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752986AbeEVUzA (ORCPT ); Tue, 22 May 2018 16:55:00 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=roeck-us.net; s=default; h=In-Reply-To:Content-Type:MIME-Version:References :Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To:Content-Transfer-Encoding :Content-ID:Content-Description:Resent-Date:Resent-From:Resent-Sender: Resent-To:Resent-Cc:Resent-Message-ID:List-Id:List-Help:List-Unsubscribe: List-Subscribe:List-Post:List-Owner:List-Archive; bh=hEo6apuM0LatiGQ0tAGJb3V+bf1Yy/khUqHQGa5qplk=; b=kEWk2+Vqu4W5YyaqYSSia9HNHr k1nHOUKFfg66dDrKz5XpZhebcOyAMiw6CRUiOrKQVNybJyx2Y+VaqVAZSMQpgs/rCAMjOHPgnFNUx rA+ucBubyZ5zh04h6mAfXdo/M2OywQJ/DOk+axDxQhypbo69QxZeFMK0oQlHw2LJ5vJMn7iGdjbj1 F7eRwKHjjcJ8DvmCCwO6qPR3gffMbC1Dqs5GmiqRkuqRyTv7QevWVPupwbcA/fCc2c+gAfuyqEAXL UXluMsC1m8uxAAaYc4W9oKmsAy1rIzCw9QeTX1WLeVTP4getD/i0qNqQ8lQMiaGKNYABG/1HPzrv7 g8JtGWeg==; Received: from 108-223-40-66.lightspeed.sntcca.sbcglobal.net ([108.223.40.66]:37958 helo=localhost) by bh-25.webhostbox.net with esmtpa (Exim 4.89) (envelope-from ) id 1fLEJ7-000CDz-SA; Tue, 22 May 2018 20:54:58 +0000 Date: Tue, 22 May 2018 13:54:57 -0700 From: Guenter Roeck To: Ray Jui Cc: Wim Van Sebroeck , Rob Herring , Mark Rutland , Frank Rowand , Catalin Marinas , Will Deacon , linux-watchdog@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, bcm-kernel-feedback-list@broadcom.com Subject: Re: [PATCH 3/5] watchdog: sp805: set WDOG_HW_RUNNING when appropriate Message-ID: <20180522205457.GA16363@roeck-us.net> References: <1527014840-21236-1-git-send-email-ray.jui@broadcom.com> <1527014840-21236-4-git-send-email-ray.jui@broadcom.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1527014840-21236-4-git-send-email-ray.jui@broadcom.com> User-Agent: Mutt/1.5.24 (2015-08-30) X-Authenticated_sender: guenter@roeck-us.net X-OutGoing-Spam-Status: No, score=-1.0 X-AntiAbuse: This header was added to track abuse, please include it with any abuse report X-AntiAbuse: Primary Hostname - bh-25.webhostbox.net X-AntiAbuse: Original Domain - vger.kernel.org X-AntiAbuse: Originator/Caller UID/GID - [47 12] / [47 12] X-AntiAbuse: Sender Address Domain - roeck-us.net X-Get-Message-Sender-Via: bh-25.webhostbox.net: authenticated_id: guenter@roeck-us.net X-Authenticated-Sender: bh-25.webhostbox.net: guenter@roeck-us.net X-Source: X-Source-Args: X-Source-Dir: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, May 22, 2018 at 11:47:18AM -0700, Ray Jui wrote: > If the watchdog hardware is already enabled during the boot process, > when the Linux watchdog driver loads, it should reset the watchdog and > tell the watchdog framework. As a result, ping can be generated from > the watchdog framework, until the userspace watchdog daemon takes over > control > > Signed-off-by: Ray Jui > Reviewed-by: Vladimir Olovyannikov > Reviewed-by: Scott Branden > --- > drivers/watchdog/sp805_wdt.c | 22 ++++++++++++++++++++++ > 1 file changed, 22 insertions(+) > > diff --git a/drivers/watchdog/sp805_wdt.c b/drivers/watchdog/sp805_wdt.c > index 1484609..408ffbe 100644 > --- a/drivers/watchdog/sp805_wdt.c > +++ b/drivers/watchdog/sp805_wdt.c > @@ -42,6 +42,7 @@ > /* control register masks */ > #define INT_ENABLE (1 << 0) > #define RESET_ENABLE (1 << 1) > + #define ENABLE_MASK (INT_ENABLE | RESET_ENABLE) > #define WDTINTCLR 0x00C > #define WDTRIS 0x010 > #define WDTMIS 0x014 > @@ -74,6 +75,18 @@ module_param(nowayout, bool, 0); > MODULE_PARM_DESC(nowayout, > "Set to 1 to keep watchdog running after device release"); > > +/* returns true if wdt is running; otherwise returns false */ > +static bool wdt_is_running(struct watchdog_device *wdd) > +{ > + struct sp805_wdt *wdt = watchdog_get_drvdata(wdd); > + > + if ((readl_relaxed(wdt->base + WDTCONTROL) & ENABLE_MASK) == > + ENABLE_MASK) > + return true; > + else > + return false; return !!(readl_relaxed(wdt->base + WDTCONTROL) & ENABLE_MASK)); > +} > + > /* This routine finds load value that will reset system in required timout */ > static int wdt_setload(struct watchdog_device *wdd, unsigned int timeout) > { > @@ -239,6 +252,15 @@ sp805_wdt_probe(struct amba_device *adev, const struct amba_id *id) > watchdog_init_timeout(&wdt->wdd, 0, &adev->dev); > wdt_setload(&wdt->wdd, wdt->wdd.timeout); > > + /* > + * If HW is already running, enable/reset the wdt and set the running > + * bit to tell the wdt subsystem > + */ > + if (wdt_is_running(&wdt->wdd)) { > + wdt_enable(&wdt->wdd); > + set_bit(WDOG_HW_RUNNING, &wdt->wdd.status); > + } > + > ret = watchdog_register_device(&wdt->wdd); > if (ret) { > dev_err(&adev->dev, "watchdog_register_device() failed: %d\n", > -- > 2.1.4 >