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:
parent
6a85ce7953
commit
16ccb8b138
4 changed files with 36 additions and 18 deletions
11
ChangeLog
11
ChangeLog
|
@ -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
2
NEWS
|
@ -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:
|
||||||
|
|
||||||
|
|
|
@ -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");
|
||||||
|
|
|
@ -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:
|
||||||
|
|
Loading…
Reference in a new issue