Commit 3cdde3a3 authored by Marc Dietrich's avatar Marc Dietrich Committed by Greg Kroah-Hartman

staging: nvec: add remove function to nvec childs

This patch cleanups registered devices on remove.
Signed-off-by: default avatarMarc Dietrich <marvin24@gmx.de>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent ac562680
...@@ -159,8 +159,17 @@ static int __devinit nvec_kbd_probe(struct platform_device *pdev) ...@@ -159,8 +159,17 @@ static int __devinit nvec_kbd_probe(struct platform_device *pdev)
return err; return err;
} }
static int __devexit nvec_kbd_remove(struct platform_device *pdev)
{
input_unregister_device(keys_dev.input);
input_free_device(keys_dev.input);
return 0;
}
static struct platform_driver nvec_kbd_driver = { static struct platform_driver nvec_kbd_driver = {
.probe = nvec_kbd_probe, .probe = nvec_kbd_probe,
.remove = __devexit_p(nvec_kbd_remove),
.driver = { .driver = {
.name = "nvec-kbd", .name = "nvec-kbd",
.owner = THIS_MODULE, .owner = THIS_MODULE,
......
...@@ -407,8 +407,25 @@ static int __devinit nvec_power_probe(struct platform_device *pdev) ...@@ -407,8 +407,25 @@ static int __devinit nvec_power_probe(struct platform_device *pdev)
return power_supply_register(&pdev->dev, psy); return power_supply_register(&pdev->dev, psy);
} }
static int __devexit nvec_power_remove(struct platform_device *pdev)
{
struct nvec_power *power = platform_get_drvdata(pdev);
cancel_delayed_work_sync(&power->poller);
switch (pdev->id) {
case AC:
power_supply_unregister(&nvec_psy);
break;
case BAT:
power_supply_unregister(&nvec_bat_psy);
}
return 0;
}
static struct platform_driver nvec_power_driver = { static struct platform_driver nvec_power_driver = {
.probe = nvec_power_probe, .probe = nvec_power_probe,
.remove = __devexit_p(nvec_power_remove),
.driver = { .driver = {
.name = "nvec-power", .name = "nvec-power",
.owner = THIS_MODULE, .owner = THIS_MODULE,
......
...@@ -123,6 +123,13 @@ static int __devinit nvec_mouse_probe(struct platform_device *pdev) ...@@ -123,6 +123,13 @@ static int __devinit nvec_mouse_probe(struct platform_device *pdev)
return 0; return 0;
} }
static int __devexit nvec_mouse_remove(struct platform_device *pdev)
{
serio_unregister_port(ps2_dev.ser_dev);
return 0;
}
#ifdef CONFIG_PM_SLEEP #ifdef CONFIG_PM_SLEEP
static int nvec_mouse_suspend(struct device *dev) static int nvec_mouse_suspend(struct device *dev)
{ {
...@@ -157,6 +164,7 @@ static const SIMPLE_DEV_PM_OPS(nvec_mouse_pm_ops, nvec_mouse_suspend, ...@@ -157,6 +164,7 @@ static const SIMPLE_DEV_PM_OPS(nvec_mouse_pm_ops, nvec_mouse_suspend,
static struct platform_driver nvec_mouse_driver = { static struct platform_driver nvec_mouse_driver = {
.probe = nvec_mouse_probe, .probe = nvec_mouse_probe,
.remove = __devexit_p(nvec_mouse_remove),
.driver = { .driver = {
.name = "nvec-mouse", .name = "nvec-mouse",
.owner = THIS_MODULE, .owner = THIS_MODULE,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment