On Thu, Dec 15, 2011 at 10:18:59PM +0000, Alan Cox wrote: > From: Heikki Krogerus <heikki.krogerus@xxxxxxxxxxxxxxx> > > This also changes the devname parameter delivered to > request_threaded_irq() from "mpu_int" to "mpu3050". > > Signed-off-by: Heikki Krogerus <heikki.krogerus@xxxxxxxxxxxxxxx> > Signed-off-by: Kirill A. Shutemov <kirill.shutemov@xxxxxxxxxxxxxxx> > Signed-off-by: Alan Cox <alan@xxxxxxxxxxxxxxx> > --- > > drivers/input/misc/mpu3050.c | 10 +++++++++- > 1 files changed, 9 insertions(+), 1 deletions(-) > > > diff --git a/drivers/input/misc/mpu3050.c b/drivers/input/misc/mpu3050.c > index 89c7160..cf42c78 100644 > --- a/drivers/input/misc/mpu3050.c > +++ b/drivers/input/misc/mpu3050.c > @@ -437,12 +437,20 @@ static int __devinit mpu3050_probe(struct i2c_client *client, > error = request_threaded_irq(client->irq, > NULL, mpu3050_interrupt_thread, > IRQF_TRIGGER_RISING, > - "mpu_int", sensor); > + "mpu3050", sensor); > if (error) { > dev_err(&client->dev, "can't get IRQ %d, error %d\n", > client->irq, error); > goto err_pm_set_suspended; > } > + > + /* Enable interrupts */ > + i2c_smbus_write_byte_data(sensor->client, MPU3050_INT_CFG, > + MPU3050_LATCH_INT_EN > + | MPU3050_RAW_RDY_EN > + | MPU3050_MPU_RDY_EN); > + if (ret < 0) > + goto err_free_irq; You are testing a random variable here. Also, this belongs in open() method. I will apply the patch below. Thanks. -- Dmitry Input: mpu3050 - ensure we enable interrupts From: Heikki Krogerus <heikki.krogerus@xxxxxxxxxxxxxxx> This also changes the devname parameter delivered to request_threaded_irq() from "mpu_int" to "mpu3050". Signed-off-by: Heikki Krogerus <heikki.krogerus@xxxxxxxxxxxxxxx> Signed-off-by: Kirill A. Shutemov <kirill.shutemov@xxxxxxxxxxxxxxx> Signed-off-by: Alan Cox <alan@xxxxxxxxxxxxxxx> Signed-off-by: Dmitry Torokhov <dtor@xxxxxxx> --- drivers/input/misc/mpu3050.c | 13 ++++++++++++- 1 files changed, 12 insertions(+), 1 deletions(-) diff --git a/drivers/input/misc/mpu3050.c b/drivers/input/misc/mpu3050.c index 28a7b19..76905ae 100644 --- a/drivers/input/misc/mpu3050.c +++ b/drivers/input/misc/mpu3050.c @@ -148,9 +148,20 @@ static void mpu3050_set_power_mode(struct i2c_client *client, u8 val) static int mpu3050_input_open(struct input_dev *input) { struct mpu3050_sensor *sensor = input_get_drvdata(input); + int error; pm_runtime_get(sensor->dev); + /* Enable interrupts */ + error = i2c_smbus_write_byte_data(sensor->client, MPU3050_INT_CFG, + MPU3050_LATCH_INT_EN | + MPU3050_RAW_RDY_EN | + MPU3050_MPU_RDY_EN); + if (error < 0) { + pm_runtime_put(sensor->dev); + return error; + } + return 0; } @@ -259,7 +270,7 @@ static int __devinit mpu3050_probe(struct i2c_client *client, error = request_threaded_irq(client->irq, NULL, mpu3050_interrupt_thread, IRQF_TRIGGER_RISING, - "mpu_int", sensor); + "mpu3050", sensor); if (error) { dev_err(&client->dev, "can't get IRQ %d, error %d\n", client->irq, error); -- 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