2007-06-21 Robert Millan <rmh@aybabtu.com>

* include/grub/i386/pc/kernel.h: Define GRUB_KERNEL_MACHINE_DATA_END to
	indicate end of data section in kernel image.
	* include/grub/i386/efi/kernel.h: Define GRUB_KERNEL_MACHINE_PREFIX and
	GRUB_KERNEL_MACHINE_DATA_END.

	* kern/i386/pc/startup.S: Do not initialize grub_prefix, only reserve
	space for it.
	* kern/i386/efi/startup.S: Likewise.

	* util/i386/pc/grub-mkimage.c: Initialize grub_prefix to /boot/grub
	during image generation.  Implement --prefix option to override this
	patch.
	* util/i386/efi/grub-mkimage.c: Likewise.

	* util/update-grub_lib.in (convert_system_path_to_grub_path): Split
	code to make path relative to its root into a separate function.

	* util/i386/pc/grub-install.in: Use newly provided
	make_system_path_relative_to_its_root() to convert ${grubdir}, then
	pass the result to grub-install --prefix.
This commit is contained in:
robertmh 2007-06-21 21:01:11 +00:00
parent baa574b487
commit bf697e2831
7 changed files with 73 additions and 14 deletions

View file

@ -30,6 +30,7 @@
#include <grub/util/resolve.h>
#include <grub/kernel.h>
#include <grub/efi/pe32.h>
#include <grub/machine/kernel.h>
static const grub_uint8_t stub[] = GRUB_PE32_MSDOS_STUB;
@ -48,7 +49,7 @@ align_pe32_section (Elf32_Addr addr)
/* Read the whole kernel image. Return the pointer to a read image,
and store the size in bytes in *SIZE. */
static char *
read_kernel_module (const char *dir, size_t *size)
read_kernel_module (const char *dir, char *prefix, size_t *size)
{
char *kernel_image;
char *kernel_path;
@ -58,6 +59,10 @@ read_kernel_module (const char *dir, size_t *size)
kernel_image = grub_util_read_image (kernel_path);
free (kernel_path);
if (GRUB_KERNEL_MACHINE_PREFIX + strlen (prefix) + 1 > GRUB_KERNEL_MACHINE_DATA_END)
grub_util_error ("prefix too long");
strcpy (kernel_image + 0x34 + GRUB_KERNEL_MACHINE_PREFIX, prefix);
return kernel_image;
}
@ -838,7 +843,7 @@ make_header (FILE *out, Elf32_Addr text_address, Elf32_Addr data_address,
/* Convert an ELF relocatable object into an EFI Application (PE32). */
void
convert_elf (const char *dir, FILE *out, char *mods[])
convert_elf (const char *dir, char *prefix, FILE *out, char *mods[])
{
char *kernel_image;
size_t kernel_size;
@ -855,7 +860,7 @@ convert_elf (const char *dir, FILE *out, char *mods[])
Elf32_Addr end_address;
/* Get the kernel image and check the format. */
kernel_image = read_kernel_module (dir, &kernel_size);
kernel_image = read_kernel_module (dir, prefix, &kernel_size);
e = (Elf32_Ehdr *) kernel_image;
if (! check_elf_header (e, kernel_size))
grub_util_error ("invalid ELF header");
@ -912,6 +917,7 @@ convert_elf (const char *dir, FILE *out, char *mods[])
static struct option options[] =
{
{"directory", required_argument, 0, 'd'},
{"prefix", required_argument, 0, 'p'},
{"output", required_argument, 0, 'o'},
{"help", no_argument, 0, 'h'},
{"version", no_argument, 0, 'V'},
@ -931,13 +937,14 @@ Usage: grub-mkimage -o FILE [OPTION]... [MODULES]\n\
Make a bootable image of GRUB.\n\
\n\
-d, --directory=DIR use images and modules under DIR [default=%s]\n\
-p, --prefix=DIR set grub_prefix directory [default=%s]\n\
-o, --output=FILE output a generated image to FILE\n\
-h, --help display this message and exit\n\
-V, --version print version information and exit\n\
-v, --verbose print verbose messages\n\
\n\
Report bugs to <%s>.\n\
", GRUB_LIBDIR, PACKAGE_BUGREPORT);
", GRUB_LIBDIR, DEFAULT_DIRECTORY, PACKAGE_BUGREPORT);
exit (status);
}
@ -948,12 +955,13 @@ main (int argc, char *argv[])
FILE *fp;
char *output = NULL;
char *dir = NULL;
char *prefix = NULL;
progname = "grub-mkimage";
while (1)
{
int c = getopt_long (argc, argv, "d:o:hVv", options, 0);
int c = getopt_long (argc, argv, "d:p:o:hVv", options, 0);
if (c == -1)
break;
@ -972,6 +980,11 @@ main (int argc, char *argv[])
free (output);
output = xstrdup (optarg);
break;
case 'p':
if (prefix)
free (prefix);
prefix = xstrdup (optarg);
break;
case 'V':
printf ("grub-mkimage (%s) %s\n", PACKAGE_NAME, PACKAGE_VERSION);
return 0;
@ -991,7 +1004,7 @@ main (int argc, char *argv[])
if (! fp)
grub_util_error ("cannot open %s", output);
convert_elf (dir ? : GRUB_LIBDIR, fp, argv + optind);
convert_elf (dir ? : GRUB_LIBDIR, prefix ? : DEFAULT_DIRECTORY, fp, argv + optind);
fclose (fp);