Message ID | 20161211072250.GA39300@dtor-ws (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Opps, sorry for containing html. Thanks again. Jingkui On Mon, Dec 12, 2016 at 11:02 AM, Jingkui Wang <jkwang@google.com> wrote: > It looks great! Really appreciate your help. > > Thanks, > Jingkui Wang > > On Sat, Dec 10, 2016 at 11:22 PM, Dmitry Torokhov > <dmitry.torokhov@gmail.com> wrote: >> >> Hi Jingkui, >> >> On Fri, Dec 09, 2016 at 01:45:26PM -0800, Jingkui Wang wrote: >> > Update driver drv260x to use generic device properties >> > Remove platform data and corresponding header file >> >> Please next time come up with more descriptive subject than "drivers: >> Update drv260x driver": when scanning commit messages person shoudl be >> able to gauge whether the change is interesting or not. >> >> > -static int drv260x_parse_dt(struct device *dev, >> > +static int drv260x_read_device_property(struct device *dev, >> > struct drv260x_data *haptics) >> > { >> > - struct device_node *np = dev->of_node; >> > unsigned int voltage; >> > int error; >> > >> > - error = of_property_read_u32(np, "mode", &haptics->mode); >> > + error = device_property_read_u32(dev, "mode", &haptics->mode); >> > if (error) { >> > dev_err(dev, "%s: No entry for mode\n", __func__); >> > return error; >> > } >> > >> > - error = of_property_read_u32(np, "library-sel", >> > &haptics->library); >> > + error = device_property_read_u32(dev, "library-sel", >> > &haptics->library); >> > if (error) { >> > dev_err(dev, "%s: No entry for library selection\n", >> > __func__); >> > return error; >> > } >> >> Now that platform code is gone there it makes no sense separating >> reading properties from validating the settings. Does the following >> version look OK to you (it needs a patch introducing temporary in >> probe() function, you'll find it attached)? >> >> Thanks. >> >> -- >> Dmitry >> >> >> Input: drv260x - use generic device properties >> >> From: Jingkui Wang <jkwang@google.com> >> >> Update driver drv260x to use generic device properties so that it can be >> used on non-DT systems. We also remove platform data as generic device >> properties work on static board code as well. >> >> Signed-off-by: Jingkui Wang <jkwang@google.com> >> Patchwork-Id: 9469075 >> Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com> >> --- >> drivers/input/misc/drv260x.c | 80 >> ++++++--------------------- >> include/linux/platform_data/drv260x-pdata.h | 28 --------- >> 2 files changed, 19 insertions(+), 89 deletions(-) >> delete mode 100644 include/linux/platform_data/drv260x-pdata.h >> >> diff --git a/drivers/input/misc/drv260x.c b/drivers/input/misc/drv260x.c >> index 18c266c..11664d7 100644 >> --- a/drivers/input/misc/drv260x.c >> +++ b/drivers/input/misc/drv260x.c >> @@ -18,8 +18,6 @@ >> #include <linux/i2c.h> >> #include <linux/input.h> >> #include <linux/module.h> >> -#include <linux/of_gpio.h> >> -#include <linux/platform_device.h> >> #include <linux/regmap.h> >> #include <linux/slab.h> >> #include <linux/delay.h> >> @@ -27,7 +25,6 @@ >> #include <linux/regulator/consumer.h> >> >> #include <dt-bindings/input/ti-drv260x.h> >> -#include <linux/platform_data/drv260x-pdata.h> >> >> #define DRV260X_STATUS 0x0 >> #define DRV260X_MODE 0x1 >> @@ -468,54 +465,12 @@ static const struct regmap_config >> drv260x_regmap_config = { >> .cache_type = REGCACHE_NONE, >> }; >> >> -#ifdef CONFIG_OF >> -static int drv260x_parse_dt(struct device *dev, >> - struct drv260x_data *haptics) >> -{ >> - struct device_node *np = dev->of_node; >> - unsigned int voltage; >> - int error; >> - >> - error = of_property_read_u32(np, "mode", &haptics->mode); >> - if (error) { >> - dev_err(dev, "%s: No entry for mode\n", __func__); >> - return error; >> - } >> - >> - error = of_property_read_u32(np, "library-sel", >> &haptics->library); >> - if (error) { >> - dev_err(dev, "%s: No entry for library selection\n", >> - __func__); >> - return error; >> - } >> - >> - error = of_property_read_u32(np, "vib-rated-mv", &voltage); >> - if (!error) >> - haptics->rated_voltage = >> drv260x_calculate_voltage(voltage); >> - >> - >> - error = of_property_read_u32(np, "vib-overdrive-mv", &voltage); >> - if (!error) >> - haptics->overdrive_voltage = >> drv260x_calculate_voltage(voltage); >> - >> - return 0; >> -} >> -#else >> -static inline int drv260x_parse_dt(struct device *dev, >> - struct drv260x_data *haptics) >> -{ >> - dev_err(dev, "no platform data defined\n"); >> - >> - return -EINVAL; >> -} >> -#endif >> - >> static int drv260x_probe(struct i2c_client *client, >> const struct i2c_device_id *id) >> { >> - const struct drv260x_platform_data *pdata = >> dev_get_platdata(&client->dev); >> struct device *dev = &client->dev; >> struct drv260x_data *haptics; >> + u32 voltage; >> int error; >> >> haptics = devm_kzalloc(dev, sizeof(*haptics), GFP_KERNEL); >> @@ -525,29 +480,24 @@ static int drv260x_probe(struct i2c_client *client, >> haptics->overdrive_voltage = DRV260X_DEF_OD_CLAMP_VOLT; >> haptics->rated_voltage = DRV260X_DEF_RATED_VOLT; >> >> - if (pdata) { >> - haptics->mode = pdata->mode; >> - haptics->library = pdata->library_selection; >> - if (pdata->vib_overdrive_voltage) >> - haptics->overdrive_voltage = >> drv260x_calculate_voltage(pdata->vib_overdrive_voltage); >> - if (pdata->vib_rated_voltage) >> - haptics->rated_voltage = >> drv260x_calculate_voltage(pdata->vib_rated_voltage); >> - } else if (client->dev.of_node) { >> - error = drv260x_parse_dt(&client->dev, haptics); >> - if (error) >> - return error; >> - } else { >> - dev_err(dev, "Platform data not set\n"); >> - return -ENODEV; >> + error = device_property_read_u32(dev, "mode", &haptics->mode); >> + if (error) { >> + dev_err(dev, "Can't fetch 'mode' property: %d\n", error); >> + return error; >> } >> >> - >> if (haptics->mode < DRV260X_LRA_MODE || >> haptics->mode > DRV260X_ERM_MODE) { >> dev_err(dev, "Vibrator mode is invalid: %i\n", >> haptics->mode); >> return -EINVAL; >> } >> >> + error = device_property_read_u32(dev, "library-sel", >> &haptics->library); >> + if (error) { >> + dev_err(dev, "Can't fetch 'library-sel' property: %d\n", >> error); >> + return error; >> + } >> + >> if (haptics->library < DRV260X_LIB_EMPTY || >> haptics->library > DRV260X_ERM_LIB_F) { >> dev_err(dev, >> @@ -569,6 +519,14 @@ static int drv260x_probe(struct i2c_client *client, >> return -EINVAL; >> } >> >> + error = device_property_read_u32(dev, "vib-rated-mv", &voltage); >> + haptics->rated_voltage = error ? DRV260X_DEF_RATED_VOLT : >> + >> drv260x_calculate_voltage(voltage); >> + >> + error = device_property_read_u32(dev, "vib-overdrive-mv", >> &voltage); >> + haptics->overdrive_voltage = error ? DRV260X_DEF_OD_CLAMP_VOLT : >> + >> drv260x_calculate_voltage(voltage); >> + >> haptics->regulator = devm_regulator_get(dev, "vbat"); >> if (IS_ERR(haptics->regulator)) { >> error = PTR_ERR(haptics->regulator); >> diff --git a/include/linux/platform_data/drv260x-pdata.h >> b/include/linux/platform_data/drv260x-pdata.h >> deleted file mode 100644 >> index 0a03b09..0000000 >> --- a/include/linux/platform_data/drv260x-pdata.h >> +++ /dev/null >> @@ -1,28 +0,0 @@ >> -/* >> - * Platform data for DRV260X haptics driver family >> - * >> - * Author: Dan Murphy <dmurphy@ti.com> >> - * >> - * Copyright: (C) 2014 Texas Instruments, Inc. >> - * >> - * This program is free software; you can redistribute it and/or modify >> - * it under the terms of the GNU General Public License version 2 as >> - * published by the Free Software Foundation. >> - * >> - * This program is distributed in the hope that it will be useful, but >> - * WITHOUT ANY WARRANTY; without even the implied warranty of >> - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU >> - * General Public License for more details. >> - */ >> - >> -#ifndef _LINUX_DRV260X_PDATA_H >> -#define _LINUX_DRV260X_PDATA_H >> - >> -struct drv260x_platform_data { >> - u32 library_selection; >> - u32 mode; >> - u32 vib_rated_voltage; >> - u32 vib_overdrive_voltage; >> -}; >> - >> -#endif > > -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Input: drv260x - use temporary for &client->dev From: Dmitry Torokhov <dmitry.torokhov@gmail.com> Let's introduce a temporary for "client->dev" is probe() as we use it quite a few times and "dev" is shorter. Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com> --- drivers/input/misc/drv260x.c | 39 ++++++++++++++++----------------------- 1 file changed, 16 insertions(+), 23 deletions(-) diff --git a/drivers/input/misc/drv260x.c b/drivers/input/misc/drv260x.c index 9789d4f..18c266c 100644 --- a/drivers/input/misc/drv260x.c +++ b/drivers/input/misc/drv260x.c @@ -514,10 +514,11 @@ static int drv260x_probe(struct i2c_client *client, const struct i2c_device_id *id) { const struct drv260x_platform_data *pdata = dev_get_platdata(&client->dev); + struct device *dev = &client->dev; struct drv260x_data *haptics; int error; - haptics = devm_kzalloc(&client->dev, sizeof(*haptics), GFP_KERNEL); + haptics = devm_kzalloc(dev, sizeof(*haptics), GFP_KERNEL); if (!haptics) return -ENOMEM; @@ -536,22 +537,20 @@ static int drv260x_probe(struct i2c_client *client, if (error) return error; } else { - dev_err(&client->dev, "Platform data not set\n"); + dev_err(dev, "Platform data not set\n"); return -ENODEV; } if (haptics->mode < DRV260X_LRA_MODE || haptics->mode > DRV260X_ERM_MODE) { - dev_err(&client->dev, - "Vibrator mode is invalid: %i\n", - haptics->mode); + dev_err(dev, "Vibrator mode is invalid: %i\n", haptics->mode); return -EINVAL; } if (haptics->library < DRV260X_LIB_EMPTY || haptics->library > DRV260X_ERM_LIB_F) { - dev_err(&client->dev, + dev_err(dev, "Library value is invalid: %i\n", haptics->library); return -EINVAL; } @@ -559,40 +558,37 @@ static int drv260x_probe(struct i2c_client *client, if (haptics->mode == DRV260X_LRA_MODE && haptics->library != DRV260X_LIB_EMPTY && haptics->library != DRV260X_LIB_LRA) { - dev_err(&client->dev, - "LRA Mode with ERM Library mismatch\n"); + dev_err(dev, "LRA Mode with ERM Library mismatch\n"); return -EINVAL; } if (haptics->mode == DRV260X_ERM_MODE && (haptics->library == DRV260X_LIB_EMPTY || haptics->library == DRV260X_LIB_LRA)) { - dev_err(&client->dev, - "ERM Mode with LRA Library mismatch\n"); + dev_err(dev, "ERM Mode with LRA Library mismatch\n"); return -EINVAL; } - haptics->regulator = devm_regulator_get(&client->dev, "vbat"); + haptics->regulator = devm_regulator_get(dev, "vbat"); if (IS_ERR(haptics->regulator)) { error = PTR_ERR(haptics->regulator); - dev_err(&client->dev, - "unable to get regulator, error: %d\n", error); + dev_err(dev, "unable to get regulator, error: %d\n", error); return error; } - haptics->enable_gpio = devm_gpiod_get_optional(&client->dev, "enable", + haptics->enable_gpio = devm_gpiod_get_optional(dev, "enable", GPIOD_OUT_HIGH); if (IS_ERR(haptics->enable_gpio)) return PTR_ERR(haptics->enable_gpio); - haptics->input_dev = devm_input_allocate_device(&client->dev); + haptics->input_dev = devm_input_allocate_device(dev); if (!haptics->input_dev) { dev_err(&client->dev, "Failed to allocate input device\n"); return -ENOMEM; } haptics->input_dev->name = "drv260x:haptics"; - haptics->input_dev->dev.parent = client->dev.parent; + haptics->input_dev->dev.parent = dev->parent; haptics->input_dev->close = drv260x_close; input_set_drvdata(haptics->input_dev, haptics); input_set_capability(haptics->input_dev, EV_FF, FF_RUMBLE); @@ -600,8 +596,7 @@ static int drv260x_probe(struct i2c_client *client, error = input_ff_create_memless(haptics->input_dev, NULL, drv260x_haptics_play); if (error) { - dev_err(&client->dev, "input_ff_create() failed: %d\n", - error); + dev_err(dev, "input_ff_create() failed: %d\n", error); return error; } @@ -613,21 +608,19 @@ static int drv260x_probe(struct i2c_client *client, haptics->regmap = devm_regmap_init_i2c(client, &drv260x_regmap_config); if (IS_ERR(haptics->regmap)) { error = PTR_ERR(haptics->regmap); - dev_err(&client->dev, "Failed to allocate register map: %d\n", - error); + dev_err(dev, "Failed to allocate register map: %d\n", error); return error; } error = drv260x_init(haptics); if (error) { - dev_err(&client->dev, "Device init failed: %d\n", error); + dev_err(dev, "Device init failed: %d\n", error); return error; } error = input_register_device(haptics->input_dev); if (error) { - dev_err(&client->dev, "couldn't register input device: %d\n", - error); + dev_err(dev, "couldn't register input device: %d\n", error); return error; }