1. 19 Sep, 2024 27 commits
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/vmd' · 11e32bbe
      Bjorn Helgaas authored
      - Fix whitespace indentation issues (Riyan Dhiman)
      
      * pci/controller/vmd:
        PCI: vmd: Fix indentation issue in vmd_shutdown()
      11e32bbe
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/rcar-gen4' · 187b8115
      Bjorn Helgaas authored
      - Make the read-only const array 'check_addr' static (Colin Ian King)
      
      - Add R-Car V4M (R8A779H0) PCIe host and endpoint to DT binding (Yoshihiro
        Shimoda)
      
      * pci/controller/rcar-gen4:
        dt-bindings: PCI: rcar-gen4-pci-ep: Add R-Car V4M compatible
        dt-bindings: PCI: rcar-gen4-pci-host: Add R-Car V4M compatible
        PCI: rcar-gen4: Make read-only const array check_addr static
      187b8115
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/qcom' · 45e981b8
      Bjorn Helgaas authored
      - Drop endpoint redundant masking of global IRQ events (Manivannan
        Sadhasivam)
      
      - Clarify unknown global IRQ message and only log it once to avoid a flood
        (Manivannan Sadhasivam)
      
      - Add Manivannan Sadhasivam as maintainer of qcom endpoint driver
        (Manivannan Sadhasivam)
      
      - Add 'linux,pci-domain' property to endpoint DT binding (Manivannan
        Sadhasivam)
      
      - Assign PCI domain number for endpoint controllers (Manivannan Sadhasivam)
      
      - Add 'qcom_pcie_ep' and the PCI domain number to IRQ names for endpoint
        controller (Manivannan Sadhasivam)
      
      - Add global SPI interrupt for PCIe link events to DT binding (Manivannan
        Sadhasivam)
      
      - Add global RC interrupt handler to handle 'Link up' events and
        automatically enumerate hot-added devices (Manivannan Sadhasivam)
      
      - Avoid mirroring of DBI and iATU register space so it doesn't overlap BAR
        MMIO space (Prudhvi Yarlagadda)
      
      - Enable controller resources like PHY only after PERST# is deasserted to
        partially avoid the problem that the endpoint SoC crashes when accessing
        things when Refclk is absent (Manivannan Sadhasivam)
      
      - Rename dw_pcie.link_gen to max_link_speed to avoid ambiguity (Manivannan
        Sadhasivam)
      
      - Cache maximum link speed value in dw_pcie.max_link_speed for use by
        vendor drivers (Manivannan Sadhasivam)
      
      - Add 16.0 GT/s equalization and RX lane margining settings (Shashank Babu
        Chinta Venkata)
      
      - Pass domain number to pci_bus_release_domain_nr() explicitly to avoid a
        NULL pointer dereference (Manivannan Sadhasivam)
      
      * pci/controller/qcom:
        PCI: Pass domain number to pci_bus_release_domain_nr() explicitly
        PCI: qcom: Add RX lane margining settings for 16.0 GT/s
        PCI: qcom: Add equalization settings for 16.0 GT/s
        PCI: dwc: Always cache the maximum link speed value in dw_pcie::max_link_speed
        PCI: dwc: Rename 'dw_pcie::link_gen' to 'dw_pcie::max_link_speed'
        PCI: qcom-ep: Enable controller resources like PHY only after refclk is available
        PCI: qcom: Disable mirroring of DBI and iATU register space in BAR region
        PCI: qcom: Enumerate endpoints based on Link up event in 'global_irq' interrupt
        dt-bindings: PCI: qcom,pcie-sm8450: Add 'global' interrupt
        PCI: qcom-ep: Modify 'global_irq' and 'perst_irq' IRQ device names
        PCI: endpoint: Assign PCI domain number for endpoint controllers
        dt-bindings: PCI: pci-ep: Document 'linux,pci-domain' property
        dt-bindings: PCI: pci-ep: Update Maintainers
        PCI: qcom-ep: Reword the error message for receiving unknown global IRQ event
        PCI: qcom-ep: Drop the redundant masking of global IRQ events
      45e981b8
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/mediatek-gen3' · 1bcf2331
      Bjorn Helgaas authored
      - Add per-SoC struct mtk_gen3_pcie_pdata to support multiple SoC types
        (Lorenzo Bianconi)
      
      - Use reset_bulk APIs to manage PHY reset lines (Lorenzo Bianconi)
      
      - Add DT and driver support for Airoha EN7581 PCIe controller (Lorenzo
        Bianconi)
      
      * pci/controller/mediatek-gen3:
        PCI: mediatek-gen3: Add Airoha EN7581 support
        PCI: mediatek-gen3: Rely on reset_bulk APIs for PHY reset lines
        PCI: mediatek-gen3: Add mtk_gen3_pcie_pdata data structure
        dt-bindings: PCI: mediatek-gen3: Add support for Airoha EN7581
      1bcf2331
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/mediatek' · 487ce3e5
      Bjorn Helgaas authored
      - Drop excess mtk_pcie.mem kerneldoc description (Bjorn Helgaas)
      
      * pci/controller/mediatek:
        PCI: mediatek: Drop excess mtk_pcie.mem kerneldoc description
      487ce3e5
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/loongson' · 97b9d65e
      Bjorn Helgaas authored
      - Increase max PCI hosts to 8 for Loongson-3C6000 and newer chipsets
        (Huacai Chen)
      
      * pci/controller/loongson:
        PCI/ACPI: Increase Loongson max PCI hosts to 8
      97b9d65e
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/kirin' · af649194
      Bjorn Helgaas authored
      - Fix potential buffer overflow in kirin_pcie_parse_port() (Alexandra
        Diupina)
      
      * pci/controller/kirin:
        PCI: kirin: Fix buffer overflow in kirin_pcie_parse_port()
      af649194
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/keystone' · e5f8d1c7
      Bjorn Helgaas authored
      - Fix NULL pointer checking when applying MRRS limitation quirk for AM65x
        SR 1.0 Errata #i2037 (Dan Carpenter)
      
      * pci/controller/keystone:
        PCI: keystone: Fix if-statement expression in ks_pcie_quirk()
      e5f8d1c7
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/j721e' · d1624da3
      Bjorn Helgaas authored
      - Add DT "ti,syscon-acspcie-proxy-ctrl" and driver support to enable the
        ACSPCIE module to drive Refclk for the Endpoint (Siddharth Vadapalli)
      
      - Extract the cadence link setup from cdns_pcie_host_setup() so link setup
        can be done separately during resume (Thomas Richard)
      
      - Use dev_err_probe() to simplify j721e probe (Thomas Richard)
      
      - Add T_PERST_CLK_US definition for the mandatory delay between Refclk
        becoming stable and PERST# being deasserted (Thomas Richard)
      
      - Add j721e suspend and resume support (Théo Lebrun)
      
      * pci/controller/j721e:
        PCI: j721e: Add suspend and resume support
        PCI: j721e: Use T_PERST_CLK_US macro
        PCI: Add T_PERST_CLK_US macro
        PCI: j721e: Add reset GPIO to struct j721e_pcie
        PCI: j721e: Use dev_err_probe() in the probe() function
        PCI: cadence: Set cdns_pcie_host_init() global
        PCI: cadence: Extract link setup sequence from cdns_pcie_host_setup()
        PCI: j721e: Enable ACSPCIE Refclk if "ti,syscon-acspcie-proxy-ctrl" exists
        dt-bindings: PCI: ti,j721e-pci-host: Add ACSPCIE proxy control property
      d1624da3
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/imx6' · f8ca62bf
      Bjorn Helgaas authored
      - Fix a code restructuring error that caused i.MX8MM and i.MX8MP Endpoints
        to fail to establish link (Richard Zhu)
      
      - Fix i.MX8MP Endpoint occasional failure to trigger MSI by enforcing
        outbound alignment requirement (Richard Zhu)
      
      - Call phy_power_off() in the .probe() error path (Frank Li)
      
      - Rename internal names from imx6_* to imx_* since i.MX7/8/9 are also
        supported (Frank Li)
      
      - Manage Refclk by using SoC-specific callbacks instead of switch
        statements (Frank Li)
      
      - Manage core reset by using SoC-specific callbacks instead of switch
        statements (Frank Li)
      
      - Expand comments for erratum ERR010728 workaround (Frank Li)
      
      - Use generic PHY APIs to configure mode, speed, and submode, which is
        harmless for devices that implement their own internal PHY management and
        don't set the generic imx_pcie->phy (Frank Li)
      
      - Add i.MX8Q (i.MX8QM, i.MX8QXP, and i.MX8DXL) DT binding and driver Root
        Complex support (Richard Zhu)
      
      * pci/controller/imx6:
        PCI: imx6: Add i.MX8Q PCIe Root Complex (RC) support
        PCI: imx6: Call common PHY API to set mode, speed, and submode
        dt-bindings: PCI: imx6q-pcie: Add i.MX8Q PCIe compatible string
        PCI: imx6: Consolidate redundant if-checks
        PCI: imx6: Improve comment for workaround ERR010728
        PCI: imx6: Simplify switch-case logic by involve core_reset callback
        PCI: imx6: Introduce SoC specific callbacks for controlling REFCLK
        PCI: imx6: Rename imx6_* with imx_*
        PCI: imx6: Fix missing call to phy_power_off() in error handling
        PCI: imx6: Fix i.MX8MP PCIe EP's occasional failure to trigger MSI
        PCI: imx6: Fix establish link failure in EP mode for i.MX8MM and i.MX8MP
      f8ca62bf
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/dra7xx' · 5ec58799
      Bjorn Helgaas authored
      - Request IRQF_ONESHOT for 'dra7xx-pcie-main' IRQ since the primary handler
        is NULL (Siddharth Vadapalli)
      
      - Handle IRQ request errors during root port and endpoint probe (Siddharth
        Vadapalli)
      
      * pci/controller/dra7xx:
        PCI: dra7xx: Fix error handling when IRQ request fails in probe
        PCI: dra7xx: Fix threaded IRQ request for "dra7xx-pcie-main" IRQ
      5ec58799
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/cadence' · da71957c
      Bjorn Helgaas authored
      - Drop excess cdns_pcie_rc.dev kerneldoc description (Bjorn Helgaas)
      
      * pci/controller/cadence:
        PCI: cadence: Drop excess cdns_pcie_rc.dev kerneldoc description
      da71957c
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/brcmstb' · b893f8ea
      Bjorn Helgaas authored
      - Change DT binding maintainer to Jim Quinlan (Jim Quinlan)
      
      - Add DT binding maxItems for reset controllers (Jim Quinlan)
      
      - Refactor .probe() error handling (Jim Quinlan)
      
      - Use the 'bridge' reset method if described in the DT (Jim Quinlan)
      
      - Use the 'swinit' reset method if described in the DT (Jim Quinlan)
      
      - Add SoC-specific HARD_DEBUG, INTR2_CPU_BASE register offsets (Jim
        Quinlan)
      
      - Drop unused RGR1_SW_INIT_1_INIT_MASK, RGR1_SW_INIT_1_INIT_SHIFT offsets
        (Jim Quinlan)
      
      - Add 'has_phy' so the existence of a 'rescal' reset controller doesn't
        imply software control of it (Jim Quinlan)
      
      - Add support for many inbound DMA windows (Jim Quinlan)
      
      - Check return values of all reset_control_*() calls (Jim Quinlan)
      
      - Rename SoC 'type' to 'soc_base' express the fact that SoCs come in
        families of multiple similar devices (Jim Quinlan)
      
      - Add Broadcom 7712 DT description and driver support (Jim Quinlan)
      
      - Sort enums, pcie_offsets[], pcie_cfg_data, .compatible strings for
        maintainability (Bjorn Helgaas)
      
      * pci/controller/brcmstb:
        PCI: brcmstb: Sort enums, pcie_offsets[], pcie_cfg_data, .compatible strings
        PCI: brcmstb: Enable 7712 SoCs
        PCI: brcmstb: Change field name from 'type' to 'soc_base'
        PCI: brcmstb: Check return value of all reset_control_* calls
        PCI: brcmstb: Refactor for chips with many regular inbound windows
        PCI: brcmstb: Don't conflate the reset rescal with PHY ctrl
        PCI: brcmstb: Remove two unused constants from driver
        PCI: brcmstb: PCI: brcmstb: Make HARD_DEBUG, INTR2_CPU_BASE offsets SoC-specific
        PCI: brcmstb: Use swinit reset if available
        PCI: brcmstb: Use bridge reset if available
        PCI: brcmstb: Use common error handling code in brcm_pcie_probe()
        dt-bindings: PCI: brcm,stb-pcie: Add 7712 SoC description
        dt-bindings: PCI: brcm,stb-pcie: Use maxItems for reset controllers
        dt-bindings: PCI: brcm,stb-pcie: Change brcmstb maintainer and cleanup
      b893f8ea
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/altera' · 37b35d4d
      Bjorn Helgaas authored
      - Replace TLP_REQ_ID() with macro PCI_DEVID(), which does the same thing
        and is what other drivers use (Jinjie Ruan)
      
      * pci/controller/altera:
        PCI: altera: Replace TLP_REQ_ID() with macro PCI_DEVID()
      37b35d4d
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/affinity' · f045bc60
      Bjorn Helgaas authored
      - Add MSI_FLAG_NO_AFFINITY flag for devices that mux MSIs onto a single IRQ
        line and cannot set the affinity of each MSI to a specific CPU core
        (Marek Vasut)
      
      - Use MSI_FLAG_NO_AFFINITY and remove unnecessary .irq_set_affinity()
        implementations in aardvark, altera, brcmstb, dwc, mediatek-gen3,
        mediatek, mobiveil, plda, rcar, tegra, vmd, xilinx-nwl, xilinx-xdma, and
        xilinx drivers to avoid "IRQ: set affinity failed" warnings (Marek Vasut)
      
      * pci/controller/affinity:
        PCI: xilinx: Silence 'set affinity failed' warning
        PCI: xilinx-xdma: Silence 'set affinity failed' warning
        PCI: xilinx-nwl: Silence 'set affinity failed' warning
        PCI: vmd: Silence 'set affinity failed' warning
        PCI: tegra: Silence 'set affinity failed' warning
        PCI: rcar-host: Silence 'set affinity failed' warning
        PCI: plda: Silence 'set affinity failed' warning
        PCI: mobiveil: Silence 'set affinity failed' warning
        PCI: mediatek: Silence 'set affinity failed' warning
        PCI: mediatek-gen3: Silence 'set affinity failed' warning
        PCI: dwc: Silence 'set affinity failed' warning
        PCI: brcmstb: Silence 'set affinity failed' warning
        PCI: altera-msi: Silence 'set affinity failed' warning
        PCI: aardvark: Silence 'set affinity failed' warning
        genirq/msi: Silence 'set affinity failed' warning
      f045bc60
    • Bjorn Helgaas's avatar
      Merge branch 'pci/controller/endpoint' · 94d6a3a0
      Bjorn Helgaas authored
      - Fix enum pci_epc_bar_type kerneldoc (Bjorn Helgaas)
      
      * pci/controller/endpoint:
        PCI: endpoint: Fix enum pci_epc_bar_type kerneldoc
      94d6a3a0
    • Bjorn Helgaas's avatar
      Merge branch 'pci/dt-bindings' · 207bcb73
      Bjorn Helgaas authored
      - Drop minItems and maxItems from ranges in PCI generic host binding since
        host bridges may have several MMIO and I/O port apertures (Frank Li)
      
      - Add kirin, rcar-gen2, uniphier DT binding top-level constraints for
        clocks (Krzysztof Kozlowski)
      
      - Replace layerscape-pcie DT binding compatible fsl,lx2160a-pcie with
        fsl,lx2160ar2-pcie (Frank Li)
      
      - Add layerscape-pcie DT binding deprecated 'num-viewport' property to
        address a DT checker warning (Frank Li)
      
      - Change layerscape-pcie DT binding 'fsl,pcie-scfg' to phandle-array (Frank
        Li)
      
      - Update qcom,pcie-sc7280 DT binding with eight interrupts (Rayyan Ansari)
      
      - Convert altera DT bindings from text to YAML (Matthew Gerlach)
      
      - Add imx6q-pcie 'dbi2' and 'atu' reg-names for i.MX8M Endpoints (Richard
        Zhu)
      
      - Add back qcom 'vddpe-3v3-supply', which was incorrectly removed earlier
        (Johan Hovold)
      
      * pci/dt-bindings:
        dt-bindings: PCI: qcom: Allow 'vddpe-3v3-supply' again
        dt-bindings: PCI: imx6q-pcie: Add reg-name "dbi2" and "atu" for i.MX8M PCIe Endpoint
        dt-bindings: PCI: altera: msi: Convert to YAML
        dt-bindings: PCI: altera: Convert to YAML
        dt-bindings: PCI: qcom,pcie-sc7280: Update bindings adding eight interrupts
        dt-bindings: PCI: layerscape-pci: Change property 'fsl,pcie-scfg' type
        dt-bindings: PCI: layerscape-pci: Add deprecated property 'num-viewport'
        dt-bindings: PCI: layerscape-pci: Replace fsl,lx2160a-pcie with fsl,lx2160ar2-pcie
        dt-bindings: PCI: socionext,uniphier-pcie-ep: Add top-level constraints
        dt-bindings: PCI: renesas,pci-rcar-gen2: Add top-level constraints
        dt-bindings: PCI: hisilicon,kirin-pcie: Add top-level constraints
        dt-bindings: PCI: host-generic-pci: Drop minItems and maxItems of ranges
      207bcb73
    • Bjorn Helgaas's avatar
      Merge branch 'pci/sysfs' · ed072e44
      Bjorn Helgaas authored
      - Add ARCH_PCI_DEV_GROUPS so s390 can add its own attribute_groups without
        having to stomp on the core's pdev->dev.groups (Lukas Wunner)
      
      * pci/sysfs:
        s390/pci: Stop usurping pdev->dev.groups
      ed072e44
    • Bjorn Helgaas's avatar
      Merge branch 'pci/reset' · f2a3ce15
      Bjorn Helgaas authored
      - Wait for each level of downstream bus, not just the first, to become
        accessible before restoring devices on that bus (Ilpo Järvinen)
      
      * pci/reset:
        PCI: Wait for Link before restoring Downstream Buses
      f2a3ce15
    • Bjorn Helgaas's avatar
      Merge branch 'pci/pwrctl' · d774674f
      Bjorn Helgaas authored
      - Add pwrctl support for ATH11K inside the WCN6855 package (Konrad Dybcio)
      
      * pci/pwrctl:
        PCI/pwrctl: Add WCN6855 support
      d774674f
    • Bjorn Helgaas's avatar
      Merge branch 'pci/npem' · 9d4f1c07
      Bjorn Helgaas authored
      - Initialize leds class earlier (with an unfortunate Makefile ordering
        change) so the PCI NPEM driver can use it (Mariusz Tkaczyk)
      
      - Add Native PCIe Enclosure Management (NPEM) support for sysfs control of
        NVMe RAID storage indicators (ok/fail/locate/rebuild/etc) (Mariusz
        Tkaczyk)
      
      - Add support for the ACPI _DSM PCIe SSD status LED management, which is
        functionally similar to NPEM but mediated by platform firmware (Mariusz
        Tkaczyk)
      
      * pci/npem:
        PCI/NPEM: Add _DSM PCIe SSD status LED management
        PCI/NPEM: Add Native PCIe Enclosure Management support
        leds: Init leds class earlier
      9d4f1c07
    • Bjorn Helgaas's avatar
      Merge branch 'pci/iommu' · e642aa6b
      Bjorn Helgaas authored
      - Add function 0 DMA alias quirk for Glenfly Arise audio function, which
        uses the function 0 Requester ID (WangYuli)
      
      * pci/iommu:
        PCI: Add function 0 DMA alias quirk for Glenfly Arise chip
      e642aa6b
    • Bjorn Helgaas's avatar
      Merge branch 'pci/hotplug' · 15a724aa
      Bjorn Helgaas authored
      - Remove unnecessary hpc_ops struct from shpchp (ngn)
      
      - Check for PCI_POSSIBLE_ERROR(), not 0xffffffff, in cpqphp (weiyufeng)
      
      * pci/hotplug:
        PCI: cpqphp: Use PCI_POSSIBLE_ERROR() to check config reads
        PCI: shpchp: Remove hpc_ops
      15a724aa
    • Bjorn Helgaas's avatar
      Merge branch 'pci/enumeration' · dffe4cca
      Bjorn Helgaas authored
      - Clear LBMS bit after a manual link retrain so we don't try to retrain a
        link when there's no downstream device anymore (Maciej W. Rozycki)
      
      - Revert to the original link speed after retraining fails instead of
        leaving it restricted to 2.5GT/s, so a future device has a chance to use
        higher speeds (Maciej W. Rozycki)
      
      - Correct interpretation of pcie_retrain_link() return status and update it
        to return 0/errno instead of true/false (Maciej W.  Rozycki)
      
      * pci/enumeration:
        PCI: Use an error code with PCIe failed link retraining
        PCI: Correct error reporting with PCIe failed link retraining
        PCI: Revert to the original speed after PCIe failed link retraining
        PCI: Clear the LBMS bit after a link retrain
      dffe4cca
    • Bjorn Helgaas's avatar
      Merge branch 'pci/devres' · dceed697
      Bjorn Helgaas authored
      - Export pcim_request_region(), a managed counterpart of
        pci_request_region(), for use by drivers (Philipp Stanner)
      
      - Request the PCI BAR used by xboxvideo (Philipp Stanner)
      
      - Export pcim_iomap_region() and deprecate pcim_iomap_regions() (Philipp
        Stanner)
      
      - Request and map drm/ast BARs with pcim_iomap_region() (Philipp Stanner)
      
      * pci/devres:
        drm/ast: Request PCI BAR with devres
        PCI: Deprecate pcim_iomap_regions() in favor of pcim_iomap_region()
        drm/vboxvideo: Add PCI region request
        PCI: Make pcim_request_region() a public function
      dceed697
    • Bjorn Helgaas's avatar
      Merge branch 'pci/crs' · 59b748cd
      Bjorn Helgaas authored
      - Wait for device readiness after reset by polling Vendor ID and looking
        for Configuration RRS instead of polling the Command register and looking
        for non-error completions (Bjorn Helgaas)
      
      - Fix an aardvark issue with emulating Configuration RRS for two-byte reads
        of Vendor ID; previously it only worked for four-byte reads (Bjorn
        Helgaas)
      
      - Rename CRS Completion Status to RRS to match spec usage (Bjorn Helgaas)
      
      * pci/crs:
        PCI: Rename CRS Completion Status to RRS
        PCI: aardvark: Correct Configuration RRS checking
        PCI: Wait for device readiness with Configuration RRS
      59b748cd
    • Bjorn Helgaas's avatar
      Merge branch 'pci/aer' · 1a346559
      Bjorn Helgaas authored
      - Use PCI_DEVID() macro in aer_inject() instead of open-coding it (Jinjie
        Ruan)
      
      * pci/aer:
        PCI/AER: Use PCI_DEVID() macro in aer_inject()
      1a346559
  2. 13 Sep, 2024 11 commits
  3. 11 Sep, 2024 2 commits