Skip to content

Commit 3719a04

Browse files
committed
Merge tag 'pci-v6.16-changes' of git://git.kernel.org/pub/scm/linux/kernel/git/pci/pci
Pull pci updates from Bjorn Helgaas: "Enumeration: - Print the actual delay time in pci_bridge_wait_for_secondary_bus() instead of assuming it was 1000ms (Wilfred Mallawa) - Revert 'iommu/amd: Prevent binding other PCI drivers to IOMMU PCI devices', which broke resume from system sleep on AMD platforms and has been fixed by other commits (Lukas Wunner) Resource management: - Remove mtip32xx use of pcim_iounmap_regions(), which is deprecated and unnecessary (Philipp Stanner) - Remove pcim_iounmap_regions() and pcim_request_region_exclusive() and related flags since all uses have been removed (Philipp Stanner) - Rework devres 'request' functions so they are no longer 'hybrid', i.e., their behavior no longer depends on whether pcim_enable_device or pci_enable_device() was used, and remove related code (Philipp Stanner) - Warn (not BUG()) about failure to assign optional resources (Ilpo Järvinen) Error handling: - Log the DPC Error Source ID only when it's actually valid (when ERR_FATAL or ERR_NONFATAL was received from a downstream device) and decode into bus/device/function (Bjorn Helgaas) - Determine AER log level once and save it so all related messages use the same level (Karolina Stolarek) - Use KERN_WARNING, not KERN_ERR, when logging PCIe Correctable Errors (Karolina Stolarek) - Ratelimit PCIe Correctable and Non-Fatal error logging, with sysfs controls on interval and burst count, to avoid flooding logs and RCU stall warnings (Jon Pan-Doh) Power management: - Increment PM usage counter when probing reset methods so we don't try to read config space of a powered-off device (Alex Williamson) - Set all devices to D0 during enumeration to ensure ACPI opregion is connected via _REG (Mario Limonciello) Power control: - Rename pwrctrl Kconfig symbols from 'PWRCTL' to 'PWRCTRL' to match the filename paths. Retain old deprecated symbols for compatibility, except for the pwrctrl slot driver (PCI_PWRCTRL_SLOT) (Johan Hovold) - When unregistering pwrctrl, cancel outstanding rescan work before cleaning up data structures to avoid use-after-free issues (Brian Norris) Bandwidth control: - Simplify link bandwidth controller by replacing the count of Link Bandwidth Management Status (LBMS) events with a PCI_LINK_LBMS_SEEN flag (Ilpo Järvinen) - Update the Link Speed after retraining, since the Link Speed may have changed (Ilpo Järvinen) PCIe native device hotplug: - Ignore Presence Detect Changed caused by DPC. pciehp already ignores Link Down/Up events caused by DPC, but on slots using in-band presence detect, DPC causes a spurious Presence Detect Changed event (Lukas Wunner) - Ignore Link Down/Up caused by Secondary Bus Reset. On hotplug ports using in-band presence detect, the reset causes a Presence Detect Changed event, which mistakenly caused teardown and re-enumeration of the device. Drivers may need to annotate code that resets their device (Lukas Wunner) Virtualization: - Add an ACS quirk for Loongson Root Ports that don't advertise ACS but don't allow peer-to-peer transactions between Root Ports; the quirk allows each Root Port to be in a separate IOMMU group (Huacai Chen) Endpoint framework: - For fixed-size BARs, retain both the actual size and the possibly larger size allocated to accommodate iATU alignment requirements (Jerome Brunet) - Simplify ctrl/SPAD space allocation and avoid allocating more space than needed (Jerome Brunet) - Correct MSI-X PBA offset calculations for DesignWare and Cadence endpoint controllers (Niklas Cassel) - Align the return value (number of interrupts) encoding for pci_epc_get_msi()/pci_epc_ops::get_msi() and pci_epc_get_msix()/pci_epc_ops::get_msix() (Niklas Cassel) - Align the nr_irqs parameter encoding for pci_epc_set_msi()/pci_epc_ops::set_msi() and pci_epc_set_msix()/pci_epc_ops::set_msix() (Niklas Cassel) Common host controller library: - Convert pci-host-common to a library so platforms that don't need native host controller drivers don't need to include these helper functions (Manivannan Sadhasivam) Apple PCIe controller driver: - Extract ECAM bridge creation helper from pci_host_common_probe() to separate driver-specific things like MSI from PCI things (Marc Zyngier) - Dynamically allocate RID-to_SID bitmap to prepare for SoCs with varying capabilities (Marc Zyngier) - Skip ports disabled in DT when setting up ports (Janne Grunau) - Add t6020 compatible string (Alyssa Rosenzweig) - Add T602x PCIe support (Hector Martin) - Directly set/clear INTx mask bits because T602x dropped the accessors that could do this without locking (Marc Zyngier) - Move port PHY registers to their own reg items to accommodate T602x, which moves them around; retain default offsets for existing DTs that lack phy%d entries with the reg offsets (Hector Martin) - Stop polling for core refclk, which doesn't work on T602x and the bootloader has already done anyway (Hector Martin) - Use gpiod_set_value_cansleep() when asserting PERST# in probe because we're allowed to sleep there (Hector Martin) Cadence PCIe controller driver: - Drop a runtime PM 'put' to resolve a runtime atomic count underflow (Hans Zhang) - Make the cadence core buildable as a module (Kishon Vijay Abraham I) - Add cdns_pcie_host_disable() and cdns_pcie_ep_disable() for use by loadable drivers when they are removed (Siddharth Vadapalli) Freescale i.MX6 PCIe controller driver: - Apply link training workaround only on IMX6Q, IMX6SX, IMX6SP (Richard Zhu) - Remove redundant dw_pcie_wait_for_link() from imx_pcie_start_link(); since the DWC core does this, imx6 only needs it when retraining for a faster link speed (Richard Zhu) - Toggle i.MX95 core reset to align with PHY powerup (Richard Zhu) - Set SYS_AUX_PWR_DET to work around i.MX95 ERR051624 erratum: in some cases, the controller can't exit 'L23 Ready' through Beacon or PERST# deassertion (Richard Zhu) - Clear GEN3_ZRXDC_NONCOMPL to work around i.MX95 ERR051586 erratum: controller can't meet 2.5 GT/s ZRX-DC timing when operating at 8 GT/s, causing timeouts in L1 (Richard Zhu) - Wait for i.MX95 PLL lock before enabling controller (Richard Zhu) - Save/restore i.MX95 LUT for suspend/resume (Richard Zhu) Mobiveil PCIe controller driver: - Return bool (not int) for link-up check in mobiveil_pab_ops.link_up() and layerscape-gen4, mobiveil (Hans Zhang) NVIDIA Tegra194 PCIe controller driver: - Create debugfs directory for 'aspm_state_cnt' only when CONFIG_PCIEASPM is enabled, since there are no other entries (Hans Zhang) Qualcomm PCIe controller driver: - Add OF support for parsing DT 'eq-presets-<N>gts' property for lane equalization presets (Krishna Chaitanya Chundru) - Read Maximum Link Width from the Link Capabilities register if DT lacks 'num-lanes' property (Krishna Chaitanya Chundru) - Add Physical Layer 64 GT/s Capability ID and register offsets for 8, 32, and 64 GT/s lane equalization registers (Krishna Chaitanya Chundru) - Add generic dwc support for configuring lane equalization presets (Krishna Chaitanya Chundru) - Add DT and driver support for PCIe on IPQ5018 SoC (Nitheesh Sekar) Renesas R-Car PCIe controller driver: - Describe endpoint BAR 4 as being fixed size (Jerome Brunet) - Document how to obtain R-Car V4H (r8a779g0) controller firmware (Yoshihiro Shimoda) Rockchip PCIe controller driver: - Reorder rockchip_pci_core_rsts because reset_control_bulk_deassert() deasserts in reverse order, to fix a link training regression (Jensen Huang) - Mark RK3399 as being capable of raising INTx interrupts (Niklas Cassel) Rockchip DesignWare PCIe controller driver: - Check only PCIE_LINKUP, not LTSSM status, to determine whether the link is up (Shawn Lin) - Increase N_FTS (used in L0s->L0 transitions) and enable ASPM L0s for Root Complex and Endpoint modes (Shawn Lin) - Hide the broken ATS Capability in rockchip_pcie_ep_init() instead of rockchip_pcie_ep_pre_init() so it stays hidden after PERST# resets non-sticky registers (Shawn Lin) - Call phy_power_off() before phy_exit() in rockchip_pcie_phy_deinit() (Diederik de Haas) Synopsys DesignWare PCIe controller driver: - Set PORT_LOGIC_LINK_WIDTH to one lane to make initial link training more robust; this will not affect the intended link width if all lanes are functional (Wenbin Yao) - Return bool (not int) for link-up check in dw_pcie_ops.link_up() and armada8k, dra7xx, dw-rockchip, exynos, histb, keembay, keystone, kirin, meson, qcom, qcom-ep, rcar_gen4, spear13xx, tegra194, uniphier, visconti (Hans Zhang) - Add debugfs support for exposing DWC device-specific PTM context (Manivannan Sadhasivam) TI J721E PCIe driver: - Make j721e buildable as a loadable and removable module (Siddharth Vadapalli) - Fix j721e host/endpoint dependencies that result in link failures in some configs (Arnd Bergmann) Device tree bindings: - Add qcom DT binding for 'global' interrupt (PCIe controller and link-specific events) for ipq8074, ipq8074-gen3, ipq6018, sa8775p, sc7280, sc8180x sdm845, sm8150, sm8250, sm8350 (Manivannan Sadhasivam) - Add qcom DT binding for 8 MSI SPI interrupts for msm8998, ipq8074, ipq8074-gen3, ipq6018 (Manivannan Sadhasivam) - Add dw rockchip DT binding for rk3576 and rk3562 (Kever Yang) - Correct indentation and style of examples in brcm,stb-pcie, cdns,cdns-pcie-ep, intel,keembay-pcie-ep, intel,keembay-pcie, microchip,pcie-host, rcar-pci-ep, rcar-pci-host, xilinx-versal-cpm (Krzysztof Kozlowski) - Convert Marvell EBU (dove, kirkwood, armada-370, armada-xp) and armada8k from text to schema DT bindings (Rob Herring) - Remove obsolete .txt DT bindings for content that has been moved to schemas (Rob Herring) - Add qcom DT binding for MHI registers in IPQ5332, IPQ6018, IPQ8074 and IPQ9574 (Varadarajan Narayanan) - Convert v3,v360epc-pci from text to DT schema binding (Rob Herring) - Change microchip,pcie-host DT binding to be 'dma-noncoherent' since PolarFire may be configured that way (Conor Dooley) Miscellaneous: - Drop 'pci' suffix from intel_mid_pci.c filename to match similar files (Andy Shevchenko) - All platforms with PCI have an MMU, so add PCI Kconfig dependency on MMU to simplify build testing and avoid inadvertent build regressions (Arnd Bergmann) - Update Krzysztof Wilczyński's email address in MAINTAINERS (Krzysztof Wilczyński) - Update Manivannan Sadhasivam's email address in MAINTAINERS (Manivannan Sadhasivam)" * tag 'pci-v6.16-changes' of git://git.kernel.org/pub/scm/linux/kernel/git/pci/pci: (147 commits) MAINTAINERS: Update Manivannan Sadhasivam email address PCI: j721e: Fix host/endpoint dependencies PCI: j721e: Add support to build as a loadable module PCI: cadence-ep: Introduce cdns_pcie_ep_disable() helper for cleanup PCI: cadence-host: Introduce cdns_pcie_host_disable() helper for cleanup PCI: cadence: Add support to build pcie-cadence library as a kernel module MAINTAINERS: Update Krzysztof Wilczyński email address PCI: Remove unnecessary linesplit in __pci_setup_bridge() PCI: WARN (not BUG()) when we fail to assign optional resources PCI: Remove unused pci_printk() PCI: qcom: Replace PERST# sleep time with proper macro PCI: dw-rockchip: Replace PERST# sleep time with proper macro PCI: host-common: Convert to library for host controller drivers PCI/ERR: Remove misleading TODO regarding kernel panic PCI: cadence: Remove duplicate message code definitions PCI: endpoint: Align pci_epc_set_msix(), pci_epc_ops::set_msix() nr_irqs encoding PCI: endpoint: Align pci_epc_set_msi(), pci_epc_ops::set_msi() nr_irqs encoding PCI: endpoint: Align pci_epc_get_msix(), pci_epc_ops::get_msix() return value encoding PCI: endpoint: Align pci_epc_get_msi(), pci_epc_ops::get_msi() return value encoding PCI: cadence-ep: Correct PBA offset in .set_msix() callback ...
2 parents 1af80d0 + 3de9148 commit 3719a04

