[PATCH -mm] kexec jump -v9
Eric W. Biederman
ebiederm at xmission.com
Wed Mar 12 20:01:16 EDT 2008
Vivek Goyal <vgoyal at redhat.com> writes:
> Yes. But this memory gets reserved at loading time and then this memory
> remains unused for the whole duration (except hibernation).
> In the example you gave, looks like you are reserving 15MB of memory for
> second kernel. In practice, we we finding it difficult to boot a regular
> kernel in 16MB of memory in kdump. We are now reserving 128MB of memory
> for kdump kernel on x86 arch, otheriwse OOM kill kicks in during init
> or while core is being copied.
Sounds like something we may want to fix. Living at the default kernel
address may alieviate that problem somewhat.
> Kexec based hibernation does not look any different than kdump in terms
> of memory requirements. The only difference seems to be that kdump does
> the contiguous memory reservation at boot time and kexec based hibernation
> does the memory reservation at kernel loading time.
> The only difference I can think of is, kdump will generally run on servers
> and hibernation will be required on desktops/laptops and run time memory
> requirements might be little different. I don't have numbers though.
> At the same time carrying a separate kernel binary just for hibernation
> purposes does not sound very good.
One difference is you only get the memory penalty just before you hibernate,
instead of continuously. So potentially you could swap out things to
make run for the kernel to save you to disk.
>> > 3. Usability.
>> > Right now, kexec based hibernation looks quite complicated to configure,
>> > and the user is apparently going to have to remember to boot a different
>> > kernel or at least a different bootloader entry in order to resume. Not
>> No, the newest implementation need not to boot a different kernel or
>> different bootloader entry. You just use one bootloader entry, it will
>> resume if there's an image, booting normally if there's not. You can
>> look at the newest hibernation example description.
> Following is the step from new method you have given.
> 7. Boot kernel compiled in step 1 (kernel C). Use the rootfs.gz as
> root file system.
> This mentions that use rootfs.gz as initrd. Without modifying the boot
> loader entry, how would I switch the initrd dynamically.
> Looks like it might be a typo. So basically we can just boot back into
> normal kernel and then a user can load the resumable core file and kexec
> to it?
> I think all this functionality can be packed into normal initrd itself
> to make user interface better.
> A user can configure the destination for hibernated image at system
> installation time and initrd will be modified accordingly to save the
> hibernated image as well to check that user specfied location to find out
> if a hibernation image is available and needs to be resumed.
Yes. And we don't need to load any of this until just before hibernation
time so we should be able to change things right up until the last moment.
More information about the kexec