Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753209AbbHTOoi (ORCPT ); Thu, 20 Aug 2015 10:44:38 -0400 Received: from mailout3.samsung.com ([203.254.224.33]:35832 "EHLO mailout3.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751738AbbHTOog (ORCPT ); Thu, 20 Aug 2015 10:44:36 -0400 X-AuditID: cbfee61b-f79706d000001b96-72-55d5e7d20e8b From: Jacek Anaszewski To: linux-leds@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Jacek Anaszewski , Andrew Lunn , Sakari Ailus , Pavel Machek , Stas Sergeev Subject: [PATCH/RFC v6 02/36] leds: Add led_set_brightness_sync to the public LED subsystem API Date: Thu, 20 Aug 2015 16:43:32 +0200 Message-id: <1440081846-11697-3-git-send-email-j.anaszewski@samsung.com> X-Mailer: git-send-email 1.7.9.5 In-reply-to: <1440081846-11697-1-git-send-email-j.anaszewski@samsung.com> References: <1440081846-11697-1-git-send-email-j.anaszewski@samsung.com> X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFprFLMWRmVeSWpSXmKPExsVy+t9jAd1Lz6+GGhx8r2Jx/u4hZoveq88Z LS7vmsNmsfXNOkaLu6eOsll82vKNyaKzbxqLA7vHvJOBHjt3fGby6NuyitFjxerv7B5Np9pZ PT5vkgtgi+KySUnNySxLLdK3S+DKOD7zCVvBYpmK7x/OsTcwHhTvYuTkkBAwkbj04DobhC0m ceHeeiCbi0NIYCmjxLkdO1ggnJ+MEpPnHGAGqWITMJT4+eI1E4gtImAj0TtjEpjNLHCMUeLn 3mgQW1ggUeJZz1xWEJtFQFXi14zNYDW8Ah4Sn/6eB9rAAbRNQWLOJBuQMKeAp8S8+V/ZQWwh oJIX77cwT2DkXcDIsIpRIrUguaA4KT3XKC+1XK84Mbe4NC9dLzk/dxMjOMSeSe9gPLzL/RCj AAejEg/vBeGroUKsiWXFlbmHGCU4mJVEeG89AwrxpiRWVqUW5ccXleakFh9ilOZgURLn1TfZ FCokkJ5YkpqdmlqQWgSTZeLglGpgrLdM9Utj7uBYctpW/NEMNw55v/3238ry2M6tWCa4stjN +dtpZp0o6e0a5+oL7HJ3RlW1X2V9YeR4y+DLTeYot1elmqY8jznl5t5mnHLvqmFU3bFn589P iQ2bbixXEvP2P7fasQNXZbqq5jiz9tnWamRrrZ9/1jpNTGazD/P5l/+5Dn7ZciNNiaU4I9FQ i7moOBEA1XSC+y0CAAA= Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3755 Lines: 114 led_set_brightness_sync function was visible only internally to the LED subsystem. It is now being made publicly available since it has become apparent that this is a caller who should decide whether brightness is to be set in a synchronous or an asynchronous way. The function is modified to use brightness_set_blocking or brightness_set op, depending on which of them is implemented, in case brightness_set_sync op wasn't been provided. Signed-off-by: Jacek Anaszewski Cc: Andrew Lunn Cc: Sakari Ailus Cc: Pavel Machek Cc: Stas Sergeev --- drivers/leds/led-core.c | 25 +++++++++++++++++++++++++ drivers/leds/leds.h | 13 ------------- include/linux/leds.h | 15 +++++++++++++++ 3 files changed, 40 insertions(+), 13 deletions(-) diff --git a/drivers/leds/led-core.c b/drivers/leds/led-core.c index 549de7e..3f3b71d 100644 --- a/drivers/leds/led-core.c +++ b/drivers/leds/led-core.c @@ -141,6 +141,31 @@ void led_set_brightness(struct led_classdev *led_cdev, } EXPORT_SYMBOL(led_set_brightness); +int led_set_brightness_sync(struct led_classdev *led_cdev, + enum led_brightness value) +{ + int ret = 0; + + led_cdev->brightness = min(value, led_cdev->max_brightness); + + if (led_cdev->flags & LED_SUSPENDED) + return 0; + + if (led_cdev->brightness_set_sync) + ret = led_cdev->brightness_set_sync(led_cdev, + led_cdev->brightness); + else if (led_cdev->brightness_set_blocking) + led_cdev->brightness_set_blocking(led_cdev, + led_cdev->brightness); + else if (led_cdev->brightness_set) + led_cdev->brightness_set(led_cdev, led_cdev->brightness); + else + ret = -EINVAL; + + return ret; +} +EXPORT_SYMBOL(led_set_brightness_sync); + int led_update_brightness(struct led_classdev *led_cdev) { int ret = 0; diff --git a/drivers/leds/leds.h b/drivers/leds/leds.h index bc89d7a..1c026c9 100644 --- a/drivers/leds/leds.h +++ b/drivers/leds/leds.h @@ -26,19 +26,6 @@ static inline void led_set_brightness_async(struct led_classdev *led_cdev, led_cdev->brightness_set(led_cdev, value); } -static inline int led_set_brightness_sync(struct led_classdev *led_cdev, - enum led_brightness value) -{ - int ret = 0; - - led_cdev->brightness = min(value, led_cdev->max_brightness); - - if (!(led_cdev->flags & LED_SUSPENDED)) - ret = led_cdev->brightness_set_sync(led_cdev, - led_cdev->brightness); - return ret; -} - static inline int led_get_brightness(struct led_classdev *led_cdev) { return led_cdev->brightness; diff --git a/include/linux/leds.h b/include/linux/leds.h index 85fad6b..2377e0f 100644 --- a/include/linux/leds.h +++ b/include/linux/leds.h @@ -166,6 +166,21 @@ extern void led_blink_set_oneshot(struct led_classdev *led_cdev, */ extern void led_set_brightness(struct led_classdev *led_cdev, enum led_brightness brightness); + +/** + * led_set_brightness_sync - set LED brightness synchronously + * @led_cdev: the LED to set + * @brightness: the brightness to set it to + * + * Set an LED's brightness immediately. This function will block + * the caller for the time required for accessing device register, + * and it can sleep. + * + * Returns: 0 on success or negative error value on failure + */ +extern int led_set_brightness_sync(struct led_classdev *led_cdev, + enum led_brightness value); + /** * led_update_brightness - update LED brightness * @led_cdev: the LED to query -- 1.7.9.5 -- 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/