Skip to content

Commit 3cc3014

Browse files
committed
Merge tag 'pci-v5.19-changes' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci
Pull pci updates from Bjorn Helgaas: "Resource management: - Restrict E820 clipping to PCI host bridge windows (Bjorn Helgaas) - Log E820 clipping better (Bjorn Helgaas) - Add kernel cmdline options to enable/disable E820 clipping (Hans de Goede) - Disable E820 reserved region clipping for IdeaPads, Yoga, Yoga Slip, Acer Spin 5, Clevo Barebone systems where clipping leaves no usable address space for touchpads, Thunderbolt devices, etc (Hans de Goede) - Disable E820 clipping by default starting in 2023 (Hans de Goede) PCI device hotplug: - Include files to remove implicit dependencies (Christophe Leroy) - Only put Root Ports in D3 if they can signal and wake from D3 so AMD Yellow Carp doesn't miss hotplug events (Mario Limonciello) Power management: - Define pci_restore_standard_config() only for CONFIG_PM_SLEEP since it's unused otherwise (Krzysztof Kozlowski) - Power up devices completely, including anything platform firmware needs to do, during runtime resume (Rafael J. Wysocki) - Move pci_resume_bus() to PM callbacks so we observe the required bridge power-up delays (Rafael J. Wysocki) - Drop unneeded runtime_d3cold device flag (Rafael J. Wysocki) - Split pci_raw_set_power_state() between pci_power_up() and a new pci_set_low_power_state() (Rafael J. Wysocki) - Set current_state to D3cold if config read returns ~0, indicating the device is not accessible (Rafael J. Wysocki) - Do not call pci_update_current_state() from pci_power_up() so BARs and ASPM config are restored correctly (Rafael J. Wysocki) - Write 0 to PMCSR in pci_power_up() in all cases (Rafael J. Wysocki) - Split pci_power_up() to pci_set_full_power_state() to avoid some redundant operations (Rafael J. Wysocki) - Skip restoring BARs if device is not in D0 (Rafael J. Wysocki) - Rearrange and clarify pci_set_power_state() (Rafael J. Wysocki) - Remove redundant BAR restores from pci_pm_thaw_noirq() (Rafael J. Wysocki) Virtualization: - Acquire device lock before config space access lock to avoid AB/BA deadlock with sriov_numvfs_store() (Yicong Yang) Error handling: - Clear MULTI_ERR_COR/UNCOR_RCV bits, which a race could previously leave permanently set (Kuppuswamy Sathyanarayanan) Peer-to-peer DMA: - Whitelist Intel Skylake-E Root Ports regardless of which devfn they are (Shlomo Pongratz) ASPM: - Override L1 acceptable latency advertised by Intel DG2 so ASPM L1 can be enabled (Mika Westerberg) Cadence PCIe controller driver: - Set up device-specific register to allow PTM Responder to be enabled by the normal architected bit (Christian Gmeiner) - Override advertised FLR support since the controller doesn't implement FLR correctly (Parshuram Thombare) Cadence PCIe endpoint driver: - Correct bitmap size for the ob_region_map of outbound window usage (Dan Carpenter) Freescale i.MX6 PCIe controller driver: - Fix PERST# assertion/deassertion so we observe the required delays before accessing device (Francesco Dolcini) Freescale Layerscape PCIe controller driver: - Add "big-endian" DT property (Hou Zhiqiang) - Update SCFG DT property (Hou Zhiqiang) - Add "aer", "pme", "intr" DT properties (Li Yang) - Add DT compatible strings for ls1028a (Xiaowei Bao) Intel VMD host bridge driver: - Assign VMD IRQ domain before enumeration to avoid IOMMU interrupt remapping errors when MSI-X remapping is disabled (Nirmal Patel) - Revert VMD workaround that kept MSI-X remapping enabled when IOMMU remapping was enabled (Nirmal Patel) Marvell MVEBU PCIe controller driver: - Add of_pci_get_slot_power_limit() to parse the 'slot-power-limit-milliwatt' DT property (Pali Rohár) - Add mvebu support for sending Set_Slot_Power_Limit message (Pali Rohár) MediaTek PCIe controller driver: - Fix refcount leak in mtk_pcie_subsys_powerup() (Miaoqian Lin) MediaTek PCIe Gen3 controller driver: - Reset PHY and MAC at probe time (AngeloGioacchino Del Regno) Microchip PolarFlare PCIe controller driver: - Add chained_irq_enter()/chained_irq_exit() calls to mc_handle_msi() and mc_handle_intx() to avoid lost interrupts (Conor Dooley) - Fix interrupt handling race (Daire McNamara) NVIDIA Tegra194 PCIe controller driver: - Drop tegra194 MSI register save/restore, which is unnecessary since the DWC core does it (Jisheng Zhang) Qualcomm PCIe controller driver: - Add SM8150 SoC DT binding and support (Bhupesh Sharma) - Fix pipe clock imbalance (Johan Hovold) - Fix runtime PM imbalance on probe errors (Johan Hovold) - Fix PHY init imbalance on probe errors (Johan Hovold) - Convert DT binding to YAML (Dmitry Baryshkov) - Update DT binding to show that resets aren't required for MSM8996/APQ8096 platforms (Dmitry Baryshkov) - Add explicit register names per chipset in DT binding (Dmitry Baryshkov) - Add sc7280-specific clock and reset definitions to DT binding (Dmitry Baryshkov) Rockchip PCIe controller driver: - Fix bitmap size when searching for free outbound region (Dan Carpenter) Rockchip DesignWare PCIe controller driver: - Remove "snps,dw-pcie" from rockchip-dwc DT "compatible" property because it's not fully compatible with rockchip (Peter Geis) - Reset rockchip-dwc controller at probe (Peter Geis) - Add rockchip-dwc INTx support (Peter Geis) Synopsys DesignWare PCIe controller driver: - Return error instead of success if DMA mapping of MSI area fails (Jiantao Zhang) Miscellaneous: - Change pci_set_dma_mask() documentation references to dma_set_mask() (Alex Williamson)" * tag 'pci-v5.19-changes' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci: (64 commits) dt-bindings: PCI: qcom: Add schema for sc7280 chipset dt-bindings: PCI: qcom: Specify reg-names explicitly dt-bindings: PCI: qcom: Do not require resets on msm8996 platforms dt-bindings: PCI: qcom: Convert to YAML PCI: qcom: Fix unbalanced PHY init on probe errors PCI: qcom: Fix runtime PM imbalance on probe errors PCI: qcom: Fix pipe clock imbalance PCI: qcom: Add SM8150 SoC support dt-bindings: pci: qcom: Document PCIe bindings for SM8150 SoC x86/PCI: Disable E820 reserved region clipping starting in 2023 x86/PCI: Disable E820 reserved region clipping via quirks x86/PCI: Add kernel cmdline options to use/ignore E820 reserved regions PCI: microchip: Fix potential race in interrupt handling PCI/AER: Clear MULTI_ERR_COR/UNCOR_RCV bits PCI: cadence: Clear FLR in device capabilities register PCI: cadence: Allow PTM Responder to be enabled PCI: vmd: Revert 2565e5b ("PCI: vmd: Do not disable MSI-X remapping if interrupt remapping is enabled by IOMMU.") PCI: vmd: Assign VMD IRQ domain before enumeration PCI: Avoid pci_dev_lock() AB/BA deadlock with sriov_numvfs_store() PCI: rockchip-dwc: Add legacy interrupt support ...
2 parents 8291eaa + 32f479d commit 3cc3014

