1. 19 Sep, 2024 12 commits
    • 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 3 commits
  3. 11 Sep, 2024 3 commits
    • Bjorn Helgaas's avatar
      PCI: Rename CRS Completion Status to RRS · 87f10faf
      Bjorn Helgaas authored
      PCIe r6.0 changed the abbreviation for "Configuration Request Retry Status"
      Completion Status from "CRS" to "RRS" and uses the terminology of
      "Configuration RRS Software Visibility" instead of "CRS Software
      Visibility".
      
      Align the Linux usage with the r6.0 spec language.  No functional change
      intended.
      
      It's confusing to make this change, but I think "RRS" *is* a better
      abbreviation because it was easy to interpret "CRS" as "Completion Retry
      Status", which really didn't make any sense.
      
      Link: https://lore.kernel.org/r/20240827234848.4429-4-helgaas@kernel.orgSigned-off-by: default avatarBjorn Helgaas <bhelgaas@google.com>
      87f10faf
    • Bjorn Helgaas's avatar
      PCI: aardvark: Correct Configuration RRS checking · dd4e47ea
      Bjorn Helgaas authored
      Per PCIe r6.0, sec 2.3.2, when a Root Complex handles a Completion with
      Request Retry Status for a Configuration Read Request that includes both
      bytes of the Vendor ID field, it must complete the Request to the host by
      returning 0001h for the Vendor ID and all 1's for any additional bytes.
      
      Previously we only returned the 0001h Vendor ID value if we got an RRS
      completion for reads of exactly 4 bytes.  A read of 2 bytes would not
      qualify, although the spec says it should.
      
      Check for reads of 2 or more bytes including the Vendor ID.
      
      I don't think this will fix any observable problems because RRS only
      applies to the first config reads after reset, and those are all currently
      dword (4-byte) reads.
      
      Link: https://lore.kernel.org/r/20240827234848.4429-3-helgaas@kernel.orgSigned-off-by: default avatarBjorn Helgaas <bhelgaas@google.com>
      dd4e47ea
    • Bjorn Helgaas's avatar
      PCI: Wait for device readiness with Configuration RRS · d591f680
      Bjorn Helgaas authored
      After a device reset, delays are required before the device can
      successfully complete config accesses.  PCIe r6.0, sec 6.6, specifies some
      delays required before software can perform config accesses.  Devices that
      require more time after those delays may respond to config accesses with
      Configuration Request Retry Status (RRS) completions.
      
      Callers of pci_dev_wait() are responsible for delays until the device can
      respond to config accesses.  pci_dev_wait() waits any additional time until
      the device can successfully complete config accesses.
      
      Reading config space of devices that are not present or not ready typically
      returns ~0 (PCI_ERROR_RESPONSE).  Previously we polled the Command register
      until we got a value other than ~0.  This is sometimes a problem because
      Root Complex handling of RRS completions may include several retries and
      implementation-specific behavior that is invisible to software (see sec
      2.3.2), so the exponential backoff in pci_dev_wait() may not work as
      intended.
      
      Linux enables Configuration RRS Software Visibility on all Root Ports that
      support it.  If it is enabled, read the Vendor ID instead of the Command
      register.  RRS completions cause immediate return of the 0x0001 reserved
      Vendor ID value, so the pci_dev_wait() backoff works correctly.
      
      When a read of Vendor ID eventually completes successfully by returning a
      non-0x0001 value (the Vendor ID or 0xffff for VFs), the device should be
      initialized and ready to respond to config requests.
      
      For conventional PCI devices or devices below Root Ports that don't support
      Configuration RRS Software Visibility, poll the Command register as before.
      
      This was developed independently, but is very similar to Stanislav
      Spassov's previous work at
      https://lore.kernel.org/linux-pci/20200223122057.6504-1-stanspas@amazon.com
      
      Link: https://lore.kernel.org/r/20240827234848.4429-2-helgaas@kernel.orgSigned-off-by: default avatarBjorn Helgaas <bhelgaas@google.com>
      Tested-by: default avatarDuc Dang <ducdang@google.com>
      d591f680
  4. 09 Sep, 2024 4 commits
  5. 06 Sep, 2024 1 commit
    • Mariusz Tkaczyk's avatar
      PCI/NPEM: Add _DSM PCIe SSD status LED management · 759ec282
      Mariusz Tkaczyk authored
      The PCIe SSD Status LED Management _DSM defined in PCI Firmware Spec r3.3
      sec 4.7 provides a way to manage LEDs via ACPI.
      
      The design is similar to NPEM defined in PCIe Base Specification r6.1 sec
      6.28:
      
        - Both standards are indication oriented,
      
        - _DSM supported bits correspond to NPEM capability register bits,
      
        - _DSM control bits correspond to NPEM control register bits.
      
      _DSM does not support enclosure-specific indications or the special NPEM
      commands NPEM_ENABLE and NPEM_RESET.
      
      _DSM is implemented as a second backend in NPEM driver. The backend used is
      logged with info priority. The same sysfs interface is used for both NPEM
      and _DSM.
      
      According to spec, _DSM has higher priority, and availability  of _DSM in
      not limited to devices with NPEM support.
      
      The Dell implementation of DSM uses acpi ipmi, which may not be available
      immediately (in fact it may take up to 10s for this interface to be
      available). It can determine if DSM is supported (GET_SUPPORTED_STATES_DSM
      is working) but it cannot serve GET_STATE_DSM or SET_STATE_DSM commands in
      this time.
      
      From userspace application perspective (primarily configured by systemd
      service) it is better to have not working but configured interface rather
      than have it available after few seconds.
      
      For that reason, npem->active_indications cache is now loaded lazily, i.e.
      any GET or SET request want cache to be updated if it is not done yet.
      
      Link: https://lore.kernel.org/r/20240904104848.23480-4-mariusz.tkaczyk@linux.intel.comSuggested-by: default avatarLukas Wunner <lukas@wunner.de>
      Signed-off-by: default avatarStuart Hayes <stuart.w.hayes@gmail.com>
      Signed-off-by: default avatarMariusz Tkaczyk <mariusz.tkaczyk@linux.intel.com>
      Signed-off-by: default avatarBjorn Helgaas <bhelgaas@google.com>
      Tested-by: default avatarStuart Hayes <stuart.w.hayes@gmail.com>
      Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
      Reviewed-by: default avatarIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
      759ec282
  6. 04 Sep, 2024 10 commits
  7. 03 Sep, 2024 1 commit
  8. 01 Sep, 2024 1 commit
  9. 23 Aug, 2024 1 commit
  10. 22 Aug, 2024 1 commit
  11. 09 Aug, 2024 3 commits