On Tue, 7 Jun 2011, Rafael J. Wysocki wrote: > On Tuesday, June 07, 2011, Frank Hofmann wrote: [ ... ] >> * there's kind of a circular dependency between CONFIG_HIBERNATION and >> CONFIG_PM_SLEEP, on ARM. The latter is necessary so that cpu_suspend >> and cpu_resume are compiled in, but it cannot be selected via >> ARCH_HIBERNATION_POSSIBLE because CONFIG_PM_SLEEP depends on >> CONFIG_HIBERNATION_INTERFACE - selected by CONFIG_HIBERNATION. >> >> Consequence is that right now, both CONFIG_PM_SLEEP and ...HIBERNATION >> must be set in your defconfig file to be able to compile. > > In fact, CONFIG_PM_SLEEP = CONFIG_SUSPEND || CONFIG_HIBERNATE_CALLBACKS, so it > should be sufficient to set HIBERNATION. ARCH_HIBERNATION_POSSIBLE only > causes HIBERNATION to become a valid option (that may or may not be set). > >> (my head swirls from writing this ...) > > What problem exactly did you have with those settings? Ah, I tried to do a "select PM_SLEEP" from ARM's ARCH_HIBERNATION_POSSIBLE ... which is circular. Sorry the noise. It does look like the diff I sent can correctly be enabled just by selecting CONFIG_HIBERNATION as it's supposed to be, and CONFIG_PM_SLEEP will be automatically enabled then. Found a few more nits with the patch as last sent: - MULTI_CPU configs don't compile, needs changes (Will Deacon is on that) for cpu_reset. - the hardcoded v:p offset in swsusp.S needs to go, the value can now be changed at kernel init and hence a small func to query it is needed - the patch assumes the codepath is single-cpu (which the framework does ensure, as disable_nonboot_cpus is called) but also assumes that the boot CPU has ID 0; only for that is the sleep_save_sp[] entry restored. At least a WARN_ON(smp_processor_id()) is warranted; having a different core suspend the system than resume it, I'm not sure ... - the identity mappings should match what setup_mm_for_reboot does, i.e. let them cover the whole user range (not just _stext.._etext). That also makes sure whatever happens during restore, swapper_pg_dir is "virgin" again afterwards. Btw, when testing this I found that generic cpu_suspend seems to be just fine for OMAP3; the OMAP platforms though do not at this time use the generic cpu_suspend/resume for sleep, is it planned to change that ? FrankH. FrankH. > > Rafael > _______________________________________________ linux-pm mailing list linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/linux-pm