File tree

148 files changed

+3402
-2221
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

148 files changed

+3402
-2221
lines changed

.mailmap

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -419,6 +419,8 @@ Krishna Manikandan <[email protected]> <[email protected]>
419419
Krzysztof Kozlowski <[email protected]> <[email protected]>
420420
Krzysztof Kozlowski <[email protected]> <[email protected]>
421421
Krzysztof Kozlowski <[email protected]> <[email protected]>
422+
Krzysztof Wilczyński <[email protected]> <[email protected]>
423+
Krzysztof Wilczyński <[email protected]> <[email protected]>
422424
423425
Kuninori Morimoto <[email protected]>
424426
@@ -461,6 +463,7 @@ Maheshwar Ajja <[email protected]> <[email protected]>
461463
462464
Manikanta Pubbisetty <[email protected]> <[email protected]>
463465
Manivannan Sadhasivam <[email protected]> <[email protected]>
466+
Manivannan Sadhasivam <[email protected]> <[email protected]>
464467
465468
466469
Lines changed: 70 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,70 @@
1+
What: /sys/kernel/debug/pcie_ptm_*/local_clock
2+
Date: May 2025
3+
Contact: Manivannan Sadhasivam <[email protected]>
4+
Description:
5+
(RO) PTM local clock in nanoseconds. Applicable for both Root
6+
Complex and Endpoint controllers.
7+
8+
What: /sys/kernel/debug/pcie_ptm_*/master_clock
9+
Date: May 2025
10+
Contact: Manivannan Sadhasivam <[email protected]>
11+
Description:
12+
(RO) PTM master clock in nanoseconds. Applicable only for
13+
Endpoint controllers.
14+
15+
What: /sys/kernel/debug/pcie_ptm_*/t1
16+
Date: May 2025
17+
Contact: Manivannan Sadhasivam <[email protected]>
18+
Description:
19+
(RO) PTM T1 timestamp in nanoseconds. Applicable only for
20+
Endpoint controllers.
21+
22+
What: /sys/kernel/debug/pcie_ptm_*/t2
23+
Date: May 2025
24+
Contact: Manivannan Sadhasivam <[email protected]>
25+
Description:
26+
(RO) PTM T2 timestamp in nanoseconds. Applicable only for
27+
Root Complex controllers.
28+
29+
What: /sys/kernel/debug/pcie_ptm_*/t3
30+
Date: May 2025
31+
Contact: Manivannan Sadhasivam <[email protected]>
32+
Description:
33+
(RO) PTM T3 timestamp in nanoseconds. Applicable only for
34+
Root Complex controllers.
35+
36+
What: /sys/kernel/debug/pcie_ptm_*/t4
37+
Date: May 2025
38+
Contact: Manivannan Sadhasivam <[email protected]>
39+
Description:
40+
(RO) PTM T4 timestamp in nanoseconds. Applicable only for
41+
Endpoint controllers.
42+
43+
What: /sys/kernel/debug/pcie_ptm_*/context_update
44+
Date: May 2025
45+
Contact: Manivannan Sadhasivam <[email protected]>
46+
Description:
47+
(RW) Control the PTM context update mode. Applicable only for
48+
Endpoint controllers.
49+
50+
Following values are supported:
51+
52+
* auto = PTM context auto update trigger for every 10ms
53+
54+
* manual = PTM context manual update. Writing 'manual' to this
55+
file triggers PTM context update (default)
56+
57+
What: /sys/kernel/debug/pcie_ptm_*/context_valid
58+
Date: May 2025
59+
Contact: Manivannan Sadhasivam <[email protected]>
60+
Description:
61+
(RW) Control the PTM context validity (local clock timing).
62+
Applicable only for Root Complex controllers. PTM context is
63+
invalidated by hardware if the Root Complex enters low power
64+
mode or changes link frequency.
65+
66+
Following values are supported:
67+
68+
* 0 = PTM context invalid (default)
69+
70+
* 1 = PTM context valid

