2005-08-20 Yoshinori K. Okuji <okuji@enbug.org>

* loader/powerpc/ieee1275/linux.c (grub_rescue_cmd_linux): Specify
        the boot file by the option BOOT_IMAGE. Use grub_stpcpy instead of
        grub_strcat.

        * loader/i386/pc/linux.c (grub_rescue_cmd_linux): Specify the boot
        file by the option BOOT_IMAGE. Use grub_stpcpy instead of
        grub_strcpy and grub_strlen. Take it into account that a space
        character is inserted as a delimiter.
This commit is contained in:
okuji 2005-08-20 08:25:51 +00:00
parent 6a85ce7953
commit 16ccb8b138
4 changed files with 36 additions and 18 deletions

View File

@ -1,3 +1,14 @@
2005-08-20 Yoshinori K. Okuji <okuji@enbug.org>
* loader/powerpc/ieee1275/linux.c (grub_rescue_cmd_linux): Specify
the boot file by the option BOOT_IMAGE. Use grub_stpcpy instead of
grub_strcat.
* loader/i386/pc/linux.c (grub_rescue_cmd_linux): Specify the boot
file by the option BOOT_IMAGE. Use grub_stpcpy instead of
grub_strcpy and grub_strlen. Take it into account that a space
character is inserted as a delimiter.
2005-08-20 Yoshinori K. Okuji <okuji@enbug.org> 2005-08-20 Yoshinori K. Okuji <okuji@enbug.org>
* partmap/pc.c (pc_partition_map_iterate): Include the value of an * partmap/pc.c (pc_partition_map_iterate): Include the value of an

2
NEWS
View File

@ -8,6 +8,8 @@ New in 1.91:
* New commands, "search", "vbetest" and "vbeinfo". * New commands, "search", "vbetest" and "vbeinfo".
* The option BOOT_IMAGE is passed to Linux.
New in 1.90 - 2005-08-07: New in 1.90 - 2005-08-07:

View File

@ -1,7 +1,7 @@
/* linux.c - boot Linux zImage or bzImage */ /* linux.c - boot Linux zImage or bzImage */
/* /*
* GRUB -- GRand Unified Bootloader * GRUB -- GRand Unified Bootloader
* Copyright (C) 1999,2000,2001,2002,2003,2004 Free Software Foundation, Inc. * Copyright (C) 1999,2000,2001,2002,2003,2004,2005 Free Software Foundation, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
@ -250,22 +250,22 @@ grub_rescue_cmd_linux (int argc, char *argv[])
((GRUB_LINUX_MAX_SETUP_SECTS - setup_sects - 1) ((GRUB_LINUX_MAX_SETUP_SECTS - setup_sects - 1)
<< GRUB_DISK_SECTOR_BITS)); << GRUB_DISK_SECTOR_BITS));
/* Specify the boot file. */
dest = grub_stpcpy (grub_linux_tmp_addr + GRUB_LINUX_CL_OFFSET,
"BOOT_IMAGE=");
dest = grub_stpcpy (dest, argv[0]);
/* Copy kernel parameters. */ /* Copy kernel parameters. */
for (i = 1, dest = grub_linux_tmp_addr + GRUB_LINUX_CL_OFFSET; for (i = 1;
i < argc i < argc
&& dest + grub_strlen (argv[i]) < (grub_linux_tmp_addr && dest + grub_strlen (argv[i]) + 1 < (grub_linux_tmp_addr
+ GRUB_LINUX_CL_END_OFFSET); + GRUB_LINUX_CL_END_OFFSET);
i++, *dest++ = ' ') i++)
{ {
grub_strcpy (dest, argv[i]); *dest++ = ' ';
dest += grub_strlen (argv[i]); dest = grub_stpcpy (dest, argv[i]);
} }
if (i != 1)
dest--;
*dest = '\0';
len = prot_size; len = prot_size;
if (grub_file_read (file, (char *) GRUB_LINUX_BZIMAGE_ADDR, len) != len) if (grub_file_read (file, (char *) GRUB_LINUX_BZIMAGE_ADDR, len) != len)
grub_error (GRUB_ERR_FILE_READ_ERROR, "Couldn't read file"); grub_error (GRUB_ERR_FILE_READ_ERROR, "Couldn't read file");

View File

@ -108,6 +108,7 @@ grub_rescue_cmd_linux (int argc, char *argv[])
grub_addr_t entry; grub_addr_t entry;
int found_addr = 0; int found_addr = 0;
int size; int size;
char *dest;
grub_dl_ref (my_mod); grub_dl_ref (my_mod);
@ -214,18 +215,22 @@ grub_rescue_cmd_linux (int argc, char *argv[])
} }
} }
size = 0; size = sizeof ("BOOT_IMAGE=") + grub_strlen (argv[0]);
for (i = 0; i < argc; i++) for (i = 0; i < argc; i++)
size += grub_strlen (argv[i]); size += grub_strlen (argv[i]) + 1;
linux_args = grub_malloc (size + argc + 1); linux_args = grub_malloc (size);
if (!linux_args) if (! linux_args)
goto fail; goto fail;
/* Specify the boot file. */
dest = grub_stpcpy (linux_args, "BOOT_IMAGE=");
dest = grub_stpcpy (dest, argv[0]);
for (i = 1; i < argc; i++) for (i = 1; i < argc; i++)
{ {
grub_strcat (linux_args, argv[i]); *dest++ = ' ';
grub_strcat (linux_args, " "); dest = grub_stpcpy (dest, argv[i]);
} }
fail: fail: