linux-pm.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] interconnect: Aggregate bandwidth votes for unused nodes in sync_state()
@ 2021-06-19 17:08 Odelu Kukatla
  2021-06-21 16:33 ` Matthias Kaehlcke
  2021-06-25 21:20 ` Mike Tipton
  0 siblings, 2 replies; 3+ messages in thread
From: Odelu Kukatla @ 2021-06-19 17:08 UTC (permalink / raw)
  To: georgi.djakov, bjorn.andersson, evgreen, Georgi Djakov, linux-pm,
	linux-kernel
  Cc: sboyd, mdtipton, sibis, saravanak, okukatla, seansw, elder,
	linux-arm-msm, linux-arm-msm-owner

When removing the initial bandwidth votes in sync_state(), make sure
to call the aggregate() function for nodes which don't have any
clients yet. aggregate_requests() does not invoke aggregate()
for unused nodes.

Signed-off-by: Odelu Kukatla <okukatla@codeaurora.org>
---
 drivers/interconnect/core.c | 11 ++++++++++-
 1 file changed, 10 insertions(+), 1 deletion(-)

diff --git a/drivers/interconnect/core.c b/drivers/interconnect/core.c
index 8a1e70e..1d9a00a 100644
--- a/drivers/interconnect/core.c
+++ b/drivers/interconnect/core.c
@@ -1106,7 +1106,16 @@ void icc_sync_state(struct device *dev)
 		dev_dbg(p->dev, "interconnect provider is in synced state\n");
 		list_for_each_entry(n, &p->nodes, node_list) {
 			if (n->init_avg || n->init_peak) {
-				aggregate_requests(n);
+				if (hlist_empty(&n->req_list)) {
+					if (p->pre_aggregate)
+						p->pre_aggregate(n);
+
+					p->aggregate(n, 0, 0, 0, &n->avg_bw,
+						&n->peak_bw);
+				} else {
+					aggregate_requests(n);
+				}
+
 				p->set(n, n);
 			}
 		}
-- 
The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum,
a Linux Foundation Collaborative Project


^ permalink raw reply related	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2021-06-25 21:20 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-06-19 17:08 [PATCH] interconnect: Aggregate bandwidth votes for unused nodes in sync_state() Odelu Kukatla
2021-06-21 16:33 ` Matthias Kaehlcke
2021-06-25 21:20 ` Mike Tipton

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).