Documentation/ABI/testing/sysfs-bus-pci-devices-aer_stats renamed to Documentation/ABI/testing/sysfs-bus-pci-devices-aer

Lines changed: 44 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -117,3 +117,47 @@ Date: July 2018
117117
KernelVersion: 4.19.0
118118
119119
Description: Total number of ERR_NONFATAL messages reported to rootport.
120+
121+
PCIe AER ratelimits
122+
-------------------
123+
124+
These attributes show up under all the devices that are AER capable.
125+
They represent configurable ratelimits of logs per error type.
126+
127+
See Documentation/PCI/pcieaer-howto.rst for more info on ratelimits.
128+
129+
What: /sys/bus/pci/devices/<dev>/aer/correctable_ratelimit_interval_ms
130+
Date: May 2025
131+
KernelVersion: 6.16.0
132+
133+
Description: Writing 0 disables AER correctable error log ratelimiting.
134+
Writing a positive value sets the ratelimit interval in ms.
135+
Default is DEFAULT_RATELIMIT_INTERVAL (5000 ms).
136+
137+
What: /sys/bus/pci/devices/<dev>/aer/correctable_ratelimit_burst
138+
Date: May 2025
139+
KernelVersion: 6.16.0
140+
141+
Description: Ratelimit burst for correctable error logs. Writing a value
142+
changes the number of errors (burst) allowed per interval
143+
before ratelimiting. Reading gets the current ratelimit
144+
burst. Default is DEFAULT_RATELIMIT_BURST (10).
145+
146+
What: /sys/bus/pci/devices/<dev>/aer/nonfatal_ratelimit_interval_ms
147+
Date: May 2025
148+
KernelVersion: 6.16.0
149+
150+
Description: Writing 0 disables AER non-fatal uncorrectable error log
151+
ratelimiting. Writing a positive value sets the ratelimit
152+
interval in ms. Default is DEFAULT_RATELIMIT_INTERVAL
153+
(5000 ms).
154+
155+
What: /sys/bus/pci/devices/<dev>/aer/nonfatal_ratelimit_burst
156+
Date: May 2025
157+
KernelVersion: 6.16.0
158+
159+
Description: Ratelimit burst for non-fatal uncorrectable error logs.
160+
Writing a value changes the number of errors (burst)
161+
allowed per interval before ratelimiting. Reading gets the
162+
current ratelimit burst. Default is DEFAULT_RATELIMIT_BURST
163+
(10).
Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
.. SPDX-License-Identifier: GPL-2.0
2+
3+
===========================================
4+
PCI Native Host Bridge and Endpoint Drivers
5+
===========================================
6+
7+
.. toctree::
8+
:maxdepth: 2
9+
10+
rcar-pcie-firmware
Lines changed: 32 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,32 @@
1+
.. SPDX-License-Identifier: GPL-2.0
2+
3+
=================================================
4+
Firmware of PCIe controller for Renesas R-Car V4H
5+
=================================================
6+
7+
Renesas R-Car V4H (r8a779g0) has a PCIe controller, requiring a specific
8+
firmware download during startup.
9+
10+
However, Renesas currently cannot distribute the firmware free of charge.
11+
12+
The firmware file "104_PCIe_fw_addr_data_ver1.05.txt" (note that the file name
13+
might be different between different datasheet revisions) can be found in the
14+
datasheet encoded as text, and as such, the file's content must be converted
15+
back to binary form. This can be achieved using the following example script:
16+
17+
.. code-block:: sh
18+
19+
$ awk '/^\s*0x[0-9A-Fa-f]{4}\s+0x[0-9A-Fa-f]{4}/ { print substr($2,5,2) substr($2,3,2) }' \
20+
104_PCIe_fw_addr_data_ver1.05.txt | \
21+
xxd -p -r > rcar_gen4_pcie.bin
22+
23+
Once the text content has been converted into a binary firmware file, verify
24+
its checksum as follows:
25+
26+
.. code-block:: sh
27+
28+
$ sha1sum rcar_gen4_pcie.bin
29+
1d0bd4b189b4eb009f5d564b1f93a79112994945 rcar_gen4_pcie.bin
30+
31+
The resulting binary file called "rcar_gen4_pcie.bin" should be placed in the
32+
"/lib/firmware" directory before the driver runs.

