* [PATCH 0/2] Input: zforce - update GPIO handling
@ 2015-07-03 9:07 Dirk Behme
2015-07-03 9:07 ` [PATCH 1/2] Input: zforce - add DT support for reset GPIO polarity Dirk Behme
2015-07-03 9:07 ` [PATCH 2/2] Input: zforce - convert to use the gpiod interface Dirk Behme
0 siblings, 2 replies; 5+ messages in thread
From: Dirk Behme @ 2015-07-03 9:07 UTC (permalink / raw)
To: linux-input; +Cc: dmitry.torokhov, Dirk Behme
This patch series updates the GPIO handling of the zforce driver.
The first patch is the same like the already sent one
http://www.spinics.net/lists/linux-input/msg39228.html
without any changes and therefore replaces that one.
The second one is new and implements the conversion to the gpiod framework
as reuested in the review comments of the first change.
Dirk
^ permalink raw reply [flat|nested] 5+ messages in thread
* [PATCH 1/2] Input: zforce - add DT support for reset GPIO polarity
2015-07-03 9:07 [PATCH 0/2] Input: zforce - update GPIO handling Dirk Behme
@ 2015-07-03 9:07 ` Dirk Behme
2015-07-03 9:07 ` [PATCH 2/2] Input: zforce - convert to use the gpiod interface Dirk Behme
1 sibling, 0 replies; 5+ messages in thread
From: Dirk Behme @ 2015-07-03 9:07 UTC (permalink / raw)
To: linux-input; +Cc: dmitry.torokhov, Knut Wohlrab, Oleksij Rempel
From: Knut Wohlrab <Knut.Wohlrab@de.bosch.com>
According to
Documentation/devicetree/bindings/input/touchscreen/zforce_ts.txt
the RST GPIO is supposed to provide a polarity flag parameter
gpios = <&GPIO_BANK GPIO_NUMBER GPIO_POLARITY>
with GPIO_POLARITY
reset active low = 1 (GPIO_ACTIVE_LOW)
reset active high = 0 (GPIO_ACTIVE_HIGH)
Example for GPIO_ACTIVE_LOW (1) reset GPIO:
zforce_ts@50 { /* Neonode zForce I2C */
compatible = "neonode,zforce-ts";
...
gpios = <&gpio6 14 GPIO_ACTIVE_HIGH>, /* INT */
<&gpio1 29 GPIO_ACTIVE_LOW>; /* RST */
...
};
Add the missing polarity flag evaluation to the driver.
Signed-off-by: Knut Wohlrab <Knut.Wohlrab@de.bosch.com>
Signed-off-by: Oleksij Rempel <external.Oleksij.Rempel@de.bosch.com>
---
drivers/input/touchscreen/zforce_ts.c | 27 +++++++++++++++++++++++----
include/linux/platform_data/zforce_ts.h | 3 +++
2 files changed, 26 insertions(+), 4 deletions(-)
diff --git a/drivers/input/touchscreen/zforce_ts.c b/drivers/input/touchscreen/zforce_ts.c
index 19880c7..125311d 100644
--- a/drivers/input/touchscreen/zforce_ts.c
+++ b/drivers/input/touchscreen/zforce_ts.c
@@ -162,6 +162,20 @@ static int zforce_command(struct zforce_ts *ts, u8 cmd)
return 0;
}
+static void zforce_reset_assert(struct zforce_ts *ts)
+{
+ const struct zforce_ts_platdata *pdata = ts->pdata;
+
+ gpio_set_value(pdata->gpio_rst, pdata->reset_active_low ? 0 : 1);
+}
+
+static void zforce_reset_deassert(struct zforce_ts *ts)
+{
+ const struct zforce_ts_platdata *pdata = ts->pdata;
+
+ gpio_set_value(pdata->gpio_rst, pdata->reset_active_low ? 1 : 0);
+}
+
static int zforce_send_wait(struct zforce_ts *ts, const char *buf, int len)
{
struct i2c_client *client = ts->client;
@@ -691,7 +705,7 @@ static void zforce_reset(void *data)
{
struct zforce_ts *ts = data;
- gpio_set_value(ts->pdata->gpio_rst, 0);
+ zforce_reset_assert(ts);
udelay(10);
@@ -703,6 +717,7 @@ static struct zforce_ts_platdata *zforce_parse_dt(struct device *dev)
{
struct zforce_ts_platdata *pdata;
struct device_node *np = dev->of_node;
+ enum of_gpio_flags flags;
if (!np)
return ERR_PTR(-ENOENT);
@@ -719,12 +734,14 @@ static struct zforce_ts_platdata *zforce_parse_dt(struct device *dev)
return ERR_PTR(-EINVAL);
}
- pdata->gpio_rst = of_get_gpio(np, 1);
+ pdata->gpio_rst = of_get_gpio_flags(np, 1, &flags);
if (!gpio_is_valid(pdata->gpio_rst)) {
dev_err(dev, "failed to get reset gpio\n");
return ERR_PTR(-EINVAL);
}
+ pdata->reset_active_low = flags & OF_GPIO_ACTIVE_LOW;
+
if (of_property_read_u32(np, "x-size", &pdata->x_max)) {
dev_err(dev, "failed to get x-size property\n");
return ERR_PTR(-EINVAL);
@@ -765,7 +782,9 @@ static int zforce_probe(struct i2c_client *client,
}
ret = devm_gpio_request_one(&client->dev, pdata->gpio_rst,
- GPIOF_OUT_INIT_LOW, "zforce_ts_rst");
+ pdata->reset_active_low ?
+ GPIOF_OUT_INIT_HIGH : GPIOF_OUT_INIT_LOW,
+ "zforce_ts_rst");
if (ret) {
dev_err(&client->dev, "request of gpio %d failed, %d\n",
pdata->gpio_rst, ret);
@@ -864,7 +883,7 @@ static int zforce_probe(struct i2c_client *client,
i2c_set_clientdata(client, ts);
/* let the controller boot */
- gpio_set_value(pdata->gpio_rst, 1);
+ zforce_reset_deassert(ts);
ts->command_waiting = NOTIFICATION_BOOTCOMPLETE;
if (wait_for_completion_timeout(&ts->command_done, WAIT_TIMEOUT) == 0)
diff --git a/include/linux/platform_data/zforce_ts.h b/include/linux/platform_data/zforce_ts.h
index 0472ab2..44cd90f 100644
--- a/include/linux/platform_data/zforce_ts.h
+++ b/include/linux/platform_data/zforce_ts.h
@@ -15,9 +15,12 @@
#ifndef _LINUX_INPUT_ZFORCE_TS_H
#define _LINUX_INPUT_ZFORCE_TS_H
+#include <linux/of_gpio.h>
+
struct zforce_ts_platdata {
int gpio_int;
int gpio_rst;
+ enum of_gpio_flags reset_active_low;
unsigned int x_max;
unsigned int y_max;
--
2.3.4
^ permalink raw reply related [flat|nested] 5+ messages in thread
* [PATCH 2/2] Input: zforce - convert to use the gpiod interface
2015-07-03 9:07 [PATCH 0/2] Input: zforce - update GPIO handling Dirk Behme
2015-07-03 9:07 ` [PATCH 1/2] Input: zforce - add DT support for reset GPIO polarity Dirk Behme
@ 2015-07-03 9:07 ` Dirk Behme
2015-07-06 23:25 ` Dmitry Torokhov
1 sibling, 1 reply; 5+ messages in thread
From: Dirk Behme @ 2015-07-03 9:07 UTC (permalink / raw)
To: linux-input; +Cc: dmitry.torokhov, Dirk Behme
Use the new GPIO descriptor interface to handle the zForce GPIOs.
This simplifies the code. No functional change.
Signed-off-by: Dirk Behme <dirk.behme@de.bosch.com>
---
drivers/input/touchscreen/zforce_ts.c | 50 +++++++++++----------------------
include/linux/platform_data/zforce_ts.h | 7 ++---
2 files changed, 18 insertions(+), 39 deletions(-)
diff --git a/drivers/input/touchscreen/zforce_ts.c b/drivers/input/touchscreen/zforce_ts.c
index 125311d..e840497 100644
--- a/drivers/input/touchscreen/zforce_ts.c
+++ b/drivers/input/touchscreen/zforce_ts.c
@@ -24,7 +24,7 @@
#include <linux/interrupt.h>
#include <linux/i2c.h>
#include <linux/delay.h>
-#include <linux/gpio.h>
+#include <linux/gpio/consumer.h>
#include <linux/device.h>
#include <linux/sysfs.h>
#include <linux/input/mt.h>
@@ -32,7 +32,6 @@
#include <linux/regulator/consumer.h>
#include <linux/delay.h>
#include <linux/of.h>
-#include <linux/of_gpio.h>
#define WAIT_TIMEOUT msecs_to_jiffies(1000)
@@ -166,14 +165,14 @@ static void zforce_reset_assert(struct zforce_ts *ts)
{
const struct zforce_ts_platdata *pdata = ts->pdata;
- gpio_set_value(pdata->gpio_rst, pdata->reset_active_low ? 0 : 1);
+ gpiod_set_value(pdata->gpio_rst, 1);
}
static void zforce_reset_deassert(struct zforce_ts *ts)
{
const struct zforce_ts_platdata *pdata = ts->pdata;
- gpio_set_value(pdata->gpio_rst, pdata->reset_active_low ? 1 : 0);
+ gpiod_set_value(pdata->gpio_rst, 0);
}
static int zforce_send_wait(struct zforce_ts *ts, const char *buf, int len)
@@ -514,7 +513,7 @@ static irqreturn_t zforce_irq_thread(int irq, void *dev_id)
if (!ts->suspending && device_may_wakeup(&client->dev))
pm_stay_awake(&client->dev);
- while (!gpio_get_value(pdata->gpio_int)) {
+ while (!gpiod_get_value(pdata->gpio_int)) {
ret = zforce_read_packet(ts, payload_buffer);
if (ret < 0) {
dev_err(&client->dev,
@@ -717,7 +716,6 @@ static struct zforce_ts_platdata *zforce_parse_dt(struct device *dev)
{
struct zforce_ts_platdata *pdata;
struct device_node *np = dev->of_node;
- enum of_gpio_flags flags;
if (!np)
return ERR_PTR(-ENOENT);
@@ -728,20 +726,22 @@ static struct zforce_ts_platdata *zforce_parse_dt(struct device *dev)
return ERR_PTR(-ENOMEM);
}
- pdata->gpio_int = of_get_gpio(np, 0);
- if (!gpio_is_valid(pdata->gpio_int)) {
- dev_err(dev, "failed to get interrupt gpio\n");
- return ERR_PTR(-EINVAL);
+ /* INT GPIO */
+ pdata->gpio_int = devm_gpiod_get_index(dev, NULL, 0, GPIOD_IN);
+ if (IS_ERR(pdata->gpio_int)) {
+ dev_err(dev, "failed to request interrupt GPIO: %ld\n",
+ PTR_ERR(pdata->gpio_int));
+ return ERR_CAST(pdata->gpio_int);
}
- pdata->gpio_rst = of_get_gpio_flags(np, 1, &flags);
- if (!gpio_is_valid(pdata->gpio_rst)) {
- dev_err(dev, "failed to get reset gpio\n");
- return ERR_PTR(-EINVAL);
+ /* RST GPIO */
+ pdata->gpio_rst = devm_gpiod_get_index(dev, NULL, 1, GPIOD_OUT_HIGH);
+ if (IS_ERR(pdata->gpio_rst)) {
+ dev_err(dev, "failed to request reset GPIO: %ld\n",
+ PTR_ERR(pdata->gpio_rst));
+ return ERR_CAST(pdata->gpio_rst);
}
- pdata->reset_active_low = flags & OF_GPIO_ACTIVE_LOW;
-
if (of_property_read_u32(np, "x-size", &pdata->x_max)) {
dev_err(dev, "failed to get x-size property\n");
return ERR_PTR(-EINVAL);
@@ -773,24 +773,6 @@ static int zforce_probe(struct i2c_client *client,
if (!ts)
return -ENOMEM;
- ret = devm_gpio_request_one(&client->dev, pdata->gpio_int, GPIOF_IN,
- "zforce_ts_int");
- if (ret) {
- dev_err(&client->dev, "request of gpio %d failed, %d\n",
- pdata->gpio_int, ret);
- return ret;
- }
-
- ret = devm_gpio_request_one(&client->dev, pdata->gpio_rst,
- pdata->reset_active_low ?
- GPIOF_OUT_INIT_HIGH : GPIOF_OUT_INIT_LOW,
- "zforce_ts_rst");
- if (ret) {
- dev_err(&client->dev, "request of gpio %d failed, %d\n",
- pdata->gpio_rst, ret);
- return ret;
- }
-
ts->reg_vdd = devm_regulator_get_optional(&client->dev, "vdd");
if (IS_ERR(ts->reg_vdd)) {
ret = PTR_ERR(ts->reg_vdd);
diff --git a/include/linux/platform_data/zforce_ts.h b/include/linux/platform_data/zforce_ts.h
index 44cd90f..1794268 100644
--- a/include/linux/platform_data/zforce_ts.h
+++ b/include/linux/platform_data/zforce_ts.h
@@ -15,12 +15,9 @@
#ifndef _LINUX_INPUT_ZFORCE_TS_H
#define _LINUX_INPUT_ZFORCE_TS_H
-#include <linux/of_gpio.h>
-
struct zforce_ts_platdata {
- int gpio_int;
- int gpio_rst;
- enum of_gpio_flags reset_active_low;
+ struct gpio_desc *gpio_int;
+ struct gpio_desc *gpio_rst;
unsigned int x_max;
unsigned int y_max;
--
2.3.4
^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH 2/2] Input: zforce - convert to use the gpiod interface
2015-07-03 9:07 ` [PATCH 2/2] Input: zforce - convert to use the gpiod interface Dirk Behme
@ 2015-07-06 23:25 ` Dmitry Torokhov
2015-07-07 18:38 ` Dirk Behme
0 siblings, 1 reply; 5+ messages in thread
From: Dmitry Torokhov @ 2015-07-06 23:25 UTC (permalink / raw)
To: Dirk Behme; +Cc: linux-input
Hi Dirk,
On Fri, Jul 03, 2015 at 11:07:49AM +0200, Dirk Behme wrote:
> diff --git a/include/linux/platform_data/zforce_ts.h b/include/linux/platform_data/zforce_ts.h
> index 44cd90f..1794268 100644
> --- a/include/linux/platform_data/zforce_ts.h
> +++ b/include/linux/platform_data/zforce_ts.h
> @@ -15,12 +15,9 @@
> #ifndef _LINUX_INPUT_ZFORCE_TS_H
> #define _LINUX_INPUT_ZFORCE_TS_H
>
> -#include <linux/of_gpio.h>
> -
> struct zforce_ts_platdata {
> - int gpio_int;
> - int gpio_rst;
> - enum of_gpio_flags reset_active_low;
> + struct gpio_desc *gpio_int;
> + struct gpio_desc *gpio_rst;
>
> unsigned int x_max;
> unsigned int y_max;
I do not think we should be plumbing GPIO descriptors directly into
platform data. If board doe snot want to use DT/ACPI they will simply
have to attach GPIO lookup table to the device (via
gpiod_add_lookup_table).
So I intend to apply the version below...
Thanks.
--
Dmitry
Input: zforce_ts - convert to use the gpiod interface
From: Dirk Behme <dirk.behme@de.bosch.com>
Use the new GPIO descriptor interface to handle the zForce GPIOs.
This simplifies the code and allows transparently handle GPIO polarity, as
specified in device tree data.
Also switch to using gpio_{set|get}_value_cansleep() since none of the
callers is in atomic context and cansleep variant allows more GPIO
controllers to be used with the touchscreen.
Signed-off-by: Dirk Behme <dirk.behme@de.bosch.com>
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
---
drivers/input/touchscreen/zforce_ts.c | 58 ++++++++++++++++---------------
include/linux/platform_data/zforce_ts.h | 3 --
2 files changed, 30 insertions(+), 31 deletions(-)
diff --git a/drivers/input/touchscreen/zforce_ts.c b/drivers/input/touchscreen/zforce_ts.c
index f58a196..c4cffcf 100644
--- a/drivers/input/touchscreen/zforce_ts.c
+++ b/drivers/input/touchscreen/zforce_ts.c
@@ -24,14 +24,13 @@
#include <linux/interrupt.h>
#include <linux/i2c.h>
#include <linux/delay.h>
-#include <linux/gpio.h>
+#include <linux/gpio/consumer.h>
#include <linux/device.h>
#include <linux/sysfs.h>
#include <linux/input/mt.h>
#include <linux/platform_data/zforce_ts.h>
#include <linux/regulator/consumer.h>
#include <linux/of.h>
-#include <linux/of_gpio.h>
#define WAIT_TIMEOUT msecs_to_jiffies(1000)
@@ -120,6 +119,9 @@ struct zforce_ts {
struct regulator *reg_vdd;
+ struct gpio_desc *gpio_int;
+ struct gpio_desc *gpio_rst;
+
bool suspending;
bool suspended;
bool boot_complete;
@@ -161,6 +163,16 @@ static int zforce_command(struct zforce_ts *ts, u8 cmd)
return 0;
}
+static void zforce_reset_assert(struct zforce_ts *ts)
+{
+ gpiod_set_value_cansleep(ts->gpio_rst, 1);
+}
+
+static void zforce_reset_deassert(struct zforce_ts *ts)
+{
+ gpiod_set_value_cansleep(ts->gpio_rst, 0);
+}
+
static int zforce_send_wait(struct zforce_ts *ts, const char *buf, int len)
{
struct i2c_client *client = ts->client;
@@ -479,7 +491,6 @@ static irqreturn_t zforce_irq_thread(int irq, void *dev_id)
{
struct zforce_ts *ts = dev_id;
struct i2c_client *client = ts->client;
- const struct zforce_ts_platdata *pdata = ts->pdata;
int ret;
u8 payload_buffer[FRAME_MAXSIZE];
u8 *payload;
@@ -499,7 +510,7 @@ static irqreturn_t zforce_irq_thread(int irq, void *dev_id)
if (!ts->suspending && device_may_wakeup(&client->dev))
pm_stay_awake(&client->dev);
- while (!gpio_get_value(pdata->gpio_int)) {
+ while (!gpiod_get_value_cansleep(ts->gpio_int)) {
ret = zforce_read_packet(ts, payload_buffer);
if (ret < 0) {
dev_err(&client->dev,
@@ -690,7 +701,7 @@ static void zforce_reset(void *data)
{
struct zforce_ts *ts = data;
- gpio_set_value(ts->pdata->gpio_rst, 0);
+ zforce_reset_assert(ts);
udelay(10);
@@ -712,18 +723,6 @@ static struct zforce_ts_platdata *zforce_parse_dt(struct device *dev)
return ERR_PTR(-ENOMEM);
}
- pdata->gpio_int = of_get_gpio(np, 0);
- if (!gpio_is_valid(pdata->gpio_int)) {
- dev_err(dev, "failed to get interrupt gpio\n");
- return ERR_PTR(-EINVAL);
- }
-
- pdata->gpio_rst = of_get_gpio(np, 1);
- if (!gpio_is_valid(pdata->gpio_rst)) {
- dev_err(dev, "failed to get reset gpio\n");
- return ERR_PTR(-EINVAL);
- }
-
if (of_property_read_u32(np, "x-size", &pdata->x_max)) {
dev_err(dev, "failed to get x-size property\n");
return ERR_PTR(-EINVAL);
@@ -755,19 +754,22 @@ static int zforce_probe(struct i2c_client *client,
if (!ts)
return -ENOMEM;
- ret = devm_gpio_request_one(&client->dev, pdata->gpio_int, GPIOF_IN,
- "zforce_ts_int");
- if (ret) {
- dev_err(&client->dev, "request of gpio %d failed, %d\n",
- pdata->gpio_int, ret);
+ /* INT GPIO */
+ ts->gpio_int = devm_gpiod_get_index(&client->dev, NULL, 0, GPIOD_IN);
+ if (IS_ERR(ts->gpio_int)) {
+ ret = PTR_ERR(ts->gpio_int);
+ dev_err(&client->dev,
+ "failed to request interrupt GPIO: %d\n", ret);
return ret;
}
- ret = devm_gpio_request_one(&client->dev, pdata->gpio_rst,
- GPIOF_OUT_INIT_LOW, "zforce_ts_rst");
- if (ret) {
- dev_err(&client->dev, "request of gpio %d failed, %d\n",
- pdata->gpio_rst, ret);
+ /* RST GPIO */
+ ts->gpio_rst = devm_gpiod_get_index(&client->dev, NULL, 1,
+ GPIOD_OUT_HIGH);
+ if (IS_ERR(ts->gpio_rst)) {
+ ret = PTR_ERR(ts->gpio_rst);
+ dev_err(&client->dev,
+ "failed to request reset GPIO: %d\n", ret);
return ret;
}
@@ -863,7 +865,7 @@ static int zforce_probe(struct i2c_client *client,
i2c_set_clientdata(client, ts);
/* let the controller boot */
- gpio_set_value(pdata->gpio_rst, 1);
+ zforce_reset_deassert(ts);
ts->command_waiting = NOTIFICATION_BOOTCOMPLETE;
if (wait_for_completion_timeout(&ts->command_done, WAIT_TIMEOUT) == 0)
diff --git a/include/linux/platform_data/zforce_ts.h b/include/linux/platform_data/zforce_ts.h
index 0472ab2..7bdece8 100644
--- a/include/linux/platform_data/zforce_ts.h
+++ b/include/linux/platform_data/zforce_ts.h
@@ -16,9 +16,6 @@
#define _LINUX_INPUT_ZFORCE_TS_H
struct zforce_ts_platdata {
- int gpio_int;
- int gpio_rst;
-
unsigned int x_max;
unsigned int y_max;
};
^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH 2/2] Input: zforce - convert to use the gpiod interface
2015-07-06 23:25 ` Dmitry Torokhov
@ 2015-07-07 18:38 ` Dirk Behme
0 siblings, 0 replies; 5+ messages in thread
From: Dirk Behme @ 2015-07-07 18:38 UTC (permalink / raw)
To: Dmitry Torokhov; +Cc: Dirk Behme, linux-input
On 07.07.2015 01:25, Dmitry Torokhov wrote:
> Hi Dirk,
>
> On Fri, Jul 03, 2015 at 11:07:49AM +0200, Dirk Behme wrote:
>> diff --git a/include/linux/platform_data/zforce_ts.h b/include/linux/platform_data/zforce_ts.h
>> index 44cd90f..1794268 100644
>> --- a/include/linux/platform_data/zforce_ts.h
>> +++ b/include/linux/platform_data/zforce_ts.h
>> @@ -15,12 +15,9 @@
>> #ifndef _LINUX_INPUT_ZFORCE_TS_H
>> #define _LINUX_INPUT_ZFORCE_TS_H
>>
>> -#include <linux/of_gpio.h>
>> -
>> struct zforce_ts_platdata {
>> - int gpio_int;
>> - int gpio_rst;
>> - enum of_gpio_flags reset_active_low;
>> + struct gpio_desc *gpio_int;
>> + struct gpio_desc *gpio_rst;
>>
>> unsigned int x_max;
>> unsigned int y_max;
>
> I do not think we should be plumbing GPIO descriptors directly into
> platform data. If board doe snot want to use DT/ACPI they will simply
> have to attach GPIO lookup table to the device (via
> gpiod_add_lookup_table).
>
> So I intend to apply the version below...
While it's technically fine, it seems to mix the two parts I've done
in separate patches (adding the missing polarity handling and
converting to gpiod) in one patch. Which might be less obvious to
reviewers and in case of regressions. But anyway, if you like this,
I'm fine with it.
Thanks!
Best regards
Dirk
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2015-07-07 18:38 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-07-03 9:07 [PATCH 0/2] Input: zforce - update GPIO handling Dirk Behme
2015-07-03 9:07 ` [PATCH 1/2] Input: zforce - add DT support for reset GPIO polarity Dirk Behme
2015-07-03 9:07 ` [PATCH 2/2] Input: zforce - convert to use the gpiod interface Dirk Behme
2015-07-06 23:25 ` Dmitry Torokhov
2015-07-07 18:38 ` Dirk Behme
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).