Re: Suspend 2 merge: 22/51: Suspend2 lowlevel code.

From: Nigel Cunningham
Date: Wed Nov 24 2004 - 16:34:32 EST


Hi.

On Thu, 2004-11-25 at 03:42, Zwane Mwaikambo wrote:
> Ok,
> Do you see anything missing (from an implementation point of view)
> for the following?
>
> Suspend:
> 1) suspend all cpus, save cpu0
> 2) proceed with state saving on cpu0 only
> 3) begin suspend
>
> Resume:
> 1) begin resume
> 2) offline all currently online cpus
> 3) proceed with state restoring
> 4) online all previously online cpus

That's roughly what we're doing now, apart from the offlining/onlining.
I had considered trying to take better advantage of SMP support (perhaps
run a decompression thread on one CPU and the writer on the other, eg),
so we might want to apply this just to the region immediately around the
atomic copy/restore. That makes me wonder, though, what the advantage is
to switching to using the hotplug functionality - is it x86 only, or
more cross platform? (If more cross platform, that might possibly be an
advantage over the current code).

> A lot of the subsystems which have work split across cpus will now have
> work migrated across to cpu0, in that regard, which have you made swsusp
> savvy? It looks like the timer changes might need looking at any others?

All of the other threads, including the migration threads, are frozen,
so I don't believe that anything gets migrated to CPU0. I'll double
check when I next suspend.

As to the timers, I fully agree. Thawing them needs a mechanism for
keeping the per-cpu timers staggered.

Regards,

Nigel
--
Nigel Cunningham
Pastoral Worker
Christian Reformed Church of Tuggeranong
PO Box 1004, Tuggeranong, ACT 2901

You see, at just the right time, when we were still powerless, Christ
died for the ungodly. -- Romans 5:6

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/