diff options
Diffstat (limited to 'drivers/pci/pci.c')
| -rw-r--r-- | drivers/pci/pci.c | 15 | 
1 files changed, 9 insertions, 6 deletions
| diff --git a/drivers/pci/pci.c b/drivers/pci/pci.c index b7f65fc54dc2..21ad9fea7878 100644 --- a/drivers/pci/pci.c +++ b/drivers/pci/pci.c @@ -1334,11 +1334,7 @@ static int pci_enable_device_flags(struct pci_dev *dev, unsigned long flags)  	 * so that things like MSI message writing will behave as expected  	 * (e.g. if the device really is in D0 at enable time).  	 */ -	if (dev->pm_cap) { -		u16 pmcsr; -		pci_read_config_word(dev, dev->pm_cap + PCI_PM_CTRL, &pmcsr); -		dev->current_state = (pmcsr & PCI_PM_CTRL_STATE_MASK); -	} +	pci_update_current_state(dev, dev->current_state);  	if (atomic_inc_return(&dev->enable_cnt) > 1)  		return 0;		/* already enabled */ @@ -1876,7 +1872,14 @@ int __pci_enable_wake(struct pci_dev *dev, pci_power_t state,  	if (enable) {  		int error; -		if (pci_pme_capable(dev, state)) +		/* +		 * Enable PME signaling if the device can signal PME from +		 * D3cold regardless of whether or not it can signal PME from +		 * the current target state, because that will allow it to +		 * signal PME when the hierarchy above it goes into D3cold and +		 * the device itself ends up in D3cold as a result of that. +		 */ +		if (pci_pme_capable(dev, state) || pci_pme_capable(dev, PCI_D3cold))  			pci_pme_active(dev, true);  		else  			ret = 1; | 
