From mboxrd@z Thu Jan 1 00:00:00 1970 From: Stas Sergeev Subject: Re: [PATCH] leds: fix brightness changing when software blinking is active Date: Thu, 14 May 2015 14:03:25 +0300 Message-ID: <555480FD.3020301@list.ru> References: <55535DA4.2010509@list.ru> <55546084.9050704@samsung.com> <55546EAC.70408@list.ru> <55547A0C.3060103@samsung.com> Mime-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: QUOTED-PRINTABLE Return-path: In-Reply-To: <55547A0C.3060103@samsung.com> Sender: linux-kernel-owner@vger.kernel.org To: Jacek Anaszewski Cc: linux-leds@vger.kernel.org, Linux kernel , Bryan Wu , Richard Purdie , Kyungmin Park , Stas Sergeev List-Id: linux-leds@vger.kernel.org 14.05.2015 13:33, Jacek Anaszewski =D0=BF=D0=B8=D1=88=D0=B5=D1=82: >> Indeed, but with these changes there should be no requirement >> for disabling a soft-blink from hard-irq context, which is what >> I really wanted to have. What am I missing? > Please look at this [1]. Author mentions setting brightness > from sound-card irq handler. >=20 > [1] http://www.spinics.net/lists/linux-leds/msg00006.html He points to the following (out-of-tree??) code: --- if ((jiffies / HZ / 2) & 1) led_trigger_blink_oneshot(ledtrig_ide, &ide_blink_delay, &ide_blink_delay, 0); if ((jiffies / HZ / 4) & 1) led_trigger_event(ledtrig_ide, 100); if ((jiffies / HZ / 8) & 1) led_trigger_event(ledtrig_ide, 0); --- I think the problem was that oneshot_trig_deactivate() was not doing led_stop_software_blink(led_cdev), and so he needed a work-queue for switching out from oneshot trigger. My patch fixes exactly that: now oneshot trigger does the proper cleanup itself. Do you think my patch is not enough to handle this case?