Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753537AbbGAMCL (ORCPT ); Wed, 1 Jul 2015 08:02:11 -0400 Received: from mailout3.w1.samsung.com ([210.118.77.13]:39404 "EHLO mailout3.w1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753889AbbGAMCA (ORCPT ); Wed, 1 Jul 2015 08:02:00 -0400 X-AuditID: cbfec7f5-f794b6d000001495-05-5593d6b52521 Message-id: <5593D6B2.4030808@samsung.com> Date: Wed, 01 Jul 2015 14:01:54 +0200 From: Jacek Anaszewski User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:17.0) Gecko/20130804 Thunderbird/17.0.8 MIME-version: 1.0 To: Sakari Ailus Cc: linux-leds@vger.kernel.org, linux-kernel@vger.kernel.org, cooloney@gmail.com, rpurdie@rpsys.net, stsp@users.sourceforge.net, pavel@ucw.cz, sakari.ailus@linux.intel.com, andreas.werner@men.de, andrew@lunn.ch, ospite@studenti.unina.it, anemo@mba.ocn.ne.jp, ben@simtec.co.uk, bootc@bootc.net, dmurphy@ti.com, daniel.jeong@ti.com, daniel@zonque.org, davem@davemloft.net, fabio.baltieri@gmail.com, balbi@ti.com, florian@openwrt.org, gshark.jeong@gmail.com, g.liakhovetski@gmx.de, ingi2.kim@samsung.com, dl9pf@gmx.de, johan@kernel.org, lenz@cs.wisc.edu, jogo@openwrt.org, q1.kim@samsung.com, kris@krisk.org, kristoffer.ericson@gmail.com, linus.walleij@linaro.org, broonie@kernel.org, michael.hennerich@analog.com, milo.kim@ti.com, nm127@freemail.hu, ncase@xes-inc.com, neilb@suse.de, nick.forbes@incepta.com, lost.distance@yahoo.com, p.meerwald@bct-electronic.com, n0-1@freewrt.org, philippe.retornaz@epfl.ch, raph@8d.com, rpurdie@openedhand.com, rod@whitby.id.au, dave@sr71.net, giometti@linux.it, bigeasy@linutronix.de, shuahkhan@gmail.com, sguinot@lacie.com Subject: Re: [PATCH/RFC v2 1/5] leds: Use set_brightness_work for brightness_set ops that can sleep References: <1435672770-4261-1-git-send-email-j.anaszewski@samsung.com> <20150630222450.GR5904@valkosipuli.retiisi.org.uk> <5593B84B.7030806@samsung.com> In-reply-to: <5593B84B.7030806@samsung.com> Content-type: text/plain; charset=ISO-8859-1; format=flowed Content-transfer-encoding: 7bit X-Brightmail-Tracker: H4sIAAAAAAAAA02SbUxTZxTH99znubeXuiZ3KO4ZbjFpsi0quuFIPIpOkZjcqbglghKSOave ARGQtOLUDw5fWKQ4ZLQSrYB0oWBRcVDeEYF2lUkxaFAiautLrJqK4pC6FlRm25jw7Zf/yznn w+Fx+GM2kk/P2imps1QZSk5OHG97Buc3DuqSvtZfp1DQUUSg32nFYNIlQvfdX6Ha8ZJAybVi DGftq+DY/Ycc2Fv/YOBCkxvDgTceAvvNnQyU9h8ioJ8oZaHA0cDCQd/P8Gqkj8BIXTkDzbfe YtC1a1loGRrj4HZtLwcHbh5hwW85LIPyyxTstjYW9K+rGRhoK+WgcbgWga+wiYMim0UG1eO1 BJ4/nyDgPtotg45TuQT+uzKJYbjFwcJEQTuBQusn4Oy1czBwxU6g7oGBAXffLQQ9/1xmwN9x D0N7m5uFvk4zB6MNrxg4/1AOXv8KyC8sISu+ESctfyLRcyNOPO1yMuJLcxURb4zXYLHBPMSI VXlnsFh52CcTvaMemdhqcMrEF/9uEm1eIxHLTV1YrK/J50Td4BFWNA/cY374MkW+dJuUkb5L Un/17WZ52rinGGePKXdfHOrGucj4qRaF8VSIob2/27gQz6RXXeeDHC6YEB3VJmiR/B0/QnSy +wEJGAphLm1s1TMBJsLn9PgFGw4wJ0RT/5OnQT1CSKavHRfZUP4j6tO5gt0ZwhfUXX+fBIZi oYunOnuzLGBMFyQ64buDQ9vKEH18zRhshwnzqLXnZPAkLMRSc3ETCvFsajn7DBchwTBliWFK zDAlVoFwDYqQcrZma7akZi5coFFlanKyUhds3ZFZj0Lv521BpktLrEjgkfJDRRrVJYWzql2a PZlWRHmsnKEYO/ZOUmxT7dkrqXf8pM7JkDRWNIsnyo8VJ9pGEsOFVNVOabskZUvq9y7Dh0Xm on0V07Ki1sUlfy9sJhHJ8evS4z/oL7uk3WD5jZr/Hl69pnnWyrXpc055Eipjl6u8ka6bJ6ZX xEaPKoRfzmnzIvJ6nxiLOvXfdaXoRv6KXz6TN0QPb3x02/BjiyMmP2V9pcfojPvMfHXZ8dn+ RSmJubH1pi0x0HroTNTibM94WMkGl0dJNGmq6LlYrVH9DxhBLP16AwAA Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4602 Lines: 116 On 07/01/2015 11:52 AM, Jacek Anaszewski wrote: > Hi Sakari, > > On 07/01/2015 12:24 AM, Sakari Ailus wrote: >> Hi Jacek, >> >> On Tue, Jun 30, 2015 at 03:59:26PM +0200, Jacek Anaszewski wrote: >>> This patch rearranges the core LED subsystem code, so that it >>> now shifts the responsibility for using work queues from drivers, >>> in case their brightness_set ops can sleep, onto the LED core >>> Addition of two flags: LED_BRIGHTNESS_FAST and LED_BLINK_DISABLE >>> as well as new_brightness_value property to the struct led_classdev >>> allows for employing existing set_brightness_work to do the job. >>> The modifications allows also to get rid of brightness_set_sync op, >>> as flash LED devices can now be handled properly only basing on the >>> SET_BRIGHTNESS_SYNC flag. >> >> Nice patch! Thanks! >> >> Looks like this is the favourite topic nowadays. ;-) > > Yeah, this allows to believe that we will manage to tackle the issue > finally :) > >> The documentation should be improved to tell how the API is expected >> to be >> have, e.g. which functions may block. I think this is out of scope for >> this >> patch though. > > Yes, I planned to cover this after the patch is accepted. > >> I think all the existing drivers that implement the set_brightness() >> callback have a fast (and non-blocking) implementation, and some of these >> drivers use a work queue. In order to avoid modifying those drivers right >> now, how about adding a flag for slow devices instead? "Slow" handlers >> should be those that do at least one of the following: 1) sleep and 2) >> take >> excessive amount of time to run. > > As Andrew Lunn mentioned, he was also working on this issue and he did > the vast majority of work [1] needed to remove work queues from existing > drivers. Only new flags would have to be added. > >> How about splitting the patch as follows: >> >> - set_brightness()/set_brightness_sync() -> set_brightness() + >> LED_BRIGHTNESS_FAST + slow handlers in a work queue, >> - add LED_BLINK_DISABLE flag, >> - fix the heartbeat trigger (it's sleeping in a timer if >> LED_BRIGHTNESS_SYNC >> is set). > > With my solution heartbeat trigger is not sleeping even if > LED_BRIGHTNESS_SYNC is set as all triggers use the new function - > led_set_brightness_nosleep. > >> I'd propose to drop led_set_brightness_async() and just make >> led_set_brightness() asynchronous (or non-blocking if you wish) as it was >> before the LED flash class patches. Considering the nature and >> tradition of >> the framework, that's probably how most users want it to be. One can >> always >> use led_set_brightness_sync() if needed. led_set_brightness called brightness_set op in a synchronous way before LED flash class patches. It was up to driver how it implemented the op - blocking or non-blocking. API was not async by default then. Adding public API led_set_brightness_sync would introduce ambiguity, as led_set_brightness also can be synchronous. >> The caller should indeed decide whether the operation is synchronous >> or not, >> that's not really a property of the LED. I requested that for the V4L2 >> framework due to the very different use cases that are typical for the >> LED >> class devices. I agree that caller should decide, but we would have to have unambiguous API for this. I am wondering if renaming led_set_brightness to led_set_brightness_async and making it always scheduling the work queue would be harmless solution. This would modify only kernel internal API. We could introduce led_set_brightness_sync API then, which would call brightness_set op in a synchronous way. >> I have some patches along these lines, but I probably won't have much >> time >> to work on them, and I can rebase mine on yours later on. If you're >> interested in taking a peek they're here: >> >> >> > > I've skimmed through the patches and I find them valuable. > Could you elaborate on the patch > "leds: Serialise access to LED framework data and drivers", > what problem does it solve? > >> >> As the result the as3645a driver is quite a bit smaller than the V4L2 >> sub-device one, which is a good sign. :-) >> > > [1] https://github.com/lunn/linux.git 3.19-rc4-led-devel-workqueue > -- Best Regards, Jacek Anaszewski -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/