Received: by 2002:a05:6a10:c604:0:0:0:0 with SMTP id y4csp3779383pxt; Tue, 10 Aug 2021 11:07:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxxGX0p5LFUtTYDTKaJ9bCCjgSqjxNpJorXmL0bNMCD34HE8PEPd4NsUkXnWAIwB1foB6az X-Received: by 2002:a02:b798:: with SMTP id f24mr28961299jam.14.1628618859401; Tue, 10 Aug 2021 11:07:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1628618859; cv=none; d=google.com; s=arc-20160816; b=cpH0Vv31LV6vaIdNehXoLeMWf7UKoSRM9r1CCa4wW+mEDVE5ZMS1RVMOuPFAZ65/6n PBJd+cFnhnTpSIB07tYOrnSrbn/0iSHaRqg92X0i5jRUcdb8gTQirHIJqy446kyiE/IJ GLkCcnmUlKuM7yk32nkLMbM0VgBdhT+GY01QYQyod7yHSA0P71QzulS8xvR0prOxoJ9y f5BwVBA/kMZUXCVPLwCj4Gt3E5bnJSj0kOlW1PLk048bfoxfhfcPa9pYFVKACVI2yIoh hkFqpqIuIJBXBL+AEc2+TTXlRBHvMP+R7e/AG6FZs4IbfQEgvJDi4SGxPqiUDtmQgTF0 wzbg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=Z9zeyzJc2n+r4rsYLOzDr3caUG/ilKkO6kJ+1irzgtE=; b=iD1X3xHHYwMB68DpM7R9eqqaMWYjK6tZfHEJ0TTl8OAuChoEUg/wQivPmic0DUcwGK ilKojG6q+LYkKO+9LPtv8mksMF2tcmPN+JwAB9DAa6WeG01+npGlgOB5H2HZQzBBfNDd NIU8tAE+c60tb65hYp/D1IVpig/AQFPxXBZj15TC4kSEmls/hzzvPgGiAKnvETHdGqp1 0sv83hAEVK2KLdjxVLp0Js4RmsJP8S0gScce4gUr6Erg76sregtJe9mDFLs4rw3vS22k p4715pRkZo4XTzXtCk03dXDEEpuNtrryDm91jlB09J1TUNiqqVWKJ7q/mbFSMqwNnGIz lyiA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=VhDuCt+V; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f12si23801334ila.117.2021.08.10.11.07.11; Tue, 10 Aug 2021 11:07:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=VhDuCt+V; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236352AbhHJSGr (ORCPT + 99 others); Tue, 10 Aug 2021 14:06:47 -0400 Received: from mail.kernel.org ([198.145.29.99]:39398 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236779AbhHJSDT (ORCPT ); Tue, 10 Aug 2021 14:03:19 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 220FF61251; Tue, 10 Aug 2021 17:47:43 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1628617664; bh=Wxvvm94BJFdhmcnx0FizZHyBx0eUN7fIOrXYHStTKQc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=VhDuCt+VRDJrddPcE/9RqxToTLEQqoF/Dd5z6sua6KjAHdglO+bZC7HTZQZGLBSps +oX5NBdkRCVk06d7KHcJTqfae5NQZ1DwjebyXj0iDZ3jvZArTbIZ3c1uo3TDHpM61L ct7zPJ6mI2CF2hbtSBh3TJe48o7laNgQTMVlsHoE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Mike Tipton , Georgi Djakov Subject: [PATCH 5.13 158/175] interconnect: qcom: icc-rpmh: Ensure floor BW is enforced for all nodes Date: Tue, 10 Aug 2021 19:31:06 +0200 Message-Id: <20210810173006.171793648@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210810173000.928681411@linuxfoundation.org> References: <20210810173000.928681411@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Mike Tipton commit ce5a595744126be4f1327e29e3c5ae9aac6b38d5 upstream. We currently only enforce BW floors for a subset of nodes in a path. All BCMs that need updating are queued in the pre_aggregate/aggregate phase. The first set() commits all queued BCMs and subsequent set() calls short-circuit without committing anything. Since the floor BW isn't set in sum_avg/max_peak until set(), then some BCMs are committed before their associated nodes reflect the floor. Set the floor as each node is being aggregated. This ensures that all all relevant floors are set before the BCMs are committed. Fixes: 266cd33b5913 ("interconnect: qcom: Ensure that the floor bandwidth value is enforced") Signed-off-by: Mike Tipton Link: https://lore.kernel.org/r/20210721175432.2119-4-mdtipton@codeaurora.org [georgi: Removed unused variable] Signed-off-by: Georgi Djakov Signed-off-by: Greg Kroah-Hartman --- drivers/interconnect/qcom/icc-rpmh.c | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) --- a/drivers/interconnect/qcom/icc-rpmh.c +++ b/drivers/interconnect/qcom/icc-rpmh.c @@ -57,6 +57,11 @@ int qcom_icc_aggregate(struct icc_node * qn->sum_avg[i] += avg_bw; qn->max_peak[i] = max_t(u32, qn->max_peak[i], peak_bw); } + + if (node->init_avg || node->init_peak) { + qn->sum_avg[i] = max_t(u64, qn->sum_avg[i], node->init_avg); + qn->max_peak[i] = max_t(u64, qn->max_peak[i], node->init_peak); + } } *agg_avg += avg_bw; @@ -79,7 +84,6 @@ EXPORT_SYMBOL_GPL(qcom_icc_aggregate); int qcom_icc_set(struct icc_node *src, struct icc_node *dst) { struct qcom_icc_provider *qp; - struct qcom_icc_node *qn; struct icc_node *node; if (!src) @@ -88,12 +92,6 @@ int qcom_icc_set(struct icc_node *src, s node = src; qp = to_qcom_provider(node->provider); - qn = node->data; - - qn->sum_avg[QCOM_ICC_BUCKET_AMC] = max_t(u64, qn->sum_avg[QCOM_ICC_BUCKET_AMC], - node->avg_bw); - qn->max_peak[QCOM_ICC_BUCKET_AMC] = max_t(u64, qn->max_peak[QCOM_ICC_BUCKET_AMC], - node->peak_bw); qcom_icc_bcm_voter_commit(qp->voter);