Some content is hidden

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

43 files changed

+1646
-748
lines changed

Documentation/PCI/pci.rst

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -273,12 +273,12 @@ Set the DMA mask size
273273
While all drivers should explicitly indicate the DMA capability
274274
(e.g. 32 or 64 bit) of the PCI bus master, devices with more than
275275
32-bit bus master capability for streaming data need the driver
276-
to "register" this capability by calling pci_set_dma_mask() with
276+
to "register" this capability by calling dma_set_mask() with
277277
appropriate parameters. In general this allows more efficient DMA
278278
on systems where System RAM exists above 4G _physical_ address.
279279

280280
Drivers for all PCI-X and PCIe compliant devices must call
281-
set_dma_mask() as they are 64-bit DMA devices.
281+
dma_set_mask() as they are 64-bit DMA devices.
282282

283283
Similarly, drivers must also "register" this capability if the device
284284
can directly address "coherent memory" in System RAM above 4G physical

Documentation/admin-guide/kernel-parameters.txt

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -4099,6 +4099,15 @@
40994099
please report a bug.
41004100
nocrs [X86] Ignore PCI host bridge windows from ACPI.
41014101
If you need to use this, please report a bug.
4102+
use_e820 [X86] Use E820 reservations to exclude parts of
4103+
PCI host bridge windows. This is a workaround
4104+
for BIOS defects in host bridge _CRS methods.
4105+
If you need to use this, please report a bug to
4106+
4107+
no_e820 [X86] Ignore E820 reservations for PCI host
4108+
bridge windows. This is the default on modern
4109+
hardware. If you need to use this, please report
4110+
a bug to <[email protected]>.
41024111
routeirq Do IRQ routing for all PCI devices.
41034112
This is normally done in pci_enable_device(),
41044113
so this option is a temporary workaround

Documentation/devicetree/bindings/pci/layerscape-pci.txt

