aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/platform/x86
diff options
context:
space:
mode:
authorShuah Khan <shuah.kh@samsung.com>2013-09-11 17:23:15 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2013-09-11 18:58:16 -0400
commit8aa6c2166b5184fb2344062cf2fa229b197c1f84 (patch)
tree27dcd541069954cd06a6a29a91591f8c1d875736 /drivers/platform/x86
parenta2fa3fb0d9a0169b10789ea3e5ea7168494df93c (diff)
platform: convert apple-gmux driver to dev_pm_ops from legacy pm_ops
Convert drivers/platform/x86/apple-gmux to use dev_pm_ops instead of legacy pm_ops. This patch depends on pnp driver bus ops change to invoke pnp_driver dev_pm_ops. Signed-off-by: Shuah Khan <shuah.kh@samsung.com> Cc: Matthew Garrett <matthew.garrett@nebula.com> Cc: Leonidas Da Silva Barbosa <leosilva@linux.vnet.ibm.com> Cc: Ashley Lai <ashley@ashleylai.com> Cc: Rajiv Andrade <mail@srajiv.net> Cc: Marcel Selhorst <tpmdd@selhorst.net> Cc: Sirrix AG <tpmdd@sirrix.com> Cc: Alessandro Zummo <a.zummo@towertech.it> Cc: "Rafael J. Wysocki" <rafael.j.wysocki@intel.com> Cc: Bjorn Helgaas <bhelgaas@google.com> Cc: Grant Likely <grant.likely@linaro.org> Cc: Rob Herring <rob.herring@calxeda.com> Cc: Peter Hüwe <PeterHuewe@gmx.de> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/platform/x86')
-rw-r--r--drivers/platform/x86/apple-gmux.c18
1 files changed, 14 insertions, 4 deletions
diff --git a/drivers/platform/x86/apple-gmux.c b/drivers/platform/x86/apple-gmux.c
index f74bfcbb7bad..8eea2efbbb6d 100644
--- a/drivers/platform/x86/apple-gmux.c
+++ b/drivers/platform/x86/apple-gmux.c
@@ -393,17 +393,21 @@ static void gmux_notify_handler(acpi_handle device, u32 value, void *context)
393 complete(&gmux_data->powerchange_done); 393 complete(&gmux_data->powerchange_done);
394} 394}
395 395
396static int gmux_suspend(struct pnp_dev *pnp, pm_message_t state) 396static int gmux_suspend(struct device *dev)
397{ 397{
398 struct pnp_dev *pnp = to_pnp_dev(dev);
398 struct apple_gmux_data *gmux_data = pnp_get_drvdata(pnp); 399 struct apple_gmux_data *gmux_data = pnp_get_drvdata(pnp);
400
399 gmux_data->resume_client_id = gmux_active_client(gmux_data); 401 gmux_data->resume_client_id = gmux_active_client(gmux_data);
400 gmux_disable_interrupts(gmux_data); 402 gmux_disable_interrupts(gmux_data);
401 return 0; 403 return 0;
402} 404}
403 405
404static int gmux_resume(struct pnp_dev *pnp) 406static int gmux_resume(struct device *dev)
405{ 407{
408 struct pnp_dev *pnp = to_pnp_dev(dev);
406 struct apple_gmux_data *gmux_data = pnp_get_drvdata(pnp); 409 struct apple_gmux_data *gmux_data = pnp_get_drvdata(pnp);
410
407 gmux_enable_interrupts(gmux_data); 411 gmux_enable_interrupts(gmux_data);
408 gmux_switchto(gmux_data->resume_client_id); 412 gmux_switchto(gmux_data->resume_client_id);
409 if (gmux_data->power_state == VGA_SWITCHEROO_OFF) 413 if (gmux_data->power_state == VGA_SWITCHEROO_OFF)
@@ -605,13 +609,19 @@ static const struct pnp_device_id gmux_device_ids[] = {
605 {"", 0} 609 {"", 0}
606}; 610};
607 611
612static const struct dev_pm_ops gmux_dev_pm_ops = {
613 .suspend = gmux_suspend,
614 .resume = gmux_resume,
615};
616
608static struct pnp_driver gmux_pnp_driver = { 617static struct pnp_driver gmux_pnp_driver = {
609 .name = "apple-gmux", 618 .name = "apple-gmux",
610 .probe = gmux_probe, 619 .probe = gmux_probe,
611 .remove = gmux_remove, 620 .remove = gmux_remove,
612 .id_table = gmux_device_ids, 621 .id_table = gmux_device_ids,
613 .suspend = gmux_suspend, 622 .driver = {
614 .resume = gmux_resume 623 .pm = &gmux_dev_pm_ops,
624 },
615}; 625};
616 626
617static int __init apple_gmux_init(void) 627static int __init apple_gmux_init(void)