lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20221012114429.2341215-2-danishanwar@ti.com>
Date:   Wed, 12 Oct 2022 17:14:25 +0530
From:   MD Danish Anwar <danishanwar@...com>
To:     Bjorn Andersson <bjorn.andersson@...aro.org>,
        Mathieu Poirier <mathieu.poirier@...aro.org>,
        Krzysztof Kozlowski <krzysztof.kozlowski+dt@...aro.org>
CC:     Suman Anna <s-anna@...com>, Roger Quadros <rogerq@...nel.org>,
        <nm@...com>, <vigneshr@...com>, <srk@...com>,
        <linux-remoteproc@...r.kernel.org>, <devicetree@...r.kernel.org>,
        <linux-kernel@...r.kernel.org>,
        <linux-arm-kernel@...ts.infradead.org>,
        MD Danish Anwar <danishanwar@...com>,
        Tero Kristo <t-kristo@...com>,
        Grzegorz Jaszczyk <grzegorz.jaszczyk@...aro.org>,
        Puranjay Mohan <p-mohan@...com>
Subject: [PATCH v6 1/5] dt-bindings: remoteproc: Add PRU consumer bindings

From: Suman Anna <s-anna@...com>

Add a YAML binding document for PRU consumers. The binding includes
all the common properties that can be used by different PRU consumer
or application nodes and supported by the PRU remoteproc driver.
These are used to configure the PRU hardware for specific user
applications.

The application nodes themselves should define their own bindings.

Co-developed-by: Tero Kristo <t-kristo@...com>
Signed-off-by: Tero Kristo <t-kristo@...com>
Signed-off-by: Suman Anna <s-anna@...com>
Co-developed-by: Grzegorz Jaszczyk <grzegorz.jaszczyk@...aro.org>
Signed-off-by: Grzegorz Jaszczyk <grzegorz.jaszczyk@...aro.org>
Signed-off-by: Puranjay Mohan <p-mohan@...com>
Signed-off-by: MD Danish Anwar <danishanwar@...com>
---
 .../bindings/remoteproc/ti,pru-consumer.yaml  | 132 ++++++++++++++++++
 1 file changed, 132 insertions(+)
 create mode 100644 Documentation/devicetree/bindings/remoteproc/ti,pru-consumer.yaml

