Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 202199
b: refs/heads/master
c: 0f622bf
h: refs/heads/master
i:
  202197: 7a56bef
  202195: 0e5181e
  202191: 4317e3d
v: v3
  • Loading branch information
Dmitry Torokhov committed Jul 3, 2010
1 parent 88ff4d1 commit ccd1a30
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 18 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: af6e1d99ea525161f70f68ecb83d0d0f54f1bf62
refs/heads/master: 0f622bf465e78c390e13c5f4a14d0b3f8fb7c7e5
35 changes: 19 additions & 16 deletions trunk/drivers/input/touchscreen/ads7846.c
Original file line number Diff line number Diff line change
Expand Up @@ -878,14 +878,15 @@ static int __devinit setup_pendown(struct spi_device *spi, struct ads7846 *ts)

static int __devinit ads7846_probe(struct spi_device *spi)
{
struct ads7846 *ts;
struct ads7846_packet *packet;
struct input_dev *input_dev;
struct ads7846_platform_data *pdata = spi->dev.platform_data;
struct spi_message *m;
struct spi_transfer *x;
int vref;
int err;
struct ads7846 *ts;
struct ads7846_packet *packet;
struct input_dev *input_dev;
const struct ads7846_platform_data *pdata = spi->dev.platform_data;
struct spi_message *m;
struct spi_transfer *x;
unsigned long irq_flags;
int vref;
int err;

if (!spi->irq) {
dev_dbg(&spi->dev, "no IRQ?\n");
Expand Down Expand Up @@ -1174,20 +1175,22 @@ static int __devinit ads7846_probe(struct spi_device *spi)
goto err_put_regulator;
}

if (!pdata->irq_flags)
pdata->irq_flags = IRQF_TRIGGER_FALLING;
irq_flags = pdata->irq_flags ? : IRQF_TRIGGER_FALLING;

if (request_irq(spi->irq, ads7846_irq, pdata->irq_flags,
spi->dev.driver->name, ts)) {
err = request_irq(spi->irq, ads7846_irq, irq_flags,
spi->dev.driver->name, ts);

if (err && !pdata->irq_flags) {
dev_info(&spi->dev,
"trying pin change workaround on irq %d\n", spi->irq);
err = request_irq(spi->irq, ads7846_irq,
IRQF_TRIGGER_FALLING | IRQF_TRIGGER_RISING,
spi->dev.driver->name, ts);
if (err) {
dev_dbg(&spi->dev, "irq %d busy?\n", spi->irq);
goto err_disable_regulator;
}
}

if (err) {
dev_dbg(&spi->dev, "irq %d busy?\n", spi->irq);
goto err_disable_regulator;
}

err = ads784x_hwmon_register(spi, ts);
Expand Down
2 changes: 1 addition & 1 deletion trunk/include/linux/spi/ads7846.h
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ struct ads7846_platform_data {
* state if get_pendown_state == NULL
*/
int (*get_pendown_state)(void);
int (*filter_init) (struct ads7846_platform_data *pdata,
int (*filter_init) (const struct ads7846_platform_data *pdata,
void **filter_data);
int (*filter) (void *filter_data, int data_idx, int *val);
void (*filter_cleanup)(void *filter_data);
Expand Down

0 comments on commit ccd1a30

Please sign in to comment.