On Friday 22 May 2015 10:46:25 Borislav Petkov wrote: > On Fri, May 22, 2015 at 10:23:11AM +0200, Arnd Bergmann wrote: > > > +static int edac_mc_idx; > > > +static int edac_mc_active_mask; > > > +static int edac_mc_registered_mask; > > > +static DEFINE_MUTEX(xgene_edac_mc_lock); > > > > It would also be best to avoid global variables, but it seems that at > > least the edac_mc_idx is needed to work with the EDAC subsystem. > > Maybe Boris has an idea for how to avoid it. > > Right, so AFAICT this is used in > > edac_mc_alloc(edac_mc_idx++ > > and basically we're supplying the memory controller numbers in the order > we're calling xgene_edac_mc_add(). Perhaps we need to make the memory > controller numbering explicit with DT... I see now that the number is also used in xgene_edac_mc_is_active() as an index for the MCBADDRMR register, which seems very fragile, as it relies on the DT nodes getting seen in the same order by the driver that the hardware blocks are used in. Better add an explicit DT property for the index that is defined to be the same as MCBADDRMR bits, e.g. edacmc@7e800000 { compatible = "apm,xgene-edac-mc"; reg = <0x0 0x7e800000 0x0 0x1000>; memory-controller = <0>; }; or use a reference to the normal memory controller DT node outside of the EDAC, and put a number in that one. Is there a strict 1:1 relation between the DIMM slot numbering on the board and the memory controller number within the EDAC registers? Arnd -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html