Documentation/PCI/endpoint/pci-nvme-function.rst

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,6 @@ PCI NVMe Function
88

99
The PCI NVMe endpoint function implements a PCI NVMe controller using the NVMe
1010
subsystem target core code. The driver for this function resides with the NVMe
11-
subsystem as drivers/nvme/target/nvmet-pciep.c.
11+
subsystem as drivers/nvme/target/pci-epf.c.
1212

1313
See Documentation/nvme/nvme-pci-endpoint-target.rst for more details.

Documentation/PCI/index.rst

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -17,5 +17,6 @@ PCI Bus Subsystem
1717
pci-error-recovery
1818
pcieaer-howto
1919
endpoint/index
20+
controller/index
2021
boot-interrupts
2122
tph

Documentation/PCI/pcieaer-howto.rst

Lines changed: 16 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -85,12 +85,27 @@ In the example, 'Requester ID' means the ID of the device that sent
8585
the error message to the Root Port. Please refer to PCIe specs for other
8686
fields.
8787

88+
AER Ratelimits
89+
--------------
90+
91+
Since error messages can be generated for each transaction, we may see
92+
large volumes of errors reported. To prevent spammy devices from flooding
93+
the console/stalling execution, messages are throttled by device and error
94+
type (correctable vs. non-fatal uncorrectable). Fatal errors, including
95+
DPC errors, are not ratelimited.
96+
97+
AER uses the default ratelimit of DEFAULT_RATELIMIT_BURST (10 events) over
98+
DEFAULT_RATELIMIT_INTERVAL (5 seconds).
99+
100+
Ratelimits are exposed in the form of sysfs attributes and configurable.
101+
See Documentation/ABI/testing/sysfs-bus-pci-devices-aer.
102+
88103
AER Statistics / Counters
89104
-------------------------
90105

