1. 05 Nov, 2021 7 commits
    • Bjorn Helgaas's avatar
      Merge branch 'pci/p2pdma' · 1f948b88
      Bjorn Helgaas authored
      - Apply bus offset correctly in DMA address calculation, which used the
        wrong sign before (Wang Lu)
      
      * pci/p2pdma:
        PCI/P2PDMA: Apply bus offset correctly in DMA address calculation
      1f948b88
    • Bjorn Helgaas's avatar
      Merge branch 'pci/msi' · efe68563
      Bjorn Helgaas authored
      - Document sysfs "irq" attribute, which contains either the INTx IRQ (the
        intended behavior) or the first MSI IRQ (historical mistake retained for
        backwards compatibility) (Barry Song)
      
      - Rework "irq" sysfs show function to explicitly fetch first MSI IRQ
        instead of depending on core to put it in dev->irq, to enable future core
        cleanup (Barry Song)
      
      * pci/msi:
        PCI/sysfs: Explicitly show first MSI IRQ for 'irq'
        PCI: Document /sys/bus/pci/devices/.../irq
      efe68563
    • Bjorn Helgaas's avatar
      Merge branch 'pci/hotplug' · 4917f718
      Bjorn Helgaas authored
      - Ignore Link Down/Up caused by error-induced Hot Reset so endpoint driver
        can remain bound to device during error recovery (Lukas Wunner)
      
      - Remove unused resume err_handler (Lukas Wunner)
      
      - Remove unused pcie_port_bus_{,un}register() declarations (Lukas Wunner)
      
      - Skip compiling err.c when CONFIG_PCIEAER not set (Lukas Wunner)
      
      * pci/hotplug:
        PCI/ERR: Reduce compile time for CONFIG_PCIEAER=n
        PCI/portdrv: Remove unused pcie_port_bus_{,un}register() declarations
        PCI/portdrv: Remove unused resume err_handler
        PCI: pciehp: Ignore Link Down/Up caused by error-induced Hot Reset
        PCI/portdrv: Rename pm_iter() to pcie_port_device_iter()
      4917f718
    • Bjorn Helgaas's avatar
      Merge branch 'pci/driver' · d03c426f
      Bjorn Helgaas authored
      - Drop the struct pci_dev.driver pointer, which is redundant with the
        struct device.driver pointer (Uwe Kleine-König)
      
      * pci/driver:
        PCI: Remove struct pci_dev->driver
        PCI: Use to_pci_driver() instead of pci_dev->driver
        x86/pci/probe_roms: Use to_pci_driver() instead of pci_dev->driver
        perf/x86/intel/uncore: Use to_pci_driver() instead of pci_dev->driver
        powerpc/eeh: Use to_pci_driver() instead of pci_dev->driver
        usb: xhci: Use to_pci_driver() instead of pci_dev->driver
        cxl: Use to_pci_driver() instead of pci_dev->driver
        cxl: Factor out common dev->driver expressions
        xen/pcifront: Use to_pci_driver() instead of pci_dev->driver
        xen/pcifront: Drop pcifront_common_process() tests of pcidev, pdrv
        nfp: use dev_driver_string() instead of pci_dev->driver->name
        mlxsw: pci: Use dev_driver_string() instead of pci_dev->driver->name
        net: marvell: prestera: use dev_driver_string() instead of pci_dev->driver->name
        net: hns3: use dev_driver_string() instead of pci_dev->driver->name
        crypto: hisilicon - use dev_driver_string() instead of pci_dev->driver->name
        powerpc/eeh: Use dev_driver_string() instead of struct pci_dev->driver->name
        ssb: Use dev_driver_string() instead of pci_dev->driver->name
        bcma: simplify reference to driver name
        crypto: qat - simplify adf_enable_aer()
        scsi: message: fusion: Remove unused mpt_pci driver .probe() 'id' parameter
        PCI/ERR: Factor out common dev->driver expressions
        PCI: Drop pci_device_probe() test of !pci_dev->driver
        PCI: Drop pci_device_remove() test of pci_dev->driver
        PCI: Return NULL for to_pci_driver(NULL)
      d03c426f
    • Bjorn Helgaas's avatar
      Merge branch 'pci/enumeration' · 1cac57a2
      Bjorn Helgaas authored
      - Rename pcibios_add_device() to pcibios_device_add() since it's called
        from pci_device_add() (Oliver O'Halloran)
      
      - Don't try to enable AtomicOps on VFs, since they can only be enabled on
        the PF (Selvin Xavier)
      
      * pci/enumeration:
        PCI: Do not enable AtomicOps on VFs
        PCI: Rename pcibios_add_device() to pcibios_device_add()
      1cac57a2
    • Bjorn Helgaas's avatar
      Merge branch 'pci/aspm' · 5e19196c
      Bjorn Helgaas authored
      - Re-enable LTR in Downstream Ports after it has been disabled by reset or
        hotplug to allow use of ASPM L1.2 again and prevent Unsupported Request
        errors when Endpoint sends LTR messages (Mingchuang Qiao)
      
      * pci/aspm:
        PCI: Re-enable Downstream Port LTR after reset or hotplug
      5e19196c
    • Bjorn Helgaas's avatar
      Merge branch 'pci/acpi' · 8d55770b
      Bjorn Helgaas authored
      - Simplify _OSC negotiation with platform for control of PCIe features
        (Joerg Roedel)
      
      * pci/acpi:
        PCI/ACPI: Check for _OSC support in acpi_pci_osc_control_set()
        PCI/ACPI: Move _OSC query checks to separate function
        PCI/ACPI: Move supported and control calculations to separate functions
        PCI/ACPI: Remove OSC_PCI_SUPPORT_MASKS and OSC_PCI_CONTROL_MASKS
      8d55770b
  2. 04 Nov, 2021 1 commit
    • Selvin Xavier's avatar
      PCI: Do not enable AtomicOps on VFs · 5ec0a6fc
      Selvin Xavier authored
      Host crashes when pci_enable_atomic_ops_to_root() is called for VFs with
      virtual buses. The virtual buses added to SR-IOV have bus->self set to NULL
      and host crashes due to this.
      
        PID: 4481   TASK: ffff89c6941b0000  CPU: 53  COMMAND: "bash"
        ...
         #3 [ffff9a9481713808] oops_end at ffffffffb9025cd6
         #4 [ffff9a9481713828] page_fault_oops at ffffffffb906e417
         #5 [ffff9a9481713888] exc_page_fault at ffffffffb9a0ad14
         #6 [ffff9a94817138b0] asm_exc_page_fault at ffffffffb9c00ace
            [exception RIP: pcie_capability_read_dword+28]
            RIP: ffffffffb952fd5c  RSP: ffff9a9481713960  RFLAGS: 00010246
            RAX: 0000000000000001  RBX: ffff89c6b1096000  RCX: 0000000000000000
            RDX: ffff9a9481713990  RSI: 0000000000000024  RDI: 0000000000000000
            RBP: 0000000000000080   R8: 0000000000000008   R9: ffff89c64341a2f8
            R10: 0000000000000002  R11: 0000000000000000  R12: ffff89c648bab000
            R13: 0000000000000000  R14: 0000000000000000  R15: ffff89c648bab0c8
            ORIG_RAX: ffffffffffffffff  CS: 0010  SS: 0018
         #7 [ffff9a9481713988] pci_enable_atomic_ops_to_root at ffffffffb95359a6
         #8 [ffff9a94817139c0] bnxt_qplib_determine_atomics at ffffffffc08c1a33 [bnxt_re]
         #9 [ffff9a94817139d0] bnxt_re_dev_init at ffffffffc08ba2d1 [bnxt_re]
      
      Per PCIe r5.0, sec 9.3.5.10, the AtomicOp Requester Enable bit in Device
      Control 2 is reserved for VFs.  The PF value applies to all associated VFs.
      
      Return -EINVAL if pci_enable_atomic_ops_to_root() is called for a VF.
      
      Link: https://lore.kernel.org/r/1631354585-16597-1-git-send-email-selvin.xavier@broadcom.com
      Fixes: 35f5ace5 ("RDMA/bnxt_re: Enable global atomic ops if platform supports")
      Fixes: 430a2368 ("PCI: Add pci_enable_atomic_ops_to_root()")
      Signed-off-by: default avatarSelvin Xavier <selvin.xavier@broadcom.com>
      Signed-off-by: default avatarBjorn Helgaas <bhelgaas@google.com>
      Reviewed-by: default avatarAndy Gospodarek <gospo@broadcom.com>
      5ec0a6fc
  3. 19 Oct, 2021 1 commit
    • Mingchuang Qiao's avatar
      PCI: Re-enable Downstream Port LTR after reset or hotplug · e1b0d0bb
      Mingchuang Qiao authored
      Per PCIe r5.0, sec 7.5.3.16, Downstream Ports must disable LTR if the link
      goes down (the Port goes DL_Down status).  This is a problem because the
      Downstream Port's dev->ltr_path is still set, so we think LTR is still
      enabled, and we enable LTR in the Endpoint.  When it sends LTR messages,
      they cause Unsupported Request errors at the Downstream Port.
      
      This happens in the reset path, where we may enable LTR in
      pci_restore_pcie_state() even though the Downstream Port disabled LTR
      because the reset caused a link down event.
      
      It also happens in the hot-remove and hot-add path, where we may enable LTR
      in pci_configure_ltr() even though the Downstream Port disabled LTR when
      the hot-remove took the link down.
      
      In these two scenarios, check the upstream bridge and restore its LTR
      enable if appropriate.
      
      The Unsupported Request may be logged by AER as follows:
      
        pcieport 0000:00:1d.0: AER: Uncorrected (Non-Fatal) error received: id=00e8
        pcieport 0000:00:1d.0: PCIe Bus Error: severity=Uncorrected (Non-Fatal), type=Transaction Layer, id=00e8(Requester ID)
        pcieport 0000:00:1d.0:   device [8086:9d18] error status/mask=00100000/00010000
        pcieport 0000:00:1d.0:    [20] Unsupported Request    (First)
      
      In addition, if LTR is not configured correctly, the link cannot enter the
      L1.2 state, which prevents some machines from entering the S0ix low power
      state.
      
      [bhelgaas: commit log]
      Link: https://lore.kernel.org/r/20211012075614.54576-1-mingchuang.qiao@mediatek.comReported-by: default avatarUtkarsh H Patel <utkarsh.h.patel@intel.com>
      Signed-off-by: default avatarMingchuang Qiao <mingchuang.qiao@mediatek.com>
      Signed-off-by: default avatarBjorn Helgaas <bhelgaas@google.com>
      Reviewed-by: default avatarMika Westerberg <mika.westerberg@linux.intel.com>
      e1b0d0bb
  4. 18 Oct, 2021 10 commits
  5. 16 Oct, 2021 1 commit
  6. 15 Oct, 2021 6 commits
  7. 12 Oct, 2021 14 commits