Re: pci_update_resource() getting called on sparc64

From: Greg KH
Date: Mon Aug 08 2005 - 14:43:50 EST


On Mon, Aug 08, 2005 at 12:32:09PM -0700, David S. Miller wrote:
> From: Greg KH <greg@xxxxxxxxx>
> Date: Mon, 8 Aug 2005 09:08:46 -0700
>
> > On Mon, Aug 08, 2005 at 11:32:41AM -0700, Linus Torvalds wrote:
> > >
> > > Not likely.
> > >
> > > Sounds like fec59a711eef002d4ef9eb8de09dd0a26986eb77, which came in
> > > through Greg. I'm surprised Greg didn't pick up on that one.
> >
> > I didn't pick up on that one, as David acked it a while ago :)
> >
> > {sigh} I only pushed that one as Ralf insisted that he needed it for
> > some of his hardware and that there wasn't any bad side-affects. Ralf,
> > any objections to removing this for 2.6.13?
>
> But this is so puzzling, because this code path should only trigger
> if the device is not in D0 state. There is no way any of the devices
> in my sparc64 box should be in any powered down state at bootup
> time. Unless the kernel would do that, which I hope it does not.
>
> Therefore, I can't figure out how this code path could even trigger.
>
> It happens for every device in my machine, my primary framebuffer
> radeonfb, my e1000, the tg3 card in the machine. In short, every
> single PCI device triggers this when it registers.
>
> I think something fishy is going on here, and the sparc64 BUG()
> is just a symptom. Why are devices in D3hot state at bootup?
>
> And lo' and behold, we find the answer in the PCI probing code.
> It initializes every PCI device's PCI power state to "unknown":
>
> /* "Unknown power state" */
> dev->current_state = 4;
>
> and thus makes this test ">= D3hot" pass in the pci_set_power_state()
> code.

Crap, gotta love >= checks on enumerated types...

Linus, can you just revert that changeset for now? That will sove
David's problem, and I'll work on getting this patch working properly
for after 2.6.13 is out.

Hm, how do you revert a git patch?

thanks,

greg k-h
-
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/