From: bryan.wu@canonical.com (Bryan Wu)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH 1/3] led-class: change back LEDS_CLASS to tristate instead of bool
Date: Sun, 11 Mar 2012 15:45:23 +0800 [thread overview]
Message-ID: <CAK5ve-+KxyQ4RgftyHZ5PLYSvbxWG263f1d6WXty0RO6khYTrA@mail.gmail.com> (raw)
In-Reply-To: <1331197863-25564-1-git-send-email-bryan.wu@canonical.com>
Richard,
How about this patch we discussed before? Thanks,
-Bryan
On Thu, Mar 8, 2012 at 5:11 PM, Bryan Wu <bryan.wu@canonical.com> wrote:
> After moving some core functions to led-core.c, led-class.c can be built as
> module again.
>
> Signed-off-by: Bryan Wu <bryan.wu@canonical.com>
> ---
> ?drivers/leds/Kconfig ? ? | ? ?2 +-
> ?drivers/leds/led-class.c | ? 70 ----------------------------------------------
> ?drivers/leds/led-core.c ?| ? 70 ++++++++++++++++++++++++++++++++++++++++++++++
> ?3 files changed, 71 insertions(+), 71 deletions(-)
>
> diff --git a/drivers/leds/Kconfig b/drivers/leds/Kconfig
> index 9ca28fc..3f17f0d 100644
> --- a/drivers/leds/Kconfig
> +++ b/drivers/leds/Kconfig
> @@ -17,7 +17,7 @@ menuconfig NEW_LEDS
> ?if NEW_LEDS
>
> ?config LEDS_CLASS
> - ? ? ? bool "LED Class Support"
> + ? ? ? tristate "LED Class Support"
> ? ? ? ?help
> ? ? ? ? ?This option enables the led sysfs class in /sys/class/leds. ?You'll
> ? ? ? ? ?need this to do anything useful with LEDs. ?If unsure, say N.
> diff --git a/drivers/leds/led-class.c b/drivers/leds/led-class.c
> index 0c8739c..5bff843 100644
> --- a/drivers/leds/led-class.c
> +++ b/drivers/leds/led-class.c
> @@ -110,50 +110,6 @@ static void led_timer_function(unsigned long data)
> ? ? ? ?mod_timer(&led_cdev->blink_timer, jiffies + msecs_to_jiffies(delay));
> ?}
>
> -static void led_stop_software_blink(struct led_classdev *led_cdev)
> -{
> - ? ? ? /* deactivate previous settings */
> - ? ? ? del_timer_sync(&led_cdev->blink_timer);
> - ? ? ? led_cdev->blink_delay_on = 0;
> - ? ? ? led_cdev->blink_delay_off = 0;
> -}
> -
> -static void led_set_software_blink(struct led_classdev *led_cdev,
> - ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?unsigned long delay_on,
> - ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?unsigned long delay_off)
> -{
> - ? ? ? int current_brightness;
> -
> - ? ? ? current_brightness = led_get_brightness(led_cdev);
> - ? ? ? if (current_brightness)
> - ? ? ? ? ? ? ? led_cdev->blink_brightness = current_brightness;
> - ? ? ? if (!led_cdev->blink_brightness)
> - ? ? ? ? ? ? ? led_cdev->blink_brightness = led_cdev->max_brightness;
> -
> - ? ? ? if (led_get_trigger_data(led_cdev) &&
> - ? ? ? ? ? delay_on == led_cdev->blink_delay_on &&
> - ? ? ? ? ? delay_off == led_cdev->blink_delay_off)
> - ? ? ? ? ? ? ? return;
> -
> - ? ? ? led_stop_software_blink(led_cdev);
> -
> - ? ? ? led_cdev->blink_delay_on = delay_on;
> - ? ? ? led_cdev->blink_delay_off = delay_off;
> -
> - ? ? ? /* never on - don't blink */
> - ? ? ? if (!delay_on)
> - ? ? ? ? ? ? ? return;
> -
> - ? ? ? /* never off - just set to brightness */
> - ? ? ? if (!delay_off) {
> - ? ? ? ? ? ? ? led_set_brightness(led_cdev, led_cdev->blink_brightness);
> - ? ? ? ? ? ? ? return;
> - ? ? ? }
> -
> - ? ? ? mod_timer(&led_cdev->blink_timer, jiffies + 1);
> -}
> -
> -
> ?/**
> ?* led_classdev_suspend - suspend an led_classdev.
> ?* @led_cdev: the led_classdev to suspend.
> @@ -262,32 +218,6 @@ void led_classdev_unregister(struct led_classdev *led_cdev)
> ?}
> ?EXPORT_SYMBOL_GPL(led_classdev_unregister);
>
> -void led_blink_set(struct led_classdev *led_cdev,
> - ? ? ? ? ? ? ? ? ?unsigned long *delay_on,
> - ? ? ? ? ? ? ? ? ?unsigned long *delay_off)
> -{
> - ? ? ? del_timer_sync(&led_cdev->blink_timer);
> -
> - ? ? ? if (led_cdev->blink_set &&
> - ? ? ? ? ? !led_cdev->blink_set(led_cdev, delay_on, delay_off))
> - ? ? ? ? ? ? ? return;
> -
> - ? ? ? /* blink with 1 Hz as default if nothing specified */
> - ? ? ? if (!*delay_on && !*delay_off)
> - ? ? ? ? ? ? ? *delay_on = *delay_off = 500;
> -
> - ? ? ? led_set_software_blink(led_cdev, *delay_on, *delay_off);
> -}
> -EXPORT_SYMBOL(led_blink_set);
> -
> -void led_brightness_set(struct led_classdev *led_cdev,
> - ? ? ? ? ? ? ? ? ? ? ? enum led_brightness brightness)
> -{
> - ? ? ? led_stop_software_blink(led_cdev);
> - ? ? ? led_cdev->brightness_set(led_cdev, brightness);
> -}
> -EXPORT_SYMBOL(led_brightness_set);
> -
> ?static int __init leds_init(void)
> ?{
> ? ? ? ?leds_class = class_create(THIS_MODULE, "leds");
> diff --git a/drivers/leds/led-core.c b/drivers/leds/led-core.c
> index 016d19f..d686004 100644
> --- a/drivers/leds/led-core.c
> +++ b/drivers/leds/led-core.c
> @@ -23,3 +23,73 @@ EXPORT_SYMBOL_GPL(leds_list_lock);
>
> ?LIST_HEAD(leds_list);
> ?EXPORT_SYMBOL_GPL(leds_list);
> +
> +static void led_stop_software_blink(struct led_classdev *led_cdev)
> +{
> + ? ? ? /* deactivate previous settings */
> + ? ? ? del_timer_sync(&led_cdev->blink_timer);
> + ? ? ? led_cdev->blink_delay_on = 0;
> + ? ? ? led_cdev->blink_delay_off = 0;
> +}
> +
> +static void led_set_software_blink(struct led_classdev *led_cdev,
> + ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?unsigned long delay_on,
> + ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?unsigned long delay_off)
> +{
> + ? ? ? int current_brightness;
> +
> + ? ? ? current_brightness = led_get_brightness(led_cdev);
> + ? ? ? if (current_brightness)
> + ? ? ? ? ? ? ? led_cdev->blink_brightness = current_brightness;
> + ? ? ? if (!led_cdev->blink_brightness)
> + ? ? ? ? ? ? ? led_cdev->blink_brightness = led_cdev->max_brightness;
> +
> + ? ? ? if (led_get_trigger_data(led_cdev) &&
> + ? ? ? ? ? delay_on == led_cdev->blink_delay_on &&
> + ? ? ? ? ? delay_off == led_cdev->blink_delay_off)
> + ? ? ? ? ? ? ? return;
> +
> + ? ? ? led_stop_software_blink(led_cdev);
> +
> + ? ? ? led_cdev->blink_delay_on = delay_on;
> + ? ? ? led_cdev->blink_delay_off = delay_off;
> +
> + ? ? ? /* never on - don't blink */
> + ? ? ? if (!delay_on)
> + ? ? ? ? ? ? ? return;
> +
> + ? ? ? /* never off - just set to brightness */
> + ? ? ? if (!delay_off) {
> + ? ? ? ? ? ? ? led_set_brightness(led_cdev, led_cdev->blink_brightness);
> + ? ? ? ? ? ? ? return;
> + ? ? ? }
> +
> + ? ? ? mod_timer(&led_cdev->blink_timer, jiffies + 1);
> +}
> +
> +
> +void led_blink_set(struct led_classdev *led_cdev,
> + ? ? ? ? ? ? ? ? ?unsigned long *delay_on,
> + ? ? ? ? ? ? ? ? ?unsigned long *delay_off)
> +{
> + ? ? ? del_timer_sync(&led_cdev->blink_timer);
> +
> + ? ? ? if (led_cdev->blink_set &&
> + ? ? ? ? ? !led_cdev->blink_set(led_cdev, delay_on, delay_off))
> + ? ? ? ? ? ? ? return;
> +
> + ? ? ? /* blink with 1 Hz as default if nothing specified */
> + ? ? ? if (!*delay_on && !*delay_off)
> + ? ? ? ? ? ? ? *delay_on = *delay_off = 500;
> +
> + ? ? ? led_set_software_blink(led_cdev, *delay_on, *delay_off);
> +}
> +EXPORT_SYMBOL(led_blink_set);
> +
> +void led_brightness_set(struct led_classdev *led_cdev,
> + ? ? ? ? ? ? ? ? ? ? ? enum led_brightness brightness)
> +{
> + ? ? ? led_stop_software_blink(led_cdev);
> + ? ? ? led_cdev->brightness_set(led_cdev, brightness);
> +}
> +EXPORT_SYMBOL(led_brightness_set);
> --
> 1.7.9
>
>
> _______________________________________________
> linux-arm-kernel mailing list
> linux-arm-kernel at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
--
Bryan Wu <bryan.wu@canonical.com>
Kernel Developer ? ?+86.138-1617-6545 Mobile
Ubuntu ARM Team
Canonical Ltd. ? ? ?www.canonical.com
Ubuntu - Linux for human beings | www.ubuntu.com
next prev parent reply other threads:[~2012-03-11 7:45 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-03-08 9:11 [PATCH 1/3] led-class: change back LEDS_CLASS to tristate instead of bool Bryan Wu
2012-03-08 9:11 ` [PATCH 2/3] led-triggers: use atomic kzalloc during led trigger registering Bryan Wu
2012-03-08 9:29 ` Uwe Kleine-König
2012-03-10 11:15 ` Bryan Wu
2012-03-12 19:37 ` Linus Walleij
2012-03-13 8:50 ` Bryan Wu
2012-03-08 9:11 ` [PATCH 3/3] led-triggers: create a trigger for CPU activity Bryan Wu
2012-03-13 23:11 ` Andrew Morton
2012-03-14 9:01 ` Linus Walleij
2012-03-15 5:08 ` Bryan Wu
2012-03-11 7:45 ` Bryan Wu [this message]
2012-03-11 13:13 ` [PATCH 1/3] led-class: change back LEDS_CLASS to tristate instead of bool Richard Purdie
2012-03-12 2:32 ` Bryan Wu
2012-03-12 19:35 ` Linus Walleij
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=CAK5ve-+KxyQ4RgftyHZ5PLYSvbxWG263f1d6WXty0RO6khYTrA@mail.gmail.com \
--to=bryan.wu@canonical.com \
--cc=linux-arm-kernel@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).