[PATCHv2] Input: omap4-keypad: Add pinctrl support
Dmitry Torokhov
dmitry.torokhov at gmail.com
Mon Oct 22 11:50:28 EDT 2012
Hi Sourav,
On Mon, Oct 22, 2012 at 06:43:00PM +0530, Sourav Poddar wrote:
> Adapt keypad to use pinctrl framework.
>
> Tested on omap4430 sdp with 3.7-rc1 kernel.
I do not see anything in the driver that would directly use pinctrl. Is
there a better place to select default pin configuration; maybe when
instantiating platform device?
Thanks.
>
> Cc: Felipe Balbi <balbi at ti.com>
> Cc: Dmitry Torokhov <dmitry.torokhov at gmail.com>
> Signed-off-by: Sourav Poddar <sourav.poddar at ti.com>
> ---
> v1->v2
> - Added "PROBE_DEFER" check
> drivers/input/keyboard/omap4-keypad.c | 11 +++++++++++
> 1 files changed, 11 insertions(+), 0 deletions(-)
>
> diff --git a/drivers/input/keyboard/omap4-keypad.c b/drivers/input/keyboard/omap4-keypad.c
> index c05f98c..502b832 100644
> --- a/drivers/input/keyboard/omap4-keypad.c
> +++ b/drivers/input/keyboard/omap4-keypad.c
> @@ -31,6 +31,7 @@
> #include <linux/input.h>
> #include <linux/slab.h>
> #include <linux/pm_runtime.h>
> +#include <linux/pinctrl/consumer.h>
>
> #include <linux/platform_data/omap4-keypad.h>
>
> @@ -76,6 +77,7 @@ enum {
>
> struct omap4_keypad {
> struct input_dev *input;
> + struct pinctrl *pins;
>
> void __iomem *base;
> unsigned int irq;
> @@ -298,6 +300,15 @@ static int __devinit omap4_keypad_probe(struct platform_device *pdev)
> goto err_release_mem;
> }
>
> + keypad_data->pins = devm_pinctrl_get_select_default(&pdev->dev);
> + if (IS_ERR(keypad_data->pins)) {
> + if (PTR_ERR(keypad_data->pins) == -EPROBE_DEFER)
> + return -EPROBE_DEFER;
> +
> + dev_warn(&pdev->dev, "did not get pins for keypad error: %li\n",
> + PTR_ERR(keypad_data->pins));
> + keypad_data->pins = NULL;
> + }
>
> /*
> * Enable clocks for the keypad module so that we can read
> --
> 1.7.1
>
--
Dmitry
More information about the linux-arm-kernel
mailing list