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:52:42 +0300 Message-ID: <55548C8A.9060607@list.ru> References: <55535DA4.2010509@list.ru> <55546084.9050704@samsung.com> <55546EAC.70408@list.ru> <55547A0C.3060103@samsung.com> <555480FD.3020301@list.ru> Mime-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: QUOTED-PRINTABLE Return-path: In-Reply-To: <555480FD.3020301@list.ru> 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 14:03, Stas Sergeev =D0=BF=D0=B8=D1=88=D0=B5=D1=82: > 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. >> >> [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? Likely not, if he switches triggers in hard-irq context. Though I wonder if it is important to care about the out-of-tree code that could use the work-queue itself? Anyway, I think I should split the patch to the fix and the cleanup, to make the life easier.