Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp969088pxk; Thu, 17 Sep 2020 23:32:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwc1fH9nNEX5rEAz+T10l3NHiWbJWasDjFLfBkKIzeUy5NgJd1TJvQLQ7OeLzjFJrxCFeVs X-Received: by 2002:a17:906:aec1:: with SMTP id me1mr17683155ejb.225.1600410739806; Thu, 17 Sep 2020 23:32:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600410739; cv=none; d=google.com; s=arc-20160816; b=o5G0MClHXLAj3e32deDXulQf6TP+ZaVnhQgftG58BdWDJknOCZUQgHayRxDxrZx+x5 G3A7SsoZusgdmkVt31N2MJy5b3zfDekB/yObtm5pZsimSbndOVUw2HGbG+6AMgD/0UAt sQ3eRBlIbYWEZfH0QTsNvHIAkSgV5tEUaig9pMS3Cfw1O1gxOkg5iO0jGz6xpQ+wKl5Y Sqii8PDivQSYGZJoNOfOi7V/mfD62P1pP2F+1jMdaRI8Os9wKTUFq44V11Nbh++T3i4P QmkUXqYQoAgjgBDJORDBS5w3nTWaZFowoZ0LSAfYKU+pGGC/fXO/seHBrxENtkY+7kXJ GnEw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent:message-id:in-reply-to :date:references:subject:cc:to:from; bh=ErHRb7vnQoQ0BmLkFxKHZzAKIv6+D294XxCW1kiIIMw=; b=TUdI4OdnfxZiH26crEimXXSykFXQR5lAhRim4ISwxkfoiau3fzDLTsFX++fK4Gt3j5 p7ArHAE66BXahHbCt6WvIgpLSaWgqktrmIDZC3/oXRbbvzuNq0TyY9AES+hMyrHPahGJ 0gB2Eso/4g/1JF4YygrAmrINUQWbcLFAx3xDvEGvb99Bi9QCn+wgYr8q2NuLdms9mGy5 AASsdnQjNiYdnL4Oh80LqGqqNJZu7xrUXBMt2eahiL26xlkeYAmZGZ8bA+IMSsj5kmAn Ty1z1/LxbxtVhJP033UmQhwXc+FQjG0ABgUsgrUQWaEHVZehus9Ld8z4kdyhi8ZSHAN3 37yA== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=toshiba.co.jp Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d11si1370236edu.492.2020.09.17.23.31.56; Thu, 17 Sep 2020 23:32:19 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=toshiba.co.jp Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726338AbgIRG3K (ORCPT + 99 others); Fri, 18 Sep 2020 02:29:10 -0400 Received: from mo-csw1516.securemx.jp ([210.130.202.155]:39796 "EHLO mo-csw.securemx.jp" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725886AbgIRG3K (ORCPT ); Fri, 18 Sep 2020 02:29:10 -0400 Received: by mo-csw.securemx.jp (mx-mo-csw1516) id 08I6StZl003562; Fri, 18 Sep 2020 15:28:55 +0900 X-Iguazu-Qid: 34trFrx2pqNWq2MYnj X-Iguazu-QSIG: v=2; s=0; t=1600410535; q=34trFrx2pqNWq2MYnj; m=XWOMKSutyKBJnyIaL4q4wThvZCfnOaUx8ba8QIcGqvo= Received: from imx2.toshiba.co.jp (imx2.toshiba.co.jp [106.186.93.51]) by relay.securemx.jp (mx-mr1510) id 08I6Srbq032718; Fri, 18 Sep 2020 15:28:53 +0900 Received: from enc01.toshiba.co.jp ([106.186.93.100]) by imx2.toshiba.co.jp with ESMTP id 08I6Srv6006057; Fri, 18 Sep 2020 15:28:53 +0900 (JST) Received: from hop001.toshiba.co.jp ([133.199.164.63]) by enc01.toshiba.co.jp with ESMTP id 08I6Sq6W005477; Fri, 18 Sep 2020 15:28:53 +0900 From: Punit Agrawal To: Ben Levinsky Cc: stefanos@xilinx.com, michals@xilinx.com, michael.auchter@ni.com, devicetree@vger.kernel.org, emooring@xilinx.com, mathieu.poirier@linaro.org, linux-remoteproc@vger.kernel.org, linux-kernel@vger.kernel.org, jliang@xilinx.com, robh+dt@kernel.org, Jason Wu , Michal Simek , linux-arm-kernel@lists.infradead.org Subject: Re: [PATCH v14 4/5] dt-bindings: remoteproc: Add documentation for ZynqMP R5 rproc bindings References: <20200917194341.16272-1-ben.levinsky@xilinx.com> <20200917194341.16272-5-ben.levinsky@xilinx.com> Date: Fri, 18 Sep 2020 15:28:50 +0900 In-Reply-To: <20200917194341.16272-5-ben.levinsky@xilinx.com> (Ben Levinsky's message of "Thu, 17 Sep 2020 12:43:40 -0700") X-TSB-HOP: ON Message-ID: <87r1qzlhst.fsf@kokedama.swc.toshiba.co.jp> User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/26.3 (gnu/linux) MIME-Version: 1.0 Content-Type: text/plain Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Ben, One query below - Ben Levinsky writes: > Add binding for ZynqMP R5 OpenAMP. > > Represent the RPU domain resources in one device node. Each RPU > processor is a subnode of the top RPU domain node. > > Signed-off-by: Jason Wu > Signed-off-by: Wendy Liang > Signed-off-by: Michal Simek > > Signed-off-by: Ben Levinsky > --- [...] > .../xilinx,zynqmp-r5-remoteproc.yaml | 119 ++++++++++++++++++ > 1 file changed, 119 insertions(+) > create mode 100644 Documentation/devicetree/bindings/remoteproc/xilinx,zynqmp-r5-remoteproc.yaml > > diff --git a/Documentation/devicetree/bindings/remoteproc/xilinx,zynqmp-r5-remoteproc.yaml b/Documentation/devicetree/bindings/remoteproc/xilinx,zynqmp-r5-remoteproc.yaml > new file mode 100644 > index 000000000000..cd2406b4dc24 > --- /dev/null > +++ b/Documentation/devicetree/bindings/remoteproc/xilinx,zynqmp-r5-remoteproc.yaml > @@ -0,0 +1,119 @@ > +# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause) > +%YAML 1.2 > +--- > +$id: "http://devicetree.org/schemas/remoteproc/xilinx,zynqmp-r5-remoteproc.yaml#" > +$schema: "http://devicetree.org/meta-schemas/core.yaml#" > + > +title: Xilinx R5 remote processor controller bindings > + > +description: > + This document defines the binding for the remoteproc component that loads and > + boots firmwares on the Xilinx Zynqmp and Versal family chipset. > + > + Note that the Linux has global addressing view of the R5-related memory (TCM) > + so the absolute address ranges are provided in TCM reg's. > +maintainers: > + - Ed Mooring > + - Ben Levinsky > + > +properties: > + compatible: > + const: "xlnx,zynqmp-r5-remoteproc-1.0" > + > + lockstep-mode: > + description: > + R5 core configuration (split is 0 or lock-step and 1) > + maxItems: 1 Looking at the driver, it seems that it is possible to set the R5s to operate in split or lock-step mode dynamically. If so, the device tree shouldn't really contain this property. Wouldn't it be better to give the users flexibility to choose the mode at run time? Thanks, Punit > + > + interrupts: > + description: > + Interrupt mapping for remoteproc IPI. It is required if the > + user uses the remoteproc driver with the RPMsg kernel driver. > + maxItems: 6 > + > + memory-region: > + description: > + collection of memory carveouts used for elf-loading and inter-processor > + communication. > + maxItems: 4 > + minItems: 4 > + meta-memory-regions: > + description: > + collection of memories that are not present in the top level memory > + nodes' mapping. For example, R5s' TCM banks. These banks are needed > + for R5 firmware meta data such as the R5 firmware's heap and stack > + pnode-id: > + maxItems: 1 > + mboxes: > + maxItems: 2 > + mbox-names: > + maxItems: 2 > + > +examples: > + - | > + reserved-memory { > + #address-cells = <1>; > + #size-cells = <1>; > + ranges; > + elf_load: rproc@3ed000000 { > + no-map; > + reg = <0x3ed00000 0x40000>; > + }; > + > + rpu0vdev0vring0: rpu0vdev0vring0@3ed40000 { > + no-map; > + reg = <0x3ed40000 0x4000>; > + }; > + rpu0vdev0vring1: rpu0vdev0vring1@3ed44000 { > + no-map; > + reg = <0x3ed44000 0x4000>; > + }; > + rpu0vdev0buffer: rpu0vdev0buffer@3ed48000 { > + no-map; > + reg = <0x3ed48000 0x100000>; > + }; > + > + }; > + > + /* > + * Below nodes are required if using TCM to load R5 firmware > + * if not, then either do not provide nodes are label as disabled in > + * status property > + */ > + tcm0a: tcm_0a@ffe00000 { > + reg = <0xffe00000 0x10000>; > + pnode-id = <0xf>; > + no-map; > + status = "okay"; > + phandle = <0x40>; > + compatible = "xlnx,tcm"; > + }; > + tcm0b: tcm_1a@ffe20000 { > + reg = <0xffe20000 0x10000>; > + pnode-id = <0x10>; > + no-map; > + status = "okay"; > + compatible = "xlnx,tcm"; > + phandle = <0x41>; > + }; > + > + rpu { > + compatible = "xlnx,zynqmp-r5-remoteproc-1.0"; > + #address-cells = <1>; > + #size-cells = <1>; > + ranges; > + lockstep-mode = <1>; > + r5_0 { > + ranges; > + #address-cells = <1>; > + #size-cells = <1>; > + memory-region = <&elf_load>, > + <&rpu0vdev0vring0>, > + <&rpu0vdev0vring1>, > + <&rpu0vdev0buffer>; > + meta-memory-regions = <&tcm_0a>, <&tcm_0b>; > + pnode-id = <0x7>; > + }; > + }; > + > +...