[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-Id: <200707140907.54607.a1426z@gawab.com>
Date: Sat, 14 Jul 2007 09:07:54 +0300
From: Al Boldi <a1426z@...ab.com>
To: linux-kernel@...r.kernel.org
Cc: "Rafael J. Wysocki" <rjw@...k.pl>
Subject: Re: [PATCH 0/2] Kexec jump: The first step to kexec base hibernation
Huang, Ying wrote:
>
> Hibernating process:
>
> 1. Normal kernel running
> 2. Hibernating is triggered, sys_kexec_load is used to load
> hibernating kernel and initramfs into memory. Then
> sys_reboot(LINUX_REBOOT_CMD_KSPAWN) is invoked.
> 3. In sys_reboot, kexec_jump is called to save device/CPU state,
> then relocate_kernel is called. kexec_jump and relocate_kernel
> reside in individual page in 16M~512M.
> 4. In relocate_kernel, 0~16M is backupped firstly, then the
> hibernating kernel and initramfs is copied to 0~16M, after that,
> the hibernating kernel is booted.
> 5. In hibernating kernel, the memory of normal kernel (it is in
> 16M~512M) is saved into a hibernation image through /dev/mem
> and ELF header.
>
>
> Resume process:
>
> 1. Resuming kernel is booted as a normal kernel, but the memory is
> restricted to 0~16M.
> 2. Checking whether there is a effective hibernation image. If
> there isn't, the memory of 16M~512M is hot added, and the normal
> boot up process continues; If there is, a resuming process is
> triggered.
> 3. sys_kexec_load is used to restore the memory state of hibernated
> kernel. The sys_kexec_load works in crashdump way, that is, the
> hibernation image is copied to destination location in 16M~512M
> in sys_kexec_load instead of relocate_kernel. There is no half
> of memory size restriction.
> 4. sys_reboot is called to trigger jumping back, which will jump back
> to kexec_jump of hibernated kernel.
> 5. In kexec_jump of hibernated kernel, the memory of 0~16M is copied
> back from the backup area in 16M~512M. The memory state of
> hibernated kernel is restored totally. The CPU and device state
> can be restored after that.
>
>
> If there is too much difficulty to hot add memory in step 2. A more
> conservative method can be used as step 1 and step 2.
>
> 1. A normal kernel is booted.
> 2. Checking whether there is a effective hibernation image. If there
> isn't, continue the normal boot process; otherwise, a resuming
> kernel is kexeced in memory 0~16M. The resuming process will
> continue in kexeced resuming kernel.
During Resume no kexec'ing is necessary; the normal kernel should be able to
read the hibernation image via the /dev/snapshot interface.
Thanks!
--
Al
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists