RE: [RFC PATCH] Board support for the the GPIO keys

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Charu,
Agree to your comments.
Will fix them.

> -----Original Message-----
> From: Varadarajan, Charulatha
> Sent: Friday, August 20, 2010 12:13 PM
> To: Datta, Shubhrajyoti; linux-omap@xxxxxxxxxxxxxxx
> Cc: linux-input@xxxxxxxxxxxxxxx
> Subject: RE: [RFC PATCH] Board support for the the GPIO keys
> 
> 
> 
> > -----Original Message-----
> > From: linux-omap-owner@xxxxxxxxxxxxxxx
> > [mailto:linux-omap-owner@xxxxxxxxxxxxxxx] On Behalf Of Datta,
> > Shubhrajyoti
> > Sent: Thursday, August 19, 2010 5:12 PM
> > To: linux-omap@xxxxxxxxxxxxxxx
> > Cc: linux-input@xxxxxxxxxxxxxxx; Datta, Shubhrajyoti
> > Subject: [RFC PATCH] Board support for the the GPIO keys
> >
> > Board support for the GPIO keys.
> > The proximity sensor is connected to GPIO and is registered as a
> > GPIO key.
> >
> > Signed-off-by: Shubhrajyoti D <shubhrajyoti@xxxxxx>
> > ---
> >  arch/arm/mach-omap2/board-4430sdp.c |   56
> > +++++++++++++++++++++++++++++++++++
> >  1 files changed, 56 insertions(+), 0 deletions(-)
> >
> > diff --git a/arch/arm/mach-omap2/board-4430sdp.c
> > b/arch/arm/mach-omap2/board-4430sdp.c
> > index 9447644..7f619bf 100644
> > --- a/arch/arm/mach-omap2/board-4430sdp.c
> > +++ b/arch/arm/mach-omap2/board-4430sdp.c
> > @@ -20,6 +20,7 @@
> >  #include <linux/usb/otg.h>
> >  #include <linux/spi/spi.h>
> >  #include <linux/i2c/twl.h>
> > +#include <linux/gpio_keys.h>
> >  #include <linux/regulator/machine.h>
> >  #include <linux/leds.h>
> >
> > @@ -40,6 +41,10 @@
> >  #define ETH_KS8851_IRQ			34
> >  #define ETH_KS8851_POWER_ON		48
> >  #define ETH_KS8851_QUART		138
> > +#define OMAP4_SFH7741_SENSOR_OUTPUT_GPIO	184
> > +#define OMAP4_SFH7741_ENABLE_GPIO		188
> 
> Insert a new line.
> 
> > +static int omap_prox_activate(struct device *dev);
> > +static void omap_prox_deactivate(struct device *dev);
> >
> >  static struct gpio_led sdp4430_gpio_leds[] = {
> >  	{
> > @@ -76,11 +81,33 @@ static struct gpio_led sdp4430_gpio_leds[] = {
> >  	},
> >
> >  };
> > +static struct gpio_keys_button sdp4430_gpio_keys[] = {
> > +	{
> > +		.desc			= "Proximity Sensor",
> > +		.type			= EV_SW,
> > +		.code			= SW_FRONT_PROXIMITY,
> > +		.gpio			=
> > OMAP4_SFH7741_SENSOR_OUTPUT_GPIO,
> > +		.active_low		= 0,
> > +	}
> > +};
> >
> >  static struct gpio_led_platform_data sdp4430_led_data = {
> >  	.leds	= sdp4430_gpio_leds,
> >  	.num_leds	= ARRAY_SIZE(sdp4430_gpio_leds),
> >  };
> 
> Insert a new line.
> 
> > +static struct gpio_keys_platform_data sdp4430_gpio_keys_data = {
> > +	.buttons	= sdp4430_gpio_keys,
> > +	.nbuttons	= ARRAY_SIZE(sdp4430_gpio_keys),
> > +	.enable		= omap_prox_activate,
> > +	.disable	= omap_prox_deactivate,
> > +};
> 
> Insert a new line.
> 
> > +static struct platform_device sdp4430_gpio_keys_device = {
> > +	.name	= "gpio-keys",
> > +	.id	= -1,
> > +	.dev	= {
> > +		.platform_data	= &sdp4430_gpio_keys_data,
> > +	},
> > +};
> >
> >  static struct platform_device sdp4430_leds_gpio = {
> >  	.name	= "leds-gpio",
> > @@ -161,6 +188,7 @@ static struct platform_device
> > sdp4430_lcd_device = {
> >
> >  static struct platform_device *sdp4430_devices[] __initdata = {
> >  	&sdp4430_lcd_device,
> > +	&sdp4430_gpio_keys_device,
> >  	&sdp4430_leds_gpio,
> >  };
> >
> > @@ -426,6 +454,33 @@ static int __init omap4_i2c_init(void)
> >  	omap_register_i2c_bus(4, 400, NULL, 0);
> >  	return 0;
> >  }
> 
> Insert a new line.
> 
> > +static int  omap_prox_activate(struct device *dev)
> > +{
> > +	gpio_set_value(OMAP4_SFH7741_ENABLE_GPIO , 1);
> > +	return 0;
> > +}
> 
> Insert a new line.
> 
> > +static void omap_prox_deactivate(struct device *dev)
> > +{
> > +	gpio_set_value(OMAP4_SFH7741_ENABLE_GPIO , 0);
> > +}
> 
> Insert a new line.
> 
> > +static void omap_sfh7741prox_init(void)
> > +{
> > +	int  error;
> > +
> > +	error = gpio_request(OMAP4_SFH7741_ENABLE_GPIO, "sfh7741");
> > +	if (error < 0) {
> > +		pr_err("failed to request GPIO %d, error %d\n",
> > +			OMAP4_SFH7741_ENABLE_GPIO, error);
> > +		return;
> > +	}
> > +
> > +	error = gpio_direction_output(OMAP4_SFH7741_ENABLE_GPIO , 1);
> > +	if (error < 0) {
> > +		pr_err("%s: GPIO configuration failed: GPIO
> > %d,error %d\n",\
> > +			 __func__, OMAP4_SFH7741_ENABLE_GPIO, error);
> > +		gpio_free(OMAP4_SFH7741_ENABLE_GPIO);
> > +	}
> > +}
> 
> Insert a new line.
> 
> >  static void __init omap_4430sdp_init(void)
> >  {
> >  	int status;
> > @@ -448,6 +503,7 @@ static void __init omap_4430sdp_init(void)
> >  		spi_register_board_info(sdp4430_spi_board_info,
> >  				ARRAY_SIZE(sdp4430_spi_board_info));
> >  	}
> > +	omap_sfh7741prox_init();
> >  }
> >
> >  static void __init omap_4430sdp_map_io(void)
> > --
> > 1.7.0.4
> >
> > --
> > To unsubscribe from this list: send the line "unsubscribe
> > linux-omap" in
> > the body of a message to majordomo@xxxxxxxxxxxxxxx
> > More majordomo info at  http://vger.kernel.org/majordomo-info.html
> >
--
To unsubscribe from this list: send the line "unsubscribe linux-input" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Media Devel]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Linux Wireless Networking]     [Linux Omap]

  Powered by Linux