From patchwork Thu Jul 7 09:38:23 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Bryan O'Donoghue X-Patchwork-Id: 588207 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 9C287C433EF for ; Thu, 7 Jul 2022 09:38:33 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234947AbiGGJib (ORCPT ); Thu, 7 Jul 2022 05:38:31 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42046 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235098AbiGGJia (ORCPT ); Thu, 7 Jul 2022 05:38:30 -0400 Received: from mail-wr1-x434.google.com (mail-wr1-x434.google.com [IPv6:2a00:1450:4864:20::434]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C61EB6594 for ; Thu, 7 Jul 2022 02:38:28 -0700 (PDT) Received: by mail-wr1-x434.google.com with SMTP id s1so25471449wra.9 for ; Thu, 07 Jul 2022 02:38:28 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=9kWQOrhoFmy774oTZXorQk1Sl8VEFQpTuVhXI8f62Fg=; b=Gtbe+RgzEMUXiokTKTzNmYpNVvw6yOPQVvghv90mIBKpwaZFctO7qwcjZU8CXJi8Xp VM8ud0JRdl8qS6XBBsh7RoGUQcK95WTzyiD4lwXH9PtUn/B+zq5lSA7JWDdRr8DmUf4C xWEO7ohWseQ4l3+c6Ad5OQmaUlRtKhltruVGF5sw+KE/mXKxiU4vPaGyXSKhoFrAwj0k 6M+Nex/CHlr7TjIisai7JXuSRdvNhRMyf45ka2DqaTVnCHsim3j/yRRUw1n4TVj/f89b 85kCZ+WTbr4/FSHxSRyjbt5xs31+dZx4BShJ53c3Hm3BLhrgdkOKj1QhOgkotZBlg0W5 bsjg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=9kWQOrhoFmy774oTZXorQk1Sl8VEFQpTuVhXI8f62Fg=; b=CGwgxNQOz6CB4W8L6YxWDJnrJLHohbOAo7qjxqdCpKYfaAr/NjsLVjDgIMXWKnQkBu Y7ug6lo8v6uuL7jO9H4k+Z8m8vey70ifO48H6BiDlaGyZURoHz16C0YCh5QmjDNTcboY NIk3HEmBBPFComhCEu6Yb6sSTzzLV3Xx3eYFigm9HDr3SGHqQBzJOcQa8IrPhUeICvQC L/pQ7dGCM0dl4za6iT98yFJqchegk0oZqEwR2D5w1Hzkt9q3Ol+qkYn61HT/kRZJMRj9 Y61tt4ssstqq7cZkCOrg3+86wTUXfK5t5bP6slHYAGYSfIxxrypwXk+lVgaRv8voTXFA N1Cg== X-Gm-Message-State: AJIora/XeVQLXCQr+pYj3lWB6MisvSNaPw6K1xWAh9Ch+vWqzwk6aj23 po/rk7gl7Nkbl4ERxFiPw7uzUA== X-Google-Smtp-Source: AGRyM1tbUaUSzMdnUl4PWsdemUZoobZzVtm+vBha/cvhQpP4EuC4TTRfh7ln3HJlSEL4j9z2t6DWng== X-Received: by 2002:a05:6000:15c6:b0:21b:ccda:fc69 with SMTP id y6-20020a05600015c600b0021bccdafc69mr42022615wry.411.1657186707260; Thu, 07 Jul 2022 02:38:27 -0700 (PDT) Received: from sagittarius-a.chello.ie (188-141-3-169.dynamic.upc.ie. [188.141.3.169]) by smtp.gmail.com with ESMTPSA id g1-20020adffc81000000b00213ba3384aesm38877781wrr.35.2022.07.07.02.38.26 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 07 Jul 2022 02:38:26 -0700 (PDT) From: Bryan O'Donoghue To: djakov@kernel.org, agross@kernel.org, bjorn.andersson@linaro.org, konrad.dybcio@somainline.org Cc: linux-arm-msm@vger.kernel.org, linux-pm@vger.kernel.org, shawn.guo@linaro.org, dmitry.baryshkov@linaro.org, leo.yan@linaro.org, bryan.odonoghue@linaro.org Subject: [PATCH] interconnect: icc-rpm: Set destination bandwidth as well as source bandwidth Date: Thu, 7 Jul 2022 10:38:23 +0100 Message-Id: <20220707093823.1691870-1-bryan.odonoghue@linaro.org> X-Mailer: git-send-email 2.36.1 MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: linux-arm-msm@vger.kernel.org Make it possible to set destination as well as source bandwidth. If the *dst pointer is non-NULL. Right now it appears that we never make the destination bw allocation call, which is inconsistent with the downstream way of doing this. Signed-off-by: Bryan O'Donoghue --- drivers/interconnect/qcom/icc-rpm.c | 41 +++++++++++++++++++++-------- 1 file changed, 30 insertions(+), 11 deletions(-) diff --git a/drivers/interconnect/qcom/icc-rpm.c b/drivers/interconnect/qcom/icc-rpm.c index fb013191c29b9..7e8bcbb2f5dba 100644 --- a/drivers/interconnect/qcom/icc-rpm.c +++ b/drivers/interconnect/qcom/icc-rpm.c @@ -233,10 +233,30 @@ static int qcom_icc_rpm_set(int mas_rpm_id, int slv_rpm_id, u64 sum_bw) return ret; } +static int __qcom_icc_set(struct icc_node *n, struct qcom_icc_node *qn, + u64 sum_bw) +{ + int ret; + + if (!qn->qos.ap_owned) { + /* send bandwidth request message to the RPM processor */ + ret = qcom_icc_rpm_set(qn->mas_rpm_id, qn->slv_rpm_id, sum_bw); + if (ret) + return ret; + } else if (qn->qos.qos_mode != -1) { + /* set bandwidth directly from the AP */ + ret = qcom_icc_qos_set(n, sum_bw); + if (ret) + return ret; + } + + return 0; +} + static int qcom_icc_set(struct icc_node *src, struct icc_node *dst) { struct qcom_icc_provider *qp; - struct qcom_icc_node *qn; + struct qcom_icc_node *src_qn = NULL, *dst_qn = NULL; struct icc_provider *provider; struct icc_node *n; u64 sum_bw; @@ -246,7 +266,9 @@ static int qcom_icc_set(struct icc_node *src, struct icc_node *dst) u32 agg_peak = 0; int ret, i; - qn = src->data; + src_qn = src->data; + if (dst) + dst_qn = dst->data; provider = src->provider; qp = to_qcom_provider(provider); @@ -257,21 +279,18 @@ static int qcom_icc_set(struct icc_node *src, struct icc_node *dst) sum_bw = icc_units_to_bps(agg_avg); max_peak_bw = icc_units_to_bps(agg_peak); - if (!qn->qos.ap_owned) { - /* send bandwidth request message to the RPM processor */ - ret = qcom_icc_rpm_set(qn->mas_rpm_id, qn->slv_rpm_id, sum_bw); - if (ret) - return ret; - } else if (qn->qos.qos_mode != -1) { - /* set bandwidth directly from the AP */ - ret = qcom_icc_qos_set(src, sum_bw); + ret = __qcom_icc_set(src, src_qn, sum_bw); + if (ret) + return ret; + if (dst_qn) { + ret = __qcom_icc_set(dst, dst_qn, sum_bw); if (ret) return ret; } rate = max(sum_bw, max_peak_bw); - do_div(rate, qn->buswidth); + do_div(rate, src_qn->buswidth); rate = min_t(u64, rate, LONG_MAX); for (i = 0; i < qp->num_clks; i++) {