|
|
@@ -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;
|
|
|
|