Re: [PATCH 06/17] pci: host: pcie-designware: Use *base-mask* for configuring the iATU

From: Arnd Bergmann
Date: Tue May 13 2014 - 09:35:11 EST


On Tuesday 13 May 2014 15:27:46 Arnd Bergmann wrote:
> On Tuesday 13 May 2014 18:56:23 Kishon Vijay Abraham I wrote:
> > > If you have a case where the outbound translation is a 256MB (i.e. 28bit)
> > > section of the CPU address space, that could be represented as
> > >
> > > ranges = <0x82000000 0 0 0xb0000000 0 0x10000000>;
> > >
> > > or
> > >
> > > ranges = <0x82000000 0 0xb0000000 0xb0000000 0 0x10000000>;
> > >
> > > depending on whether you want the BARs to be programmed using a low
> > > address 0x0-0x0fffffff or an address matching the window
> > > 0xb0000000-0xbfffffff.
> >
> > The problem is, for configuring the window starting at 0xb0000000, the ATU
> > should be programmed 0x0000000 (the cpu address for it will be 0xb0000000 though).
> >
>
> Then use the first of the two?
>

To clarify: using <0x82000000 0 0 0xb0000000 0 0x10000000> will give you
a mem_offset of 0xb0000000, which should work just fine for this case.

What I don't understand is why the ATU cares about whether the outbound
address is 0x0000000 or 0xb0000000 if it just decodes the lower 28 bit
anyway. Did you mean that we have to program the BARs using low addresses
regardless of what is programmed in the ATU? That would make more sense,
and it also matches what I suggested.

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