mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-01 02:36:02 +00:00
Input updates for 6.7 merge window:
- a number of input drivers has been converted to use facilities provided by the device core to instantiate driver-specific attributes instead of using devm_device_add_group() and similar APIs - platform input devices have been converted to use remove() callback returning void - a fix for use-after-free when tearing down a Synaptics RMI device - a few flexible arrays in input structures have been annotated with __counted_by to help hardening efforts - handling of vddio supply in cyttsp5 driver - other miscellaneous fixups -----BEGIN PGP SIGNATURE----- iHUEABYIAB0WIQST2eWILY88ieB2DOtAj56VGEWXnAUCZUyblQAKCRBAj56VGEWX nDVoAQDzsznzm0JMx+irkldF4fX6jeY6QNlMJbczQMTe1+i+egD/ZeHpvt7UboUo 4J2Hin/datV0HVPl0GUBVw6XVaC4jQ4= =TD2n -----END PGP SIGNATURE----- Merge tag 'input-for-v6.7-rc0' of git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input Pull input updates from Dmitry Torokhov: - a number of input drivers has been converted to use facilities provided by the device core to instantiate driver-specific attributes instead of using devm_device_add_group() and similar APIs - platform input devices have been converted to use remove() callback returning void - a fix for use-after-free when tearing down a Synaptics RMI device - a few flexible arrays in input structures have been annotated with __counted_by to help hardening efforts - handling of vddio supply in cyttsp5 driver - other miscellaneous fixups * tag 'input-for-v6.7-rc0' of git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input: (86 commits) Input: walkera0701 - use module_parport_driver macro to simplify the code Input: synaptics-rmi4 - fix use after free in rmi_unregister_function() dt-bindings: input: fsl,scu-key: Document wakeup-source Input: cyttsp5 - add handling for vddio regulator dt-bindings: input: cyttsp5: document vddio-supply Input: tegra-kbc - use device_get_match_data() Input: Annotate struct ff_device with __counted_by Input: axp20x-pek - avoid needless newline removal Input: mt - annotate struct input_mt with __counted_by Input: leds - annotate struct input_leds with __counted_by Input: evdev - annotate struct evdev_client with __counted_by Input: synaptics-rmi4 - replace deprecated strncpy Input: wm97xx-core - convert to platform remove callback returning void Input: wm831x-ts - convert to platform remove callback returning void Input: ti_am335x_tsc - convert to platform remove callback returning void Input: sun4i-ts - convert to platform remove callback returning void Input: stmpe-ts - convert to platform remove callback returning void Input: pcap_ts - convert to platform remove callback returning void Input: mc13783_ts - convert to platform remove callback returning void Input: mainstone-wm97xx - convert to platform remove callback returning void ...
This commit is contained in:
commit
a12deb44f9
@ -24,6 +24,8 @@ properties:
|
||||
linux,keycodes:
|
||||
maxItems: 1
|
||||
|
||||
wakeup-source: true
|
||||
|
||||
required:
|
||||
- compatible
|
||||
- linux,keycodes
|
||||
|
@ -34,6 +34,9 @@ properties:
|
||||
vdd-supply:
|
||||
description: Regulator for voltage.
|
||||
|
||||
vddio-supply:
|
||||
description: Optional Regulator for I/O voltage.
|
||||
|
||||
reset-gpios:
|
||||
maxItems: 1
|
||||
|
||||
|
@ -50,7 +50,7 @@ struct evdev_client {
|
||||
bool revoked;
|
||||
unsigned long *evmasks[EV_CNT];
|
||||
unsigned int bufsize;
|
||||
struct input_event buffer[];
|
||||
struct input_event buffer[] __counted_by(bufsize);
|
||||
};
|
||||
|
||||
static size_t evdev_get_mask_cnt(unsigned int type)
|
||||
|
@ -44,7 +44,7 @@ struct input_led {
|
||||
struct input_leds {
|
||||
struct input_handle handle;
|
||||
unsigned int num_leds;
|
||||
struct input_led leds[];
|
||||
struct input_led leds[] __counted_by(num_leds);
|
||||
};
|
||||
|
||||
static enum led_brightness input_leds_brightness_get(struct led_classdev *cdev)
|
||||
|
@ -296,15 +296,4 @@ static struct parport_driver walkera0701_parport_driver = {
|
||||
.devmodel = true,
|
||||
};
|
||||
|
||||
static int __init walkera0701_init(void)
|
||||
{
|
||||
return parport_register_driver(&walkera0701_parport_driver);
|
||||
}
|
||||
|
||||
static void __exit walkera0701_exit(void)
|
||||
{
|
||||
parport_unregister_driver(&walkera0701_parport_driver);
|
||||
}
|
||||
|
||||
module_init(walkera0701_init);
|
||||
module_exit(walkera0701_exit);
|
||||
module_parport_driver(walkera0701_parport_driver);
|
||||
|
@ -168,14 +168,12 @@ static int adp5520_keys_probe(struct platform_device *pdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int adp5520_keys_remove(struct platform_device *pdev)
|
||||
static void adp5520_keys_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct adp5520_keys *dev = platform_get_drvdata(pdev);
|
||||
|
||||
adp5520_unregister_notifier(dev->master, &dev->notifier,
|
||||
ADP5520_KP_IEN | ADP5520_KR_IEN);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver adp5520_keys_driver = {
|
||||
@ -183,7 +181,7 @@ static struct platform_driver adp5520_keys_driver = {
|
||||
.name = "adp5520-keys",
|
||||
},
|
||||
.probe = adp5520_keys_probe,
|
||||
.remove = adp5520_keys_remove,
|
||||
.remove_new = adp5520_keys_remove,
|
||||
};
|
||||
module_platform_driver(adp5520_keys_driver);
|
||||
|
||||
|
@ -686,10 +686,11 @@ static umode_t cros_ec_keyb_attr_is_visible(struct kobject *kobj,
|
||||
return attr->mode;
|
||||
}
|
||||
|
||||
static const struct attribute_group cros_ec_keyb_attr_group = {
|
||||
static const struct attribute_group cros_ec_keyb_group = {
|
||||
.is_visible = cros_ec_keyb_attr_is_visible,
|
||||
.attrs = cros_ec_keyb_attrs,
|
||||
};
|
||||
__ATTRIBUTE_GROUPS(cros_ec_keyb);
|
||||
|
||||
static int cros_ec_keyb_probe(struct platform_device *pdev)
|
||||
{
|
||||
@ -730,12 +731,6 @@ static int cros_ec_keyb_probe(struct platform_device *pdev)
|
||||
return err;
|
||||
}
|
||||
|
||||
err = devm_device_add_group(dev, &cros_ec_keyb_attr_group);
|
||||
if (err) {
|
||||
dev_err(dev, "failed to create attributes: %d\n", err);
|
||||
return err;
|
||||
}
|
||||
|
||||
ckdev->notifier.notifier_call = cros_ec_keyb_work;
|
||||
err = blocking_notifier_chain_register(&ckdev->ec->event_notifier,
|
||||
&ckdev->notifier);
|
||||
@ -748,14 +743,12 @@ static int cros_ec_keyb_probe(struct platform_device *pdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cros_ec_keyb_remove(struct platform_device *pdev)
|
||||
static void cros_ec_keyb_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct cros_ec_keyb *ckdev = dev_get_drvdata(&pdev->dev);
|
||||
|
||||
blocking_notifier_chain_unregister(&ckdev->ec->event_notifier,
|
||||
&ckdev->notifier);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_ACPI
|
||||
@ -779,9 +772,10 @@ static DEFINE_SIMPLE_DEV_PM_OPS(cros_ec_keyb_pm_ops, NULL, cros_ec_keyb_resume);
|
||||
|
||||
static struct platform_driver cros_ec_keyb_driver = {
|
||||
.probe = cros_ec_keyb_probe,
|
||||
.remove = cros_ec_keyb_remove,
|
||||
.remove_new = cros_ec_keyb_remove,
|
||||
.driver = {
|
||||
.name = "cros-ec-keyb",
|
||||
.dev_groups = cros_ec_keyb_groups,
|
||||
.of_match_table = of_match_ptr(cros_ec_keyb_of_match),
|
||||
.acpi_match_table = ACPI_PTR(cros_ec_keyb_acpi_match),
|
||||
.pm = pm_sleep_ptr(&cros_ec_keyb_pm_ops),
|
||||
|
@ -308,11 +308,9 @@ static int ep93xx_keypad_probe(struct platform_device *pdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int ep93xx_keypad_remove(struct platform_device *pdev)
|
||||
static void ep93xx_keypad_remove(struct platform_device *pdev)
|
||||
{
|
||||
dev_pm_clear_wake_irq(&pdev->dev);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver ep93xx_keypad_driver = {
|
||||
@ -321,7 +319,7 @@ static struct platform_driver ep93xx_keypad_driver = {
|
||||
.pm = pm_sleep_ptr(&ep93xx_keypad_pm_ops),
|
||||
},
|
||||
.probe = ep93xx_keypad_probe,
|
||||
.remove = ep93xx_keypad_remove,
|
||||
.remove_new = ep93xx_keypad_remove,
|
||||
};
|
||||
module_platform_driver(ep93xx_keypad_driver);
|
||||
|
||||
|
@ -310,7 +310,7 @@ static int iqs62x_keys_probe(struct platform_device *pdev)
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int iqs62x_keys_remove(struct platform_device *pdev)
|
||||
static void iqs62x_keys_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct iqs62x_keys_private *iqs62x_keys = platform_get_drvdata(pdev);
|
||||
int ret;
|
||||
@ -319,8 +319,6 @@ static int iqs62x_keys_remove(struct platform_device *pdev)
|
||||
&iqs62x_keys->notifier);
|
||||
if (ret)
|
||||
dev_err(&pdev->dev, "Failed to unregister notifier: %d\n", ret);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver iqs62x_keys_platform_driver = {
|
||||
@ -328,7 +326,7 @@ static struct platform_driver iqs62x_keys_platform_driver = {
|
||||
.name = "iqs62x-keys",
|
||||
},
|
||||
.probe = iqs62x_keys_probe,
|
||||
.remove = iqs62x_keys_remove,
|
||||
.remove_new = iqs62x_keys_remove,
|
||||
};
|
||||
module_platform_driver(iqs62x_keys_platform_driver);
|
||||
|
||||
|
@ -549,15 +549,13 @@ static int matrix_keypad_probe(struct platform_device *pdev)
|
||||
return err;
|
||||
}
|
||||
|
||||
static int matrix_keypad_remove(struct platform_device *pdev)
|
||||
static void matrix_keypad_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct matrix_keypad *keypad = platform_get_drvdata(pdev);
|
||||
|
||||
matrix_keypad_free_gpio(keypad);
|
||||
input_unregister_device(keypad->input_dev);
|
||||
kfree(keypad);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_OF
|
||||
@ -570,7 +568,7 @@ MODULE_DEVICE_TABLE(of, matrix_keypad_dt_match);
|
||||
|
||||
static struct platform_driver matrix_keypad_driver = {
|
||||
.probe = matrix_keypad_probe,
|
||||
.remove = matrix_keypad_remove,
|
||||
.remove_new = matrix_keypad_remove,
|
||||
.driver = {
|
||||
.name = "matrix-keypad",
|
||||
.pm = pm_sleep_ptr(&matrix_keypad_pm_ops),
|
||||
|
@ -287,7 +287,7 @@ static int omap_kp_probe(struct platform_device *pdev)
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
static int omap_kp_remove(struct platform_device *pdev)
|
||||
static void omap_kp_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct omap_kp *omap_kp = platform_get_drvdata(pdev);
|
||||
|
||||
@ -303,13 +303,11 @@ static int omap_kp_remove(struct platform_device *pdev)
|
||||
input_unregister_device(omap_kp->input);
|
||||
|
||||
kfree(omap_kp);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver omap_kp_driver = {
|
||||
.probe = omap_kp_probe,
|
||||
.remove = omap_kp_remove,
|
||||
.remove_new = omap_kp_remove,
|
||||
.driver = {
|
||||
.name = "omap-keypad",
|
||||
},
|
||||
|
@ -461,11 +461,9 @@ static int omap4_keypad_probe(struct platform_device *pdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int omap4_keypad_remove(struct platform_device *pdev)
|
||||
static void omap4_keypad_remove(struct platform_device *pdev)
|
||||
{
|
||||
dev_pm_clear_wake_irq(&pdev->dev);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static const struct of_device_id omap_keypad_dt_match[] = {
|
||||
@ -476,7 +474,7 @@ MODULE_DEVICE_TABLE(of, omap_keypad_dt_match);
|
||||
|
||||
static struct platform_driver omap4_keypad_driver = {
|
||||
.probe = omap4_keypad_probe,
|
||||
.remove = omap4_keypad_remove,
|
||||
.remove_new = omap4_keypad_remove,
|
||||
.driver = {
|
||||
.name = "omap4-keypad",
|
||||
.of_match_table = omap_keypad_dt_match,
|
||||
|
@ -444,7 +444,7 @@ static int samsung_keypad_probe(struct platform_device *pdev)
|
||||
return error;
|
||||
}
|
||||
|
||||
static int samsung_keypad_remove(struct platform_device *pdev)
|
||||
static void samsung_keypad_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct samsung_keypad *keypad = platform_get_drvdata(pdev);
|
||||
|
||||
@ -453,8 +453,6 @@ static int samsung_keypad_remove(struct platform_device *pdev)
|
||||
input_unregister_device(keypad->input_dev);
|
||||
|
||||
clk_unprepare(keypad->clk);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int samsung_keypad_runtime_suspend(struct device *dev)
|
||||
@ -589,7 +587,7 @@ MODULE_DEVICE_TABLE(platform, samsung_keypad_driver_ids);
|
||||
|
||||
static struct platform_driver samsung_keypad_driver = {
|
||||
.probe = samsung_keypad_probe,
|
||||
.remove = samsung_keypad_remove,
|
||||
.remove_new = samsung_keypad_remove,
|
||||
.driver = {
|
||||
.name = "samsung-keypad",
|
||||
.of_match_table = of_match_ptr(samsung_keypad_dt_match),
|
||||
|
@ -265,7 +265,7 @@ static int sh_keysc_probe(struct platform_device *pdev)
|
||||
return error;
|
||||
}
|
||||
|
||||
static int sh_keysc_remove(struct platform_device *pdev)
|
||||
static void sh_keysc_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct sh_keysc_priv *priv = platform_get_drvdata(pdev);
|
||||
|
||||
@ -279,8 +279,6 @@ static int sh_keysc_remove(struct platform_device *pdev)
|
||||
pm_runtime_disable(&pdev->dev);
|
||||
|
||||
kfree(priv);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int sh_keysc_suspend(struct device *dev)
|
||||
@ -321,7 +319,7 @@ static DEFINE_SIMPLE_DEV_PM_OPS(sh_keysc_dev_pm_ops,
|
||||
|
||||
static struct platform_driver sh_keysc_device_driver = {
|
||||
.probe = sh_keysc_probe,
|
||||
.remove = sh_keysc_remove,
|
||||
.remove_new = sh_keysc_remove,
|
||||
.driver = {
|
||||
.name = "sh_keysc",
|
||||
.pm = pm_sleep_ptr(&sh_keysc_dev_pm_ops),
|
||||
|
@ -272,14 +272,12 @@ static int spear_kbd_probe(struct platform_device *pdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int spear_kbd_remove(struct platform_device *pdev)
|
||||
static void spear_kbd_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct spear_kbd *kbd = platform_get_drvdata(pdev);
|
||||
|
||||
input_unregister_device(kbd->input);
|
||||
clk_unprepare(kbd->clk);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int spear_kbd_suspend(struct device *dev)
|
||||
@ -375,7 +373,7 @@ MODULE_DEVICE_TABLE(of, spear_kbd_id_table);
|
||||
|
||||
static struct platform_driver spear_kbd_driver = {
|
||||
.probe = spear_kbd_probe,
|
||||
.remove = spear_kbd_remove,
|
||||
.remove_new = spear_kbd_remove,
|
||||
.driver = {
|
||||
.name = "keyboard",
|
||||
.pm = pm_sleep_ptr(&spear_kbd_pm_ops),
|
||||
|
@ -404,20 +404,18 @@ static int stmpe_keypad_probe(struct platform_device *pdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int stmpe_keypad_remove(struct platform_device *pdev)
|
||||
static void stmpe_keypad_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct stmpe_keypad *keypad = platform_get_drvdata(pdev);
|
||||
|
||||
stmpe_disable(keypad->stmpe, STMPE_BLOCK_KEYPAD);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver stmpe_keypad_driver = {
|
||||
.driver.name = "stmpe-keypad",
|
||||
.driver.owner = THIS_MODULE,
|
||||
.probe = stmpe_keypad_probe,
|
||||
.remove = stmpe_keypad_remove,
|
||||
.remove_new = stmpe_keypad_remove,
|
||||
};
|
||||
module_platform_driver(stmpe_keypad_driver);
|
||||
|
||||
|
@ -14,7 +14,7 @@
|
||||
#include <linux/io.h>
|
||||
#include <linux/interrupt.h>
|
||||
#include <linux/of.h>
|
||||
#include <linux/of_device.h>
|
||||
#include <linux/property.h>
|
||||
#include <linux/clk.h>
|
||||
#include <linux/slab.h>
|
||||
#include <linux/input/matrix_keypad.h>
|
||||
@ -602,9 +602,6 @@ static int tegra_kbc_probe(struct platform_device *pdev)
|
||||
unsigned int debounce_cnt;
|
||||
unsigned int scan_time_rows;
|
||||
unsigned int keymap_rows;
|
||||
const struct of_device_id *match;
|
||||
|
||||
match = of_match_device(tegra_kbc_of_match, &pdev->dev);
|
||||
|
||||
kbc = devm_kzalloc(&pdev->dev, sizeof(*kbc), GFP_KERNEL);
|
||||
if (!kbc) {
|
||||
@ -613,7 +610,7 @@ static int tegra_kbc_probe(struct platform_device *pdev)
|
||||
}
|
||||
|
||||
kbc->dev = &pdev->dev;
|
||||
kbc->hw_support = match->data;
|
||||
kbc->hw_support = device_get_match_data(&pdev->dev);
|
||||
kbc->max_keys = kbc->hw_support->max_rows *
|
||||
kbc->hw_support->max_columns;
|
||||
kbc->num_rows_and_columns = kbc->hw_support->max_rows +
|
||||
|
@ -138,14 +138,13 @@ static int pm80x_onkey_probe(struct platform_device *pdev)
|
||||
return err;
|
||||
}
|
||||
|
||||
static int pm80x_onkey_remove(struct platform_device *pdev)
|
||||
static void pm80x_onkey_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct pm80x_onkey_info *info = platform_get_drvdata(pdev);
|
||||
|
||||
pm80x_free_irq(info->pm80x, info->irq, info);
|
||||
input_unregister_device(info->idev);
|
||||
kfree(info);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver pm80x_onkey_driver = {
|
||||
@ -154,7 +153,7 @@ static struct platform_driver pm80x_onkey_driver = {
|
||||
.pm = &pm80x_onkey_pm_ops,
|
||||
},
|
||||
.probe = pm80x_onkey_probe,
|
||||
.remove = pm80x_onkey_remove,
|
||||
.remove_new = pm80x_onkey_remove,
|
||||
};
|
||||
|
||||
module_platform_driver(pm80x_onkey_driver);
|
||||
|
@ -133,20 +133,11 @@ static ssize_t axp20x_store_attr(struct device *dev,
|
||||
size_t count)
|
||||
{
|
||||
struct axp20x_pek *axp20x_pek = dev_get_drvdata(dev);
|
||||
char val_str[20];
|
||||
size_t len;
|
||||
int ret, i;
|
||||
unsigned int val, idx = 0;
|
||||
unsigned int best_err = UINT_MAX;
|
||||
|
||||
val_str[sizeof(val_str) - 1] = '\0';
|
||||
strncpy(val_str, buf, sizeof(val_str) - 1);
|
||||
len = strlen(val_str);
|
||||
|
||||
if (len && val_str[len - 1] == '\n')
|
||||
val_str[len - 1] = '\0';
|
||||
|
||||
ret = kstrtouint(val_str, 10, &val);
|
||||
ret = kstrtouint(buf, 10, &val);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
|
@ -127,7 +127,7 @@ static int da9052_onkey_probe(struct platform_device *pdev)
|
||||
return error;
|
||||
}
|
||||
|
||||
static int da9052_onkey_remove(struct platform_device *pdev)
|
||||
static void da9052_onkey_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct da9052_onkey *onkey = platform_get_drvdata(pdev);
|
||||
|
||||
@ -136,13 +136,11 @@ static int da9052_onkey_remove(struct platform_device *pdev)
|
||||
|
||||
input_unregister_device(onkey->input);
|
||||
kfree(onkey);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver da9052_onkey_driver = {
|
||||
.probe = da9052_onkey_probe,
|
||||
.remove = da9052_onkey_remove,
|
||||
.remove_new = da9052_onkey_remove,
|
||||
.driver = {
|
||||
.name = "da9052-onkey",
|
||||
},
|
||||
|
@ -132,7 +132,7 @@ static int da9055_onkey_probe(struct platform_device *pdev)
|
||||
return err;
|
||||
}
|
||||
|
||||
static int da9055_onkey_remove(struct platform_device *pdev)
|
||||
static void da9055_onkey_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct da9055_onkey *onkey = platform_get_drvdata(pdev);
|
||||
int irq = platform_get_irq_byname(pdev, "ONKEY");
|
||||
@ -141,13 +141,11 @@ static int da9055_onkey_remove(struct platform_device *pdev)
|
||||
free_irq(irq, onkey);
|
||||
cancel_delayed_work_sync(&onkey->work);
|
||||
input_unregister_device(onkey->input);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver da9055_onkey_driver = {
|
||||
.probe = da9055_onkey_probe,
|
||||
.remove = da9055_onkey_remove,
|
||||
.remove_new = da9055_onkey_remove,
|
||||
.driver = {
|
||||
.name = "da9055-onkey",
|
||||
},
|
||||
|
@ -256,20 +256,18 @@ static int __init ideapad_probe(struct platform_device* pdev)
|
||||
return err;
|
||||
}
|
||||
|
||||
static int ideapad_remove(struct platform_device *pdev)
|
||||
static void ideapad_remove(struct platform_device *pdev)
|
||||
{
|
||||
i8042_remove_filter(slidebar_i8042_filter);
|
||||
input_unregister_device(slidebar_input_dev);
|
||||
release_region(IDEAPAD_BASE, 3);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver slidebar_drv = {
|
||||
.driver = {
|
||||
.name = "ideapad_slidebar",
|
||||
},
|
||||
.remove = ideapad_remove,
|
||||
.remove_new = ideapad_remove,
|
||||
};
|
||||
|
||||
static int __init ideapad_dmi_check(const struct dmi_system_id *id)
|
||||
|
@ -1586,10 +1586,7 @@ static struct attribute *iqs269_attrs[] = {
|
||||
&dev_attr_ati_trigger.attr,
|
||||
NULL,
|
||||
};
|
||||
|
||||
static const struct attribute_group iqs269_attr_group = {
|
||||
.attrs = iqs269_attrs,
|
||||
};
|
||||
ATTRIBUTE_GROUPS(iqs269);
|
||||
|
||||
static const struct regmap_config iqs269_regmap_config = {
|
||||
.reg_bits = 8,
|
||||
@ -1671,10 +1668,6 @@ static int iqs269_probe(struct i2c_client *client)
|
||||
return error;
|
||||
}
|
||||
|
||||
error = devm_device_add_group(&client->dev, &iqs269_attr_group);
|
||||
if (error)
|
||||
dev_err(&client->dev, "Failed to add attributes: %d\n", error);
|
||||
|
||||
return error;
|
||||
}
|
||||
|
||||
@ -1743,6 +1736,7 @@ MODULE_DEVICE_TABLE(of, iqs269_of_match);
|
||||
static struct i2c_driver iqs269_i2c_driver = {
|
||||
.driver = {
|
||||
.name = "iqs269a",
|
||||
.dev_groups = iqs269_groups,
|
||||
.of_match_table = iqs269_of_match,
|
||||
.pm = pm_sleep_ptr(&iqs269_pm),
|
||||
},
|
||||
|
@ -334,14 +334,25 @@ static ssize_t kxtj9_set_poll(struct device *dev, struct device_attribute *attr,
|
||||
|
||||
static DEVICE_ATTR(poll, S_IRUGO|S_IWUSR, kxtj9_get_poll, kxtj9_set_poll);
|
||||
|
||||
static struct attribute *kxtj9_attributes[] = {
|
||||
static struct attribute *kxtj9_attrs[] = {
|
||||
&dev_attr_poll.attr,
|
||||
NULL
|
||||
};
|
||||
|
||||
static struct attribute_group kxtj9_attribute_group = {
|
||||
.attrs = kxtj9_attributes
|
||||
static umode_t kxtj9_attr_is_visible(struct kobject *kobj,
|
||||
struct attribute *attr, int n)
|
||||
{
|
||||
struct device *dev = kobj_to_dev(kobj);
|
||||
struct i2c_client *client = to_i2c_client(dev);
|
||||
|
||||
return client->irq ? attr->mode : 0;
|
||||
}
|
||||
|
||||
static struct attribute_group kxtj9_group = {
|
||||
.attrs = kxtj9_attrs,
|
||||
.is_visible = kxtj9_attr_is_visible,
|
||||
};
|
||||
__ATTRIBUTE_GROUPS(kxtj9);
|
||||
|
||||
static void kxtj9_poll(struct input_dev *input)
|
||||
{
|
||||
@ -482,13 +493,6 @@ static int kxtj9_probe(struct i2c_client *client)
|
||||
dev_err(&client->dev, "request irq failed: %d\n", err);
|
||||
return err;
|
||||
}
|
||||
|
||||
err = devm_device_add_group(&client->dev,
|
||||
&kxtj9_attribute_group);
|
||||
if (err) {
|
||||
dev_err(&client->dev, "sysfs create failed: %d\n", err);
|
||||
return err;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
@ -535,8 +539,9 @@ MODULE_DEVICE_TABLE(i2c, kxtj9_id);
|
||||
|
||||
static struct i2c_driver kxtj9_driver = {
|
||||
.driver = {
|
||||
.name = NAME,
|
||||
.pm = pm_sleep_ptr(&kxtj9_pm_ops),
|
||||
.name = NAME,
|
||||
.dev_groups = kxtj9_groups,
|
||||
.pm = pm_sleep_ptr(&kxtj9_pm_ops),
|
||||
},
|
||||
.probe = kxtj9_probe,
|
||||
.id_table = kxtj9_id,
|
||||
|
@ -75,15 +75,13 @@ static int m68kspkr_probe(struct platform_device *dev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int m68kspkr_remove(struct platform_device *dev)
|
||||
static void m68kspkr_remove(struct platform_device *dev)
|
||||
{
|
||||
struct input_dev *input_dev = platform_get_drvdata(dev);
|
||||
|
||||
input_unregister_device(input_dev);
|
||||
/* turn off the speaker */
|
||||
m68kspkr_event(NULL, EV_SND, SND_BELL, 0);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void m68kspkr_shutdown(struct platform_device *dev)
|
||||
@ -97,7 +95,7 @@ static struct platform_driver m68kspkr_platform_driver = {
|
||||
.name = "m68kspkr",
|
||||
},
|
||||
.probe = m68kspkr_probe,
|
||||
.remove = m68kspkr_remove,
|
||||
.remove_new = m68kspkr_remove,
|
||||
.shutdown = m68kspkr_shutdown,
|
||||
};
|
||||
|
||||
|
@ -351,7 +351,7 @@ static int max8997_haptic_probe(struct platform_device *pdev)
|
||||
return error;
|
||||
}
|
||||
|
||||
static int max8997_haptic_remove(struct platform_device *pdev)
|
||||
static void max8997_haptic_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct max8997_haptic *chip = platform_get_drvdata(pdev);
|
||||
|
||||
@ -362,8 +362,6 @@ static int max8997_haptic_remove(struct platform_device *pdev)
|
||||
pwm_put(chip->pwm);
|
||||
|
||||
kfree(chip);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int max8997_haptic_suspend(struct device *dev)
|
||||
@ -391,7 +389,7 @@ static struct platform_driver max8997_haptic_driver = {
|
||||
.pm = pm_sleep_ptr(&max8997_haptic_pm_ops),
|
||||
},
|
||||
.probe = max8997_haptic_probe,
|
||||
.remove = max8997_haptic_remove,
|
||||
.remove_new = max8997_haptic_remove,
|
||||
.id_table = max8997_haptic_id,
|
||||
};
|
||||
module_platform_driver(max8997_haptic_driver);
|
||||
|
@ -229,7 +229,7 @@ static int mc13783_pwrbutton_probe(struct platform_device *pdev)
|
||||
return err;
|
||||
}
|
||||
|
||||
static int mc13783_pwrbutton_remove(struct platform_device *pdev)
|
||||
static void mc13783_pwrbutton_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct mc13783_pwrb *priv = platform_get_drvdata(pdev);
|
||||
const struct mc13xxx_buttons_platform_data *pdata;
|
||||
@ -249,13 +249,11 @@ static int mc13783_pwrbutton_remove(struct platform_device *pdev)
|
||||
|
||||
input_unregister_device(priv->pwr);
|
||||
kfree(priv);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver mc13783_pwrbutton_driver = {
|
||||
.probe = mc13783_pwrbutton_probe,
|
||||
.remove = mc13783_pwrbutton_remove,
|
||||
.remove_new = mc13783_pwrbutton_remove,
|
||||
.driver = {
|
||||
.name = "mc13783-pwrbutton",
|
||||
},
|
||||
|
@ -245,7 +245,7 @@ static int palmas_pwron_probe(struct platform_device *pdev)
|
||||
*
|
||||
* Return: 0
|
||||
*/
|
||||
static int palmas_pwron_remove(struct platform_device *pdev)
|
||||
static void palmas_pwron_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct palmas_pwron *pwron = platform_get_drvdata(pdev);
|
||||
|
||||
@ -254,8 +254,6 @@ static int palmas_pwron_remove(struct platform_device *pdev)
|
||||
|
||||
input_unregister_device(pwron->input_dev);
|
||||
kfree(pwron);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -312,7 +310,7 @@ MODULE_DEVICE_TABLE(of, of_palmas_pwr_match);
|
||||
|
||||
static struct platform_driver palmas_pwron_driver = {
|
||||
.probe = palmas_pwron_probe,
|
||||
.remove = palmas_pwron_remove,
|
||||
.remove_new = palmas_pwron_remove,
|
||||
.driver = {
|
||||
.name = "palmas_pwrbutton",
|
||||
.of_match_table = of_match_ptr(of_palmas_pwr_match),
|
||||
|
@ -99,7 +99,7 @@ static int pcap_keys_probe(struct platform_device *pdev)
|
||||
return err;
|
||||
}
|
||||
|
||||
static int pcap_keys_remove(struct platform_device *pdev)
|
||||
static void pcap_keys_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct pcap_keys *pcap_keys = platform_get_drvdata(pdev);
|
||||
|
||||
@ -108,13 +108,11 @@ static int pcap_keys_remove(struct platform_device *pdev)
|
||||
|
||||
input_unregister_device(pcap_keys->input);
|
||||
kfree(pcap_keys);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver pcap_keys_device_driver = {
|
||||
.probe = pcap_keys_probe,
|
||||
.remove = pcap_keys_remove,
|
||||
.remove_new = pcap_keys_remove,
|
||||
.driver = {
|
||||
.name = "pcap-keys",
|
||||
}
|
||||
|
@ -87,7 +87,7 @@ static int pcf50633_input_probe(struct platform_device *pdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int pcf50633_input_remove(struct platform_device *pdev)
|
||||
static void pcf50633_input_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct pcf50633_input *input = platform_get_drvdata(pdev);
|
||||
|
||||
@ -96,8 +96,6 @@ static int pcf50633_input_remove(struct platform_device *pdev)
|
||||
|
||||
input_unregister_device(input->input_dev);
|
||||
kfree(input);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver pcf50633_input_driver = {
|
||||
@ -105,7 +103,7 @@ static struct platform_driver pcf50633_input_driver = {
|
||||
.name = "pcf50633-input",
|
||||
},
|
||||
.probe = pcf50633_input_probe,
|
||||
.remove = pcf50633_input_remove,
|
||||
.remove_new = pcf50633_input_remove,
|
||||
};
|
||||
module_platform_driver(pcf50633_input_driver);
|
||||
|
||||
|
@ -95,15 +95,13 @@ static int pcspkr_probe(struct platform_device *dev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int pcspkr_remove(struct platform_device *dev)
|
||||
static void pcspkr_remove(struct platform_device *dev)
|
||||
{
|
||||
struct input_dev *pcspkr_dev = platform_get_drvdata(dev);
|
||||
|
||||
input_unregister_device(pcspkr_dev);
|
||||
/* turn off the speaker */
|
||||
pcspkr_event(NULL, EV_SND, SND_BELL, 0);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int pcspkr_suspend(struct device *dev)
|
||||
@ -129,7 +127,7 @@ static struct platform_driver pcspkr_platform_driver = {
|
||||
.pm = &pcspkr_pm_ops,
|
||||
},
|
||||
.probe = pcspkr_probe,
|
||||
.remove = pcspkr_remove,
|
||||
.remove_new = pcspkr_remove,
|
||||
.shutdown = pcspkr_shutdown,
|
||||
};
|
||||
module_platform_driver(pcspkr_platform_driver);
|
||||
|
@ -408,14 +408,12 @@ static int pm8941_pwrkey_probe(struct platform_device *pdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int pm8941_pwrkey_remove(struct platform_device *pdev)
|
||||
static void pm8941_pwrkey_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct pm8941_pwrkey *pwrkey = platform_get_drvdata(pdev);
|
||||
|
||||
if (pwrkey->data->supports_ps_hold_poff_config)
|
||||
unregister_reboot_notifier(&pwrkey->reboot_notifier);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static const struct pm8941_data pwrkey_data = {
|
||||
@ -467,7 +465,7 @@ MODULE_DEVICE_TABLE(of, pm8941_pwr_key_id_table);
|
||||
|
||||
static struct platform_driver pm8941_pwrkey_driver = {
|
||||
.probe = pm8941_pwrkey_probe,
|
||||
.remove = pm8941_pwrkey_remove,
|
||||
.remove_new = pm8941_pwrkey_remove,
|
||||
.driver = {
|
||||
.name = "pm8941-pwrkey",
|
||||
.pm = pm_sleep_ptr(&pm8941_pwr_key_pm_ops),
|
||||
|
@ -411,7 +411,7 @@ static struct soc_button_info *soc_button_get_button_info(struct device *dev)
|
||||
return button_info;
|
||||
}
|
||||
|
||||
static int soc_button_remove(struct platform_device *pdev)
|
||||
static void soc_button_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct soc_button_data *priv = platform_get_drvdata(pdev);
|
||||
|
||||
@ -420,8 +420,6 @@ static int soc_button_remove(struct platform_device *pdev)
|
||||
for (i = 0; i < BUTTON_TYPES; i++)
|
||||
if (priv->children[i])
|
||||
platform_device_unregister(priv->children[i]);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int soc_button_probe(struct platform_device *pdev)
|
||||
@ -609,7 +607,7 @@ MODULE_DEVICE_TABLE(acpi, soc_button_acpi_match);
|
||||
|
||||
static struct platform_driver soc_button_driver = {
|
||||
.probe = soc_button_probe,
|
||||
.remove = soc_button_remove,
|
||||
.remove_new = soc_button_remove,
|
||||
.driver = {
|
||||
.name = KBUILD_MODNAME,
|
||||
.acpi_match_table = ACPI_PTR(soc_button_acpi_match),
|
||||
|
@ -231,7 +231,7 @@ static int bbc_beep_probe(struct platform_device *op)
|
||||
return err;
|
||||
}
|
||||
|
||||
static int bbc_remove(struct platform_device *op)
|
||||
static void bbc_remove(struct platform_device *op)
|
||||
{
|
||||
struct sparcspkr_state *state = platform_get_drvdata(op);
|
||||
struct input_dev *input_dev = state->input_dev;
|
||||
@ -245,8 +245,6 @@ static int bbc_remove(struct platform_device *op)
|
||||
of_iounmap(&op->resource[0], info->regs, 6);
|
||||
|
||||
kfree(state);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static const struct of_device_id bbc_beep_match[] = {
|
||||
@ -264,7 +262,7 @@ static struct platform_driver bbc_beep_driver = {
|
||||
.of_match_table = bbc_beep_match,
|
||||
},
|
||||
.probe = bbc_beep_probe,
|
||||
.remove = bbc_remove,
|
||||
.remove_new = bbc_remove,
|
||||
.shutdown = sparcspkr_shutdown,
|
||||
};
|
||||
|
||||
@ -310,7 +308,7 @@ static int grover_beep_probe(struct platform_device *op)
|
||||
return err;
|
||||
}
|
||||
|
||||
static int grover_remove(struct platform_device *op)
|
||||
static void grover_remove(struct platform_device *op)
|
||||
{
|
||||
struct sparcspkr_state *state = platform_get_drvdata(op);
|
||||
struct grover_beep_info *info = &state->u.grover;
|
||||
@ -325,8 +323,6 @@ static int grover_remove(struct platform_device *op)
|
||||
of_iounmap(&op->resource[2], info->freq_regs, 2);
|
||||
|
||||
kfree(state);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static const struct of_device_id grover_beep_match[] = {
|
||||
@ -344,7 +340,7 @@ static struct platform_driver grover_beep_driver = {
|
||||
.of_match_table = grover_beep_match,
|
||||
},
|
||||
.probe = grover_beep_probe,
|
||||
.remove = grover_remove,
|
||||
.remove_new = grover_remove,
|
||||
.shutdown = sparcspkr_shutdown,
|
||||
};
|
||||
|
||||
|
@ -1286,13 +1286,11 @@ static int wistron_probe(struct platform_device *dev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int wistron_remove(struct platform_device *dev)
|
||||
static void wistron_remove(struct platform_device *dev)
|
||||
{
|
||||
wistron_led_remove();
|
||||
input_unregister_device(wistron_idev);
|
||||
bios_detach();
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int wistron_suspend(struct device *dev)
|
||||
@ -1336,7 +1334,7 @@ static struct platform_driver wistron_driver = {
|
||||
.pm = pm_sleep_ptr(&wistron_pm_ops),
|
||||
},
|
||||
.probe = wistron_probe,
|
||||
.remove = wistron_remove,
|
||||
.remove_new = wistron_remove,
|
||||
};
|
||||
|
||||
static int __init wb_module_init(void)
|
||||
|
@ -123,20 +123,18 @@ static int wm831x_on_probe(struct platform_device *pdev)
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int wm831x_on_remove(struct platform_device *pdev)
|
||||
static void wm831x_on_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct wm831x_on *wm831x_on = platform_get_drvdata(pdev);
|
||||
int irq = platform_get_irq(pdev, 0);
|
||||
|
||||
free_irq(irq, wm831x_on);
|
||||
cancel_delayed_work_sync(&wm831x_on->work);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver wm831x_on_driver = {
|
||||
.probe = wm831x_on_probe,
|
||||
.remove = wm831x_on_remove,
|
||||
.remove_new = wm831x_on_remove,
|
||||
.driver = {
|
||||
.name = "wm831x-on",
|
||||
},
|
||||
|
@ -1223,7 +1223,7 @@ static DEVICE_ATTR(baseline, S_IRUGO, cyapa_show_baseline, NULL);
|
||||
static DEVICE_ATTR(calibrate, S_IWUSR, NULL, cyapa_calibrate_store);
|
||||
static DEVICE_ATTR(mode, S_IRUGO, cyapa_show_mode, NULL);
|
||||
|
||||
static struct attribute *cyapa_sysfs_entries[] = {
|
||||
static struct attribute *cyapa_attrs[] = {
|
||||
&dev_attr_firmware_version.attr,
|
||||
&dev_attr_product_id.attr,
|
||||
&dev_attr_update_fw.attr,
|
||||
@ -1232,10 +1232,7 @@ static struct attribute *cyapa_sysfs_entries[] = {
|
||||
&dev_attr_mode.attr,
|
||||
NULL,
|
||||
};
|
||||
|
||||
static const struct attribute_group cyapa_sysfs_group = {
|
||||
.attrs = cyapa_sysfs_entries,
|
||||
};
|
||||
ATTRIBUTE_GROUPS(cyapa);
|
||||
|
||||
static void cyapa_disable_regulator(void *data)
|
||||
{
|
||||
@ -1302,12 +1299,6 @@ static int cyapa_probe(struct i2c_client *client)
|
||||
return error;
|
||||
}
|
||||
|
||||
error = devm_device_add_group(dev, &cyapa_sysfs_group);
|
||||
if (error) {
|
||||
dev_err(dev, "failed to create sysfs entries: %d\n", error);
|
||||
return error;
|
||||
}
|
||||
|
||||
error = cyapa_prepare_wakeup_controls(cyapa);
|
||||
if (error) {
|
||||
dev_err(dev, "failed to prepare wakeup controls: %d\n", error);
|
||||
@ -1484,6 +1475,7 @@ MODULE_DEVICE_TABLE(of, cyapa_of_match);
|
||||
static struct i2c_driver cyapa_driver = {
|
||||
.driver = {
|
||||
.name = "cyapa",
|
||||
.dev_groups = cyapa_groups,
|
||||
.pm = pm_ptr(&cyapa_pm_ops),
|
||||
.acpi_match_table = ACPI_PTR(cyapa_acpi_id),
|
||||
.of_match_table = of_match_ptr(cyapa_of_match),
|
||||
|
@ -295,7 +295,7 @@ static int navpoint_probe(struct platform_device *pdev)
|
||||
return error;
|
||||
}
|
||||
|
||||
static int navpoint_remove(struct platform_device *pdev)
|
||||
static void navpoint_remove(struct platform_device *pdev)
|
||||
{
|
||||
const struct navpoint_platform_data *pdata =
|
||||
dev_get_platdata(&pdev->dev);
|
||||
@ -311,8 +311,6 @@ static int navpoint_remove(struct platform_device *pdev)
|
||||
|
||||
if (gpio_is_valid(pdata->gpio))
|
||||
gpio_free(pdata->gpio);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int navpoint_suspend(struct device *dev)
|
||||
@ -348,7 +346,7 @@ static DEFINE_SIMPLE_DEV_PM_OPS(navpoint_pm_ops,
|
||||
|
||||
static struct platform_driver navpoint_driver = {
|
||||
.probe = navpoint_probe,
|
||||
.remove = navpoint_remove,
|
||||
.remove_new = navpoint_remove,
|
||||
.driver = {
|
||||
.name = "navpoint",
|
||||
.pm = pm_sleep_ptr(&navpoint_pm_ops),
|
||||
|
@ -277,11 +277,11 @@ void rmi_unregister_function(struct rmi_function *fn)
|
||||
|
||||
device_del(&fn->dev);
|
||||
of_node_put(fn->dev.of_node);
|
||||
put_device(&fn->dev);
|
||||
|
||||
for (i = 0; i < fn->num_of_irqs; i++)
|
||||
irq_dispose_mapping(fn->irq[i]);
|
||||
|
||||
put_device(&fn->dev);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -471,7 +471,7 @@ static ssize_t rmi_driver_update_fw_store(struct device *dev,
|
||||
if (buf[count - 1] == '\0' || buf[count - 1] == '\n')
|
||||
copy_count -= 1;
|
||||
|
||||
strncpy(fw_name, buf, copy_count);
|
||||
memcpy(fw_name, buf, copy_count);
|
||||
fw_name[copy_count] = '\0';
|
||||
|
||||
ret = request_firmware(&fw, fw_name, dev);
|
||||
|
@ -125,13 +125,11 @@ static int altera_ps2_probe(struct platform_device *pdev)
|
||||
/*
|
||||
* Remove one device from this driver.
|
||||
*/
|
||||
static int altera_ps2_remove(struct platform_device *pdev)
|
||||
static void altera_ps2_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct ps2if *ps2if = platform_get_drvdata(pdev);
|
||||
|
||||
serio_unregister_port(ps2if->io);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_OF
|
||||
@ -148,7 +146,7 @@ MODULE_DEVICE_TABLE(of, altera_ps2_match);
|
||||
*/
|
||||
static struct platform_driver altera_ps2_driver = {
|
||||
.probe = altera_ps2_probe,
|
||||
.remove = altera_ps2_remove,
|
||||
.remove_new = altera_ps2_remove,
|
||||
.driver = {
|
||||
.name = DRV_NAME,
|
||||
.of_match_table = of_match_ptr(altera_ps2_match),
|
||||
|
@ -173,18 +173,16 @@ static int ams_delta_serio_init(struct platform_device *pdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int ams_delta_serio_exit(struct platform_device *pdev)
|
||||
static void ams_delta_serio_exit(struct platform_device *pdev)
|
||||
{
|
||||
struct ams_delta_serio *priv = platform_get_drvdata(pdev);
|
||||
|
||||
serio_unregister_port(priv->serio);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver ams_delta_serio_driver = {
|
||||
.probe = ams_delta_serio_init,
|
||||
.remove = ams_delta_serio_exit,
|
||||
.remove_new = ams_delta_serio_exit,
|
||||
.driver = {
|
||||
.name = DRIVER_NAME
|
||||
},
|
||||
|
@ -187,13 +187,11 @@ static int apbps2_of_probe(struct platform_device *ofdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int apbps2_of_remove(struct platform_device *of_dev)
|
||||
static void apbps2_of_remove(struct platform_device *of_dev)
|
||||
{
|
||||
struct apbps2_priv *priv = platform_get_drvdata(of_dev);
|
||||
|
||||
serio_unregister_port(priv->io);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static const struct of_device_id apbps2_of_match[] = {
|
||||
@ -210,7 +208,7 @@ static struct platform_driver apbps2_of_driver = {
|
||||
.of_match_table = apbps2_of_match,
|
||||
},
|
||||
.probe = apbps2_of_probe,
|
||||
.remove = apbps2_of_remove,
|
||||
.remove_new = apbps2_of_remove,
|
||||
};
|
||||
|
||||
module_platform_driver(apbps2_of_driver);
|
||||
|
@ -232,7 +232,7 @@ static int arc_ps2_probe(struct platform_device *pdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int arc_ps2_remove(struct platform_device *pdev)
|
||||
static void arc_ps2_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct arc_ps2_data *arc_ps2 = platform_get_drvdata(pdev);
|
||||
int i;
|
||||
@ -244,8 +244,6 @@ static int arc_ps2_remove(struct platform_device *pdev)
|
||||
dev_dbg(&pdev->dev, "frame error count = %i\n", arc_ps2->frame_error);
|
||||
dev_dbg(&pdev->dev, "buffer overflow count = %i\n",
|
||||
arc_ps2->buf_overflow);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_OF
|
||||
@ -262,7 +260,7 @@ static struct platform_driver arc_ps2_driver = {
|
||||
.of_match_table = of_match_ptr(arc_ps2_match),
|
||||
},
|
||||
.probe = arc_ps2_probe,
|
||||
.remove = arc_ps2_remove,
|
||||
.remove_new = arc_ps2_remove,
|
||||
};
|
||||
|
||||
module_platform_driver(arc_ps2_driver);
|
||||
|
@ -180,11 +180,9 @@ static int ct82c710_probe(struct platform_device *dev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int ct82c710_remove(struct platform_device *dev)
|
||||
static void ct82c710_remove(struct platform_device *dev)
|
||||
{
|
||||
serio_unregister_port(ct82c710_port);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver ct82c710_driver = {
|
||||
@ -192,7 +190,7 @@ static struct platform_driver ct82c710_driver = {
|
||||
.name = "ct82c710",
|
||||
},
|
||||
.probe = ct82c710_probe,
|
||||
.remove = ct82c710_remove,
|
||||
.remove_new = ct82c710_remove,
|
||||
};
|
||||
|
||||
|
||||
|
@ -82,11 +82,9 @@ static int sparc_i8042_probe(struct platform_device *op)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int sparc_i8042_remove(struct platform_device *op)
|
||||
static void sparc_i8042_remove(struct platform_device *op)
|
||||
{
|
||||
of_iounmap(kbd_res, kbd_iobase, 8);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static const struct of_device_id sparc_i8042_match[] = {
|
||||
@ -103,7 +101,7 @@ static struct platform_driver sparc_i8042_driver = {
|
||||
.of_match_table = sparc_i8042_match,
|
||||
},
|
||||
.probe = sparc_i8042_probe,
|
||||
.remove = sparc_i8042_remove,
|
||||
.remove_new = sparc_i8042_remove,
|
||||
};
|
||||
|
||||
static bool i8042_is_mr_coffee(void)
|
||||
|
@ -1584,13 +1584,11 @@ static int i8042_probe(struct platform_device *dev)
|
||||
return error;
|
||||
}
|
||||
|
||||
static int i8042_remove(struct platform_device *dev)
|
||||
static void i8042_remove(struct platform_device *dev)
|
||||
{
|
||||
i8042_unregister_ports();
|
||||
i8042_free_irqs();
|
||||
i8042_controller_reset(false);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver i8042_driver = {
|
||||
@ -1601,7 +1599,7 @@ static struct platform_driver i8042_driver = {
|
||||
#endif
|
||||
},
|
||||
.probe = i8042_probe,
|
||||
.remove = i8042_remove,
|
||||
.remove_new = i8042_remove,
|
||||
.shutdown = i8042_shutdown,
|
||||
};
|
||||
|
||||
|
@ -190,7 +190,7 @@ static int ioc3kbd_probe(struct platform_device *pdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int ioc3kbd_remove(struct platform_device *pdev)
|
||||
static void ioc3kbd_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct ioc3kbd_data *d = platform_get_drvdata(pdev);
|
||||
|
||||
@ -198,13 +198,11 @@ static int ioc3kbd_remove(struct platform_device *pdev)
|
||||
|
||||
serio_unregister_port(d->kbd);
|
||||
serio_unregister_port(d->aux);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver ioc3kbd_driver = {
|
||||
.probe = ioc3kbd_probe,
|
||||
.remove = ioc3kbd_remove,
|
||||
.remove_new = ioc3kbd_remove,
|
||||
.driver = {
|
||||
.name = "ioc3-kbd",
|
||||
},
|
||||
|
@ -148,12 +148,10 @@ static int maceps2_probe(struct platform_device *dev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int maceps2_remove(struct platform_device *dev)
|
||||
static void maceps2_remove(struct platform_device *dev)
|
||||
{
|
||||
serio_unregister_port(maceps2_port[0]);
|
||||
serio_unregister_port(maceps2_port[1]);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver maceps2_driver = {
|
||||
@ -161,7 +159,7 @@ static struct platform_driver maceps2_driver = {
|
||||
.name = "maceps2",
|
||||
},
|
||||
.probe = maceps2_probe,
|
||||
.remove = maceps2_remove,
|
||||
.remove_new = maceps2_remove,
|
||||
};
|
||||
|
||||
static int __init maceps2_init(void)
|
||||
|
@ -238,7 +238,7 @@ static int olpc_apsp_probe(struct platform_device *pdev)
|
||||
return error;
|
||||
}
|
||||
|
||||
static int olpc_apsp_remove(struct platform_device *pdev)
|
||||
static void olpc_apsp_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct olpc_apsp *priv = platform_get_drvdata(pdev);
|
||||
|
||||
@ -246,8 +246,6 @@ static int olpc_apsp_remove(struct platform_device *pdev)
|
||||
|
||||
serio_unregister_port(priv->kbio);
|
||||
serio_unregister_port(priv->padio);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static const struct of_device_id olpc_apsp_dt_ids[] = {
|
||||
@ -258,7 +256,7 @@ MODULE_DEVICE_TABLE(of, olpc_apsp_dt_ids);
|
||||
|
||||
static struct platform_driver olpc_apsp_driver = {
|
||||
.probe = olpc_apsp_probe,
|
||||
.remove = olpc_apsp_remove,
|
||||
.remove_new = olpc_apsp_remove,
|
||||
.driver = {
|
||||
.name = "olpc-apsp",
|
||||
.of_match_table = olpc_apsp_dt_ids,
|
||||
|
@ -476,12 +476,11 @@ static int ps2_gpio_probe(struct platform_device *pdev)
|
||||
return error;
|
||||
}
|
||||
|
||||
static int ps2_gpio_remove(struct platform_device *pdev)
|
||||
static void ps2_gpio_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct ps2_gpio_data *drvdata = platform_get_drvdata(pdev);
|
||||
|
||||
serio_unregister_port(drvdata->serio);
|
||||
return 0;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_OF)
|
||||
@ -494,7 +493,7 @@ MODULE_DEVICE_TABLE(of, ps2_gpio_match);
|
||||
|
||||
static struct platform_driver ps2_gpio_driver = {
|
||||
.probe = ps2_gpio_probe,
|
||||
.remove = ps2_gpio_remove,
|
||||
.remove_new = ps2_gpio_remove,
|
||||
.driver = {
|
||||
.name = DRIVER_NAME,
|
||||
.of_match_table = of_match_ptr(ps2_gpio_match),
|
||||
|
@ -148,7 +148,7 @@ static int q40kbd_probe(struct platform_device *pdev)
|
||||
return error;
|
||||
}
|
||||
|
||||
static int q40kbd_remove(struct platform_device *pdev)
|
||||
static void q40kbd_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct q40kbd *q40kbd = platform_get_drvdata(pdev);
|
||||
|
||||
@ -160,15 +160,13 @@ static int q40kbd_remove(struct platform_device *pdev)
|
||||
serio_unregister_port(q40kbd->port);
|
||||
free_irq(Q40_IRQ_KEYBOARD, q40kbd);
|
||||
kfree(q40kbd);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver q40kbd_driver = {
|
||||
.driver = {
|
||||
.name = "q40kbd",
|
||||
},
|
||||
.remove = q40kbd_remove,
|
||||
.remove_new = q40kbd_remove,
|
||||
};
|
||||
|
||||
module_platform_driver_probe(q40kbd_driver, q40kbd_probe);
|
||||
|
@ -133,20 +133,18 @@ static int rpckbd_probe(struct platform_device *dev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int rpckbd_remove(struct platform_device *dev)
|
||||
static void rpckbd_remove(struct platform_device *dev)
|
||||
{
|
||||
struct serio *serio = platform_get_drvdata(dev);
|
||||
struct rpckbd_data *rpckbd = serio->port_data;
|
||||
|
||||
serio_unregister_port(serio);
|
||||
kfree(rpckbd);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver rpckbd_driver = {
|
||||
.probe = rpckbd_probe,
|
||||
.remove = rpckbd_remove,
|
||||
.remove_new = rpckbd_remove,
|
||||
.driver = {
|
||||
.name = "kart",
|
||||
},
|
||||
|
@ -297,7 +297,7 @@ static int sun4i_ps2_probe(struct platform_device *pdev)
|
||||
return error;
|
||||
}
|
||||
|
||||
static int sun4i_ps2_remove(struct platform_device *pdev)
|
||||
static void sun4i_ps2_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct sun4i_ps2data *drvdata = platform_get_drvdata(pdev);
|
||||
|
||||
@ -311,8 +311,6 @@ static int sun4i_ps2_remove(struct platform_device *pdev)
|
||||
iounmap(drvdata->reg_base);
|
||||
|
||||
kfree(drvdata);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static const struct of_device_id sun4i_ps2_match[] = {
|
||||
@ -324,7 +322,7 @@ MODULE_DEVICE_TABLE(of, sun4i_ps2_match);
|
||||
|
||||
static struct platform_driver sun4i_ps2_driver = {
|
||||
.probe = sun4i_ps2_probe,
|
||||
.remove = sun4i_ps2_remove,
|
||||
.remove_new = sun4i_ps2_remove,
|
||||
.driver = {
|
||||
.name = DRIVER_NAME,
|
||||
.of_match_table = sun4i_ps2_match,
|
||||
|
@ -329,7 +329,7 @@ static int xps2_of_probe(struct platform_device *ofdev)
|
||||
* if the driver module is being unloaded. It frees any resources allocated to
|
||||
* the device.
|
||||
*/
|
||||
static int xps2_of_remove(struct platform_device *of_dev)
|
||||
static void xps2_of_remove(struct platform_device *of_dev)
|
||||
{
|
||||
struct xps2data *drvdata = platform_get_drvdata(of_dev);
|
||||
struct resource r_mem; /* IO mem resources */
|
||||
@ -344,8 +344,6 @@ static int xps2_of_remove(struct platform_device *of_dev)
|
||||
release_mem_region(r_mem.start, resource_size(&r_mem));
|
||||
|
||||
kfree(drvdata);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Match table for of_platform binding */
|
||||
@ -361,7 +359,7 @@ static struct platform_driver xps2_of_driver = {
|
||||
.of_match_table = xps2_of_match,
|
||||
},
|
||||
.probe = xps2_of_probe,
|
||||
.remove = xps2_of_remove,
|
||||
.remove_new = xps2_of_remove,
|
||||
};
|
||||
module_platform_driver(xps2_of_driver);
|
||||
|
||||
|
@ -612,10 +612,11 @@ static umode_t ad7877_attr_is_visible(struct kobject *kobj,
|
||||
return mode;
|
||||
}
|
||||
|
||||
static const struct attribute_group ad7877_attr_group = {
|
||||
static const struct attribute_group ad7877_group = {
|
||||
.is_visible = ad7877_attr_is_visible,
|
||||
.attrs = ad7877_attributes,
|
||||
};
|
||||
__ATTRIBUTE_GROUPS(ad7877);
|
||||
|
||||
static void ad7877_setup_ts_def_msg(struct spi_device *spi, struct ad7877 *ts)
|
||||
{
|
||||
@ -777,10 +778,6 @@ static int ad7877_probe(struct spi_device *spi)
|
||||
return err;
|
||||
}
|
||||
|
||||
err = devm_device_add_group(&spi->dev, &ad7877_attr_group);
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
err = input_register_device(input_dev);
|
||||
if (err)
|
||||
return err;
|
||||
@ -810,8 +807,9 @@ static DEFINE_SIMPLE_DEV_PM_OPS(ad7877_pm, ad7877_suspend, ad7877_resume);
|
||||
|
||||
static struct spi_driver ad7877_driver = {
|
||||
.driver = {
|
||||
.name = "ad7877",
|
||||
.pm = pm_sleep_ptr(&ad7877_pm),
|
||||
.name = "ad7877",
|
||||
.dev_groups = ad7877_groups,
|
||||
.pm = pm_sleep_ptr(&ad7877_pm),
|
||||
},
|
||||
.probe = ad7877_probe,
|
||||
};
|
||||
|
@ -58,9 +58,10 @@ MODULE_DEVICE_TABLE(of, ad7879_i2c_dt_ids);
|
||||
|
||||
static struct i2c_driver ad7879_i2c_driver = {
|
||||
.driver = {
|
||||
.name = "ad7879",
|
||||
.pm = &ad7879_pm_ops,
|
||||
.of_match_table = of_match_ptr(ad7879_i2c_dt_ids),
|
||||
.name = "ad7879",
|
||||
.dev_groups = ad7879_groups,
|
||||
.pm = &ad7879_pm_ops,
|
||||
.of_match_table = of_match_ptr(ad7879_i2c_dt_ids),
|
||||
},
|
||||
.probe = ad7879_i2c_probe,
|
||||
.id_table = ad7879_id,
|
||||
|
@ -56,9 +56,10 @@ MODULE_DEVICE_TABLE(of, ad7879_spi_dt_ids);
|
||||
|
||||
static struct spi_driver ad7879_spi_driver = {
|
||||
.driver = {
|
||||
.name = "ad7879",
|
||||
.pm = &ad7879_pm_ops,
|
||||
.of_match_table = of_match_ptr(ad7879_spi_dt_ids),
|
||||
.name = "ad7879",
|
||||
.dev_groups = ad7879_groups,
|
||||
.pm = &ad7879_pm_ops,
|
||||
.of_match_table = of_match_ptr(ad7879_spi_dt_ids),
|
||||
},
|
||||
.probe = ad7879_spi_probe,
|
||||
};
|
||||
|
@ -391,6 +391,12 @@ static const struct attribute_group ad7879_attr_group = {
|
||||
.attrs = ad7879_attributes,
|
||||
};
|
||||
|
||||
const struct attribute_group *ad7879_groups[] = {
|
||||
&ad7879_attr_group,
|
||||
NULL
|
||||
};
|
||||
EXPORT_SYMBOL_GPL(ad7879_groups);
|
||||
|
||||
#ifdef CONFIG_GPIOLIB
|
||||
static int ad7879_gpio_direction_input(struct gpio_chip *chip,
|
||||
unsigned gpio)
|
||||
@ -612,10 +618,6 @@ int ad7879_probe(struct device *dev, struct regmap *regmap,
|
||||
|
||||
__ad7879_disable(ts);
|
||||
|
||||
err = devm_device_add_group(dev, &ad7879_attr_group);
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
err = ad7879_gpio_add(ts);
|
||||
if (err)
|
||||
return err;
|
||||
|
@ -8,11 +8,14 @@
|
||||
#ifndef _AD7879_H_
|
||||
#define _AD7879_H_
|
||||
|
||||
#include <linux/pm.h>
|
||||
#include <linux/types.h>
|
||||
|
||||
struct attribute_group;
|
||||
struct device;
|
||||
struct regmap;
|
||||
|
||||
extern const struct attribute_group *ad7879_groups[];
|
||||
extern const struct dev_pm_ops ad7879_pm_ops;
|
||||
|
||||
int ad7879_probe(struct device *dev, struct regmap *regmap,
|
||||
|
@ -625,15 +625,12 @@ static ssize_t ads7846_disable_store(struct device *dev,
|
||||
|
||||
static DEVICE_ATTR(disable, 0664, ads7846_disable_show, ads7846_disable_store);
|
||||
|
||||
static struct attribute *ads784x_attributes[] = {
|
||||
static struct attribute *ads784x_attrs[] = {
|
||||
&dev_attr_pen_down.attr,
|
||||
&dev_attr_disable.attr,
|
||||
NULL,
|
||||
};
|
||||
|
||||
static const struct attribute_group ads784x_attr_group = {
|
||||
.attrs = ads784x_attributes,
|
||||
};
|
||||
ATTRIBUTE_GROUPS(ads784x);
|
||||
|
||||
/*--------------------------------------------------------------------------*/
|
||||
|
||||
@ -1357,10 +1354,6 @@ static int ads7846_probe(struct spi_device *spi)
|
||||
else
|
||||
(void) ads7846_read12_ser(dev, READ_12BIT_SER(vaux));
|
||||
|
||||
err = devm_device_add_group(dev, &ads784x_attr_group);
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
err = input_register_device(input_dev);
|
||||
if (err)
|
||||
return err;
|
||||
@ -1386,9 +1379,10 @@ static void ads7846_remove(struct spi_device *spi)
|
||||
|
||||
static struct spi_driver ads7846_driver = {
|
||||
.driver = {
|
||||
.name = "ads7846",
|
||||
.pm = pm_sleep_ptr(&ads7846_pm),
|
||||
.of_match_table = ads7846_dt_ids,
|
||||
.name = "ads7846",
|
||||
.dev_groups = ads784x_groups,
|
||||
.pm = pm_sleep_ptr(&ads7846_pm),
|
||||
.of_match_table = ads7846_dt_ids,
|
||||
},
|
||||
.probe = ads7846_probe,
|
||||
.remove = ads7846_remove,
|
||||
|
@ -207,7 +207,7 @@ struct cyttsp5 {
|
||||
int num_prv_rec;
|
||||
struct regmap *regmap;
|
||||
struct touchscreen_properties prop;
|
||||
struct regulator *vdd;
|
||||
struct regulator_bulk_data supplies[2];
|
||||
};
|
||||
|
||||
/*
|
||||
@ -817,7 +817,7 @@ static void cyttsp5_cleanup(void *data)
|
||||
{
|
||||
struct cyttsp5 *ts = data;
|
||||
|
||||
regulator_disable(ts->vdd);
|
||||
regulator_bulk_disable(ARRAY_SIZE(ts->supplies), ts->supplies);
|
||||
}
|
||||
|
||||
static int cyttsp5_probe(struct device *dev, struct regmap *regmap, int irq,
|
||||
@ -840,9 +840,12 @@ static int cyttsp5_probe(struct device *dev, struct regmap *regmap, int irq,
|
||||
init_completion(&ts->cmd_done);
|
||||
|
||||
/* Power up the device */
|
||||
ts->vdd = devm_regulator_get(dev, "vdd");
|
||||
if (IS_ERR(ts->vdd)) {
|
||||
error = PTR_ERR(ts->vdd);
|
||||
ts->supplies[0].supply = "vdd";
|
||||
ts->supplies[1].supply = "vddio";
|
||||
error = devm_regulator_bulk_get(dev, ARRAY_SIZE(ts->supplies),
|
||||
ts->supplies);
|
||||
if (error) {
|
||||
dev_err(ts->dev, "Failed to get regulators, error %d\n", error);
|
||||
return error;
|
||||
}
|
||||
|
||||
@ -850,9 +853,11 @@ static int cyttsp5_probe(struct device *dev, struct regmap *regmap, int irq,
|
||||
if (error)
|
||||
return error;
|
||||
|
||||
error = regulator_enable(ts->vdd);
|
||||
if (error)
|
||||
error = regulator_bulk_enable(ARRAY_SIZE(ts->supplies), ts->supplies);
|
||||
if (error) {
|
||||
dev_err(ts->dev, "Failed to enable regulators, error %d\n", error);
|
||||
return error;
|
||||
}
|
||||
|
||||
ts->input = devm_input_allocate_device(dev);
|
||||
if (!ts->input) {
|
||||
|
@ -311,7 +311,7 @@ static int da9052_ts_probe(struct platform_device *pdev)
|
||||
return error;
|
||||
}
|
||||
|
||||
static int da9052_ts_remove(struct platform_device *pdev)
|
||||
static void da9052_ts_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct da9052_tsi *tsi = platform_get_drvdata(pdev);
|
||||
|
||||
@ -322,13 +322,11 @@ static int da9052_ts_remove(struct platform_device *pdev)
|
||||
|
||||
input_unregister_device(tsi->dev);
|
||||
kfree(tsi);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver da9052_tsi_driver = {
|
||||
.probe = da9052_ts_probe,
|
||||
.remove = da9052_ts_remove,
|
||||
.remove_new = da9052_ts_remove,
|
||||
.driver = {
|
||||
.name = "da9052-tsi",
|
||||
},
|
||||
|
@ -580,10 +580,7 @@ static struct attribute *edt_ft5x06_attrs[] = {
|
||||
&dev_attr_crc_errors.attr,
|
||||
NULL
|
||||
};
|
||||
|
||||
static const struct attribute_group edt_ft5x06_attr_group = {
|
||||
.attrs = edt_ft5x06_attrs,
|
||||
};
|
||||
ATTRIBUTE_GROUPS(edt_ft5x06);
|
||||
|
||||
static void edt_ft5x06_restore_reg_parameters(struct edt_ft5x06_ts_data *tsdata)
|
||||
{
|
||||
@ -1330,10 +1327,6 @@ static int edt_ft5x06_ts_probe(struct i2c_client *client)
|
||||
return error;
|
||||
}
|
||||
|
||||
error = devm_device_add_group(&client->dev, &edt_ft5x06_attr_group);
|
||||
if (error)
|
||||
return error;
|
||||
|
||||
error = input_register_device(input);
|
||||
if (error)
|
||||
return error;
|
||||
@ -1502,6 +1495,7 @@ MODULE_DEVICE_TABLE(of, edt_ft5x06_of_match);
|
||||
static struct i2c_driver edt_ft5x06_ts_driver = {
|
||||
.driver = {
|
||||
.name = "edt_ft5x06",
|
||||
.dev_groups = edt_ft5x06_groups,
|
||||
.of_match_table = edt_ft5x06_of_match,
|
||||
.pm = pm_sleep_ptr(&edt_ft5x06_ts_pm_ops),
|
||||
.probe_type = PROBE_PREFER_ASYNCHRONOUS,
|
||||
|
@ -1299,7 +1299,7 @@ static ELANTS_VERSION_ATTR(solution_version);
|
||||
static ELANTS_VERSION_ATTR(bc_version);
|
||||
static ELANTS_VERSION_ATTR(iap_version);
|
||||
|
||||
static struct attribute *elants_attributes[] = {
|
||||
static struct attribute *elants_i2c_attrs[] = {
|
||||
&dev_attr_calibrate.attr,
|
||||
&dev_attr_update_fw.attr,
|
||||
&dev_attr_iap_mode.attr,
|
||||
@ -1313,10 +1313,7 @@ static struct attribute *elants_attributes[] = {
|
||||
&elants_ver_attr_iap_version.dattr.attr,
|
||||
NULL
|
||||
};
|
||||
|
||||
static const struct attribute_group elants_attribute_group = {
|
||||
.attrs = elants_attributes,
|
||||
};
|
||||
ATTRIBUTE_GROUPS(elants_i2c);
|
||||
|
||||
static int elants_i2c_power_on(struct elants_data *ts)
|
||||
{
|
||||
@ -1552,13 +1549,6 @@ static int elants_i2c_probe(struct i2c_client *client)
|
||||
return error;
|
||||
}
|
||||
|
||||
error = devm_device_add_group(&client->dev, &elants_attribute_group);
|
||||
if (error) {
|
||||
dev_err(&client->dev, "failed to create sysfs attributes: %d\n",
|
||||
error);
|
||||
return error;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -1667,6 +1657,7 @@ static struct i2c_driver elants_i2c_driver = {
|
||||
.id_table = elants_i2c_id,
|
||||
.driver = {
|
||||
.name = DEVICE_NAME,
|
||||
.dev_groups = elants_i2c_groups,
|
||||
.pm = pm_sleep_ptr(&elants_i2c_pm_ops),
|
||||
.acpi_match_table = ACPI_PTR(elants_acpi_id),
|
||||
.of_match_table = of_match_ptr(elants_of_match),
|
||||
|
@ -325,16 +325,13 @@ static ssize_t type_show(struct device *dev,
|
||||
}
|
||||
static DEVICE_ATTR_RO(type);
|
||||
|
||||
static struct attribute *sysfs_attrs[] = {
|
||||
static struct attribute *exc3000_attrs[] = {
|
||||
&dev_attr_fw_version.attr,
|
||||
&dev_attr_model.attr,
|
||||
&dev_attr_type.attr,
|
||||
NULL
|
||||
};
|
||||
|
||||
static struct attribute_group exc3000_attribute_group = {
|
||||
.attrs = sysfs_attrs
|
||||
};
|
||||
ATTRIBUTE_GROUPS(exc3000);
|
||||
|
||||
static int exc3000_probe(struct i2c_client *client)
|
||||
{
|
||||
@ -437,10 +434,6 @@ static int exc3000_probe(struct i2c_client *client)
|
||||
|
||||
i2c_set_clientdata(client, data);
|
||||
|
||||
error = devm_device_add_group(&client->dev, &exc3000_attribute_group);
|
||||
if (error)
|
||||
return error;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -473,6 +466,7 @@ MODULE_DEVICE_TABLE(acpi, exc3000_acpi_match);
|
||||
static struct i2c_driver exc3000_driver = {
|
||||
.driver = {
|
||||
.name = "exc3000",
|
||||
.dev_groups = exc3000_groups,
|
||||
.of_match_table = of_match_ptr(exc3000_of_match),
|
||||
.acpi_match_table = ACPI_PTR(exc3000_acpi_match),
|
||||
},
|
||||
|
@ -954,16 +954,13 @@ static DEVICE_ATTR(version, 0664, hideep_fw_version_show, NULL);
|
||||
static DEVICE_ATTR(product_id, 0664, hideep_product_id_show, NULL);
|
||||
static DEVICE_ATTR(update_fw, 0664, NULL, hideep_update_fw);
|
||||
|
||||
static struct attribute *hideep_ts_sysfs_entries[] = {
|
||||
static struct attribute *hideep_ts_attrs[] = {
|
||||
&dev_attr_version.attr,
|
||||
&dev_attr_product_id.attr,
|
||||
&dev_attr_update_fw.attr,
|
||||
NULL,
|
||||
};
|
||||
|
||||
static const struct attribute_group hideep_ts_attr_group = {
|
||||
.attrs = hideep_ts_sysfs_entries,
|
||||
};
|
||||
ATTRIBUTE_GROUPS(hideep_ts);
|
||||
|
||||
static void hideep_set_work_mode(struct hideep_ts *ts)
|
||||
{
|
||||
@ -1096,13 +1093,6 @@ static int hideep_probe(struct i2c_client *client)
|
||||
return error;
|
||||
}
|
||||
|
||||
error = devm_device_add_group(&client->dev, &hideep_ts_attr_group);
|
||||
if (error) {
|
||||
dev_err(&client->dev,
|
||||
"failed to add sysfs attributes: %d\n", error);
|
||||
return error;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -1131,6 +1121,7 @@ MODULE_DEVICE_TABLE(of, hideep_match_table);
|
||||
static struct i2c_driver hideep_driver = {
|
||||
.driver = {
|
||||
.name = HIDEEP_I2C_NAME,
|
||||
.dev_groups = hideep_ts_groups,
|
||||
.of_match_table = of_match_ptr(hideep_match_table),
|
||||
.acpi_match_table = ACPI_PTR(hideep_acpi_id),
|
||||
.pm = pm_sleep_ptr(&hideep_pm_ops),
|
||||
|
@ -274,10 +274,7 @@ static struct attribute *hycon_hy46xx_attrs[] = {
|
||||
&hycon_hy46xx_attr_bootloader_version.dattr.attr,
|
||||
NULL
|
||||
};
|
||||
|
||||
static const struct attribute_group hycon_hy46xx_attr_group = {
|
||||
.attrs = hycon_hy46xx_attrs,
|
||||
};
|
||||
ATTRIBUTE_GROUPS(hycon_hy46xx);
|
||||
|
||||
static void hycon_hy46xx_get_defaults(struct device *dev, struct hycon_hy46xx_data *tsdata)
|
||||
{
|
||||
@ -535,10 +532,6 @@ static int hycon_hy46xx_probe(struct i2c_client *client)
|
||||
return error;
|
||||
}
|
||||
|
||||
error = devm_device_add_group(&client->dev, &hycon_hy46xx_attr_group);
|
||||
if (error)
|
||||
return error;
|
||||
|
||||
error = input_register_device(input);
|
||||
if (error)
|
||||
return error;
|
||||
@ -576,6 +569,7 @@ MODULE_DEVICE_TABLE(of, hycon_hy46xx_of_match);
|
||||
static struct i2c_driver hycon_hy46xx_driver = {
|
||||
.driver = {
|
||||
.name = "hycon_hy46xx",
|
||||
.dev_groups = hycon_hy46xx_groups,
|
||||
.of_match_table = hycon_hy46xx_of_match,
|
||||
.probe_type = PROBE_PREFER_ASYNCHRONOUS,
|
||||
},
|
||||
|
@ -876,7 +876,7 @@ static ssize_t ili210x_firmware_update_store(struct device *dev,
|
||||
|
||||
static DEVICE_ATTR(firmware_update, 0200, NULL, ili210x_firmware_update_store);
|
||||
|
||||
static struct attribute *ili210x_attributes[] = {
|
||||
static struct attribute *ili210x_attrs[] = {
|
||||
&dev_attr_calibrate.attr,
|
||||
&dev_attr_firmware_update.attr,
|
||||
&dev_attr_firmware_version.attr,
|
||||
@ -904,10 +904,11 @@ static umode_t ili210x_attributes_visible(struct kobject *kobj,
|
||||
return attr->mode;
|
||||
}
|
||||
|
||||
static const struct attribute_group ili210x_attr_group = {
|
||||
.attrs = ili210x_attributes,
|
||||
static const struct attribute_group ili210x_group = {
|
||||
.attrs = ili210x_attrs,
|
||||
.is_visible = ili210x_attributes_visible,
|
||||
};
|
||||
__ATTRIBUTE_GROUPS(ili210x);
|
||||
|
||||
static void ili210x_power_down(void *data)
|
||||
{
|
||||
@ -1013,13 +1014,6 @@ static int ili210x_i2c_probe(struct i2c_client *client)
|
||||
if (error)
|
||||
return error;
|
||||
|
||||
error = devm_device_add_group(dev, &ili210x_attr_group);
|
||||
if (error) {
|
||||
dev_err(dev, "Unable to create sysfs attributes, err: %d\n",
|
||||
error);
|
||||
return error;
|
||||
}
|
||||
|
||||
error = input_register_device(priv->input);
|
||||
if (error) {
|
||||
dev_err(dev, "Cannot register input device, err: %d\n", error);
|
||||
@ -1050,6 +1044,7 @@ MODULE_DEVICE_TABLE(of, ili210x_dt_ids);
|
||||
static struct i2c_driver ili210x_ts_driver = {
|
||||
.driver = {
|
||||
.name = "ili210x_i2c",
|
||||
.dev_groups = ili210x_groups,
|
||||
.of_match_table = ili210x_dt_ids,
|
||||
},
|
||||
.id_table = ili210x_i2c_id,
|
||||
|
@ -537,10 +537,7 @@ static struct attribute *ilitek_sysfs_attrs[] = {
|
||||
&dev_attr_product_id.attr,
|
||||
NULL
|
||||
};
|
||||
|
||||
static struct attribute_group ilitek_attrs_group = {
|
||||
.attrs = ilitek_sysfs_attrs,
|
||||
};
|
||||
ATTRIBUTE_GROUPS(ilitek_sysfs);
|
||||
|
||||
static int ilitek_ts_i2c_probe(struct i2c_client *client)
|
||||
{
|
||||
@ -595,12 +592,6 @@ static int ilitek_ts_i2c_probe(struct i2c_client *client)
|
||||
return error;
|
||||
}
|
||||
|
||||
error = devm_device_add_group(dev, &ilitek_attrs_group);
|
||||
if (error) {
|
||||
dev_err(dev, "sysfs create group failed: %d\n", error);
|
||||
return error;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -675,6 +666,7 @@ MODULE_DEVICE_TABLE(of, ilitek_ts_i2c_match);
|
||||
static struct i2c_driver ilitek_ts_i2c_driver = {
|
||||
.driver = {
|
||||
.name = ILITEK_TS_NAME,
|
||||
.dev_groups = ilitek_sysfs_groups,
|
||||
.pm = pm_sleep_ptr(&ilitek_pm_ops),
|
||||
.of_match_table = of_match_ptr(ilitek_ts_i2c_match),
|
||||
.acpi_match_table = ACPI_PTR(ilitekts_acpi_id),
|
||||
|
@ -974,10 +974,11 @@ static umode_t iqs5xx_attr_is_visible(struct kobject *kobj,
|
||||
return attr->mode;
|
||||
}
|
||||
|
||||
static const struct attribute_group iqs5xx_attr_group = {
|
||||
static const struct attribute_group iqs5xx_group = {
|
||||
.is_visible = iqs5xx_attr_is_visible,
|
||||
.attrs = iqs5xx_attrs,
|
||||
};
|
||||
__ATTRIBUTE_GROUPS(iqs5xx);
|
||||
|
||||
static int iqs5xx_suspend(struct device *dev)
|
||||
{
|
||||
@ -1053,12 +1054,6 @@ static int iqs5xx_probe(struct i2c_client *client)
|
||||
return error;
|
||||
}
|
||||
|
||||
error = devm_device_add_group(&client->dev, &iqs5xx_attr_group);
|
||||
if (error) {
|
||||
dev_err(&client->dev, "Failed to add attributes: %d\n", error);
|
||||
return error;
|
||||
}
|
||||
|
||||
if (iqs5xx->input) {
|
||||
error = input_register_device(iqs5xx->input);
|
||||
if (error)
|
||||
@ -1089,6 +1084,7 @@ MODULE_DEVICE_TABLE(of, iqs5xx_of_match);
|
||||
static struct i2c_driver iqs5xx_i2c_driver = {
|
||||
.driver = {
|
||||
.name = "iqs5xx",
|
||||
.dev_groups = iqs5xx_groups,
|
||||
.of_match_table = iqs5xx_of_match,
|
||||
.pm = pm_sleep_ptr(&iqs5xx_pm),
|
||||
},
|
||||
|
@ -252,18 +252,16 @@ static int mainstone_wm97xx_probe(struct platform_device *pdev)
|
||||
return wm97xx_register_mach_ops(wm, &mainstone_mach_ops);
|
||||
}
|
||||
|
||||
static int mainstone_wm97xx_remove(struct platform_device *pdev)
|
||||
static void mainstone_wm97xx_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct wm97xx *wm = platform_get_drvdata(pdev);
|
||||
|
||||
wm97xx_unregister_mach_ops(wm);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver mainstone_wm97xx_driver = {
|
||||
.probe = mainstone_wm97xx_probe,
|
||||
.remove = mainstone_wm97xx_remove,
|
||||
.remove_new = mainstone_wm97xx_remove,
|
||||
.driver = {
|
||||
.name = "wm97xx-touch",
|
||||
},
|
||||
|
@ -217,18 +217,16 @@ static int __init mc13783_ts_probe(struct platform_device *pdev)
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int mc13783_ts_remove(struct platform_device *pdev)
|
||||
static void mc13783_ts_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct mc13783_ts_priv *priv = platform_get_drvdata(pdev);
|
||||
|
||||
input_unregister_device(priv->idev);
|
||||
kfree(priv);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver mc13783_ts_driver = {
|
||||
.remove = mc13783_ts_remove,
|
||||
.remove_new = mc13783_ts_remove,
|
||||
.driver = {
|
||||
.name = MC13783_TS_NAME,
|
||||
},
|
||||
|
@ -1419,10 +1419,7 @@ static struct attribute *mip4_attrs[] = {
|
||||
&dev_attr_update_fw.attr,
|
||||
NULL,
|
||||
};
|
||||
|
||||
static const struct attribute_group mip4_attr_group = {
|
||||
.attrs = mip4_attrs,
|
||||
};
|
||||
ATTRIBUTE_GROUPS(mip4);
|
||||
|
||||
static int mip4_probe(struct i2c_client *client)
|
||||
{
|
||||
@ -1514,13 +1511,6 @@ static int mip4_probe(struct i2c_client *client)
|
||||
return error;
|
||||
}
|
||||
|
||||
error = devm_device_add_group(&client->dev, &mip4_attr_group);
|
||||
if (error) {
|
||||
dev_err(&client->dev,
|
||||
"Failed to create sysfs attribute group: %d\n", error);
|
||||
return error;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -1589,6 +1579,7 @@ static struct i2c_driver mip4_driver = {
|
||||
.probe = mip4_probe,
|
||||
.driver = {
|
||||
.name = MIP4_DEVICE_NAME,
|
||||
.dev_groups = mip4_groups,
|
||||
.of_match_table = of_match_ptr(mip4_of_match),
|
||||
.acpi_match_table = ACPI_PTR(mip4_acpi_match),
|
||||
.pm = pm_sleep_ptr(&mip4_pm_ops),
|
||||
|
@ -197,7 +197,7 @@ static int pcap_ts_probe(struct platform_device *pdev)
|
||||
return err;
|
||||
}
|
||||
|
||||
static int pcap_ts_remove(struct platform_device *pdev)
|
||||
static void pcap_ts_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct pcap_ts *pcap_ts = platform_get_drvdata(pdev);
|
||||
|
||||
@ -207,8 +207,6 @@ static int pcap_ts_remove(struct platform_device *pdev)
|
||||
input_unregister_device(pcap_ts->input);
|
||||
|
||||
kfree(pcap_ts);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_PM
|
||||
@ -240,7 +238,7 @@ static const struct dev_pm_ops pcap_ts_pm_ops = {
|
||||
|
||||
static struct platform_driver pcap_ts_driver = {
|
||||
.probe = pcap_ts_probe,
|
||||
.remove = pcap_ts_remove,
|
||||
.remove_new = pcap_ts_remove,
|
||||
.driver = {
|
||||
.name = "pcap-ts",
|
||||
.pm = PCAP_TS_PM_OPS,
|
||||
|
@ -1004,7 +1004,7 @@ static DEVICE_ATTR(boot_mode, S_IRUGO, raydium_i2c_boot_mode_show, NULL);
|
||||
static DEVICE_ATTR(update_fw, S_IWUSR, NULL, raydium_i2c_update_fw_store);
|
||||
static DEVICE_ATTR(calibrate, S_IWUSR, NULL, raydium_i2c_calibrate_store);
|
||||
|
||||
static struct attribute *raydium_i2c_attributes[] = {
|
||||
static struct attribute *raydium_i2c_attrs[] = {
|
||||
&dev_attr_update_fw.attr,
|
||||
&dev_attr_boot_mode.attr,
|
||||
&dev_attr_fw_version.attr,
|
||||
@ -1012,10 +1012,7 @@ static struct attribute *raydium_i2c_attributes[] = {
|
||||
&dev_attr_calibrate.attr,
|
||||
NULL
|
||||
};
|
||||
|
||||
static const struct attribute_group raydium_i2c_attribute_group = {
|
||||
.attrs = raydium_i2c_attributes,
|
||||
};
|
||||
ATTRIBUTE_GROUPS(raydium_i2c);
|
||||
|
||||
static int raydium_i2c_power_on(struct raydium_data *ts)
|
||||
{
|
||||
@ -1174,14 +1171,6 @@ static int raydium_i2c_probe(struct i2c_client *client)
|
||||
return error;
|
||||
}
|
||||
|
||||
error = devm_device_add_group(&client->dev,
|
||||
&raydium_i2c_attribute_group);
|
||||
if (error) {
|
||||
dev_err(&client->dev, "failed to create sysfs attributes: %d\n",
|
||||
error);
|
||||
return error;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -1265,6 +1254,7 @@ static struct i2c_driver raydium_i2c_driver = {
|
||||
.id_table = raydium_i2c_id,
|
||||
.driver = {
|
||||
.name = "raydium_ts",
|
||||
.dev_groups = raydium_i2c_groups,
|
||||
.pm = pm_sleep_ptr(&raydium_i2c_pm_ops),
|
||||
.acpi_match_table = ACPI_PTR(raydium_acpi_id),
|
||||
.of_match_table = of_match_ptr(raydium_of_match),
|
||||
|
@ -854,10 +854,7 @@ static struct attribute *rohm_ts_attrs[] = {
|
||||
&dev_attr_inv_y.attr,
|
||||
NULL,
|
||||
};
|
||||
|
||||
static const struct attribute_group rohm_ts_attr_group = {
|
||||
.attrs = rohm_ts_attrs,
|
||||
};
|
||||
ATTRIBUTE_GROUPS(rohm_ts);
|
||||
|
||||
static int rohm_ts_device_init(struct i2c_client *client, u8 setup2)
|
||||
{
|
||||
@ -1164,12 +1161,6 @@ static int rohm_bu21023_i2c_probe(struct i2c_client *client)
|
||||
return error;
|
||||
}
|
||||
|
||||
error = devm_device_add_group(dev, &rohm_ts_attr_group);
|
||||
if (error) {
|
||||
dev_err(dev, "failed to create sysfs group: %d\n", error);
|
||||
return error;
|
||||
}
|
||||
|
||||
return error;
|
||||
}
|
||||
|
||||
@ -1182,6 +1173,7 @@ MODULE_DEVICE_TABLE(i2c, rohm_bu21023_i2c_id);
|
||||
static struct i2c_driver rohm_bu21023_i2c_driver = {
|
||||
.driver = {
|
||||
.name = BU21023_NAME,
|
||||
.dev_groups = rohm_ts_groups,
|
||||
},
|
||||
.probe = rohm_bu21023_i2c_probe,
|
||||
.id_table = rohm_bu21023_i2c_id,
|
||||
|
@ -286,10 +286,7 @@ static struct attribute *s6sy761_sysfs_attrs[] = {
|
||||
&dev_attr_devid.attr,
|
||||
NULL
|
||||
};
|
||||
|
||||
static struct attribute_group s6sy761_attribute_group = {
|
||||
.attrs = s6sy761_sysfs_attrs
|
||||
};
|
||||
ATTRIBUTE_GROUPS(s6sy761_sysfs);
|
||||
|
||||
static int s6sy761_power_on(struct s6sy761_data *sdata)
|
||||
{
|
||||
@ -465,10 +462,6 @@ static int s6sy761_probe(struct i2c_client *client)
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
err = devm_device_add_group(&client->dev, &s6sy761_attribute_group);
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
pm_runtime_enable(&client->dev);
|
||||
|
||||
return 0;
|
||||
@ -535,6 +528,7 @@ MODULE_DEVICE_TABLE(i2c, s6sy761_id);
|
||||
static struct i2c_driver s6sy761_driver = {
|
||||
.driver = {
|
||||
.name = S6SY761_DEV_NAME,
|
||||
.dev_groups = s6sy761_sysfs_groups,
|
||||
.of_match_table = of_match_ptr(s6sy761_of_match),
|
||||
.pm = pm_ptr(&s6sy761_pm_ops),
|
||||
},
|
||||
|
@ -517,10 +517,7 @@ static struct attribute *stmfts_sysfs_attrs[] = {
|
||||
&dev_attr_hover_enable.attr,
|
||||
NULL
|
||||
};
|
||||
|
||||
static struct attribute_group stmfts_attribute_group = {
|
||||
.attrs = stmfts_sysfs_attrs
|
||||
};
|
||||
ATTRIBUTE_GROUPS(stmfts_sysfs);
|
||||
|
||||
static int stmfts_power_on(struct stmfts_data *sdata)
|
||||
{
|
||||
@ -727,10 +724,6 @@ static int stmfts_probe(struct i2c_client *client)
|
||||
}
|
||||
}
|
||||
|
||||
err = devm_device_add_group(&client->dev, &stmfts_attribute_group);
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
pm_runtime_enable(&client->dev);
|
||||
device_enable_async_suspend(&client->dev);
|
||||
|
||||
@ -804,6 +797,7 @@ MODULE_DEVICE_TABLE(i2c, stmfts_id);
|
||||
static struct i2c_driver stmfts_driver = {
|
||||
.driver = {
|
||||
.name = STMFTS_DEV_NAME,
|
||||
.dev_groups = stmfts_sysfs_groups,
|
||||
.of_match_table = of_match_ptr(stmfts_of_match),
|
||||
.pm = pm_ptr(&stmfts_pm_ops),
|
||||
.probe_type = PROBE_PREFER_ASYNCHRONOUS,
|
||||
|
@ -350,13 +350,11 @@ static int stmpe_input_probe(struct platform_device *pdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int stmpe_ts_remove(struct platform_device *pdev)
|
||||
static void stmpe_ts_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct stmpe_touch *ts = platform_get_drvdata(pdev);
|
||||
|
||||
stmpe_disable(ts->stmpe, STMPE_BLOCK_TOUCHSCREEN);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver stmpe_ts_driver = {
|
||||
@ -364,7 +362,7 @@ static struct platform_driver stmpe_ts_driver = {
|
||||
.name = STMPE_TS_NAME,
|
||||
},
|
||||
.probe = stmpe_input_probe,
|
||||
.remove = stmpe_ts_remove,
|
||||
.remove_new = stmpe_ts_remove,
|
||||
};
|
||||
module_platform_driver(stmpe_ts_driver);
|
||||
|
||||
|
@ -375,7 +375,7 @@ static int sun4i_ts_probe(struct platform_device *pdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int sun4i_ts_remove(struct platform_device *pdev)
|
||||
static void sun4i_ts_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct sun4i_ts_data *ts = platform_get_drvdata(pdev);
|
||||
|
||||
@ -385,8 +385,6 @@ static int sun4i_ts_remove(struct platform_device *pdev)
|
||||
|
||||
/* Deactivate all IRQs */
|
||||
writel(0, ts->base + TP_INT_FIFOC);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static const struct of_device_id sun4i_ts_of_match[] = {
|
||||
@ -403,7 +401,7 @@ static struct platform_driver sun4i_ts_driver = {
|
||||
.of_match_table = sun4i_ts_of_match,
|
||||
},
|
||||
.probe = sun4i_ts_probe,
|
||||
.remove = sun4i_ts_remove,
|
||||
.remove_new = sun4i_ts_remove,
|
||||
};
|
||||
|
||||
module_platform_driver(sun4i_ts_driver);
|
||||
|
@ -491,7 +491,7 @@ static int titsc_probe(struct platform_device *pdev)
|
||||
return err;
|
||||
}
|
||||
|
||||
static int titsc_remove(struct platform_device *pdev)
|
||||
static void titsc_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct titsc *ts_dev = platform_get_drvdata(pdev);
|
||||
u32 steps;
|
||||
@ -508,7 +508,6 @@ static int titsc_remove(struct platform_device *pdev)
|
||||
input_unregister_device(ts_dev->input);
|
||||
|
||||
kfree(ts_dev);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int titsc_suspend(struct device *dev)
|
||||
@ -552,7 +551,7 @@ MODULE_DEVICE_TABLE(of, ti_tsc_dt_ids);
|
||||
|
||||
static struct platform_driver ti_tsc_driver = {
|
||||
.probe = titsc_probe,
|
||||
.remove = titsc_remove,
|
||||
.remove_new = titsc_remove,
|
||||
.driver = {
|
||||
.name = "TI-am335x-tsc",
|
||||
.pm = pm_sleep_ptr(&titsc_pm_ops),
|
||||
|
@ -63,9 +63,10 @@ MODULE_DEVICE_TABLE(of, tsc2004_of_match);
|
||||
|
||||
static struct i2c_driver tsc2004_driver = {
|
||||
.driver = {
|
||||
.name = "tsc2004",
|
||||
.of_match_table = of_match_ptr(tsc2004_of_match),
|
||||
.pm = pm_sleep_ptr(&tsc200x_pm_ops),
|
||||
.name = "tsc2004",
|
||||
.dev_groups = tsc200x_groups,
|
||||
.of_match_table = of_match_ptr(tsc2004_of_match),
|
||||
.pm = pm_sleep_ptr(&tsc200x_pm_ops),
|
||||
},
|
||||
.id_table = tsc2004_idtable,
|
||||
.probe = tsc2004_probe,
|
||||
|
@ -79,9 +79,10 @@ MODULE_DEVICE_TABLE(of, tsc2005_of_match);
|
||||
|
||||
static struct spi_driver tsc2005_driver = {
|
||||
.driver = {
|
||||
.name = "tsc2005",
|
||||
.of_match_table = of_match_ptr(tsc2005_of_match),
|
||||
.pm = pm_sleep_ptr(&tsc200x_pm_ops),
|
||||
.name = "tsc2005",
|
||||
.dev_groups = tsc200x_groups,
|
||||
.of_match_table = of_match_ptr(tsc2005_of_match),
|
||||
.pm = pm_sleep_ptr(&tsc200x_pm_ops),
|
||||
},
|
||||
.probe = tsc2005_probe,
|
||||
.remove = tsc2005_remove,
|
||||
|
@ -356,6 +356,12 @@ static const struct attribute_group tsc200x_attr_group = {
|
||||
.attrs = tsc200x_attrs,
|
||||
};
|
||||
|
||||
const struct attribute_group *tsc200x_groups[] = {
|
||||
&tsc200x_attr_group,
|
||||
NULL
|
||||
};
|
||||
EXPORT_SYMBOL_GPL(tsc200x_groups);
|
||||
|
||||
static void tsc200x_esd_work(struct work_struct *work)
|
||||
{
|
||||
struct tsc200x *ts = container_of(work, struct tsc200x, esd_work.work);
|
||||
@ -553,25 +559,17 @@ int tsc200x_probe(struct device *dev, int irq, const struct input_id *tsc_id,
|
||||
return error;
|
||||
|
||||
dev_set_drvdata(dev, ts);
|
||||
error = sysfs_create_group(&dev->kobj, &tsc200x_attr_group);
|
||||
if (error) {
|
||||
dev_err(dev,
|
||||
"Failed to create sysfs attributes, err: %d\n", error);
|
||||
goto disable_regulator;
|
||||
}
|
||||
|
||||
error = input_register_device(ts->idev);
|
||||
if (error) {
|
||||
dev_err(dev,
|
||||
"Failed to register input device, err: %d\n", error);
|
||||
goto err_remove_sysfs;
|
||||
goto disable_regulator;
|
||||
}
|
||||
|
||||
irq_set_irq_wake(irq, 1);
|
||||
return 0;
|
||||
|
||||
err_remove_sysfs:
|
||||
sysfs_remove_group(&dev->kobj, &tsc200x_attr_group);
|
||||
disable_regulator:
|
||||
regulator_disable(ts->vio);
|
||||
return error;
|
||||
@ -582,8 +580,6 @@ void tsc200x_remove(struct device *dev)
|
||||
{
|
||||
struct tsc200x *ts = dev_get_drvdata(dev);
|
||||
|
||||
sysfs_remove_group(&dev->kobj, &tsc200x_attr_group);
|
||||
|
||||
regulator_disable(ts->vio);
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(tsc200x_remove);
|
||||
|
@ -70,6 +70,7 @@
|
||||
|
||||
extern const struct regmap_config tsc200x_regmap_config;
|
||||
extern const struct dev_pm_ops tsc200x_pm_ops;
|
||||
extern const struct attribute_group *tsc200x_groups[];
|
||||
|
||||
int tsc200x_probe(struct device *dev, int irq, const struct input_id *tsc_id,
|
||||
struct regmap *regmap,
|
||||
|
@ -944,10 +944,7 @@ static struct attribute *wdt87xx_attrs[] = {
|
||||
&dev_attr_update_fw.attr,
|
||||
NULL
|
||||
};
|
||||
|
||||
static const struct attribute_group wdt87xx_attr_group = {
|
||||
.attrs = wdt87xx_attrs,
|
||||
};
|
||||
ATTRIBUTE_GROUPS(wdt87xx);
|
||||
|
||||
static void wdt87xx_report_contact(struct input_dev *input,
|
||||
struct wdt87xx_sys_param *param,
|
||||
@ -1104,12 +1101,6 @@ static int wdt87xx_ts_probe(struct i2c_client *client)
|
||||
return error;
|
||||
}
|
||||
|
||||
error = devm_device_add_group(&client->dev, &wdt87xx_attr_group);
|
||||
if (error) {
|
||||
dev_err(&client->dev, "create sysfs failed: %d\n", error);
|
||||
return error;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -1172,8 +1163,9 @@ static struct i2c_driver wdt87xx_driver = {
|
||||
.probe = wdt87xx_ts_probe,
|
||||
.id_table = wdt87xx_dev_id,
|
||||
.driver = {
|
||||
.name = WDT87XX_NAME,
|
||||
.pm = pm_sleep_ptr(&wdt87xx_pm_ops),
|
||||
.name = WDT87XX_NAME,
|
||||
.dev_groups = wdt87xx_groups,
|
||||
.pm = pm_sleep_ptr(&wdt87xx_pm_ops),
|
||||
.acpi_match_table = ACPI_PTR(wdt87xx_acpi_id),
|
||||
},
|
||||
};
|
||||
|
@ -374,14 +374,12 @@ static int wm831x_ts_probe(struct platform_device *pdev)
|
||||
return error;
|
||||
}
|
||||
|
||||
static int wm831x_ts_remove(struct platform_device *pdev)
|
||||
static void wm831x_ts_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct wm831x_ts *wm831x_ts = platform_get_drvdata(pdev);
|
||||
|
||||
free_irq(wm831x_ts->pd_irq, wm831x_ts);
|
||||
free_irq(wm831x_ts->data_irq, wm831x_ts);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct platform_driver wm831x_ts_driver = {
|
||||
@ -389,7 +387,7 @@ static struct platform_driver wm831x_ts_driver = {
|
||||
.name = "wm831x-touch",
|
||||
},
|
||||
.probe = wm831x_ts_probe,
|
||||
.remove = wm831x_ts_remove,
|
||||
.remove_new = wm831x_ts_remove,
|
||||
};
|
||||
module_platform_driver(wm831x_ts_driver);
|
||||
|
||||
|
@ -756,11 +756,9 @@ static int wm97xx_mfd_probe(struct platform_device *pdev)
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int wm97xx_mfd_remove(struct platform_device *pdev)
|
||||
static void wm97xx_mfd_remove(struct platform_device *pdev)
|
||||
{
|
||||
wm97xx_remove(&pdev->dev);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int wm97xx_suspend(struct device *dev)
|
||||
@ -878,7 +876,7 @@ static struct platform_driver wm97xx_mfd_driver = {
|
||||
.pm = pm_sleep_ptr(&wm97xx_pm_ops),
|
||||
},
|
||||
.probe = wm97xx_mfd_probe,
|
||||
.remove = wm97xx_mfd_remove,
|
||||
.remove_new = wm97xx_mfd_remove,
|
||||
};
|
||||
|
||||
static int __init wm97xx_init(void)
|
||||
|
@ -562,7 +562,7 @@ struct ff_device {
|
||||
|
||||
int max_effects;
|
||||
struct ff_effect *effects;
|
||||
struct file *effect_owners[];
|
||||
struct file *effect_owners[] __counted_by(max_effects);
|
||||
};
|
||||
|
||||
int input_ff_create(struct input_dev *dev, unsigned int max_effects);
|
||||
|
@ -47,7 +47,7 @@ struct input_mt {
|
||||
unsigned int flags;
|
||||
unsigned int frame;
|
||||
int *red;
|
||||
struct input_mt_slot slots[];
|
||||
struct input_mt_slot slots[] __counted_by(num_slots);
|
||||
};
|
||||
|
||||
static inline void input_mt_set_value(struct input_mt_slot *slot,
|
||||
|
Loading…
Reference in New Issue
Block a user