On Fri, 2013-06-07 at 17:02 -0500, Scott Wood wrote: > O > > I thought the device tree was for describing the hardware, rather > > than configuration? :-)
A bit of both really. See things like /chosen etc... Also to what extent a MAC address is HW vs. configuration ? :-) The HW configuration for a given boards (ie, internal address map, location of the various bridge windows etc...) is a fairly common thing to put in a device-tree. If the PCI outbound windows are there (and they are), why not the inbound ones ? IE, it's not far fetched. > > A kernel command line option might be more appropriate, unless you > > just mean describing the difference between e6500 (which supports 40 > > bit addresses) and previous chips (which support 36 bits), rather > > than an ability to move it earlier even on e6500. Well, so we could indeed locate it at 36 on e5500 and that would clear the current use case and break again on e6500... or we can make it depend on the overall address map of the board, which is described in the device-tree. IE, if you don't "locate" anything above 39-bit in our address map, then using 39 for the window is ok. IE. It's a choice. A server board setup that doesn't need gfx but want address space for some other things wouldn't care. A board wanting to use gfx (either desktop style, or some of the military applications I've seen using FSL chips and radeons) would chose the address map differently to allow the radeons to work. > > That said, the current code looks broken -- it checks whether a card > > can do 40-bit DMA, and if it can, it sets the DMA offset to (1ULL << > > 40), thus requiring 41-bit DMA. It should be > instead of >= in > > fsl_pci_dma_set_mask. Yes, this was broken for a while, I remember mentioning it a while back but never actually sending a patch to fix it ... oops ;-) > > Maybe we could by default use the size of actual RAM, rather than the > > physical address space. Then only odd scenarios such as DMA to > > non-kernel-owned RAM would need manual adjustment (MSIs would still > > go through the special window below 4G). You also need to account for other on-chip MMIOs no ? Or do you never intend to let PCI devices hit them ? If not, then top of RAM aligned to the next power of two sounds like a great plan. Also, those radeons are *also* broken for 64-bit MSIs (they advertize support but are limited to 40-bit of address). We have added hacks to deal with that in pseries that I was thinking of generalizing. Cheers, Ben. _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev