Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753371AbbHTOps (ORCPT ); Thu, 20 Aug 2015 10:45:48 -0400 Received: from mailout4.samsung.com ([203.254.224.34]:52167 "EHLO mailout4.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752105AbbHTOpo (ORCPT ); Thu, 20 Aug 2015 10:45:44 -0400 X-AuditID: cbfee61b-f79706d000001b96-d9-55d5e817b28b From: Jacek Anaszewski To: linux-leds@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Jacek Anaszewski , Sakari Ailus , Bryan Wu Subject: [PATCH/RFC v6 09/36] leds: aat1290: Remove work queue Date: Thu, 20 Aug 2015 16:43:39 +0200 Message-id: <1440081846-11697-10-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+NgFmphluLIzCtJLcpLzFFi42I5/e+xgK74i6uhBls/8lkc3TmRyaL36nNG i8u75rBZbH2zjtHi05ZvTA6sHjtn3WX3mHcy0KNvyypGj8+b5AJYorhsUlJzMstSi/TtErgy riwQK2iVqTj6XKyB8ZV4FyMnh4SAicTD/02MELaYxIV769m6GLk4hASWMkpMmv2eGcL5ySix 4kMHE0gVm4ChxM8Xr8FsEQEbid4Zk8BsZoFaie4tP9hBbGEBO4kJ85exgdgsAqoSp5ZtBavh FfCUaNz9CcjmANqmIDFnkg1ImBMoPG/+V7BWIQEPiRfvtzBPYORdwMiwilEitSC5oDgpPdco L7Vcrzgxt7g0L10vOT93EyM4bJ5J72A8vMv9EKMAB6MSD+8F4auhQqyJZcWVuYcYJTiYlUR4 bz0DCvGmJFZWpRblxxeV5qQWH2KU5mBREufVN9kUKiSQnliSmp2aWpBaBJNl4uCUamA0/lpv vvIEU6VL6wPeYp4Fgn9W7N3eaZJSsPVYyYJTR/3Np564o3Vzxrc99r8Zs94dvaV5RG/zwi/O Ug8OTHU/qq7ybq3TpsX3VKb0+W0t8v+xzaBZbH+bxdkzh07P5LSdHDMv5bLNHvebxY8W6CVL 6sSLWBw9vjbj4DU7v1klNr5hNc2J++/3KrEUZyQaajEXFScCAH+ifnYXAgAA Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3723 Lines: 116 Now the core implements the work queue, remove it from the drivers, and switch to using brightness_set_blocking op. Signed-off-by: Jacek Anaszewski Cc: Sakari Ailus Cc: Bryan Wu --- drivers/leds/leds-aat1290.c | 40 ++++++++++++++-------------------------- 1 file changed, 14 insertions(+), 26 deletions(-) diff --git a/drivers/leds/leds-aat1290.c b/drivers/leds/leds-aat1290.c index 0ecaf76..d802fbb 100644 --- a/drivers/leds/leds-aat1290.c +++ b/drivers/leds/leds-aat1290.c @@ -20,7 +20,6 @@ #include #include #include -#include #include #define AAT1290_MOVIE_MODE_CURRENT_ADDR 17 @@ -82,8 +81,6 @@ struct aat1290_led { /* brightness cache */ unsigned int torch_brightness; - /* assures led-triggers compatibility */ - struct work_struct work_brightness_set; }; static struct aat1290_led *fled_cdev_to_led( @@ -92,6 +89,12 @@ static struct aat1290_led *fled_cdev_to_led( return container_of(fled_cdev, struct aat1290_led, fled_cdev); } +static struct led_classdev_flash *led_cdev_to_fled_cdev( + struct led_classdev *led_cdev) +{ + return container_of(led_cdev, struct led_classdev_flash, led_cdev); +} + static void aat1290_as2cwire_write(struct aat1290_led *led, int addr, int value) { int i; @@ -134,9 +137,14 @@ static void aat1290_set_flash_safety_timer(struct aat1290_led *led, flash_tm_reg); } -static void aat1290_brightness_set(struct aat1290_led *led, +/* LED subsystem callbacks */ + +static int aat1290_led_brightness_set(struct led_classdev *led_cdev, enum led_brightness brightness) { + struct led_classdev_flash *fled_cdev = led_cdev_to_fled_cdev(led_cdev); + struct aat1290_led *led = fled_cdev_to_led(fled_cdev); + mutex_lock(&led->lock); if (brightness == 0) { @@ -158,26 +166,8 @@ static void aat1290_brightness_set(struct aat1290_led *led, } mutex_unlock(&led->lock); -} - -/* LED subsystem callbacks */ -static void aat1290_brightness_set_work(struct work_struct *work) -{ - struct aat1290_led *led = - container_of(work, struct aat1290_led, work_brightness_set); - - aat1290_brightness_set(led, led->torch_brightness); -} - -static void aat1290_led_brightness_set(struct led_classdev *led_cdev, - enum led_brightness brightness) -{ - struct led_classdev_flash *fled_cdev = lcdev_to_flcdev(led_cdev); - struct aat1290_led *led = fled_cdev_to_led(fled_cdev); - - led->torch_brightness = brightness; - schedule_work(&led->work_brightness_set); + return 0; } static int aat1290_led_flash_strobe_set(struct led_classdev_flash *fled_cdev, @@ -498,10 +488,9 @@ static int aat1290_led_probe(struct platform_device *pdev) mutex_init(&led->lock); /* Initialize LED Flash class device */ - led_cdev->brightness_set = aat1290_led_brightness_set; + led_cdev->brightness_set_blocking = aat1290_led_brightness_set; led_cdev->max_brightness = led_cfg.max_brightness; led_cdev->flags |= LED_DEV_CAP_FLASH; - INIT_WORK(&led->work_brightness_set, aat1290_brightness_set_work); aat1290_init_flash_timeout(led, &led_cfg); @@ -536,7 +525,6 @@ static int aat1290_led_remove(struct platform_device *pdev) v4l2_flash_release(led->v4l2_flash); led_classdev_flash_unregister(&led->fled_cdev); - cancel_work_sync(&led->work_brightness_set); mutex_destroy(&led->lock); -- 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/