Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp11234107imu; Thu, 6 Dec 2018 13:54:18 -0800 (PST) X-Google-Smtp-Source: AFSGD/Vf8/qs+9A/+S6zlKemfnmDIN+q14JDq+3M0J8wj9fYQxsCKZ0JgECLZwKMPr6soyn9Id59 X-Received: by 2002:a62:42d4:: with SMTP id h81mr30141257pfd.259.1544133258342; Thu, 06 Dec 2018 13:54:18 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544133258; cv=none; d=google.com; s=arc-20160816; b=PGaQhYg0y+1+IBMMhomt3hoOT2KW/Vr2Q8zxxPnIM37h/Mi8duE9RH77GEn6TDk3Qw C4nZXtku1WvPnds1jKiwcUED9AuieanlilQLKjxlbkYArf4bDT/eF3YUHNzGUKyUhLdm yX1ywbCdD/DJ01EiRe5NHvWYcB8HameShnaDQjoAk+64secCb8Io2tlMKduBZYoHPiqQ 2TV9/s4/JFE88pHyLf892tfITDYTpcWiz5EKITaz97WHH35zNOTtm/qf2lOaMKeA4IPh iEi8X43oz5Zc68+fwbqFSG+MJrWjsepab4mOpoJnPWLJcOR2fvXLQTWVtlh2hiXWVuWJ XU+Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dmarc-filter :dkim-signature:dkim-signature; bh=FfqlEJBL0h4PlG3EGmpAni7ObsTZ5lQYRfmZ8PPv6GI=; b=UM/sLHfFWzkYtg2VUuAPxB7eCXuH2DOjyJJkVNGkn1TDb7P/bL8Xzh8C8fKDrFWfDw DWuzxAHP5s0k0TtpwZ2W6/XGTa7F8lEljsS8TPG3vOn8mIZwQ1Mf39uLFdu7ejX861Qo dj5hsydULBQHHTXmNOZVceCwVN2v3QeZJ/2NZs30iM1v9Xa7JFfHmb9EUlFzsEV8kHPj nEpMs64pVu3VDwfKamdrMe67ui/kFeYwBkpcgAaTYbIT+/g7JqY1jrdUWoBtDK8agRZq dMnBsDJFL56vNT29w6tFAnYK4/SV2Omq39RY32fsrmQcM1Y3om7sSejP+ihTsY72UxYu 5dDA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=AuRqnsHB; dkim=pass header.i=@codeaurora.org header.s=default header.b=Qk6N1dXh; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 204si1290042pfu.273.2018.12.06.13.54.02; Thu, 06 Dec 2018 13:54:18 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=AuRqnsHB; dkim=pass header.i=@codeaurora.org header.s=default header.b=Qk6N1dXh; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726019AbeLFVx1 (ORCPT + 99 others); Thu, 6 Dec 2018 16:53:27 -0500 Received: from smtp.codeaurora.org ([198.145.29.96]:39948 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725945AbeLFVx0 (ORCPT ); Thu, 6 Dec 2018 16:53:26 -0500 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 1BAF060B7E; Thu, 6 Dec 2018 21:53:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1544133205; bh=Q8BIfm9Udyijxho8wELnzvz/rcNmTRyjFuV2hlA5Ty0=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=AuRqnsHBkYSzfFPlk/gZglFDUh0zFLqXLD0OalilLTJ4MXdVMWVgEaJVcd/ou5zQk drYlXj1FhL1S3s9mDCaI6KliiBZcdj1R8rR2xrQHvPaRwXwKgzmdJK0liAk7lJX2CE Si+M6LTwlqbpmOZ8GJ7BjHUoEvmWyJQNSYs++vB8= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.7 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_INVALID,DKIM_SIGNED autolearn=no autolearn_force=no version=3.4.0 Received: from [10.46.162.234] (i-global254.qualcomm.com [199.106.103.254]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: daidavid1@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id 5942F6019F; Thu, 6 Dec 2018 21:53:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1544133203; bh=Q8BIfm9Udyijxho8wELnzvz/rcNmTRyjFuV2hlA5Ty0=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=Qk6N1dXhax+JGynONfXAz1NccXegykdM6lPQtGMxnMem+QL/Ka+tA4s1wVhevQmWH TrBmhQlI25qYnFlxPJAdW+89VjuK1DXH3K/peAwIvCA5zhCesjS8Br6ExYEuux8Xsj n+WHWTWLieJXJ3Mvs/Iwt25g3lm7XW8GZisS5f0o= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 5942F6019F Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=daidavid1@codeaurora.org Subject: Re: [PATCH v10 5/7] interconnect: qcom: Add sdm845 interconnect provider driver To: Georgi Djakov , Evan Green Cc: linux-pm@vger.kernel.org, gregkh@linuxfoundation.org, rjw@rjwysocki.net, robh+dt@kernel.org, Michael Turquette , khilman@baylibre.com, Vincent Guittot , Saravana Kannan , Bjorn Andersson , amit.kucheria@linaro.org, seansw@qti.qualcomm.com, mark.rutland@arm.com, lorenzo.pieralisi@arm.com, Alexandre Bailon , maxime.ripard@bootlin.com, Arnd Bergmann , thierry.reding@gmail.com, ksitaraman@nvidia.com, sanjayc@nvidia.com, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-arm-msm@vger.kernel.org, linux-tegra@vger.kernel.org References: <20181127180349.29997-1-georgi.djakov@linaro.org> <20181127180349.29997-6-georgi.djakov@linaro.org> From: David Dai Message-ID: <266c7bf9-18c1-8255-eca2-814aab3850c6@codeaurora.org> Date: Thu, 6 Dec 2018 13:53:21 -0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 12/5/2018 8:00 AM, Georgi Djakov wrote: > Hi Evan, > > On 12/1/18 02:39, Evan Green wrote: >> On Tue, Nov 27, 2018 at 10:04 AM Georgi Djakov wrote: >>> From: David Dai >>> >>> Introduce Qualcomm SDM845 specific provider driver using the >>> interconnect framework. >>> >>> Signed-off-by: David Dai >>> Signed-off-by: Georgi Djakov >>> --- >>> .../bindings/interconnect/qcom,sdm845.txt | 24 + >>> drivers/interconnect/Kconfig | 5 + >>> drivers/interconnect/Makefile | 1 + >>> drivers/interconnect/qcom/Kconfig | 13 + >>> drivers/interconnect/qcom/Makefile | 5 + >>> drivers/interconnect/qcom/sdm845.c | 836 ++++++++++++++++++ >>> .../dt-bindings/interconnect/qcom,sdm845.h | 143 +++ >>> 7 files changed, 1027 insertions(+) >>> create mode 100644 Documentation/devicetree/bindings/interconnect/qcom,sdm845.txt >>> create mode 100644 drivers/interconnect/qcom/Kconfig >>> create mode 100644 drivers/interconnect/qcom/Makefile >>> create mode 100644 drivers/interconnect/qcom/sdm845.c >>> create mode 100644 include/dt-bindings/interconnect/qcom,sdm845.h >>> >>> diff --git a/Documentation/devicetree/bindings/interconnect/qcom,sdm845.txt b/Documentation/devicetree/bindings/interconnect/qcom,sdm845.txt >>> new file mode 100644 >>> index 000000000000..d45150e99665 >>> --- /dev/null >>> +++ b/Documentation/devicetree/bindings/interconnect/qcom,sdm845.txt >>> @@ -0,0 +1,24 @@ >>> +Qualcomm SDM845 Network-On-Chip interconnect driver binding >>> +----------------------------------------------------------- >>> + >>> +SDM845 interconnect providers support system bandwidth requirements through >>> +RPMh hardware accelerators known as Bus Clock Manager(BCM). The provider is able >>> +to communicate with the BCM through the Resource State Coordinator(RSC) >>> +associated with each execution environment. Provider nodes must reside within >>> +an RPMh device node pertaining to their RSC and each provider maps to >>> +a single RPMh resource. >>> + >>> +Required properties : >>> +- compatible : shall contain only one of the following: >>> + "qcom,sdm845-rsc-hlos" >> I wonder if maybe hlos isn't necessary. Unless you somehow imagine >> secure mode would have a device tree entry in here as well? Probably >> not. > Ok, will remove it. David, please chime in if you have any concerns with > this. No strong preferences in terms of naming, but need to make the distinction between this and potential other rsc types if we're to add additional provider drivers. >>> +- #interconnect-cells : should contain 1 >>> + >>> +Examples: >>> + >>> +apps_rsc: rsc { >>> + qnoc: qnoc-rsc-hlos { >>> + compatible = "qcom,sdm845-rsc-hlos"; >>> + #interconnect-cells = <1>; >>> + }; >>> +}; >>> + >> ... >>> diff --git a/drivers/interconnect/qcom/sdm845.c b/drivers/interconnect/qcom/sdm845.c >>> new file mode 100644 >>> index 000000000000..1678de91ca52 >>> --- /dev/null >>> +++ b/drivers/interconnect/qcom/sdm845.c >>> @@ -0,0 +1,836 @@ >> ... >>> + >>> +static void tcs_list_gen(struct list_head *bcm_list, >>> + struct tcs_cmd *tcs_list, int *n) >> We could make the prototype of this function be: >> >> static void tcs_list_gen(struct list_head *bcm_list, >> struct tcs_cmd tcs_list[SDM845_MAX_VCD], int n[SDM845_MAX_VCD]) >> >> which would catch errors if somebody later passed in an array that >> wasn't the right size, since we blindly memset below. > Yes, sounds good. I will try to optimize it. > > Thanks, > Georgi > >>> +{ >>> + struct qcom_icc_bcm *bcm; >>> + bool commit; >>> + size_t idx = 0, batch = 0, cur_vcd_size = 0; >>> + >>> + memset(n, 0, sizeof(int) * SDM845_MAX_VCD); >>> + >>> + list_for_each_entry(bcm, bcm_list, list) { >>> + commit = false; >>> + cur_vcd_size++; >>> + if ((list_is_last(&bcm->list, bcm_list)) || >>> + bcm->aux_data.vcd != list_next_entry(bcm, list)->aux_data.vcd) { >>> + commit = true; >>> + cur_vcd_size = 0; >>> + } >>> + tcs_cmd_gen(&tcs_list[idx], bcm->vote_x, bcm->vote_y, >>> + bcm->addr, commit); >>> + idx++; >>> + n[batch]++; >>> + /* >>> + * Batch the BCMs in such a way that we do not split them in >>> + * multiple payloads when they are under the same VCD. This is >>> + * to ensure that every BCM is committed since we only set the >>> + * commit bit on the last BCM request of every VCD. >>> + */ >>> + if (n[batch] >= MAX_RPMH_PAYLOAD) { >>> + if (!commit) { >>> + n[batch] -= cur_vcd_size; >>> + n[batch + 1] = cur_vcd_size; >>> + } >>> + batch++; >>> + } >>> + } >>> +} >>> + -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project