91106
When PCIe AER errors are captured, the counters / statistics are also exposed
92107
in the form of sysfs attributes which are documented at
93-
Documentation/ABI/testing/sysfs-bus-pci-devices-aer_stats
108+
Documentation/ABI/testing/sysfs-bus-pci-devices-aer.
94109

95110
Developer Guide
96111
===============

Documentation/devicetree/bindings/pci/apple,pcie.yaml

Lines changed: 26 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,10 @@ description: |
1717
implements its root ports. But the ATU found on most DesignWare
1818
PCIe host bridges is absent.
1919
20+
On systems derived from T602x, the PHY registers are in a region
21+
separate from the port registers. In that case, there is one PHY
22+
register range per port register range.
23+
2024
All root ports share a single ECAM space, but separate GPIOs are
2125
used to take the PCI devices on those ports out of reset. Therefore
2226
the standard "reset-gpios" and "max-link-speed" properties appear on
@@ -30,16 +34,18 @@ description: |
3034
3135
properties:
3236
compatible:
33-
items:
34-
- enum:
35-
- apple,t8103-pcie
36-
- apple,t8112-pcie
37-
- apple,t6000-pcie
38-
- const: apple,pcie
37+
oneOf:
38+
- items:
39+
- enum:
40+
- apple,t8103-pcie
41+
- apple,t8112-pcie
42+
- apple,t6000-pcie
43+
- const: apple,pcie
44+
- const: apple,t6020-pcie
3945

4046
reg:
4147
minItems: 3
42-
maxItems: 6
48+
maxItems: 10
4349

4450
reg-names:
4551
minItems: 3
@@ -50,6 +56,10 @@ properties:
5056
- const: port1
5157
- const: port2
5258
- const: port3
59+
- const: phy0
60+
- const: phy1
61+
- const: phy2
62+
- const: phy3
5363

5464
ranges:
5565
minItems: 2
@@ -98,6 +108,15 @@ allOf:
98108
maxItems: 5
99109
interrupts:
100110
maxItems: 3
111+
- if:
112+
properties:
113+
compatible:
114+
contains:
115+
const: apple,t6020-pcie
116+
then:
117+
properties:
118+
reg-names:
119+
minItems: 10
101120

102121
examples:
103122
- |

Documentation/devicetree/bindings/pci/brcm,stb-pcie.yaml

Lines changed: 43 additions & 44 deletions
Original file line numberDiff line numberDiff line change
@@ -186,49 +186,48 @@ examples:
186186
#include <dt-bindings/interrupt-controller/arm-gic.h>
187187
188188
scb {
189-
#address-cells = <2>;
190-
#size-cells = <1>;
191-
pcie0: pcie@7d500000 {
192-
compatible = "brcm,bcm2711-pcie";
193-
reg = <0x0 0x7d500000 0x9310>;
194-
device_type = "pci";
195-
#address-cells = <3>;
196-
#size-cells = <2>;
197-
#interrupt-cells = <1>;
198-
interrupts = <GIC_SPI 147 IRQ_TYPE_LEVEL_HIGH>,
199-
<GIC_SPI 148 IRQ_TYPE_LEVEL_HIGH>;
200-
interrupt-names = "pcie", "msi";
201-
interrupt-map-mask = <0x0 0x0 0x0 0x7>;
202-
interrupt-map = <0 0 0 1 &gicv2 GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH
203-
0 0 0 2 &gicv2 GIC_SPI 144 IRQ_TYPE_LEVEL_HIGH
204-
0 0 0 3 &gicv2 GIC_SPI 145 IRQ_TYPE_LEVEL_HIGH
205-
0 0 0 4 &gicv2 GIC_SPI 146 IRQ_TYPE_LEVEL_HIGH>;
206-
207-
msi-parent = <&pcie0>;
208-
msi-controller;
209-
ranges = <0x02000000 0x0 0xf8000000 0x6 0x00000000 0x0 0x04000000>;
210-
dma-ranges = <0x42000000 0x1 0x00000000 0x0 0x40000000 0x0 0x80000000>,
211-
<0x42000000 0x1 0x80000000 0x3 0x00000000 0x0 0x80000000>;
212-
brcm,enable-ssc;
213-
brcm,scb-sizes = <0x0000000080000000 0x0000000080000000>;
214-
215-
/* PCIe bridge, Root Port */
216-
pci@0,0 {
217-
#address-cells = <3>;
218-
#size-cells = <2>;
219-
reg = <0x0 0x0 0x0 0x0 0x0>;
220-
compatible = "pciclass,0604";
221-
device_type = "pci";
222-
vpcie3v3-supply = <&vreg7>;
223-
ranges;
224-
225-
/* PCIe endpoint */
226-
pci-ep@0,0 {
227-
assigned-addresses =
228-
<0x82010000 0x0 0xf8000000 0x6 0x00000000 0x0 0x2000>;
229-
reg = <0x0 0x0 0x0 0x0 0x0>;
230-
compatible = "pci14e4,1688";
231-
};
232-
};
189+
#address-cells = <2>;
190+
#size-cells = <1>;
191+
pcie0: pcie@7d500000 {
192+
compatible = "brcm,bcm2711-pcie";
193+
reg = <0x0 0x7d500000 0x9310>;
194+
device_type = "pci";
195+
#address-cells = <3>;
196+
#size-cells = <2>;
197+
#interrupt-cells = <1>;
198+
interrupts = <GIC_SPI 147 IRQ_TYPE_LEVEL_HIGH>,
199+
<GIC_SPI 148 IRQ_TYPE_LEVEL_HIGH>;
200+
interrupt-names = "pcie", "msi";
201+
interrupt-map-mask = <0x0 0x0 0x0 0x7>;
202+
interrupt-map = <0 0 0 1 &gicv2 GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH
203+
0 0 0 2 &gicv2 GIC_SPI 144 IRQ_TYPE_LEVEL_HIGH
204+
0 0 0 3 &gicv2 GIC_SPI 145 IRQ_TYPE_LEVEL_HIGH
205+
0 0 0 4 &gicv2 GIC_SPI 146 IRQ_TYPE_LEVEL_HIGH>;
206+
207+
msi-parent = <&pcie0>;
208+
msi-controller;
209+
ranges = <0x02000000 0x0 0xf8000000 0x6 0x00000000 0x0 0x04000000>;
210+
dma-ranges = <0x42000000 0x1 0x00000000 0x0 0x40000000 0x0 0x80000000>,
211+
<0x42000000 0x1 0x80000000 0x3 0x00000000 0x0 0x80000000>;
212+
brcm,enable-ssc;
213+
brcm,scb-sizes = <0x0000000080000000 0x0000000080000000>;
214+
215+
/* PCIe bridge, Root Port */
216+
pci@0,0 {
217+
#address-cells = <3>;
218+
#size-cells = <2>;
219+
reg = <0x0 0x0 0x0 0x0 0x0>;
220+
compatible = "pciclass,0604";
221+
device_type = "pci";
222+
vpcie3v3-supply = <&vreg7>;
223+
ranges;
224+
225+
/* PCIe endpoint */
226+
pci-ep@0,0 {
227+
assigned-addresses = <0x82010000 0x0 0xf8000000 0x6 0x00000000 0x0 0x2000>;
228+
reg = <0x0 0x0 0x0 0x0 0x0>;
229+
compatible = "pci14e4,1688";
230+
};
233231
};
232+
};
234233
};

0 commit comments

Comments
 (0)