On Sunday 18 Apr 2010 20:03:46 Arjan van de Ven wrote: > The ondemand cpufreq governor uses CPU busy time (e.g. not-idle time) as > a measure for scaling the CPU frequency up or down. > If the CPU is busy, the CPU frequency scales up, if it's idle, the CPU > frequency scales down. Effectively, it uses the CPU busy time as proxy > variable for the more nebulous "how critical is performance right now" > question. > > This algorithm falls flat on its face in the light of workloads where > you're alternatingly disk and CPU bound, such as the ever popular > "git grep", but also things like startup of programs and maildir using > email clients... much to the chagarin of Andrew Morton. > > This patch changes the ondemand algorithm to count iowait time as busy, > not idle, time. As shown in the breakdown cases above, iowait is > performance critical often, and by counting iowait, the proxy variable > becomes a more accurate representation of the "how critical is > performance" question. Is the improvement really because IO benefited from CPU being held at a higher frequency, or perhaps because it is now not scaled down during IO, so when CPU intensive part of git grep comes along it is already "revved up"? Or in other words, does a pure IO workload benefit from now higher selected frequency? One idea I had but a) never had time to implement it and b) was not sure it would be accepted anyway, was to modify ondemand governor to ramp up instantly, but slow down slowly (in a configurable way). Or to make it a hybrid of conservative and ondemand in a way. (This was all long time ago so perhaps today what I wanted to do then is already achievable with some knobs.) It was not an idea out of thin air, but based on unpleasant desktop latencies with ondemand, while performance governor was of course perfect. Tvrtko Sophos Plc, The Pentagon, Abingdon Science Park, Abingdon, OX14 3YP, United Kingdom. Company Reg No 2096520. VAT Reg No GB 348 3873 20. -- 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