On Sat, 2012-02-11 at 15:53 +0100, Peter Zijlstra wrote: > On Sat, 2012-02-11 at 14:39 +0000, Mark Brown wrote: > > > > For step downs this isn't such a big deal as we don't often care if the > > voltage drops immediately but for step ups it's critical as if the > > voltage hasn't ramped before the CPU tries to run at the higher > > frequency the CPU will brown out. > > Why isn't all this done by micro-controllers, software writes a desired > state in some machine register (fast), micro-controller sets about > making it so in an asynchronous way. If it finds the settings have > changed by the time it reached its former goal, goto 1. > > Having to actually wait for this in software is quite ridiculous. Not necessarily micro-controllers no. Or rather, it's generally done by uC (or system controllers) on desktop or server machines, but not on embedded (ie. phones) where arguably that's where it is the most important :-) Now often (but not always) the trigger to initiate a change is indeed a simple register or register-based gpio, so that's fast. But you also often have to wait for a transition to be complete before initiating another one, or sychronize between voltage and frequency. For example, if you are ramping up, you need to up the voltage first, then wait for it to reach the nominal value & stabilize, then ramp up the frequency. It's not that often automated. Then there's the case where to communicate with those chips, you have to go via a bus such as i2c which requires schedulable contexts. Cheers, Ben. -- To unsubscribe from this list: send the line "unsubscribe cpufreq" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html