From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755635Ab2DXPYh (ORCPT ); Tue, 24 Apr 2012 11:24:37 -0400 Received: from g5t0009.atlanta.hp.com ([15.192.0.46]:12959 "EHLO g5t0009.atlanta.hp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755608Ab2DXPYg (ORCPT ); Tue, 24 Apr 2012 11:24:36 -0400 Message-ID: <1335281074.2347.4.camel@lorien2> Subject: Re: [PATCH v2] leds: heartbeat: stop on shutdown From: Shuah Khan Reply-To: shuahkhan@gmail.com To: Alexander Holler Cc: shuahkhan@gmail.com, linux-kernel@vger.kernel.org, Richard Purdie Date: Tue, 24 Apr 2012 09:24:34 -0600 In-Reply-To: <1335280022-16308-1-git-send-email-holler@ahsoftware.de> References: <1335275034-22135-1-git-send-email-holler@ahsoftware.de> <1335280022-16308-1-git-send-email-holler@ahsoftware.de> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.2.2- Content-Transfer-Encoding: 7bit Mime-Version: 1.0 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 2012-04-24 at 17:07 +0200, Alexander Holler wrote: > A halted kernel should not show a heartbeat. > > Signed-off-by: Alexander Holler > --- > drivers/leds/ledtrig-heartbeat.c | 18 +++++++++++++++++- > 1 files changed, 17 insertions(+), 1 deletions(-) > > diff --git a/drivers/leds/ledtrig-heartbeat.c b/drivers/leds/ledtrig-heartbeat.c > index 759c0bb..1c05bd9 100644 > --- a/drivers/leds/ledtrig-heartbeat.c > +++ b/drivers/leds/ledtrig-heartbeat.c > @@ -18,6 +18,7 @@ > #include > #include > #include > +#include > #include "leds.h" > > struct heartbeat_trig_data { > @@ -101,13 +102,28 @@ static struct led_trigger heartbeat_led_trigger = { > .deactivate = heartbeat_trig_deactivate, > }; > > +static int heartbeat_reboot_notifier(struct notifier_block *nb, > + unsigned long code, void *unused) > +{ > + led_trigger_unregister(&heartbeat_led_trigger); > + return NOTIFY_DONE; > +} > + > +static struct notifier_block heartbeat_reboot_nb = { > + .notifier_call = heartbeat_reboot_notifier, > +}; > + > static int __init heartbeat_trig_init(void) > { > - return led_trigger_register(&heartbeat_led_trigger); > + int rc = led_trigger_register(&heartbeat_led_trigger); > + if( ! rc ) > + register_reboot_notifier(&heartbeat_reboot_nb); Do you need to check return value here? I see return value being checked in some places in the kernel and not in others. Not checking is fine for now since register_reboot_notifier() always returns 0. Maybe adding return handling might not be a bad idea to be consistent with other places that do check. FYI - Andrew Morton is handling led patches these days. You might want to send include him > + return rc; > } > > static void __exit heartbeat_trig_exit(void) > { > + unregister_reboot_notifier(&heartbeat_reboot_nb); > led_trigger_unregister(&heartbeat_led_trigger); > } >