[U-Boot] [PATCH 2/6 v2] misc: add gpio based status led driver
Scott McNutt
smcnutt at psyent.com
Tue May 25 21:39:47 CEST 2010
Applied to:
git://git.denx.de/u-boot-nios.git next
Thanks,
--Scott
Thomas Chou wrote:
> This patch adds a status led driver followed the GPIO access
> conventions of Linux. The led mask is used to specify the gpio pin.
>
> Signed-off-by: Thomas Chou <thomas at wytron.com.tw>
> ---
> v2: moved to drivers/misc.
>
> drivers/misc/Makefile | 1 +
> drivers/misc/gpio_led.c | 30 ++++++++++++++++++++++++++++++
> 2 files changed, 31 insertions(+), 0 deletions(-)
> create mode 100644 drivers/misc/gpio_led.c
>
> diff --git a/drivers/misc/Makefile b/drivers/misc/Makefile
> index f6df60f..55ff17f 100644
> --- a/drivers/misc/Makefile
> +++ b/drivers/misc/Makefile
> @@ -28,6 +28,7 @@ LIB := $(obj)libmisc.a
> COBJS-$(CONFIG_ALI152X) += ali512x.o
> COBJS-$(CONFIG_DS4510) += ds4510.o
> COBJS-$(CONFIG_FSL_LAW) += fsl_law.o
> +COBJS-$(CONFIG_GPIO_LED) += gpio_led.o
> COBJS-$(CONFIG_NS87308) += ns87308.o
> COBJS-$(CONFIG_STATUS_LED) += status_led.o
> COBJS-$(CONFIG_TWL4030_LED) += twl4030_led.o
> diff --git a/drivers/misc/gpio_led.c b/drivers/misc/gpio_led.c
> new file mode 100644
> index 0000000..acd6a90
> --- /dev/null
> +++ b/drivers/misc/gpio_led.c
> @@ -0,0 +1,30 @@
> +/*
> + * Status LED driver based on GPIO access conventions of Linux
> + *
> + * Copyright (C) 2010 Thomas Chou <thomas at wytron.com.tw>
> + *
> + * 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
> + * published by the Free Software Foundation.
> + */
> +
> +#include <common.h>
> +#include <status_led.h>
> +#include <asm/gpio.h>
> +
> +/* assume led is active low */
> +
> +void __led_init(led_id_t mask, int state)
> +{
> + gpio_direction_output(mask, (state == STATUS_LED_ON) ? 0 : 1);
> +}
> +
> +void __led_set(led_id_t mask, int state)
> +{
> + gpio_set_value(mask, (state == STATUS_LED_ON) ? 0 : 1);
> +}
> +
> +void __led_toggle(led_id_t mask)
> +{
> + gpio_set_value(mask, !gpio_get_value(mask));
> +}
More information about the U-Boot
mailing list