diff --git a/Documentation/devicetree/bindings/remoteproc/ti,pru-consumer.yaml b/Documentation/devicetree/bindings/remoteproc/ti,pru-consumer.yaml
new file mode 100644
index 000000000000..16be98b7d600
--- /dev/null
+++ b/Documentation/devicetree/bindings/remoteproc/ti,pru-consumer.yaml
@@ -0,0 +1,132 @@
+# SPDX-License-Identifier: (GPL-2.0-only or BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/remoteproc/ti,pru-consumer.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Common TI PRU Consumer Binding
+
+maintainers:
+  - Suman Anna <s-anna@...com>
+
+description: |
+  A PRU application/consumer/user node typically uses one or more PRU device
+  nodes to implement a PRU application/functionality. Each application/client
+  node would need a reference to at least a PRU node, and optionally define
+  some properties needed for hardware/firmware configuration. The below
+  properties are a list of common properties supported by the PRU remoteproc
+  infrastructure.
+
+  The application nodes shall define their own bindings like regular platform
+  devices, so below are in addition to each node's bindings.
+
+properties:
+  ti,prus:
+    $ref: /schemas/types.yaml#/definitions/phandle-array
+    description: phandles to the PRU, RTU or Tx_PRU nodes used
+    minItems: 1
+    maxItems: 6
+    items:
+      maxItems: 1
+
+  firmware-name:
+    $ref: /schemas/types.yaml#/definitions/string-array
+    minItems: 1
+    maxItems: 6
+    description: |
+      firmwares for the PRU cores, the default firmware for the core from
+      the PRU node will be used if not provided. The firmware names should
+      correspond to the PRU cores listed in the 'ti,prus' property
+
+  ti,pruss-gp-mux-sel:
+    $ref: /schemas/types.yaml#/definitions/uint32-array
+    minItems: 1
+    maxItems: 6
+    items:
+      enum: [0, 1, 2, 3, 4]
+    description: |
+      array of values for the GP_MUX_SEL under PRUSS_GPCFG register for a PRU.
+      This selects the internal muxing scheme for the PRU instance. Values
+      should correspond to the PRU cores listed in the 'ti,prus' property. The
+      GP_MUX_SEL setting is a per-slice setting (one setting for PRU0, RTU0,
+      and Tx_PRU0 on K3 SoCs). Use the same value for all cores within the
+      same slice in the associative array. If the array size is smaller than
+      the size of 'ti,prus' property, the default out-of-reset value (0) for the
+      PRU core is used.
+
+required:
+  - ti,prus
+
+additionalProperties: true
+
+examples:
+  - |
+    /* PRU application node full example */
+    icssg2_eth: icssg2-eth {
+      compatible = "ti,am654-icssg-prueth";
+      pinctrl-names = "default";
+      pinctrl-0 = <&icssg2_rgmii_pins_default>;
+      sram = <&msmc_ram>;
+      ti,prus = <&pru2_0>, <&rtu2_0>, <&tx_pru2_0>,
+        <&pru2_1>, <&rtu2_1>, <&tx_pru2_1>;
+      firmware-name = "ti-pruss/am65x-sr2-pru0-prueth-fw.elf",
+          "ti-pruss/am65x-sr2-rtu0-prueth-fw.elf",
+          "ti-pruss/am65x-sr2-txpru0-prueth-fw.elf",
+          "ti-pruss/am65x-sr2-pru1-prueth-fw.elf",
+          "ti-pruss/am65x-sr2-rtu1-prueth-fw.elf",
+          "ti-pruss/am65x-sr2-txpru1-prueth-fw.elf";
+
+      ti,pruss-gp-mux-sel = <2>,      /* MII mode */
+                <2>,
+                <2>,
+                <2>,  /* MII mode */
+                <2>,
+                <2>;
+
+      ti,mii-g-rt = <&icssg2_mii_g_rt>;
+      ti,mii-rt = <&icssg2_mii_rt>;
+      iep = <&icssg2_iep0>,  <&icssg2_iep1>;
+
+      interrupt-parent = <&icssg2_intc>;
+      interrupts = <24 0 2>, <25 1 3>;
+      interrupt-names = "tx_ts0", "tx_ts1";
+
+      dmas = <&main_udmap 0xc300>, /* egress slice 0 */
+             <&main_udmap 0xc301>, /* egress slice 0 */
+             <&main_udmap 0xc302>, /* egress slice 0 */
+             <&main_udmap 0xc303>, /* egress slice 0 */
+             <&main_udmap 0xc304>, /* egress slice 1 */
+             <&main_udmap 0xc305>, /* egress slice 1 */
+             <&main_udmap 0xc306>, /* egress slice 1 */
+             <&main_udmap 0xc307>, /* egress slice 1 */
+
+             <&main_udmap 0x4300>, /* ingress slice 0 */
+             <&main_udmap 0x4301>, /* ingress slice 1 */
+             <&main_udmap 0x4302>, /* mgmnt rsp slice 0 */
+             <&main_udmap 0x4303>; /* mgmnt rsp slice 1 */
+      dma-names = "tx0-0", "tx0-1", "tx0-2", "tx0-3",
+            "tx1-0", "tx1-1", "tx1-2", "tx1-3",
+            "rx0", "rx1",
+            "rxmgm0", "rxmgm1";
+
+      ethernet-ports {
+        #address-cells = <1>;
+        #size-cells = <0>;
+        port@0 {
+          reg = <0>;
+          phy-handle = <&icssg2_phy0>;
+          phy-mode = "rgmii-rxid";
+          ti,syscon-rgmii-delay = <&scm_conf 0x4120>;
+          /* Filled in by bootloader */
+          local-mac-address = [00 00 00 00 00 00];
+        };
+        port@1 {
+          reg = <1>;
+          phy-handle = <&icssg2_phy1>;
+          phy-mode = "rgmii-rxid";
+          ti,syscon-rgmii-delay = <&scm_conf 0x4124>;
+          /* Filled in by bootloader */
+          local-mac-address = [00 00 00 00 00 00];
+        };
+      };
+    };
-- 
2.25.1

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