[PATCH] Kexec on panic vmlinux initrd fix
authorVivek Goyal <vgoyal@in.ibm.com>
Sat, 25 Jun 2005 21:57:55 +0000 (14:57 -0700)
committerLinus Torvalds <torvalds@ppc970.osdl.org>
Sat, 25 Jun 2005 23:24:48 +0000 (16:24 -0700)
This is a minor bug fix in kexec to resolve the problem of loading panic
kernel with initrd.

o Problem: Loading a capture kenrel fails if initrd is also being loaded.
  This has been observed for vmlinux image for kexec on panic case.

o This patch fixes the problem. In segment location and size verification
  logic, minor correction has been done. Segment memory end (mend) should be
  mstart + memsz - 1. This one byte offset was source of failure for initrd
  loading which was being loaded at hole boundary.

Signed-off-by: Vivek Goyal <vgoyal@in.ibm.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
kernel/kexec.c

index def9c73ec9a68c6e17cb68cee04f2cacc8ba83f3..a0411b3bd54a58d0df0c7ee3036b9a6c37871933 100644 (file)
@@ -264,7 +264,7 @@ static int kimage_crash_alloc(struct kimage **rimage, unsigned long entry,
        for (i = 0; i < nr_segments; i++) {
                unsigned long mstart, mend;
                mstart = image->segment[i].mem;
-               mend = mstart + image->segment[i].memsz;
+               mend = mstart + image->segment[i].memsz - 1;
                /* Ensure we are within the crash kernel limits */
                if ((mstart < crashk_res.start) || (mend > crashk_res.end))
                        goto out;