Lines changed: 38 additions & 27 deletions
Original file line numberDiff line numberDiff line change
@@ -23,46 +23,57 @@ Required properties:
2323
"fsl,ls1012a-pcie"
2424
"fsl,ls1028a-pcie"
2525
EP mode:
26+
"fsl,ls1028a-pcie-ep", "fsl,ls-pcie-ep"
2627
"fsl,ls1046a-pcie-ep", "fsl,ls-pcie-ep"
2728
"fsl,ls1088a-pcie-ep", "fsl,ls-pcie-ep"
2829
"fsl,ls2088a-pcie-ep", "fsl,ls-pcie-ep"
2930
"fsl,lx2160ar2-pcie-ep", "fsl,ls-pcie-ep"
3031
- reg: base addresses and lengths of the PCIe controller register blocks.
3132
- interrupts: A list of interrupt outputs of the controller. Must contain an
3233
entry for each entry in the interrupt-names property.
33-
- interrupt-names: Must include the following entries:
34-
"intr": The interrupt that is asserted for controller interrupts
34+
- interrupt-names: It could include the following entries:
35+
"aer": Used for interrupt line which reports AER events when
36+
non MSI/MSI-X/INTx mode is used
37+
"pme": Used for interrupt line which reports PME events when
38+
non MSI/MSI-X/INTx mode is used
39+
"intr": Used for SoCs(like ls2080a, lx2160a, ls2080a, ls2088a, ls1088a)
40+
which has a single interrupt line for miscellaneous controller
41+
events(could include AER and PME events).
3542
- fsl,pcie-scfg: Must include two entries.
3643
The first entry must be a link to the SCFG device node
37-
The second entry must be '0' or '1' based on physical PCIe controller index.
44+
The second entry is the physical PCIe controller index starting from '0'.
3845
This is used to get SCFG PEXN registers
3946
- dma-coherent: Indicates that the hardware IP block can ensure the coherency
4047
of the data transferred from/to the IP block. This can avoid the software
4148
cache flush/invalid actions, and improve the performance significantly.
4249

50+
Optional properties:
51+
- big-endian: If the PEX_LUT and PF register block is in big-endian, specify
52+
this property.
53+
4354
Example:
4455

45-
pcie@3400000 {
46-
compatible = "fsl,ls1021a-pcie";
47-
reg = <0x00 0x03400000 0x0 0x00010000 /* controller registers */
48-
0x40 0x00000000 0x0 0x00002000>; /* configuration space */
49-
reg-names = "regs", "config";
50-
interrupts = <GIC_SPI 177 IRQ_TYPE_LEVEL_HIGH>; /* controller interrupt */
51-
interrupt-names = "intr";
52-
fsl,pcie-scfg = <&scfg 0>;
53-
#address-cells = <3>;
54-
#size-cells = <2>;
55-
device_type = "pci";
56-
dma-coherent;
57-
num-lanes = <4>;
58-
bus-range = <0x0 0xff>;
59-
ranges = <0x81000000 0x0 0x00000000 0x40 0x00010000 0x0 0x00010000 /* downstream I/O */
60-
0xc2000000 0x0 0x20000000 0x40 0x20000000 0x0 0x20000000 /* prefetchable memory */
61-
0x82000000 0x0 0x40000000 0x40 0x40000000 0x0 0x40000000>; /* non-prefetchable memory */
62-
#interrupt-cells = <1>;
63-
interrupt-map-mask = <0 0 0 7>;
64-
interrupt-map = <0000 0 0 1 &gic GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>,
65-
<0000 0 0 2 &gic GIC_SPI 188 IRQ_TYPE_LEVEL_HIGH>,
66-
<0000 0 0 3 &gic GIC_SPI 190 IRQ_TYPE_LEVEL_HIGH>,
67-
<0000 0 0 4 &gic GIC_SPI 192 IRQ_TYPE_LEVEL_HIGH>;
68-
};
56+
pcie@3400000 {
57+
compatible = "fsl,ls1088a-pcie";
58+
reg = <0x00 0x03400000 0x0 0x00100000>, /* controller registers */
59+
<0x20 0x00000000 0x0 0x00002000>; /* configuration space */
60+
reg-names = "regs", "config";
61+
interrupts = <0 108 IRQ_TYPE_LEVEL_HIGH>; /* aer interrupt */
62+
interrupt-names = "aer";
63+
#address-cells = <3>;
64+
#size-cells = <2>;
65+
device_type = "pci";
66+
dma-coherent;
67+
num-viewport = <256>;
68+
bus-range = <0x0 0xff>;
69+
ranges = <0x81000000 0x0 0x00000000 0x20 0x00010000 0x0 0x00010000 /* downstream I/O */
70+
0x82000000 0x0 0x40000000 0x20 0x40000000 0x0 0x40000000>; /* non-prefetchable memory */
71+
msi-parent = <&its>;
72+
#interrupt-cells = <1>;
73+
interrupt-map-mask = <0 0 0 7>;
74+
interrupt-map = <0000 0 0 1 &gic 0 0 0 109 IRQ_TYPE_LEVEL_HIGH>,
75+
<0000 0 0 2 &gic 0 0 0 110 IRQ_TYPE_LEVEL_HIGH>,
76+
<0000 0 0 3 &gic 0 0 0 111 IRQ_TYPE_LEVEL_HIGH>,
77+
<0000 0 0 4 &gic 0 0 0 112 IRQ_TYPE_LEVEL_HIGH>;
78+
iommu-map = <0 &smmu 0 1>; /* Fixed-up by bootloader */
79+
};

0 commit comments

Comments
 (0)