diff options
Diffstat (limited to 'drivers/base/power/main.c')
-rw-r--r-- | drivers/base/power/main.c | 64 |
1 files changed, 31 insertions, 33 deletions
diff --git a/drivers/base/power/main.c b/drivers/base/power/main.c index abe3ab709e87..3b354560f306 100644 --- a/drivers/base/power/main.c +++ b/drivers/base/power/main.c | |||
@@ -426,10 +426,8 @@ static int device_resume_noirq(struct device *dev, pm_message_t state) | |||
426 | 426 | ||
427 | if (dev->pwr_domain) { | 427 | if (dev->pwr_domain) { |
428 | pm_dev_dbg(dev, state, "EARLY power domain "); | 428 | pm_dev_dbg(dev, state, "EARLY power domain "); |
429 | pm_noirq_op(dev, &dev->pwr_domain->ops, state); | 429 | error = pm_noirq_op(dev, &dev->pwr_domain->ops, state); |
430 | } | 430 | } else if (dev->type && dev->type->pm) { |
431 | |||
432 | if (dev->type && dev->type->pm) { | ||
433 | pm_dev_dbg(dev, state, "EARLY type "); | 431 | pm_dev_dbg(dev, state, "EARLY type "); |
434 | error = pm_noirq_op(dev, dev->type->pm, state); | 432 | error = pm_noirq_op(dev, dev->type->pm, state); |
435 | } else if (dev->class && dev->class->pm) { | 433 | } else if (dev->class && dev->class->pm) { |
@@ -517,7 +515,8 @@ static int device_resume(struct device *dev, pm_message_t state, bool async) | |||
517 | 515 | ||
518 | if (dev->pwr_domain) { | 516 | if (dev->pwr_domain) { |
519 | pm_dev_dbg(dev, state, "power domain "); | 517 | pm_dev_dbg(dev, state, "power domain "); |
520 | pm_op(dev, &dev->pwr_domain->ops, state); | 518 | error = pm_op(dev, &dev->pwr_domain->ops, state); |
519 | goto End; | ||
521 | } | 520 | } |
522 | 521 | ||
523 | if (dev->type && dev->type->pm) { | 522 | if (dev->type && dev->type->pm) { |
@@ -629,12 +628,11 @@ static void device_complete(struct device *dev, pm_message_t state) | |||
629 | { | 628 | { |
630 | device_lock(dev); | 629 | device_lock(dev); |
631 | 630 | ||
632 | if (dev->pwr_domain && dev->pwr_domain->ops.complete) { | 631 | if (dev->pwr_domain) { |
633 | pm_dev_dbg(dev, state, "completing power domain "); | 632 | pm_dev_dbg(dev, state, "completing power domain "); |
634 | dev->pwr_domain->ops.complete(dev); | 633 | if (dev->pwr_domain->ops.complete) |
635 | } | 634 | dev->pwr_domain->ops.complete(dev); |
636 | 635 | } else if (dev->type && dev->type->pm) { | |
637 | if (dev->type && dev->type->pm) { | ||
638 | pm_dev_dbg(dev, state, "completing type "); | 636 | pm_dev_dbg(dev, state, "completing type "); |
639 | if (dev->type->pm->complete) | 637 | if (dev->type->pm->complete) |
640 | dev->type->pm->complete(dev); | 638 | dev->type->pm->complete(dev); |
@@ -732,7 +730,12 @@ static int device_suspend_noirq(struct device *dev, pm_message_t state) | |||
732 | { | 730 | { |
733 | int error; | 731 | int error; |
734 | 732 | ||
735 | if (dev->type && dev->type->pm) { | 733 | if (dev->pwr_domain) { |
734 | pm_dev_dbg(dev, state, "LATE power domain "); | ||
735 | error = pm_noirq_op(dev, &dev->pwr_domain->ops, state); | ||
736 | if (error) | ||
737 | return error; | ||
738 | } else if (dev->type && dev->type->pm) { | ||
736 | pm_dev_dbg(dev, state, "LATE type "); | 739 | pm_dev_dbg(dev, state, "LATE type "); |
737 | error = pm_noirq_op(dev, dev->type->pm, state); | 740 | error = pm_noirq_op(dev, dev->type->pm, state); |
738 | if (error) | 741 | if (error) |
@@ -749,11 +752,6 @@ static int device_suspend_noirq(struct device *dev, pm_message_t state) | |||
749 | return error; | 752 | return error; |
750 | } | 753 | } |
751 | 754 | ||
752 | if (dev->pwr_domain) { | ||
753 | pm_dev_dbg(dev, state, "LATE power domain "); | ||
754 | pm_noirq_op(dev, &dev->pwr_domain->ops, state); | ||
755 | } | ||
756 | |||
757 | return 0; | 755 | return 0; |
758 | } | 756 | } |
759 | 757 | ||
@@ -841,21 +839,27 @@ static int __device_suspend(struct device *dev, pm_message_t state, bool async) | |||
841 | goto End; | 839 | goto End; |
842 | } | 840 | } |
843 | 841 | ||
842 | if (dev->pwr_domain) { | ||
843 | pm_dev_dbg(dev, state, "power domain "); | ||
844 | error = pm_op(dev, &dev->pwr_domain->ops, state); | ||
845 | goto End; | ||
846 | } | ||
847 | |||
844 | if (dev->type && dev->type->pm) { | 848 | if (dev->type && dev->type->pm) { |
845 | pm_dev_dbg(dev, state, "type "); | 849 | pm_dev_dbg(dev, state, "type "); |
846 | error = pm_op(dev, dev->type->pm, state); | 850 | error = pm_op(dev, dev->type->pm, state); |
847 | goto Domain; | 851 | goto End; |
848 | } | 852 | } |
849 | 853 | ||
850 | if (dev->class) { | 854 | if (dev->class) { |
851 | if (dev->class->pm) { | 855 | if (dev->class->pm) { |
852 | pm_dev_dbg(dev, state, "class "); | 856 | pm_dev_dbg(dev, state, "class "); |
853 | error = pm_op(dev, dev->class->pm, state); | 857 | error = pm_op(dev, dev->class->pm, state); |
854 | goto Domain; | 858 | goto End; |
855 | } else if (dev->class->suspend) { | 859 | } else if (dev->class->suspend) { |
856 | pm_dev_dbg(dev, state, "legacy class "); | 860 | pm_dev_dbg(dev, state, "legacy class "); |
857 | error = legacy_suspend(dev, state, dev->class->suspend); | 861 | error = legacy_suspend(dev, state, dev->class->suspend); |
858 | goto Domain; | 862 | goto End; |
859 | } | 863 | } |
860 | } | 864 | } |
861 | 865 | ||
@@ -869,12 +873,6 @@ static int __device_suspend(struct device *dev, pm_message_t state, bool async) | |||
869 | } | 873 | } |
870 | } | 874 | } |
871 | 875 | ||
872 | Domain: | ||
873 | if (!error && dev->pwr_domain) { | ||
874 | pm_dev_dbg(dev, state, "power domain "); | ||
875 | pm_op(dev, &dev->pwr_domain->ops, state); | ||
876 | } | ||
877 | |||
878 | End: | 876 | End: |
879 | device_unlock(dev); | 877 | device_unlock(dev); |
880 | complete_all(&dev->power.completion); | 878 | complete_all(&dev->power.completion); |
@@ -965,7 +963,14 @@ static int device_prepare(struct device *dev, pm_message_t state) | |||
965 | 963 | ||
966 | device_lock(dev); | 964 | device_lock(dev); |
967 | 965 | ||
968 | if (dev->type && dev->type->pm) { | 966 | if (dev->pwr_domain) { |
967 | pm_dev_dbg(dev, state, "preparing power domain "); | ||
968 | if (dev->pwr_domain->ops.prepare) | ||
969 | error = dev->pwr_domain->ops.prepare(dev); | ||
970 | suspend_report_result(dev->pwr_domain->ops.prepare, error); | ||
971 | if (error) | ||
972 | goto End; | ||
973 | } else if (dev->type && dev->type->pm) { | ||
969 | pm_dev_dbg(dev, state, "preparing type "); | 974 | pm_dev_dbg(dev, state, "preparing type "); |
970 | if (dev->type->pm->prepare) | 975 | if (dev->type->pm->prepare) |
971 | error = dev->type->pm->prepare(dev); | 976 | error = dev->type->pm->prepare(dev); |
@@ -984,13 +989,6 @@ static int device_prepare(struct device *dev, pm_message_t state) | |||
984 | if (dev->bus->pm->prepare) | 989 | if (dev->bus->pm->prepare) |
985 | error = dev->bus->pm->prepare(dev); | 990 | error = dev->bus->pm->prepare(dev); |
986 | suspend_report_result(dev->bus->pm->prepare, error); | 991 | suspend_report_result(dev->bus->pm->prepare, error); |
987 | if (error) | ||
988 | goto End; | ||
989 | } | ||
990 | |||
991 | if (dev->pwr_domain && dev->pwr_domain->ops.prepare) { | ||
992 | pm_dev_dbg(dev, state, "preparing power domain "); | ||
993 | dev->pwr_domain->ops.prepare(dev); | ||
994 | } | 992 | } |
995 | 993 | ||
996 | End: | 994 | End: |