Hi Olof, On Mon, Jun 17, 2013 at 10:44:51AM -0700, Olof Johansson wrote: > On Mon, Jun 17, 2013 at 04:51:09PM +0100, Lorenzo Pieralisi wrote: > > The TC2 versatile express core tile integrates a logic block that provides > > the > > interface between the dual cluster test-chip and the M3 microcontroller that > > carries out power management. The logic block, called Serial Power > > Controller > > (SPC), contains several memory mapped registers to control among other > > things > > low-power states, operating points and reset control. > > > > This patch provides a driver that enables run-time control of features > > implemented by the SPC control logic. > > > > The SPC control logic is required to be programmed very early in the boot > > process to reset secondary CPUs on the TC2 testchip, set-up jump addresses > > and > > wake-up IRQs for power management. > > Since the SPC logic is also used to control clocks and operating points, > > that have to be initialized early as well, the SPC interface consumers can > > not > > rely on early initcalls ordering, which is inconsistent, to wait for SPC > > initialization. Hence, in order to keep the components relying on the SPC > > coded in a sane way, the driver puts in place a synchronization scheme that > > allows kernel drivers to check if the SPC driver has been initialized and if > > not, to initialize it upon check. > > > > A status variable is kept in memory so that loadable modules that require > > SPC > > interface (eg CPUfreq drivers) can still check the correct initialization > > and > > use the driver correctly after functions used at boot to init the driver are > > freed. > > > > The driver also provides a bridge interface through the vexpress config > > infrastructure. Operations allowing to read/write operating points are > > made to go via the same interface as configuration transactions so that > > all requests to M3 are serialized. > > > > Device tree bindings documentation for the SPC component is provided with > > the patchset. > > Sorry, I got to think of this over the weekend and should have replied > before you had a chance to repost, but still: > > Why is the operating point and frequency change code in this driver at all? > Usually, the MFD driver contains a shared method to access register space on > a multifunction device, but the actual operation of each subdevice is handled > by individual drivers in the regular locations. I suppose that's what I meant with my initial comment: "Why is that stuff under drivers/mfd/ ?"
> So, in the case of operating points and requencies, that should be in > a cpufreq driver. And the clock setup should presumably be in a clk > framework driver if needed. Yep, several drivers do that already. > Then all that would be left here is the functionality for submitting the two > kinds of commands, and handling interrupts. > > That'll trim down the driver to a point where I think you'll find it much > easier to get merged. :-) Definitely, yes. And the code would be a lot easier to review and maintain too. Cheers, Samuel. -- Intel Open Source Technology Centre http://oss.intel.com/ -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/