On Sunday December 9 2007 09:31:27 pm Shaohua Li wrote: > On Sun, 2007-12-09 at 23:04 +0100, Adrian Bunk wrote: > > On Sun, Dec 09, 2007 at 04:12:25PM -0500, Elvis Pranskevichus wrote: > > > Jean Delvare wrote: > > > > Hi Mike, > > > > > > > > On Sat, 8 Dec 2007 21:22:34 -0500, Mike Houston wrote: > > > >> On Sun, 9 Dec 2007 01:05:54 +0100 > > > >> > > > >> Adrian Bunk <bunk at stusta.de> wrote: > > > >> > On Tue, Dec 04, 2007 at 09:51:54PM -0500, Mike Houston wrote: > > > >> > > I finally got around to testing Linux 2.6.24 (2.6.24-rc4) and > > > >> > > found that the it87 driver fails to probe and consequently, my > > > >> > > sensors no longer work. This was fine with Linux 2.6.23.8 (the > > > >> > > last kernel I was using) > > > >> > > > > > >> > > The necessary modules load, but: > > > >> > > > > > >> > > it87: Found IT8718F chip at 0x290, revision 2 > > > >> > > it87: in3 is VCC (+5V) > > > >> > > it87 it87.656: Failed to request region 0x290-0x297 > > > >> > > it87: probe of it87.656 failed with error -16 > > > >> > > > > > >> > > Coretemp still works. > > > >> > > > > > >> > > It appears it has something to do with the ioport range being > > > >> > > reserved for some reason: > > > >> > > > > > >> > > system 00:01: ioport range 0x290-0x29f has been reserved > > > >> > > > > >> > Thanks for your report. > > > >> > > > > >> > Please also provide: > > > >> > - dmesg from 2.6.23.8 > > > >> > - The output of "cat /proc/ioports" for both kernels > > > >> > > > >> Thanks Adrian, here is the information you have requested, for > > > >> both kernels (I have 2.6.23.9 now though where it87 still works) > > > >> > > > >> Linux 2.6.23.9: > > > >> http://www.mikeserv.com/temp/proc_ioports-2.6.23.9.txt > > > >> http://www.mikeserv.com/temp/dmesg-2.6.23.9.txt > > > >> http://www.mikeserv.com/temp/config-2.6.23.9.txt > > > >> > > > >> Linux 2.6.24-rc4: > > > >> http://www.mikeserv.com/temp/proc_ioports-2.6.24-rc4.txt > > > >> http://www.mikeserv.com/temp/dmesg-2.6.24-rc4.txt > > > > > > > > This one shows: > > > > > > > > system 00:01: ioport range 0x290-0x29f has been reserved > > > > (...) > > > > system 00:01: ioport range 0x290-0x294 has been reserved > > > > > > > > This is clearly not correct as both areas overlap. The second > > > > reservation is responsible for the it87 breakage, because it > > > > conflicts with what the it87 driver later attempts to request > > > > (0x290-0x297). The first is wrong as well (the IT87xxF environment > > > > controller I/O area is 8 port wide, not 16) but shouldn't be a > > > > problem in practice. > > > > > > > > These port reservations weren't happening in 2.6.23.9 according to > > > > your dmesg output for that kernel. I don't know what changed in this > > > > area since 2.6.23.9, maybe Bjorn or Adam (Cc'd) can tell. > > > > > > Hi, > > > > > > I have exactly the same problem here on a Gigabyte GA-965G-DS3 > > > motherboard based box: > > > > > > it87: Found IT8718F chip at 0x290, revision 1 > > > it87: in3 is VCC (+5V) > > > it87 it87.656: Failed to request region 0x290-0x297 > > > it87: probe of it87.656 failed with error -16 > > > > > > git bisecting revealed the offending commit: > > > > > > a7839e960675b54: PNP: increase the maximum number of resources > > > > > > Happened between rc3 and rc4. > > > > Thanks for doing the work of bisecting! > > > > > > Either way, the overlapping areas smell like a BIOS bug, meaning that > > > > you should look for an updated BIOS for your system first. > > > > > > > >> http://www.mikeserv.com/temp/config-2.6.24-rc4.txt > > > > > > This indeed looks like a broken ACPI BIOS since the aforementioned > > > commit touches only the PNP ACPI driver. I'm not sure how to work > > > around this, though. Ideas? > > > > People responsible for this commit + ACPI maintainer added to Cc. > > This should exist in previous kernel (before we remove acpi motherboard > driver) too. Basically it's a broken BIOS. Could below patch work around > it? > > Thanks, > Shaohua > > Index: linux/drivers/pnp/system.c > =================================================================== > --- linux.orig/drivers/pnp/system.c 2007-12-10 10:17:46.000000000 +0800 > +++ linux/drivers/pnp/system.c 2007-12-10 10:24:42.000000000 +0800 > @@ -22,7 +22,7 @@ static const struct pnp_device_id pnp_de > {"", 0} > }; > > -static void reserve_range(struct pnp_dev *dev, resource_size_t start, > +static struct resource* reserve_range(struct pnp_dev *dev, resource_size_t > start, resource_size_t end, int port) > { > char *regionid; > @@ -31,16 +31,14 @@ static void reserve_range(struct pnp_dev > > regionid = kmalloc(16, GFP_KERNEL); > if (!regionid) > - return; > + return NULL; > > snprintf(regionid, 16, "pnp %s", pnpid); > if (port) > res = request_region(start, end - start + 1, regionid); > else > res = request_mem_region(start, end - start + 1, regionid); > - if (res) > - res->flags &= ~IORESOURCE_BUSY; > - else > + if (!res) > kfree(regionid); > > /* > @@ -52,12 +50,17 @@ static void reserve_range(struct pnp_dev > port ? "ioport" : "iomem", > (unsigned long long) start, (unsigned long long) end, > res ? "has been" : "could not be"); > + return res; > } > > static void reserve_resources_of_dev(struct pnp_dev *dev) > { > int i; > + struct resource **res; > > + res = kzalloc(sizeof(struct resource *) * PNP_MAX_PORT, GFP_KERNEL); > + if (!res) > + return; > for (i = 0; i < PNP_MAX_PORT; i++) { > if (!pnp_port_valid(dev, i)) > continue; > @@ -76,17 +79,28 @@ static void reserve_resources_of_dev(str > if (pnp_port_end(dev, i) < pnp_port_start(dev, i)) > continue; /* invalid */ > > - reserve_range(dev, pnp_port_start(dev, i), > + res[i] = reserve_range(dev, pnp_port_start(dev, i), > pnp_port_end(dev, i), 1); > } > + for (i = 0; i < PNP_MAX_PORT; i++) > + if (res[i]) > + res[i]->flags &= ~IORESOURCE_BUSY; > + kfree(res); > > + res = kzalloc(sizeof(struct resource *) * PNP_MAX_MEM, GFP_KERNEL); > + if (!res) > + return; > for (i = 0; i < PNP_MAX_MEM; i++) { > if (!pnp_mem_valid(dev, i)) > continue; > > - reserve_range(dev, pnp_mem_start(dev, i), > + res[i] = reserve_range(dev, pnp_mem_start(dev, i), > pnp_mem_end(dev, i), 0); > } > + for (i = 0; i < PNP_MAX_MEM; i++) > + if (res[i]) > + res[i]->flags &= ~IORESOURCE_BUSY; > + kfree(res); > } > > static int system_pnp_probe(struct pnp_dev *dev, Hi Shaohua, Your patch works for me. /proc/ioports looks sane now: 0290-029f : pnp 00:01 0290-0297 : it87 0290-0297 : it87 And it87 doesn't complain anymore. Thanks! -- Elvis