Re: [BK PATCH] I2C update for 2.6.8-rc1

From: Linus Torvalds
Date: Tue Aug 24 2004 - 21:05:52 EST




On Tue, 24 Aug 2004, Alex Williamson wrote:
> >
> > How about this _trivial_ change? Does that fix things for you guys? Can
> > you send the /proc/ioport output if this works out for you, just so that
> > we can see?
>
> Yes, this works. Please commit.

Greg? Opinions? I'll happily commit it, since it's almost certainly bound
to be better than what we have now, but I have to admit that I could also
see it causing confusion if two devices are set up by the BIOS to be on
top of each other (since insert_resource() would indeed allow that).

Now, admittedly, that would be a VERY broken BIOS, and likely such a
situation wouldn't have worked _anyway_, but you're the PCI maintainer, so
you get to sit in the hot seat and say aye or nay.

> I still have reservations about exposing this device (that firmware owns
> and we can't possibly synchronize access to), but this is a big
> improvement over the unusable state w/o this change.

In general, it's always a good idea to expose the devices, because if you
don't, other device drivers may end up thinking part of the addresses are
free for the taking. Which is why we have ACPI do it's things too.


> Here's my /proc/ioports:
>
> 1000-107f : 0000:00:1f.0
> 1000-107f : motherboard
> 1000-1003 : PM1a_EVT_BLK
> 1004-1005 : PM1a_CNT_BLK
> 1008-100b : PM_TMR
> 1010-1015 : ACPI CPU throttle
> 1020-1020 : PM2_CNT_BLK
> 1028-102f : GPE0_BLK

Nice and readable.

> 1100-113f : 0000:00:1f.0
> 1100-113f : motherboard

Same.

> 1200-121f : motherboard
> 1200-121f : 0000:00:1f.3

This is apparently the one that used to cause trouble, and you can see it
from the nesting level: the device nests inside the description, rather
than the other way around.

This does bring up an alternate fix: namely to do the PCI quirks
_earlier_.

If we had done the PCI quirk handling and probing for this device _before_
ACPI populated the IO stuff, and we'd never have seen this problem. Why
did we let ACPI come in first in the first place? Greg? Len?

The right order (I think) should be:
- walk the existing PCI setup, do the header quirks, populate the device
and resource trees..
- _than_ do the ACPI resources

The allocation of new PCI resources will happen much later - if/when the
device is actually enabled.

Or am I missing something?

Linus
-
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/