Received: by 10.192.165.148 with SMTP id m20csp342056imm; Wed, 2 May 2018 00:56:22 -0700 (PDT) X-Google-Smtp-Source: AB8JxZqapvAtdsLbLDj0Dellkm10hKitNUpw7WZyYr4n+WB1H1lmFUWq7AUATB4ZuUxHrftsZDJb X-Received: by 2002:a65:5844:: with SMTP id s4-v6mr15390379pgr.232.1525247781963; Wed, 02 May 2018 00:56:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525247781; cv=none; d=google.com; s=arc-20160816; b=dgkcQZafI3mZtuDrA+dXRzBPY6vk3YfmoSlbhxzz2L7PiXouj8pJtH+gsYHHBEYYzP 53CEB6UAYebPcisP3ej8txgsAgKLahXuRPI8fxsKwPjxbU81p2J7nLmNsFKW7yyUdJ1B fY56j/Xtx5nB5PeDQB+merg2svSOdxMkzedhHj9h3FH9z5A/lxkX1xpyq9JltaBca3P/ iRsWzmQK6t34XUdhxOsUH/6WzL4Qp1tH/s9iyNH6q7ryZArBnbwKhlFp5muzvMhd+Gx5 XIVDqkJUv53k8GCoeFGpO3xVwAYjPDaXzrPkk6U9IJD3G4yNTaD9hTqXqYOn3Jg1I9Ke 8BBw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=l9Wh+yTWgkTUImZ1v8+QJsCJ8pXincOmBs/69NqzAa8=; b=IZqOXPRTqI40DG4Xpti6Zc5yL9Gd+2USSpfRX0HQ1rVRCQnd8/g4lA+s0V/t/Qa2ed TtmAggDPGaDINj+rl2spOGJB8ygSZ2BwPoycInd/TIEzERo9IcOcv6fCkh8e+pK1/iy0 UoL4jiRXhi4xEDRixYqbGeKEPbbT2saRmnHQoE5NTnQeOm9cqcYGKSkue4s6aHge8qi5 EVmgeH/fHp8w8vBmL0pJhTxuiLZymdeVTmy8m6SqFimx5yTWHCv8VAqH/zv9OERedaBE JbwPBAPyM04FNNLvERifEElvO2l0LdoxekZOnzbOEqkEBlOEGtKjFQ5LdecBNkUIeEhB 3zLw== 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 e2si11515790pfm.220.2018.05.02.00.56.07; Wed, 02 May 2018 00:56:21 -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; 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 S1751301AbeEBHzP (ORCPT + 99 others); Wed, 2 May 2018 03:55:15 -0400 Received: from lgeamrelo13.lge.com ([156.147.23.53]:50750 "EHLO lgeamrelo11.lge.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751087AbeEBHzM (ORCPT ); Wed, 2 May 2018 03:55:12 -0400 Received: from unknown (HELO lgeamrelo01.lge.com) (156.147.1.125) by 156.147.23.53 with ESMTP; 2 May 2018 16:55:08 +0900 X-Original-SENDERIP: 156.147.1.125 X-Original-MAILFROM: neidhard.kim@lge.com Received: from unknown (HELO ?10.178.37.74?) (10.178.37.74) by 156.147.1.125 with ESMTP; 2 May 2018 16:55:07 +0900 X-Original-SENDERIP: 10.178.37.74 X-Original-MAILFROM: neidhard.kim@lge.com Subject: Re: [PATCH] watchdog: sp805: add restart handler To: Guenter Roeck , Viresh Kumar , Wim Van Sebroeck , linux-watchdog@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Chanho Min References: <20180430064433.28715-1-neidhard.kim@lge.com> <452a2320-c297-2bd2-2e98-0b71a077c065@roeck-us.net> From: Jongsung Kim Message-ID: Date: Wed, 2 May 2018 16:55:06 +0900 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: <452a2320-c297-2bd2-2e98-0b71a077c065@roeck-us.net> Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 04/30/2018 08:18 PM, Guenter Roeck wrote: > On 04/29/2018 11:44 PM, Jongsung Kim wrote: >> Add restart handler for SP805 watchdog so that the driver can be >> used to reboot the system. >> >> Signed-off-by: Jongsung Kim >> --- >> ? drivers/watchdog/sp805_wdt.c | 19 +++++++++++++++++++ >> ? 1 file changed, 19 insertions(+) >> >> diff --git a/drivers/watchdog/sp805_wdt.c b/drivers/watchdog/sp805_wdt.c >> index 01d816251302..01f7b6c29f92 100644 >> --- a/drivers/watchdog/sp805_wdt.c >> +++ b/drivers/watchdog/sp805_wdt.c >> @@ -23,6 +23,7 @@ >> ? #include >> ? #include >> ? #include >> +#include >> ? #include >> ? #include >> ? #include >> @@ -67,6 +68,7 @@ struct sp805_wdt { >> ????? struct clk??????????? *clk; >> ????? struct amba_device??????? *adev; >> ????? unsigned int??????????? load_val; >> +??? struct notifier_block??????? restart; >> ? }; >> ? ? static bool nowayout = WATCHDOG_NOWAYOUT; >> @@ -200,6 +202,18 @@ static const struct watchdog_ops wdt_ops = { >> ????? .get_timeleft??? = wdt_timeleft, >> ? }; >> ? +static int >> +wdt_restart(struct notifier_block *this, unsigned long mode, void *cmd) >> +{ >> +??? struct sp805_wdt *wdt = container_of(this, struct sp805_wdt, restart); >> + >> +??? writel_relaxed(0, wdt->base + WDTCONTROL); >> +??? writel_relaxed(0, wdt->base + WDTLOAD); >> +??? writel_relaxed(INT_ENABLE | RESET_ENABLE, wdt->base + WDTCONTROL); >> + >> +??? return 0; >> +} >> + >> ? static int >> ? sp805_wdt_probe(struct amba_device *adev, const struct amba_id *id) >> ? { >> @@ -241,6 +255,10 @@ sp805_wdt_probe(struct amba_device *adev, const struct amba_id *id) >> ????? } >> ????? amba_set_drvdata(adev, wdt); >> ? +??? wdt->restart.notifier_call = wdt_restart; >> +??? wdt->restart.priority = 128; >> +??? register_restart_handler(&wdt->restart); >> + > > Why not use the watchdog core ? Thank you for pointing this. I didn't noticed core changes about restart function because I'm still using old v4.4.xx.. > > Guenter > >> ????? dev_info(&adev->dev, "registration successful\n"); >> ????? return 0; >> ? @@ -253,6 +271,7 @@ static int sp805_wdt_remove(struct amba_device *adev) >> ? { >> ????? struct sp805_wdt *wdt = amba_get_drvdata(adev); >> ? +??? unregister_restart_handler(&wdt->restart); >> ????? watchdog_unregister_device(&wdt->wdd); >> ????? watchdog_set_drvdata(&wdt->wdd, NULL); >> ? > >