Re: Cleanup PCI power states

From: Pavel Machek
Date: Fri Dec 17 2004 - 18:56:45 EST


Hi!

> > Okay, here it is, slightly expanded version. It actually makes use of
> > newly defined type for type-checking purposes; still no code changes.
>
> Alright, I've applied this, and it will show up in the next -mm release.
> I also fixed up pci.h for when CONFIG_PCI=N due to your changed
> functions.
>
> Now, care to send patches to fix up all of the new sparse warnings in
> the drivers/pci/* directory?

This should reduce number of warnings in pci.c. It will still warn on
comparison (because we are using __bitwise, but in fact we want
something like "this is unique but arithmetic is still ok"), but that
probably needs to be fixed in sparse.

Also killed "function does not return anything" warning.

Please apply,
Pavel

Signed-off-by: Pavel Machek <pavel@xxxxxxx>

--- linux.middle//drivers/pci/pci.c 2004-11-14 23:36:46.000000000 +0100
+++ linux/drivers/pci/pci.c 2004-12-18 00:47:53.000000000 +0100
@@ -248,13 +248,13 @@
u16 pmcsr;

/* bound the state we're entering */
- if (state > 3) state = 3;
+ if (state > PCI_D3hot) state = PCI_D3hot;

/* Validate current state:
* Can enter D0 from any state, but if we can only go deeper
* to sleep if we're already in a low power state
*/
- if (state > 0 && dev->current_state > state)
+ if (state != PCI_D0 && dev->current_state > state)
return -EINVAL;
else if (dev->current_state == state)
return 0; /* we're already there */
@@ -266,18 +266,18 @@
if (!pm) return -EIO;

/* check if this device supports the desired state */
- if (state == 1 || state == 2) {
+ if (state == PCI_D1 || state == PCI_D2) {
u16 pmc;
pci_read_config_word(dev,pm + PCI_PM_PMC,&pmc);
- if (state == 1 && !(pmc & PCI_PM_CAP_D1)) return -EIO;
- else if (state == 2 && !(pmc & PCI_PM_CAP_D2)) return -EIO;
+ if (state == PCI_D1 && !(pmc & PCI_PM_CAP_D1)) return -EIO;
+ else if (state == PCI_D2 && !(pmc & PCI_PM_CAP_D2)) return -EIO;
}

/* If we're in D3, force entire word to 0.
* This doesn't affect PME_Status, disables PME_En, and
* sets PowerState to 0.
*/
- if (dev->current_state >= 3)
+ if (dev->current_state >= PCI_D3hot)
pmcsr = 0;
else {
pci_read_config_word(dev, pm + PCI_PM_CTRL, &pmcsr);
@@ -290,9 +290,9 @@

/* Mandatory power management transition delays */
/* see PCI PM 1.1 5.6.1 table 18 */
- if(state == 3 || dev->current_state == 3)
+ if (state == PCI_D3hot || dev->current_state == PCI_D3hot)
msleep(10);
- else if(state == 2 || dev->current_state == 2)
+ else if (state == PCI_D2 || dev->current_state == PCI_D2)
udelay(200);
dev->current_state = state;

@@ -319,6 +319,7 @@
case 3: return PCI_D3hot;
default: BUG();
}
+ return PCI_D0;
}

EXPORT_SYMBOL(pci_choose_state);


--
People were complaining that M$ turns users into beta-testers...
...jr ghea gurz vagb qrirybcref, naq gurl frrz gb yvxr vg gung jnl!
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/