From mboxrd@z Thu Jan 1 00:00:00 1970 From: Igor Grinberg Subject: Re: [PATCH] Input: synaptics_i2c - Convert to dev_pm_ops Date: Mon, 14 Feb 2011 11:31:22 +0200 Message-ID: <4D58F66A.8000705@compulab.co.il> References: <1297438904-27430-1-git-send-email-broonie@opensource.wolfsonmicro.com> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Return-path: Received: from compulab.co.il ([67.18.134.219]:41233 "EHLO compulab.co.il" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752219Ab1BNJb1 (ORCPT ); Mon, 14 Feb 2011 04:31:27 -0500 In-Reply-To: <1297438904-27430-1-git-send-email-broonie@opensource.wolfsonmicro.com> Sender: linux-input-owner@vger.kernel.org List-Id: linux-input@vger.kernel.org To: Mark Brown Cc: Mike Rapoport , Dmitry Torokhov , linux-input@vger.kernel.org On 02/11/11 17:41, Mark Brown wrote: > There is a general move to convert drivers to dev_pm_ops rather than bus > specific PM ops in order to facilitate core development. Do this converison > for synaptics-i2c. > > Signed-off-by: Mark Brown Acked-by: Igor Grinberg > --- > drivers/input/mouse/synaptics_i2c.c | 16 +++++++++------- > 1 files changed, 9 insertions(+), 7 deletions(-) > > diff --git a/drivers/input/mouse/synaptics_i2c.c b/drivers/input/mouse/synaptics_i2c.c > index 0ae62f0..f6aa26d 100644 > --- a/drivers/input/mouse/synaptics_i2c.c > +++ b/drivers/input/mouse/synaptics_i2c.c > @@ -18,6 +18,7 @@ > #include > #include > #include > +#include > > #define DRIVER_NAME "synaptics_i2c" > /* maximum product id is 15 characters */ > @@ -619,8 +620,9 @@ static int __devexit synaptics_i2c_remove(struct i2c_client *client) > } > > #ifdef CONFIG_PM > -static int synaptics_i2c_suspend(struct i2c_client *client, pm_message_t mesg) > +static int synaptics_i2c_suspend(struct device *dev) > { > + struct i2c_client *client = to_i2c_client(dev); > struct synaptics_i2c *touch = i2c_get_clientdata(client); > > cancel_delayed_work_sync(&touch->dwork); > @@ -631,9 +633,10 @@ static int synaptics_i2c_suspend(struct i2c_client *client, pm_message_t mesg) > return 0; > } > > -static int synaptics_i2c_resume(struct i2c_client *client) > +static int synaptics_i2c_resume(struct device *dev) > { > int ret; > + struct i2c_client *client = to_i2c_client(dev); > struct synaptics_i2c *touch = i2c_get_clientdata(client); > > ret = synaptics_i2c_reset_config(client); > @@ -645,11 +648,11 @@ static int synaptics_i2c_resume(struct i2c_client *client) > > return 0; > } > -#else > -#define synaptics_i2c_suspend NULL > -#define synaptics_i2c_resume NULL > #endif > > +static SIMPLE_DEV_PM_OPS(synaptics_i2c_pm, synaptics_i2c_suspend, > + synaptics_i2c_resume); > + > static const struct i2c_device_id synaptics_i2c_id_table[] = { > { "synaptics_i2c", 0 }, > { }, > @@ -660,13 +663,12 @@ static struct i2c_driver synaptics_i2c_driver = { > .driver = { > .name = DRIVER_NAME, > .owner = THIS_MODULE, > + .pm = &synaptics_i2c_pm, > }, > > .probe = synaptics_i2c_probe, > .remove = __devexit_p(synaptics_i2c_remove), > > - .suspend = synaptics_i2c_suspend, > - .resume = synaptics_i2c_resume, > .id_table = synaptics_i2c_id_table, > }; > -- Regards, Igor.