diff options
| author | Sumit Gupta <sumitg@nvidia.com> | 2025-07-10 00:21:46 +0200 | 
|---|---|---|
| committer | Thierry Reding <treding@nvidia.com> | 2025-07-11 16:48:06 +0200 | 
| commit | 0b226380d4cce2e6ee50800d861934d474a30121 (patch) | |
| tree | 60c93aeb94fab0fc15fc26d78aa273dc309d5e46 | |
| parent | 19272b37aa4f83ca52bdf9c16d5d81bdd1354494 (diff) | |
dt-bindings: memory: tegra: Add Tegra264 support
Add bindings for the Memory Controller (MC) and External Memory
Controller (EMC) found on the Tegra264 SoC. Tegra264 SoC has a different
number of interrupt lines for MC sub-units: UCF_SOC, hub, hub common,
syncpoint and MC channel. The total number of interrupt lines is eight.
Update maxItems for MC interrupts accordingly.
This also adds a header containing the memory client ID definitions that
are used by the interconnects property in DT and the tegra_mc_client
table in the MC driver. These IDs are defined by the hardware, so the
numbering doesn't start at 0 and contains holes. Also added are the
stream IDs for various hardware blocks found on Tegra264. These are
allocated as blocks of 256 IDs and each block can be subdivided for
additional fine-grained isolation if needed.
Signed-off-by: Sumit Gupta <sumitg@nvidia.com>
[treding@nvidia.com: add SMMU stream IDs, squash patches]
Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Link: https://lore.kernel.org/r/20250709222147.3758356-2-thierry.reding@gmail.com
Signed-off-by: Thierry Reding <treding@nvidia.com>
| -rw-r--r-- | Documentation/devicetree/bindings/memory-controllers/nvidia,tegra186-mc.yaml | 84 | ||||
| -rw-r--r-- | include/dt-bindings/memory/nvidia,tegra264.h | 136 | 
2 files changed, 218 insertions, 2 deletions
| diff --git a/Documentation/devicetree/bindings/memory-controllers/nvidia,tegra186-mc.yaml b/Documentation/devicetree/bindings/memory-controllers/nvidia,tegra186-mc.yaml index 935d63d181d9..b901f1b3e0fc 100644 --- a/Documentation/devicetree/bindings/memory-controllers/nvidia,tegra186-mc.yaml +++ b/Documentation/devicetree/bindings/memory-controllers/nvidia,tegra186-mc.yaml @@ -32,6 +32,7 @@ properties:            - nvidia,tegra186-mc            - nvidia,tegra194-mc            - nvidia,tegra234-mc +          - nvidia,tegra264-mc    reg:      minItems: 6 @@ -42,8 +43,12 @@ properties:      maxItems: 18    interrupts: -    items: -      - description: MC general interrupt +    minItems: 1 +    maxItems: 8 + +  interrupt-names: +    minItems: 1 +    maxItems: 8    "#address-cells":      const: 2 @@ -74,6 +79,7 @@ patternProperties:                - nvidia,tegra186-emc                - nvidia,tegra194-emc                - nvidia,tegra234-emc +              - nvidia,tegra264-emc        reg:          minItems: 1 @@ -127,6 +133,15 @@ patternProperties:              reg:                minItems: 2 +      - if: +          properties: +            compatible: +              const: nvidia,tegra264-emc +        then: +          properties: +            reg: +              minItems: 2 +      additionalProperties: false      required: @@ -158,6 +173,12 @@ allOf:              - const: ch2              - const: ch3 +        interrupts: +          items: +            - description: MC general interrupt + +        interrupt-names: false +    - if:        properties:          compatible: @@ -189,6 +210,12 @@ allOf:              - const: ch14              - const: ch15 +        interrupts: +          items: +            - description: MC general interrupt + +        interrupt-names: false +    - if:        properties:          compatible: @@ -220,6 +247,59 @@ allOf:              - const: ch14              - const: ch15 +        interrupts: +          items: +            - description: MC general interrupt + +        interrupt-names: false + +  - if: +      properties: +        compatible: +          const: nvidia,tegra264-mc +    then: +      properties: +        reg: +          minItems: 17 +          maxItems: 17 +          description: 17 memory controller channels + +        reg-names: +          items: +            - const: broadcast +            - const: ch0 +            - const: ch1 +            - const: ch2 +            - const: ch3 +            - const: ch4 +            - const: ch5 +            - const: ch6 +            - const: ch7 +            - const: ch8 +            - const: ch9 +            - const: ch10 +            - const: ch11 +            - const: ch12 +            - const: ch13 +            - const: ch14 +            - const: ch15 + +        interrupts: +          minItems: 8 +          maxItems: 8 +          description: One interrupt line for each MC component + +        interrupt-names: +          items: +            - const: mcf +            - const: hub1 +            - const: hub2 +            - const: hub3 +            - const: hub4 +            - const: hub5 +            - const: sbs +            - const: channel +  additionalProperties: false  required: diff --git a/include/dt-bindings/memory/nvidia,tegra264.h b/include/dt-bindings/memory/nvidia,tegra264.h new file mode 100644 index 000000000000..521405c01f84 --- /dev/null +++ b/include/dt-bindings/memory/nvidia,tegra264.h @@ -0,0 +1,136 @@ +/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) */ +/* Copyright (c) 2025, NVIDIA CORPORATION. All rights reserved. */ + +#ifndef DT_BINDINGS_MEMORY_NVIDIA_TEGRA264_H +#define DT_BINDINGS_MEMORY_NVIDIA_TEGRA264_H + +#define TEGRA264_SID(x) ((x) << 8) + +/* + * SMMU stream IDs + */ + +#define TEGRA264_SID_AON       TEGRA264_SID(0x01) +#define TEGRA264_SID_APE       TEGRA264_SID(0x02) +#define TEGRA264_SID_ETR       TEGRA264_SID(0x03) +#define TEGRA264_SID_BPMP      TEGRA264_SID(0x04) +#define TEGRA264_SID_DCE       TEGRA264_SID(0x05) +#define TEGRA264_SID_EQOS      TEGRA264_SID(0x06) +#define TEGRA264_SID_GPCDMA    TEGRA264_SID(0x08) +#define TEGRA264_SID_DISP      TEGRA264_SID(0x09) +#define TEGRA264_SID_HDA       TEGRA264_SID(0x0a) +#define TEGRA264_SID_HOST1X    TEGRA264_SID(0x0b) +#define TEGRA264_SID_ISP0      TEGRA264_SID(0x0c) +#define TEGRA264_SID_ISP1      TEGRA264_SID(0x0d) +#define TEGRA264_SID_PMA0      TEGRA264_SID(0x0e) +#define TEGRA264_SID_FSI0      TEGRA264_SID(0x0f) +#define TEGRA264_SID_FSI1      TEGRA264_SID(0x10) +#define TEGRA264_SID_PVA       TEGRA264_SID(0x11) +#define TEGRA264_SID_SDMMC0    TEGRA264_SID(0x12) +#define TEGRA264_SID_MGBE0     TEGRA264_SID(0x13) +#define TEGRA264_SID_MGBE1     TEGRA264_SID(0x14) +#define TEGRA264_SID_MGBE2     TEGRA264_SID(0x15) +#define TEGRA264_SID_MGBE3     TEGRA264_SID(0x16) +#define TEGRA264_SID_MSSSEQ    TEGRA264_SID(0x17) +#define TEGRA264_SID_SE        TEGRA264_SID(0x18) +#define TEGRA264_SID_SEU1      TEGRA264_SID(0x19) +#define TEGRA264_SID_SEU2      TEGRA264_SID(0x1a) +#define TEGRA264_SID_SEU3      TEGRA264_SID(0x1b) +#define TEGRA264_SID_PSC       TEGRA264_SID(0x1c) +#define TEGRA264_SID_OESP      TEGRA264_SID(0x23) +#define TEGRA264_SID_SB        TEGRA264_SID(0x24) +#define TEGRA264_SID_XSPI0     TEGRA264_SID(0x25) +#define TEGRA264_SID_TSEC      TEGRA264_SID(0x29) +#define TEGRA264_SID_UFS       TEGRA264_SID(0x2a) +#define TEGRA264_SID_RCE       TEGRA264_SID(0x2b) +#define TEGRA264_SID_RCE1      TEGRA264_SID(0x2c) +#define TEGRA264_SID_VI        TEGRA264_SID(0x2e) +#define TEGRA264_SID_VI1       TEGRA264_SID(0x2f) +#define TEGRA264_SID_VIC       TEGRA264_SID(0x30) +#define TEGRA264_SID_XUSB_DEV  TEGRA264_SID(0x32) +#define TEGRA264_SID_XUSB_DEV1 TEGRA264_SID(0x33) +#define TEGRA264_SID_XUSB_DEV2 TEGRA264_SID(0x34) +#define TEGRA264_SID_XUSB_DEV3 TEGRA264_SID(0x35) +#define TEGRA264_SID_XUSB_DEV4 TEGRA264_SID(0x36) +#define TEGRA264_SID_XUSB_DEV5 TEGRA264_SID(0x37) + +/* + * memory client IDs + */ + +/* HOST1X read client */ +#define TEGRA264_MEMORY_CLIENT_HOST1XR		0x16 +/* VIC read client */ +#define TEGRA264_MEMORY_CLIENT_VICR		0x6c +/* VIC Write client */ +#define TEGRA264_MEMORY_CLIENT_VICW		0x6d +/* VI R5 Write client */ +#define TEGRA264_MEMORY_CLIENT_VIW		0x72 +#define TEGRA264_MEMORY_CLIENT_NVDECSRD2MC	0x78 +#define TEGRA264_MEMORY_CLIENT_NVDECSWR2MC	0x79 +/* Audio processor(APE) Read client */ +#define TEGRA264_MEMORY_CLIENT_APER		0x7a +/* Audio processor(APE) Write client */ +#define TEGRA264_MEMORY_CLIENT_APEW		0x7b +/* Audio DMA Read client */ +#define TEGRA264_MEMORY_CLIENT_APEDMAR		0x9f +/* Audio DMA Write client */ +#define TEGRA264_MEMORY_CLIENT_APEDMAW		0xa0 +#define TEGRA264_MEMORY_CLIENT_GPUR02MC		0xb6 +#define TEGRA264_MEMORY_CLIENT_GPUW02MC		0xb7 +/* VI Falcon Read client */ +#define TEGRA264_MEMORY_CLIENT_VIFALCONR	0xbc +/* VI Falcon Write client */ +#define TEGRA264_MEMORY_CLIENT_VIFALCONW	0xbd +/* Read Client of RCE */ +#define TEGRA264_MEMORY_CLIENT_RCER		0xd2 +/* Write client of RCE */ +#define TEGRA264_MEMORY_CLIENT_RCEW		0xd3 +/* PCIE0/MSI Write clients */ +#define TEGRA264_MEMORY_CLIENT_PCIE0W		0xd9 +/* PCIE1/RPX4 Read clients */ +#define TEGRA264_MEMORY_CLIENT_PCIE1R		0xda +/* PCIE1/RPX4 Write clients */ +#define TEGRA264_MEMORY_CLIENT_PCIE1W		0xdb +/* PCIE2/DMX4 Read clients */ +#define TEGRA264_MEMORY_CLIENT_PCIE2AR		0xdc +/* PCIE2/DMX4 Write clients */ +#define TEGRA264_MEMORY_CLIENT_PCIE2AW		0xdd +/* PCIE3/RPX4 Read clients */ +#define TEGRA264_MEMORY_CLIENT_PCIE3R		0xde +/* PCIE3/RPX4 Write clients */ +#define TEGRA264_MEMORY_CLIENT_PCIE3W		0xdf +/* PCIE4/DMX8 Read clients */ +#define TEGRA264_MEMORY_CLIENT_PCIE4R		0xe0 +/* PCIE4/DMX8 Write clients */ +#define TEGRA264_MEMORY_CLIENT_PCIE4W		0xe1 +/* PCIE5/DMX4 Read clients */ +#define TEGRA264_MEMORY_CLIENT_PCIE5R		0xe2 +/* PCIE5/DMX4 Write clients */ +#define TEGRA264_MEMORY_CLIENT_PCIE5W		0xe3 +/* UFS Read client */ +#define TEGRA264_MEMORY_CLIENT_UFSR		0x15c +/* UFS write client */ +#define TEGRA264_MEMORY_CLIENT_UFSW		0x15d +/* HDA Read client */ +#define TEGRA264_MEMORY_CLIENT_HDAR		0x17c +/* HDA Write client */ +#define TEGRA264_MEMORY_CLIENT_HDAW		0x17d +/* Disp ISO Read Client */ +#define TEGRA264_MEMORY_CLIENT_DISPR		0x182 +/* MGBE0 Read mccif */ +#define TEGRA264_MEMORY_CLIENT_MGBE0R		0x1a2 +/* MGBE0 Write mccif */ +#define TEGRA264_MEMORY_CLIENT_MGBE0W		0x1a3 +/* MGBE1 Read mccif */ +#define TEGRA264_MEMORY_CLIENT_MGBE1R		0x1a4 +/* MGBE1 Write mccif */ +#define TEGRA264_MEMORY_CLIENT_MGBE1W		0x1a5 +/* VI1 R5 Write client */ +#define TEGRA264_MEMORY_CLIENT_VI1W		0x1a6 +/* SDMMC0 Read mccif */ +#define TEGRA264_MEMORY_CLIENT_SDMMC0R		0x1c2 +/* SDMMC0 Write mccif */ +#define TEGRA264_MEMORY_CLIENT_SDMMC0W		0x1c3 + +#endif /* DT_BINDINGS_MEMORY_NVIDIA_TEGRA264_H */ | 
