Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757430AbbGQJPA (ORCPT ); Fri, 17 Jul 2015 05:15:00 -0400 Received: from mailout1.samsung.com ([203.254.224.24]:49104 "EHLO mailout1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756725AbbGQIsG (ORCPT ); Fri, 17 Jul 2015 04:48:06 -0400 X-AuditID: cbfee61a-f79516d000006302-86-55a8c13de021 From: Jacek Anaszewski To: linux-leds@vger.kernel.org Cc: linux-kernel@vger.kernel.org, cooloney@gmail.com, rpurdie@rpsys.net, stsp@users.sourceforge.net, Jacek Anaszewski , Andrew Lunn , Sakari Ailus , Pavel Machek Subject: [PATCH/RFC 03/51] leds: Add an internal led_set_brightness_nosleep function Date: Fri, 17 Jul 2015 10:46:49 +0200 Message-id: <1437122857-6765-4-git-send-email-j.anaszewski@samsung.com> X-Mailer: git-send-email 1.7.9.5 In-reply-to: <1437122857-6765-1-git-send-email-j.anaszewski@samsung.com> References: <1437122857-6765-1-git-send-email-j.anaszewski@samsung.com> X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFlrOLMWRmVeSWpSXmKPExsVy+t9jAV3bgytCDbYsFrY4f/cQs8XRnROZ LHqvPme0uLxrDpvF1jfrGC3unjrKZrF711NWi09bvjFZdPZNY3Hg9Ng56y67x7yTgR47d3xm 8tgz/werR9+WVYweK1Z/Z/doOtXO6vF5k1wARxSXTUpqTmZZapG+XQJXxvHTEQXTRCo+PIxq YDwk0MXIySEhYCLR/vYUG4QtJnHh3nogm4tDSGARo8TD11/ZQRJCAj8ZJXb/FwOx2QQMJX6+ eM3UxcjBISIgJ7HzTCVIPbPAP0aJWa+egg0SFgiTeHp4HStIDYuAqsS3B+YgYV4Bd4n92xeB tUoIKEjMmWQDEuYU8JB4/2AlC8Qmd4m2PxfZJjDyLmBkWMUomlqQXFCclJ5rqFecmFtcmpeu l5yfu4kRHHzPpHYwrmywOMQowMGoxMPb4LoiVIg1say4MvcQowQHs5IIb+VOoBBvSmJlVWpR fnxRaU5q8SFGaQ4WJXHek/k+oUIC6YklqdmpqQWpRTBZJg5OqQZGZwm5NeG7JX/r8RucqONc XHJo5ufilqonPB7pu6Q+yZ9acCK/R5C7zMRFd7Hz0nU5z1St3DY38+/uWDpxxuKM4tkb/J97 H7tXu2/t2eIynQ+xxxj4o7Xzlnj+5vZYaqnq+uedg+Hkk4yLve90aN35e/+yydnvRWxhaupR m199mvcisCvQ95GZEktxRqKhFnNRcSIAXjMZFToCAAA= Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2752 Lines: 80 This patch adds led_set_brightness_nosleep function as well as LED_BRIGHTNESS_FAST flag. The flag, when set by a driver means that its brightness_set op is guaranteed not to sleep. Basing on this information the function decides whether brightness should be set in an asynchronous or synchronous way. Signed-off-by: Jacek Anaszewski Cc: Bryan Wu Cc: Andrew Lunn Cc: Sakari Ailus Cc: Pavel Machek Cc: Stas Sergeev --- drivers/leds/leds.h | 18 ++++++++++++++++++ include/linux/leds.h | 3 ++- 2 files changed, 20 insertions(+), 1 deletion(-) diff --git a/drivers/leds/leds.h b/drivers/leds/leds.h index ca38f6a..6c56142 100644 --- a/drivers/leds/leds.h +++ b/drivers/leds/leds.h @@ -2,8 +2,10 @@ * LED Core * * Copyright 2005 Openedhand Ltd. + * Copyright 2014, 2015 Samsung Electronics Co., Ltd. * * Author: Richard Purdie + * Author: Jacek Anaszewski * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as @@ -23,6 +25,22 @@ static inline void led_set_brightness_async(struct led_classdev *led_cdev, schedule_work(&led_cdev->set_brightness_work); } +static inline void led_set_brightness_nosleep(struct led_classdev *led_cdev, + enum led_brightness value) +{ + if (led_cdev->flags & LED_BRIGHTNESS_FAST) { + led_set_brightness_sync(led_cdev, value); + return; + } + + /* + * Delegate setting brightness to a work queue task only for slow + * LEDs as the FAST ones are guaranteed not to sleep while setting + * brightness. + */ + led_set_brightness_async(led_cdev, value); +} + 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 a72ab56..2fdfc13 100644 --- a/include/linux/leds.h +++ b/include/linux/leds.h @@ -49,9 +49,10 @@ struct led_classdev { #define SET_BRIGHTNESS_SYNC (1 << 22) #define LED_DEV_CAP_FLASH (1 << 23) #define LED_BLINK_DISABLE (1 << 24) +#define LED_BRIGHTNESS_FAST (1 << 25) /* Set LED brightness level */ - /* Must not sleep, use a workqueue if needed */ + /* Must not sleep if the driver sets LED_BRIGHTNESS_FAST flag */ void (*brightness_set)(struct led_classdev *led_cdev, enum led_brightness brightness); /* -- 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/