PM: suspend: Fix platform_suspend_prepare_noirq()
authorRafael J. Wysocki <rafael.j.wysocki@intel.com>
Sat, 10 Aug 2019 11:18:06 +0000 (13:18 +0200)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Sat, 10 Aug 2019 11:18:06 +0000 (13:18 +0200)
After commit ac9eafbe930a ("ACPI: PM: s2idle: Execute LPS0 _DSM
functions with suspended devices"), a NULL pointer may be dereferenced
if suspend-to-idle is attempted on a platform without "traditional"
suspend support due to invalid fall-through in
platform_suspend_prepare_noirq().

Fix that and while at it add missing braces in platform_resume_noirq().

Fixes: ac9eafbe930a ("ACPI: PM: s2idle: Execute LPS0 _DSM functions with suspended devices")
Reported-by: Marek Szyprowski <m.szyprowski@samsung.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
kernel/power/suspend.c

index ed9ddef12b134635caaf2ae7d52f1da17c9283d3..f3b7239f1892fd501ca6a4412e9a4f7f6086bc3b 100644 (file)
@@ -253,10 +253,10 @@ static int platform_suspend_prepare_late(suspend_state_t state)
 
 static int platform_suspend_prepare_noirq(suspend_state_t state)
 {
-       if (state == PM_SUSPEND_TO_IDLE) {
-               if (s2idle_ops && s2idle_ops->prepare_late)
-                       return s2idle_ops->prepare_late();
-       }
+       if (state == PM_SUSPEND_TO_IDLE)
+               return s2idle_ops && s2idle_ops->prepare_late ?
+                       s2idle_ops->prepare_late() : 0;
+
        return suspend_ops->prepare_late ? suspend_ops->prepare_late() : 0;
 }
 
@@ -265,8 +265,9 @@ static void platform_resume_noirq(suspend_state_t state)
        if (state == PM_SUSPEND_TO_IDLE) {
                if (s2idle_ops && s2idle_ops->restore_early)
                        s2idle_ops->restore_early();
-       } else if (suspend_ops->wake)
+       } else if (suspend_ops->wake) {
                suspend_ops->wake();
+       }
 }
 
 static void platform_resume_early(suspend_state_t state)