[PATCH] powerpc: enable access to HT Host-Bridge on Maple
Dmitry Eremin-Solenikov
dbaryshkov at gmail.com
Mon Jul 4 22:46:52 EST 2011
Hello,
On 03.07.2011 01:50, Segher Boessenkool wrote:
>>>> +static int u3_ht_root_write_config(struct pci_controller *hose, u8
>>>> offset,
>>>> + int len, u32 val)
>>>> +{
>>>> + volatile void __iomem *addr;
>>>> +
>>>> + addr = hose->cfg_addr + ((offset & ~3) << 2) + (4 - len - (offset
>>>> & 3));
>>>> +
>>>> + if (offset >= PCI_BASE_ADDRESS_0 && offset < PCI_CAPABILITY_LIST)
>>>> + return PCIBIOS_SUCCESSFUL;
>>>
>>> This is a workaround for something; at the very least it needs a
>>> comment,
>>> but probably it shouldn't be here at all.
>>
>> I'll add a comment. Basically these registers are unimplemented on u3/u4
>> bridges and at least some kinds of access to them cause system freeze.
>> I'll try to check what triggers what this night.
>
> I don't think the hardware freezes, but probably Linux isn't happy when it
> tries to write to the non-existent BARs. Or something like that.
I've run several experiments. At least writing to the ROM_ADDRESS (0x30)
causes some kind of strange reboot (I see 'Error: Magic number in
message area NVRAM is not valid.') errors on the service console and
Linux consoles are silent. Writing to other BARs seem to cause no direct
effect (reg remains =0), but causes very strange behaviour during boot.
All PCI access cycles seem to return 0, strange DRAM ECC error pops up,
etc. I'd prefer to leave these register writes disabled, even if it's
the problem of some hardware revision (?).
--
With best wishes
Dmitry
More information about the Linuxppc-dev
mailing list