From mboxrd@z Thu Jan 1 00:00:00 1970 From: dmitry.torokhov@gmail.com (Dmitry Torokhov) Date: Fri, 8 Dec 2017 17:24:46 -0800 Subject: [PATCH 4/5] Input: edt-ft5x06 - Add support for regulator In-Reply-To: <20171209011629.4nkcjxj2l2j7zyph@dtor-ws> References: <20171208215419.30396-1-mylene.josserand@free-electrons.com> <20171208215419.30396-5-mylene.josserand@free-electrons.com> <20171209011629.4nkcjxj2l2j7zyph@dtor-ws> Message-ID: <20171209012446.4oha36s6pf2fjlvn@dtor-ws> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org On Fri, Dec 08, 2017 at 05:16:29PM -0800, Dmitry Torokhov wrote: > Hi Myl?ne, > > On Fri, Dec 08, 2017 at 10:54:18PM +0100, Myl?ne Josserand wrote: > > Add the support of regulator to use them as VCC source. > > > > Signed-off-by: Myl?ne Josserand > > --- > > drivers/input/touchscreen/edt-ft5x06.c | 33 +++++++++++++++++++++++++++++++++ > > 1 file changed, 33 insertions(+) > > > > diff --git a/drivers/input/touchscreen/edt-ft5x06.c b/drivers/input/touchscreen/edt-ft5x06.c > > index c53a3d7239e7..44b0e04a8f35 100644 > > --- a/drivers/input/touchscreen/edt-ft5x06.c > > +++ b/drivers/input/touchscreen/edt-ft5x06.c > > @@ -39,6 +39,7 @@ > > #include > > #include > > #include > > +#include > > > > #define WORK_REGISTER_THRESHOLD 0x00 > > #define WORK_REGISTER_REPORT_RATE 0x08 > > @@ -91,6 +92,7 @@ struct edt_ft5x06_ts_data { > > struct touchscreen_properties prop; > > u16 num_x; > > u16 num_y; > > + struct regulator *supply; > > > > struct gpio_desc *reset_gpio; > > struct gpio_desc *wake_gpio; > > @@ -993,6 +995,23 @@ static int edt_ft5x06_ts_probe(struct i2c_client *client, > > > > tsdata->max_support_points = chip_data->max_support_points; > > > > + tsdata->supply = devm_regulator_get_optional(&client->dev, "power"); > > I'd prefer if we used devm_regulator_get() instead. On a > fully-constrained systems a missing regulator will be substituted with a > dummy one that you can then use in regulator_enable() and > regulator_disable(). The _optional regulator API is reserved for cases > where some of chip functionality is optional and you can engage it by > powering up parts of the chip. The reset is not such case: it is always > present, but may not be exposed to the OS to control. > > I think the preference is to call the supply by the name is a datasheet, > something like "vcc" or "vdd", etc. Looking at this some more, you need to make sure your new regulator support plays well with reset/wake GPIOs. I.e. you probably want to properly bring the chip out of reset in edt_ft5x06_ts_resume() and maybe driver the reset line low in suspend to make sure you do not leak into the unpowered chip? Also, please update Documentation/devicetree/bindings/input/touchscreen/edt-ft5x06.txt with the additional binding data and cc device tree folks and Rob Herring. Thanks. -- Dmitry