On Tue, Jul 03, 2018 at 06:41:33PM +0530, p...@codeaurora.org wrote:
> pciehp_unconfigure_device doing little more than enumeration to quiescence
> the bus.
> 
>               /*
>                * Ensure that no new Requests will be generated from
>                * the device.
>                */
>               if (presence) {
>                       pci_read_config_word(dev, PCI_COMMAND, &command);
>                       command &= ~(PCI_COMMAND_MASTER | PCI_COMMAND_SERR);
>                       command |= PCI_COMMAND_INTX_DISABLE;
>                       pci_write_config_word(dev, PCI_COMMAND, command);
>               }

That piece of code is supposed to be executed on safe removal via sysfs
or an Attention Button press:  The card remains in the slot, even though
the slot is brought down.  So the card is quiesced.

However IIUC, on fatal error the link goes down and for pciehp, that's
essentially a surprise removal.  In that case, the above code is not
intended to be executed, rather the devices below the hotplug bridge
are marked disconnected.  See this patch I posted yesterday:
https://www.spinics.net/lists/linux-pci/msg74763.html

Thanks,

Lukas

Reply via email to