Commit 19a3e160 authored by Dmitry Torokhov's avatar Dmitry Torokhov

Merge branch 'ib/ads7846-hsync' into next

Bring in ADS7846 hsync changes.
parents 866a5c7e 8685f22b
...@@ -57,6 +57,7 @@ Optional properties: ...@@ -57,6 +57,7 @@ Optional properties:
pendown-gpio (u32). pendown-gpio (u32).
pendown-gpio GPIO handle describing the pin the !PENIRQ pendown-gpio GPIO handle describing the pin the !PENIRQ
line is connected to. line is connected to.
ti,hsync-gpios GPIO line to poll for hsync
wakeup-source use any event on touchscreen as wakeup event. wakeup-source use any event on touchscreen as wakeup event.
(Legacy property support: "linux,wakeup") (Legacy property support: "linux,wakeup")
touchscreen-size-x General touchscreen binding, see [1]. touchscreen-size-x General touchscreen binding, see [1].
......
...@@ -138,6 +138,7 @@ struct ads7846 { ...@@ -138,6 +138,7 @@ struct ads7846 {
void *filter_data; void *filter_data;
int (*get_pendown_state)(void); int (*get_pendown_state)(void);
struct gpio_desc *gpio_pendown; struct gpio_desc *gpio_pendown;
struct gpio_desc *gpio_hsync;
void (*wait_for_sync)(void); void (*wait_for_sync)(void);
}; };
...@@ -634,10 +635,6 @@ ATTRIBUTE_GROUPS(ads784x); ...@@ -634,10 +635,6 @@ ATTRIBUTE_GROUPS(ads784x);
/*--------------------------------------------------------------------------*/ /*--------------------------------------------------------------------------*/
static void null_wait_for_sync(void)
{
}
static int ads7846_debounce_filter(void *ads, int data_idx, int *val) static int ads7846_debounce_filter(void *ads, int data_idx, int *val)
{ {
struct ads7846 *ts = ads; struct ads7846 *ts = ads;
...@@ -790,6 +787,28 @@ static int ads7846_filter(struct ads7846 *ts) ...@@ -790,6 +787,28 @@ static int ads7846_filter(struct ads7846 *ts)
return 0; return 0;
} }
static void ads7846_wait_for_hsync(struct ads7846 *ts)
{
if (ts->wait_for_sync) {
ts->wait_for_sync();
return;
}
if (!ts->gpio_hsync)
return;
/*
* Wait for HSYNC to assert the line should be flagged
* as active low so here we are waiting for it to assert
*/
while (!gpiod_get_value(ts->gpio_hsync))
cpu_relax();
/* Then we wait for it do de-assert */
while (gpiod_get_value(ts->gpio_hsync))
cpu_relax();
}
static void ads7846_read_state(struct ads7846 *ts) static void ads7846_read_state(struct ads7846 *ts)
{ {
struct ads7846_packet *packet = ts->packet; struct ads7846_packet *packet = ts->packet;
...@@ -800,7 +819,7 @@ static void ads7846_read_state(struct ads7846 *ts) ...@@ -800,7 +819,7 @@ static void ads7846_read_state(struct ads7846 *ts)
packet->last_cmd_idx = 0; packet->last_cmd_idx = 0;
while (true) { while (true) {
ts->wait_for_sync(); ads7846_wait_for_hsync(ts);
m = &ts->msg[msg_idx]; m = &ts->msg[msg_idx];
error = spi_sync(ts->spi, m); error = spi_sync(ts->spi, m);
...@@ -1258,7 +1277,11 @@ static int ads7846_probe(struct spi_device *spi) ...@@ -1258,7 +1277,11 @@ static int ads7846_probe(struct spi_device *spi)
ts->penirq_recheck_delay_usecs = ts->penirq_recheck_delay_usecs =
pdata->penirq_recheck_delay_usecs; pdata->penirq_recheck_delay_usecs;
ts->wait_for_sync = pdata->wait_for_sync ? : null_wait_for_sync; ts->wait_for_sync = pdata->wait_for_sync;
ts->gpio_hsync = devm_gpiod_get_optional(dev, "ti,hsync", GPIOD_IN);
if (IS_ERR(ts->gpio_hsync))
return PTR_ERR(ts->gpio_hsync);
snprintf(ts->phys, sizeof(ts->phys), "%s/input0", dev_name(dev)); snprintf(ts->phys, sizeof(ts->phys), "%s/input0", dev_name(dev));
snprintf(ts->name, sizeof(ts->name), "ADS%d Touchscreen", ts->model); snprintf(ts->name, sizeof(ts->name), "ADS%d Touchscreen", ts->model);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment