On Tue, Mar 13, 2012 at 7:04 PM, Arjan van de Ven <arjan@xxxxxxxxxxxxxxx> wrote: > On 3/13/2012 4:52 PM, Kevin Hilman wrote: >> Checking the ready_count seemed like an easy way to do this, but did you >> have any other mechanisms in mind for CPUs to communicate that they've >> exited/aborted? > > this indeed is the tricky part (which I warned about earlier); > I've spent quite a lot of time (weeks) to get this provably working for > an Intel system with similar requirements... and it's extremely unfunny, > and needed firmware support to close some of the race conditions. As long as you can tell from cpu0 that cpu1 has succesfully entered the low power state, this should be easy, and the coupled_cpuidle_parallel_barrier helper should make it even easier. This series just allows the exact same sequence of transitions used by hotplug cpufreq governors to happen from the idle thread: 1. cpu0 forces cpu1 offline. From a wakeup perspective, this is exactly like hotplug removing cpu1. Unlike hotplug, the state of cpu1 has to be saved, and the scheduler is not told that the cpu is gone. Instead of using the IPI signalling that hotplug uses, we call the same function on both cpus, and one cpu runs the equivalent of platform_cpu_kill, and the other the equivalent of platform_cpu_die. Wakeup events that are only targeted at cpu1 will need to be temporarily migrated to cpu0. 2. If the hotplug is successful, cpu0 goes to a low power state, the same way it would when the hotplug cpufreq governor had removed cpu1. 3. cpu0 wakes up, because all wakeup events are pointed at it. 4. After restoring its own state, cpu0 brings cpu1 back online, exactly like hotplug online would, except that the boot vector has to point to a cpu_resume handler instead of secondary start. > I sure hope that hardware with these requirements is on the way out... > it's not very OS friendly. Even hardware that was designed not not have these requirements sometimes has bugs that require this kind of sequencing. OMAP4430 should theoretically support idle without sequencing, but OMAP4460 introduced a ROM code bug that requires sequencing again (turning on cpu1 corrupts the interrupt controller, so cpu0 has to be waiting with interrupts off to run a workaround whenever cpu1 turns on). Out of curiosity, what Intel hardware needs this? -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html