195 lines
7.2 KiB
YAML
195 lines
7.2 KiB
YAML
|
# SPDX-License-Identifier: GPL-2.0
|
||
|
%YAML 1.2
|
||
|
---
|
||
|
$id: http://devicetree.org/schemas/pci/snps,dw-pcie-ep.yaml#
|
||
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
||
|
|
||
|
title: Synopsys DesignWare PCIe endpoint interface
|
||
|
|
||
|
maintainers:
|
||
|
- Jingoo Han <jingoohan1@gmail.com>
|
||
|
- Gustavo Pimentel <gustavo.pimentel@synopsys.com>
|
||
|
|
||
|
description: |
|
||
|
Synopsys DesignWare PCIe host controller endpoint
|
||
|
|
||
|
# Please create a separate DT-schema for your DWC PCIe Endpoint controller
|
||
|
# and make sure it's assigned with the vendor-specific compatible string.
|
||
|
select:
|
||
|
properties:
|
||
|
compatible:
|
||
|
const: snps,dw-pcie-ep
|
||
|
required:
|
||
|
- compatible
|
||
|
|
||
|
allOf:
|
||
|
- $ref: /schemas/pci/pci-ep.yaml#
|
||
|
- $ref: /schemas/pci/snps,dw-pcie-common.yaml#
|
||
|
|
||
|
properties:
|
||
|
reg:
|
||
|
description:
|
||
|
DBI, DBI2 reg-spaces and outbound memory window are required for the
|
||
|
normal controller functioning. iATU memory IO region is also required
|
||
|
if the space is unrolled (IP-core version >= 4.80a).
|
||
|
minItems: 2
|
||
|
maxItems: 7
|
||
|
|
||
|
reg-names:
|
||
|
minItems: 2
|
||
|
maxItems: 7
|
||
|
items:
|
||
|
oneOf:
|
||
|
- description:
|
||
|
Basic DWC PCIe controller configuration-space accessible over
|
||
|
the DBI interface. This memory space is either activated with
|
||
|
CDM/ELBI = 0 and CS2 = 0 or is a contiguous memory region
|
||
|
with all spaces. Note iATU/eDMA CSRs are indirectly accessible
|
||
|
via the PL viewports on the DWC PCIe controllers older than
|
||
|
v4.80a.
|
||
|
const: dbi
|
||
|
- description:
|
||
|
Shadow DWC PCIe config-space registers. This space is selected
|
||
|
by setting CDM/ELBI = 0 and CS2 = 1. This is an intermix of
|
||
|
the PCI-SIG PCIe CFG-space with the shadow registers for some
|
||
|
PCI Header space, PCI Standard and Extended Structures. It's
|
||
|
mainly relevant for the end-point controller configuration,
|
||
|
but still there are some shadow registers available for the
|
||
|
Root Port mode too.
|
||
|
const: dbi2
|
||
|
- description:
|
||
|
External Local Bus registers. It's an application-dependent
|
||
|
registers normally defined by the platform engineers. The space
|
||
|
can be selected by setting CDM/ELBI = 1 and CS2 = 0 wires or can
|
||
|
be accessed over some platform-specific means (for instance
|
||
|
as a part of a system controller).
|
||
|
enum: [ elbi, app ]
|
||
|
- description:
|
||
|
iATU/eDMA registers common for all device functions. It's an
|
||
|
unrolled memory space with the internal Address Translation
|
||
|
Unit and Enhanced DMA, which is selected by setting CDM/ELBI = 1
|
||
|
and CS2 = 1. For IP-core releases prior v4.80a, these registers
|
||
|
have been programmed via an indirect addressing scheme using a
|
||
|
set of viewport CSRs mapped into the PL space. Note iATU is
|
||
|
normally mapped to the 0x0 address of this region, while eDMA
|
||
|
is available at 0x80000 base address.
|
||
|
const: atu
|
||
|
- description:
|
||
|
Platform-specific eDMA registers. Some platforms may have eDMA
|
||
|
CSRs mapped in a non-standard base address. The registers offset
|
||
|
can be changed or the MS/LS-bits of the address can be attached
|
||
|
in an additional RTL block before the MEM-IO transactions reach
|
||
|
the DW PCIe slave interface.
|
||
|
const: dma
|
||
|
- description:
|
||
|
PHY/PCS configuration registers. Some platforms can have the
|
||
|
PCS and PHY CSRs accessible over a dedicated memory mapped
|
||
|
region, but mainly these registers are indirectly accessible
|
||
|
either by means of the embedded PHY viewport schema or by some
|
||
|
platform-specific method.
|
||
|
const: phy
|
||
|
- description:
|
||
|
Outbound iATU-capable memory-region which will be used to
|
||
|
generate various application-specific traffic on the PCIe bus
|
||
|
hierarchy. It's usage scenario depends on the endpoint
|
||
|
functionality, for instance it can be used to create MSI(X)
|
||
|
messages.
|
||
|
const: addr_space
|
||
|
- description:
|
||
|
Vendor-specific CSR names. Consider using the generic names above
|
||
|
for new bindings.
|
||
|
oneOf:
|
||
|
- description: See native 'elbi/app' CSR region for details.
|
||
|
enum: [ link, appl ]
|
||
|
- description: See native 'atu' CSR region for details.
|
||
|
enum: [ atu_dma ]
|
||
|
allOf:
|
||
|
- contains:
|
||
|
const: dbi
|
||
|
- contains:
|
||
|
const: addr_space
|
||
|
|
||
|
interrupts:
|
||
|
description:
|
||
|
There is no mandatory IRQ signals for the normal controller functioning,
|
||
|
but in addition to the native set the platforms may have a link- or
|
||
|
PM-related IRQs specified.
|
||
|
minItems: 1
|
||
|
maxItems: 20
|
||
|
|
||
|
interrupt-names:
|
||
|
minItems: 1
|
||
|
maxItems: 20
|
||
|
items:
|
||
|
oneOf:
|
||
|
- description:
|
||
|
Controller request to read or write virtual product data
|
||
|
from/to the VPD capability registers.
|
||
|
const: vpd
|
||
|
- description:
|
||
|
Link Equalization Request flag is set in the Link Status 2
|
||
|
register (applicable if the corresponding IRQ is enabled in
|
||
|
the Link Control 3 register).
|
||
|
const: l_eq
|
||
|
- description:
|
||
|
Indicates that the eDMA Tx/Rx transfer is complete or that an
|
||
|
error has occurred on the corresponding channel. eDMA can have
|
||
|
eight Tx (Write) and Rx (Read) eDMA channels thus supporting up
|
||
|
to 16 IRQ signals all together. Write eDMA channels shall go
|
||
|
first in the ordered row as per default edma_int[*] bus setup.
|
||
|
pattern: '^dma([0-9]|1[0-5])?$'
|
||
|
- description:
|
||
|
PCIe protocol correctable error or a Data Path protection
|
||
|
correctable error is detected by the automotive/safety
|
||
|
feature.
|
||
|
const: sft_ce
|
||
|
- description:
|
||
|
Indicates that the internal safety mechanism has detected an
|
||
|
uncorrectable error.
|
||
|
const: sft_ue
|
||
|
- description:
|
||
|
Application-specific IRQ raised depending on the vendor-specific
|
||
|
events basis.
|
||
|
const: app
|
||
|
- description:
|
||
|
Vendor-specific IRQ names. Consider using the generic names above
|
||
|
for new bindings.
|
||
|
oneOf:
|
||
|
- description: See native "app" IRQ for details
|
||
|
enum: [ intr ]
|
||
|
|
||
|
max-functions:
|
||
|
maximum: 32
|
||
|
|
||
|
required:
|
||
|
- compatible
|
||
|
- reg
|
||
|
- reg-names
|
||
|
|
||
|
additionalProperties: true
|
||
|
|
||
|
examples:
|
||
|
- |
|
||
|
pcie-ep@dfd00000 {
|
||
|
compatible = "snps,dw-pcie-ep";
|
||
|
reg = <0xdfc00000 0x0001000>, /* IP registers 1 */
|
||
|
<0xdfc01000 0x0001000>, /* IP registers 2 */
|
||
|
<0xd0000000 0x2000000>; /* Configuration space */
|
||
|
reg-names = "dbi", "dbi2", "addr_space";
|
||
|
|
||
|
interrupts = <23>, <24>;
|
||
|
interrupt-names = "dma0", "dma1";
|
||
|
|
||
|
clocks = <&sys_clk 12>, <&sys_clk 24>;
|
||
|
clock-names = "dbi", "ref";
|
||
|
|
||
|
resets = <&sys_rst 12>, <&sys_rst 24>;
|
||
|
reset-names = "dbi", "phy";
|
||
|
|
||
|
phys = <&pcie_phy0>, <&pcie_phy1>, <&pcie_phy2>, <&pcie_phy3>;
|
||
|
phy-names = "pcie0", "pcie1", "pcie2", "pcie3";
|
||
|
|
||
|
max-link-speed = <3>;
|
||
|
max-functions = /bits/ 8 <4>;
|
||
|
};
|