Heiko, On Wed, Oct 29, 2014 at 2:50 PM, Heiko St?bner <heiko at sntech.de> wrote: > Am Mittwoch, 29. Oktober 2014, 13:06:05 schrieb Kevin Hilman: >> Hi Chris, >> >> Chris Zhong <zyw at rock-chips.com> writes: >> > RK3288 can shut down the cpu, gpu and other device controllers in suspend, >> > and it will pull the GLOBAL_PWROFF pin to high in the final stage of the >> > process of suspend, pull the pin to low again when resume. >> >> I tried to test this on top of linux-next (next-20141029) and it doesn't >> wake up from serial port activity. >> >> Can you describe how to test this, as well as describe dependencies on >> other out-of-tree patches, including pointers to where they've been >> posted. >> >> Also, please describe how you tested this and on which hardware >> platforms. It's a big help to reviewers to know how it's been tested, >> and for anyone with similar hardware to know what else it's been tested >> on. > > When testing this series it did go to sleep with > > / # echo mem > /sys/power/state > PM: Syncing filesystems ... done. > Freezing user space processes ... (elapsed 0.010 seconds) done. > Freezing remaining freezable tasks ... (elapsed 0.010 seconds) done. > PM: suspend of devices complete after 0.001 msecs > PM: late suspend of devices complete after 0.001 msecs > PM: noirq suspend of devices complete after 0.001 msecs > Disabling non-boot CPUs ... > CPU1: shutdown > CPU2: shutdown > CPU3: shutdown > > and the change in pmic-noise lets me assume it's really asleep. > > > But I'm not exactly sure how to wake it up again. I even hard-wired the gpio- > keys to always enable the irq wake, but so far it didn't wake again when > pressing the power-key on the evb. > > If anyone wants to peek, the collected patches (Doug's and Chris') can be > found on [0]. Unless you get a device tree that sets up regulator states I think you're going to be SOL. In other words one thing that will definitely bite you is (7592100 ARM: dts: add suspend voltage setting for RK808). That's referencing the "global_pwroff" which means we'll be telling the PMIC when we suspend. That's good but the PMIC hasn't been programmed with any reasonable voltages because all the device tree properties are ignored. That's not good. You can see my comments about this at <https://patchwork.kernel.org/patch/5186951/> Also: I think that I remember the GPU being pretty unhappy if you turned its voltage off but didn't gate its power domain. At the moment I've got all the power domain patches sitting in my tree plus <https://chromium-review.googlesource.com/#/c/223464/>. You might also just be able to change the GPU not to be powered off in suspend (but then you need to program a good voltage to it). At the moment all of my testing is happening in the chromeos-3.14 tree (which has a ton of backports and thus isn't that different than mainline as far as Rockchip is concerned). You could theoretically try jamming Chris's stuff into the top of the chromeos-3.14 tree and see what happens on EVB. I may be able to give that a shot tomorrow... -Doug