PM / OPP: Add support for opp-suspend
authorViresh Kumar <viresh.kumar@linaro.org>
Sat, 13 Jun 2015 09:40:21 +0000 (15:10 +0530)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Fri, 7 Aug 2015 01:06:15 +0000 (03:06 +0200)
With "operating-points-v2" bindings, it's possible to specify the OPP to
which the device must be switched, before suspending.

This patch adds support for getting that information.

Reviewed-by: Stephen Boyd <sboyd@codeaurora.org>
Reviewed-by: Bartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com>
Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
drivers/base/power/opp.c

index 5d699e3ec13681c4f8ca6929671f85ae079a3820..0ebcea49145abfaa295ea532177ff6cb5f9b5157 100644 (file)
@@ -133,6 +133,7 @@ struct device_opp {
        struct device_node *np;
        unsigned long clock_latency_ns_max;
        bool shared_opp;
+       struct dev_pm_opp *suspend_opp;
 };
 
 /*
@@ -923,6 +924,16 @@ static int _opp_add_static_v2(struct device *dev, struct device_node *np)
        if (ret)
                goto free_opp;
 
+       /* OPP to select on device suspend */
+       if (of_property_read_bool(np, "opp-suspend")) {
+               if (dev_opp->suspend_opp)
+                       dev_warn(dev, "%s: Multiple suspend OPPs found (%lu %lu)\n",
+                                __func__, dev_opp->suspend_opp->rate,
+                                new_opp->rate);
+               else
+                       dev_opp->suspend_opp = new_opp;
+       }
+
        if (new_opp->clock_latency_ns > dev_opp->clock_latency_ns_max)
                dev_opp->clock_latency_ns_max = new_opp->clock_latency_ns;