[PATCH] ARM: shmobile: lager: Add GPIO LEDs
Simon Horman
horms at verge.net.au
Mon Apr 22 21:15:25 EDT 2013
On Mon, Apr 22, 2013 at 12:00:02PM +0200, Laurent Pinchart wrote:
> Hi Simon,
>
> Thank you for the patch.
>
> On Monday 22 April 2013 12:06:30 Simon Horman wrote:
> > The board has 3 LEDs connected to GPIOs. Add a led-gpio device to
> > support them.
> >
> > Based on "ARM: shmobile: marzen: Add GPIO LEDs" by Laurent Pinchart.
> >
> > Cc: Laurent Pinchart <laurent.pinchart+renesas at ideasonboard.com>
> > Signed-off-by: Simon Horman <horms+renesas at verge.net.au>
> > ---
> > arch/arm/mach-shmobile/board-lager.c | 37 +++++++++++++++++++++++++++++++++
> > 1 file changed, 37 insertions(+)
> >
> > Tested on lager board.
> > Based on the tag renesas-next-20130419 of my renesas tree.
> >
> > diff --git a/arch/arm/mach-shmobile/board-lager.c
> > b/arch/arm/mach-shmobile/board-lager.c index 6114edd..a8aa04f 100644
> > --- a/arch/arm/mach-shmobile/board-lager.c
> > +++ b/arch/arm/mach-shmobile/board-lager.c
> > @@ -21,13 +21,49 @@
> > #include <linux/interrupt.h>
> > #include <linux/irqchip.h>
> > #include <linux/kernel.h>
> > +#include <linux/leds.h>
> > #include <linux/pinctrl/machine.h>
> > +#include <linux/platform_data/gpio-rcar.h>
> > #include <linux/platform_device.h>
> > #include <mach/common.h>
> > #include <mach/r8a7790.h>
> > #include <asm/mach-types.h>
> > #include <asm/mach/arch.h>
> >
> > +/* LEDS */
> > +static struct gpio_led lager_leds[] = {
> > + {
> > + .name = "led8",
> > + .gpio = RCAR_GP_PIN(5, 17),
> > + .default_state = LEDS_GPIO_DEFSTATE_ON,
> > + }, {
> > + .name = "led7",
> > + .gpio = RCAR_GP_PIN(4, 23),
> > + .default_state = LEDS_GPIO_DEFSTATE_ON,
> > + }, {
> > + .name = "led6",
> > + .gpio = RCAR_GP_PIN(4, 22),
> > + .default_state = LEDS_GPIO_DEFSTATE_ON,
>
> Just out of curiosity, why is the default state on ?
Only because thats what the marzen code does.
Would off be a better choice?
>
> > + },
> > +};
> > +
> > +static struct gpio_led_platform_data lager_leds_pdata = {
> > + .leds = lager_leds,
> > + .num_leds = ARRAY_SIZE(lager_leds),
> > +};
> > +
> > +static struct platform_device leds_device = {
> > + .name = "leds-gpio",
> > + .id = 0,
>
> As there's a single leds-gpio device, maybe id = -1 ?
Yes, true. I'll fix that.
I think the marzen code should probably be fixed too.
> > + .dev = {
> > + .platform_data = &lager_leds_pdata,
> > + },
> > +};
> > +
> > +static struct platform_device *lager_devices[] __initdata = {
> > + &leds_device,
> > +};
> > +
> > static const struct pinctrl_map lager_pinctrl_map[] = {
> > /* SCIF0 (CN19: DEBUG SERIAL0) */
> > PIN_MAP_MUX_GROUP_DEFAULT("sh-sci.6", "pfc-r8a7790",
> > @@ -46,6 +82,7 @@ static void __init lager_add_standard_devices(void)
> > r8a7790_pinmux_init();
> >
> > r8a7790_add_standard_devices();
> > + platform_add_devices(lager_devices, ARRAY_SIZE(lager_devices));
> > }
> >
> > static const char *lager_boards_compat_dt[] __initdata = {
>
> --
> Regards,
>
> Laurent Pinchart
>
More information about the linux-arm-kernel
mailing list