From: Keith Busch <keith.busch@intel.com>
To: Linux PCI <linux-pci@vger.kernel.org>,
Bjorn Helgaas <bhelgaas@google.com>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>,
Sinan Kaya <okaya@kernel.org>, Thomas Tai <thomas.tai@oracle.com>,
poza@codeaurora.org, Lukas Wunner <lukas@wunner.de>,
Christoph Hellwig <hch@lst.de>,
Keith Busch <keith.busch@intel.com>
Subject: [PATCHv2 00/20] PCI, error handling and hot plug
Date: Wed, 5 Sep 2018 14:35:26 -0600 [thread overview]
Message-ID: <20180905203546.21921-1-keith.busch@intel.com> (raw)
v1 -> v2:
* Use Dennis' patch for the incorrect slot reset detection since he
posted that fix first
* I found some DPC and HPC capable ports (PLX Device 9781 to be
specific) that don't have data-link active reporting capabilities,
so I added another patch to handle that
* If the recovery determines the precence detection has changed during
error handling, we need to prevent the downstream driver from
accessing the device under its old context. This was a little tricky
because of a circular dependency on the pci_bus_sem, so there is a
prep patch to allow recursive pci bus walking, and then we use it
from pciehp's slot_reset callback.
* Make error handling not able to change the error state away from
pci_channel_state_perm_failure so that hotplug and error handling
may use the same state (suggested by Benjamin Herrenschmidt)
* Moved the link active wait requirements into generic code
(suggested by Sinan Kaya)
* Check for successful secondary bus reset on recovery failure
(suggested by Sinan Kaya)
* Use pcie_device for service driver error callbacks (suggested by
Lukas Wunner)
* Hold pci_slot_lock when doing a slot reset (suggested by
Lukas Wunner)
* Fixed processing user orderly hotplug requests during error handling
suggested by Lukas Wunner)
* Various code cleanups (suggested by Christoph Hellwig)
* Split dpc code cleanup into separate patch
* Changelog grammer fixes and wording clarity
Dennis Dalessandro (1):
PCI: Fix faulty logic in pci_reset_bus()
Keith Busch (18):
PCI: Add required waits on link active
PCI/AER: Remove dead code
PCI/ERR: Use slot reset if available
PCI/ERR: Handle fatal error recovery
PCI/ERR: Always use the first downstream port
PCI/ERR: Simplify broadcast callouts
PCI/ERR: Report current recovery status for udev
PCI/ERR: Remove devices on recovery failure
PCI/portdrv: Provide pci error callbacks
PCI/portdrv: Restore pci state on slot reset
PCI: Make link active reporting detection generic
PCI: Create recursive bus walk
PCI/pciehp: Fix powerfault detection order
PCI/pciehp: Implement error handling callbacks
PCI/pciehp: Ignore link events during DPC event
PCI/DPC: Wait for link active after reset
PCI/DPC: Link reset code cleanup
PCI: Unify device inaccessible
Lukas Wunner (1):
PCI: Simplify disconnected marking
drivers/pci/bus.c | 14 +-
drivers/pci/hotplug/pciehp.h | 2 +-
drivers/pci/hotplug/pciehp_core.c | 39 +++++
drivers/pci/hotplug/pciehp_hpc.c | 56 +++----
drivers/pci/hotplug/pciehp_pci.c | 9 +-
drivers/pci/pci.c | 68 +++++++-
drivers/pci/pci.h | 17 +-
drivers/pci/pcie/aer.c | 27 ++--
drivers/pci/pcie/dpc.c | 37 +++--
drivers/pci/pcie/err.c | 327 +++++++++++++-------------------------
drivers/pci/pcie/portdrv.h | 10 +-
drivers/pci/pcie/portdrv_pci.c | 45 +++++-
drivers/pci/probe.c | 1 +
drivers/pci/slot.c | 2 +-
include/linux/pci.h | 10 ++
15 files changed, 353 insertions(+), 311 deletions(-)
--
2.14.4
next reply other threads:[~2018-09-06 1:06 UTC|newest]
Thread overview: 44+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-09-05 20:35 Keith Busch [this message]
2018-09-05 20:35 ` [PATCHv2 01/20] PCI: Simplify disconnected marking Keith Busch
2018-09-05 20:35 ` [PATCHv2 02/20] PCI: Fix faulty logic in pci_reset_bus() Keith Busch
2018-09-05 20:35 ` [PATCHv2 03/20] PCI: Add required waits on link active Keith Busch
2018-09-06 11:42 ` Lukas Wunner
2018-09-06 14:44 ` Keith Busch
2018-09-05 20:35 ` [PATCHv2 04/20] PCI/AER: Remove dead code Keith Busch
2018-09-05 20:35 ` [PATCHv2 05/20] PCI/ERR: Use slot reset if available Keith Busch
2018-09-05 20:35 ` [PATCHv2 06/20] PCI/ERR: Handle fatal error recovery Keith Busch
2018-09-05 20:35 ` [PATCHv2 07/20] PCI/ERR: Always use the first downstream port Keith Busch
2018-09-05 20:35 ` [PATCHv2 08/20] PCI/ERR: Simplify broadcast callouts Keith Busch
2018-09-05 20:35 ` [PATCHv2 09/20] PCI/ERR: Report current recovery status for udev Keith Busch
2018-09-05 20:35 ` [PATCHv2 10/20] PCI/ERR: Remove devices on recovery failure Keith Busch
2018-09-05 20:35 ` [PATCHv2 11/20] PCI/portdrv: Provide pci error callbacks Keith Busch
2018-09-05 20:35 ` [PATCHv2 12/20] PCI/portdrv: Restore pci state on slot reset Keith Busch
2018-09-05 20:35 ` [PATCHv2 13/20] PCI: Make link active reporting detection generic Keith Busch
2018-09-06 12:38 ` Lukas Wunner
2018-09-05 20:35 ` [PATCHv2 14/20] PCI: Create recursive bus walk Keith Busch
2018-09-05 20:35 ` [PATCHv2 15/20] PCI/pciehp: Fix powerfault detection order Keith Busch
2018-09-06 19:36 ` Bjorn Helgaas
2018-09-06 19:50 ` Keith Busch
2018-09-07 16:53 ` Bjorn Helgaas
2018-09-07 20:03 ` Bjorn Helgaas
2018-09-07 20:18 ` Keith Busch
2018-09-18 21:46 ` Bjorn Helgaas
2018-09-18 22:11 ` Keith Busch
2018-09-07 20:26 ` Lukas Wunner
2018-09-05 20:35 ` [PATCHv2 16/20] PCI/pciehp: Implement error handling callbacks Keith Busch
2018-09-06 18:23 ` Thomas Tai
2018-09-06 18:49 ` Keith Busch
2018-09-10 13:20 ` Lukas Wunner
2018-09-10 14:56 ` Keith Busch
2018-09-10 16:09 ` Lukas Wunner
2018-09-10 16:18 ` Keith Busch
2018-09-10 16:45 ` Keith Busch
2018-09-10 17:08 ` Lukas Wunner
2018-09-10 17:22 ` Keith Busch
2018-09-05 20:35 ` [PATCHv2 17/20] PCI/pciehp: Ignore link events during DPC event Keith Busch
2018-09-05 20:35 ` [PATCHv2 18/20] PCI/DPC: Wait for link active after reset Keith Busch
2018-09-05 20:35 ` [PATCHv2 19/20] PCI/DPC: Link reset code cleanup Keith Busch
2018-09-05 20:35 ` [PATCHv2 20/20] PCI: Unify device inaccessible Keith Busch
2018-09-06 4:20 ` Benjamin Herrenschmidt
2018-09-06 17:30 ` [PATCHv2 00/20] PCI, error handling and hot plug Thomas Tai
2018-09-06 17:36 ` Keith Busch
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20180905203546.21921-1-keith.busch@intel.com \
--to=keith.busch@intel.com \
--cc=benh@kernel.crashing.org \
--cc=bhelgaas@google.com \
--cc=hch@lst.de \
--cc=linux-pci@vger.kernel.org \
--cc=lukas@wunner.de \
--cc=okaya@kernel.org \
--cc=poza@codeaurora.org \
--cc=thomas.tai@oracle.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.