[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <86802c441001130045i17f75692tb0ad5aadaabdfd2a@mail.gmail.com>
Date: Wed, 13 Jan 2010 00:45:17 -0800
From: Yinghai Lu <yinghai@...nel.org>
To: Jeff Garrett <jeff@...rrett.org>
Cc: linux-kernel@...r.kernel.org, Len Brown <lenb@...nel.org>,
linux-acpi@...r.kernel.org,
Jesse Barnes <jbarnes@...tuousgeek.org>,
linux-pci@...r.kernel.org, David Airlie <airlied@...ux.ie>
Subject: Re: 2.6.33-rc3: pci host bridge windows ignored (works with
pci=use_crs)
On Wed, Jan 13, 2010 at 12:44 AM, Yinghai Lu <yinghai@...nel.org> wrote:
> On Tue, Jan 12, 2010 at 9:37 PM, Jeff Garrett <jeff@...rrett.org> wrote:
>> Took a stab at getting the right emails. If I missed anyone, sorry...
>>
>> I have a desktop machine with a radeon HD 4850, and on recent kernels
>> the radeon driver has failed with the message "No valid linear
>> framebuffer address". lspci on the broken configuration showed the
>> first memory region at d0000000 of the radeon card to be ignored. dmesg
>> showed there to be a host bridge window at that address which was also
>> ignored.
>>
>> I haven't quantified "recent" kernel. I was using the Ubuntu/lucid
>> kernels and it broke in the 2.6.32-* timeline, at which point I switched
>> to vanilla 2.6.33-rc3 to see if that worked. I could probably bisect it
>> in a day or two when I get a little time.
>>
>> Following dmesg's instructions, setting pci=use_crs causes the region
>> not to be ignored, and my video works again.
>>
>> I'm attaching a dmesg from the broken & working configurations, lspci
>> -vvv output from the working configuration, and the output of acpidump.
>>
>> (Between the failed/working, I also applied the patch at
>> http://bugzilla.kernel.org/show_bug.cgi?id=14954
>> to get rid of the ACPI-parsing oops. But that only fixed the oops.)
>
> [ 0.000000] BIOS-provided physical RAM map:
> [ 0.000000] BIOS-e820: 0000000000000000 - 000000000009fc00 (usable)
> [ 0.000000] BIOS-e820: 000000000009fc00 - 00000000000a0000 (reserved)
> [ 0.000000] BIOS-e820: 00000000000e0000 - 0000000000100000 (reserved)
> [ 0.000000] BIOS-e820: 0000000000100000 - 00000000bf790000 (usable)
> [ 0.000000] BIOS-e820: 00000000bf790000 - 00000000bf79e000 (ACPI data)
> [ 0.000000] BIOS-e820: 00000000bf79e000 - 00000000bf7d0000 (ACPI NVS)
> [ 0.000000] BIOS-e820: 00000000bf7d0000 - 00000000bf7e0000 (reserved)
> [ 0.000000] BIOS-e820: 00000000bf7ec000 - 00000000c0000000 (reserved)
> [ 0.000000] BIOS-e820: 00000000fee00000 - 00000000fee01000 (reserved)
> [ 0.000000] BIOS-e820: 00000000ffb00000 - 0000000100000000 (reserved)
> [ 0.000000] BIOS-e820: 0000000100000000 - 0000000340000000 (usable)
> ...
>
> [ 0.833443] PCI: MMCONFIG for domain 0000 [bus 00-ff] at [mem
> 0xe0000000-0xefffffff] (base 0xe0000000)
> [ 0.835028] PCI: MMCONFIG at [mem 0xe0000000-0xefffffff] reserved
> in ACPI motherboard resources
> ...
>
> [ 0.847449] ACPI: PCI Root Bridge [PCI0] (0000:00)
> [ 0.847470] pci_root PNP0A08:00: ignoring host bridge windows from
> ACPI; boot with "pci=use_crs" to use them
> [ 0.847693] pci_root PNP0A08:00: host bridge window [io
> 0x0000-0x0cf7] (ignored)
> [ 0.847695] pci_root PNP0A08:00: host bridge window [io
> 0x0d00-0xffff] (ignored)
> [ 0.847697] pci_root PNP0A08:00: host bridge window [mem
> 0x000a0000-0x000bffff] (ignored)
> [ 0.847699] pci_root PNP0A08:00: host bridge window [mem
> 0x000d0000-0x000dffff] (ignored)
> [ 0.847701] pci_root PNP0A08:00: host bridge window [mem
> 0xc0000000-0xdfffffff] (ignored)
> [ 0.847703] pci_root PNP0A08:00: host bridge window [mem
> 0xf0000000-0xfed8ffff] (ignored)
> ...
> [ 0.848025] IOH bus: [00, fb]
> [ 0.848026] IOH bus: 00 index 0 io port: [0, ffff]
> [ 0.848028] IOH bus: 00 index 1 mmio: [e0000000, fdffffff]
> ...
> [ 0.849289] PCI: peer root bus 00 res updated from pci conf
> ...
> [ 0.849361] pci 0000:04:00.0: reg 10: [mem 0xd0000000-0xdfffffff 64bit pref]
> [ 0.849369] pci 0000:04:00.0: reg 18: [mem 0xfbee0000-0xfbeeffff 64bit]
> [ 0.849374] pci 0000:04:00.0: reg 20: [io 0xe000-0xe0ff]
> [ 0.849381] pci 0000:04:00.0: reg 30: [mem 0xfbec0000-0xfbedffff pref]
> [ 0.849423] pci 0000:04:00.1: reg 10: [mem 0xfbefc000-0xfbefffff 64bit]
> [ 0.849481] pci 0000:00:07.0: PCI bridge to [bus 04-04]
> [ 0.849484] pci 0000:00:07.0: bridge window [io 0xe000-0xefff]
> [ 0.849487] pci 0000:00:07.0: bridge window [mem 0xfbe00000-0xfbefffff]
> [ 0.849491] pci 0000:00:07.0: bridge window [mem
> 0xd0000000-0xdfffffff 64bit pref]
>
>
> it seems HW IOH only can use [e000000 - fdffffff] under that bridge...
>
> and _CRS said the peer root bus could use [c000000 - dfffffff]
>
> could be that we need to check other register to decide if we can use
> reading from ioh reg directly.
can you send out
lspci -tvnn
lspci -vvxxxx
YH
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists