[PATCH 1/2] pci: Add IORESOURCE_BIT entry for PCIe ECAM resources.
From: Grant Likely <hidden>
Date: 2014-06-03 08:45:12
Also in:
linux-arm-msm, linux-devicetree, linux-pci, lkml
On Mon, 2 Jun 2014 13:09:08 -0500, Kumar Gala [off-list ref] wrote:
On Jun 2, 2014, at 11:23 AM, Grant Likely [off-list ref] wrote:quoted
On Mon, 2 Jun 2014 10:40:30 -0500, Kumar Gala [off-list ref] wrote:quoted
On Jun 2, 2014, at 10:09 AM, Grant Likely [off-list ref] wrote:quoted
On Sat, 31 May 2014 20:41:04 +0200, Arnd Bergmann [off-list ref] wrote:quoted
On Saturday 31 May 2014 01:36:40 Liviu Dudau wrote:quoted
We would like to be able to describe PCIe ECAM resources as IORESOURCE_MEM blocks while distinguish them from standard memory resources. Add an IORESOURCE_BIT entry for this case. Signed-off-by: Liviu Dudau <Liviu.Dudau@arm.com>I still don't see any value in this at all. What is the advantage of doing this opposed to just having a standardized 'reg' property for a particular compatible string?I'm inclined to agree. It doesn't seem appropriate to put config space in ranges, and the host controller binding is responsible for identifying how config space is memory mapped. g.I don???t agree when it comes to ECAM, but we can drop this for now until someone really does that.Okay, humor me then. What would a ranges property look like for ECAM? Do you have an example? I believe there would need to be a separate entry for each and every PCI device on the bus to get the config spaces to be contiguous.The definition of ECAM is a 256M linear region with each 4k being a different bus/dev/func. So the ranges would look something like: ranges = <0x00000000 0 0x00000000 0x0ff00000 0 0x10000000> /* configuration space */ The reason I think allow an ECAM makes sense in ranges is because it allows for a direct IO read/write to CFG space (w/o any mapping) similar to what one would do for MEM space or IO.
I don't think that's right. PCI addresses are defined as follows:
phys.hi cell: npt000ss bbbbbbbb dddddfff rrrrrrrr
phys.mid cell: hhhhhhhh hhhhhhhh hhhhhhhh hhhhhhhh
phys.low cell: llllllll llllllll llllllll llllllll
where 'ddddd' is the device number (0-31) and 'fff' is the function number (0-7)
Going up by one device number or even function number does not result in
contiguious address values:
device 0: 0x00000000 00000000 00000000
device 1: 0x00000800 00000000 00000000
device 2: 0x00001000 00000000 00000000
device 3: 0x00001800 00000000 00000000
...
device 30:0x0000f000 00000000 00000000
device 31:0x0000f800 00000000 00000000
a simple ranges doesn't work transparently because each of those config
ranges needs to be mapped to a 4k block. I think ranges would need to
look like this:
ranges = <0x00000000 0 0 0x0ff00000 0x1000>,
<0x00000800 0 0 0x0ff01000 0x1000>,
<0x00001800 0 0 0x0ff02000 0x1000>,
...
<0x0000f000 0 0 0x0ff1e000 0x1000>,
<0x0000f800 0 0 0x0ff1f000 0x1000>;
(I just hacked the above up; I make no claims to it's accuracy for
actual address values)
But I don't even thing the semantics work there because the address is
encoded in the phys.hi cell, not the phys.low cell. Incrementing by one
does not behaves as most bus addresses work. To actually work properly
we would have needed a way to define a stride of 64bits when
incrementing config space addresses in a ranges mapping.
quoted
However, what do we do with the 2 cases that exist in upstream thatquoted
are using ranges for cfg space?Ignore them in the core code? Make the specific host controller handle them I would think.I just meant, should we ???break??? their DTs and move them from using ranges to reg?
If ranges is the only place to get the config space address for those platforms, and if the support is in mainline, then we can't break it. Fix the in-tree dts files, but leave backwards compatible code in the host controller driver (perhaps with a warning sent to the kernel log). The best we can do is discourage new boards from using the broken pattern. If it /won't/ affect deployed systems then it is okay to remove the broken behaviour. g.