merge merge-mkimage into rescue-efi
This commit is contained in:
		
						commit
						19ba92760a
					
				
					 89 changed files with 4039 additions and 2886 deletions
				
			
		
							
								
								
									
										138
									
								
								ChangeLog
									
										
									
									
									
								
							
							
						
						
									
										138
									
								
								ChangeLog
									
										
									
									
									
								
							|  | @ -1,3 +1,141 @@ | |||
| 2010-04-24  Christian Franke  <franke@computer.org> | ||||
| 
 | ||||
| 	* Makefile.in (TARGET_LDFLAGS): Add -static-libgcc. | ||||
| 	(kernel_img_LDFLAGS): Remove -static-libgcc. | ||||
| 
 | ||||
| 2010-04-24  Christian Franke  <franke@computer.org> | ||||
| 
 | ||||
| 	* configure.ac: Do not CHECK_BSS_START_SYMBOL | ||||
| 	and CHECK_END_SYMBOL if grub-emu is built. | ||||
| 	Unset TARGET_OBJ2ELF if grub-emu is built | ||||
| 	without module support. | ||||
| 
 | ||||
| 2010-04-24  Jiro SEKIBA <jir@unicus.jp> | ||||
| 
 | ||||
| 	Nilfs2 support. | ||||
| 
 | ||||
| 	* conf/common.rmk (grub_probe_SOURCES): Add fs/nilfs2.c. | ||||
| 	(grub_fstest_SOURCES): Likewise. | ||||
| 	(pkglib_MODULES): Add nilfs2.mod. | ||||
| 	(nilfs2_mod_SOURCES): New variable. | ||||
| 	(nilfs2_mod_CFLAGS): Likewise. | ||||
| 	(nilfs2_mod_LDFLAGS): Likewise. | ||||
| 	* conf/i386-pc.rmk (grub_setup_SOURCES): Add fs/nilfs2.c. | ||||
| 	* conf/sparc64-ieee1275.rmk (grub_setup_SOURCES): Add fs/nilfs2.c. | ||||
| 	* fs/nilfs2.c: New file. | ||||
| 
 | ||||
| 2010-04-21  Vladimir Serbinenko  <phcoder@gmail.com> | ||||
| 
 | ||||
| 	* configure.ac: Refuse to compile for x86_64-efi is mcmodel=large | ||||
| 	is not supported. | ||||
| 
 | ||||
| 2010-04-19  Grégoire Sutre  <gregoire.sutre@gmail.com> | ||||
| 
 | ||||
| 	Add grub-mkconfig support for NetBSD. | ||||
| 
 | ||||
| 	* util/grub.d/10_netbsd.in: grub-mkconfig helper script for NetBSD. | ||||
| 	* util/grub-mkconfig.in: export new NetBSD specific variables. | ||||
| 	* po/POTFILES-shell: added 10_netbsd.in. | ||||
| 	* util/grub-mkconfig_lib.in: check for gettext binary, default to echo. | ||||
| 
 | ||||
| 2010-04-19  BVK Chaitanya  <bvk.groups@gmail.com> | ||||
| 
 | ||||
| 	Fix emu build with grub-emu-pci and grub-emu-modules. | ||||
| 
 | ||||
| 	* include/grub/util/misc.h: Export grub_util_{info,error,warn} | ||||
| 	functions. | ||||
| 	* include/grub/libpciaccess.h: New file. | ||||
| 	* conf/any-emu.rmk: Update kernel headers for emu build. | ||||
| 
 | ||||
| 2010-04-19  Vladimir Serbinenko  <phcoder@gmail.com> | ||||
| 
 | ||||
| 	* fs/udf.c (grub_udf_iterate_dir): Silence a spurious warning. | ||||
| 
 | ||||
| 2010-04-19  Vladimir Serbinenko  <phcoder@gmail.com> | ||||
| 
 | ||||
| 	* fs/udf.c (grub_udf_iterate_dir): Decode the Unicode filenames. | ||||
| 
 | ||||
| 2010-04-18  Vladimir Serbinenko  <phcoder@gmail.com> | ||||
| 
 | ||||
| 	* boot/sparc64/ieee1275/boot.S: Various size-reducing changes. | ||||
| 	Retrieve chosen/bootpath if bootpath isn't hardcoded. | ||||
| 	* conf/sparc64-ieee1275.rmk (grub_setup_SOURCES): Add | ||||
| 	util/ieee1275/ofpath.c. | ||||
| 	* util/sparc64/ieee1275/grub-ofpathname.c: Renamed to ... | ||||
| 	* util/ieee1275/grub-ofpathname.c: ... this. All users updated | ||||
| 	* include/grub/sparc64/ieee1275/boot.h | ||||
| 	(GRUB_BOOT_MACHINE_KERNEL_SECTOR): Renamed to ... | ||||
| 	(GRUB_BOOT_MACHINE_KERNEL_BYTE): ...this. Moved 8 bytes lower. | ||||
| 	* util/hostdisk.c (grub_util_biosdisk_get_osdev): New function. | ||||
| 	* util/ieee1275/ofpath.c (grub_util_devname_to_ofpath): Make argument | ||||
| 	const char *. | ||||
| 	* util/sparc64/ieee1275/grub-setup.c (compute_dest_ofpath): Removed. | ||||
| 	(setup): Use KERNEL_BYTE instead of KERNEL_SECTOR. | ||||
| 	Use grub_util_devname_to_ofpath. Zero-fill boot_devpath on same disk | ||||
| 	install. | ||||
| 
 | ||||
| 2010-04-18  Grégoire Sutre  <gregoire.sutre@gmail.com> | ||||
| 
 | ||||
| 	* util/grub-mkconfig.in: Corrected two == equality tests. | ||||
| 	Set grub_prefix as in grub-install for NetBSD and OpenBSD. | ||||
| 	* configure.ac: All definitions and uses of TARGET_IMG_LDFLAGS_AC now | ||||
| 	expect a number appended to it. | ||||
| 	* acinclude.m4 (grub_PROG_OBJCOPY_ABSOLUTE): ${TARGET_IMG_LDFLAGS_AC} | ||||
| 	expects a number appended to it. | ||||
| 
 | ||||
| 2010-04-18  Vladimir Serbinenko  <phcoder@gmail.com> | ||||
| 
 | ||||
| 	* po/POTFILES: Renamed multiboot_loader.c to multiboot.c | ||||
| 
 | ||||
| 2010-04-18  Vladimir Serbinenko  <phcoder@gmail.com> | ||||
| 
 | ||||
| 	* util/hostdisk.c (make_device_name): Change to new partition naming. | ||||
| 
 | ||||
| 2010-04-17  Vladimir Serbinenko  <phcoder@gmail.com> | ||||
| 
 | ||||
| 	* disk/lvm.c (grub_lvm_memberlist): Issue an error if pv->disk = 0. | ||||
| 
 | ||||
| 2010-04-17  Christian Franke <franke@computer.org> | ||||
| 
 | ||||
| 	* Makefile.in: Add missing localedir setting. | ||||
| 
 | ||||
| 2010-04-14  Colin Watson  <cjwatson@ubuntu.com> | ||||
| 
 | ||||
| 	Restore TEXTDOMAINDIR correction from r1889, lost apparently by | ||||
| 	mistake in r2156.  Noticed by Anthony Fok. | ||||
| 
 | ||||
| 	* util/grub.d/10_kfreebsd.in (TEXTDOMAINDIR): Set to lowercased | ||||
| 	@localedir@. | ||||
| 	* util/grub.d/10_linux.in (TEXTDOMAINDIR): Likewise. | ||||
| 
 | ||||
| 2010-04-14  BVK Chaitanya  <bvk.groups@gmail.com> | ||||
| 
 | ||||
| 	Fix a spurious, uninitialized variable warning. | ||||
| 
 | ||||
| 	* loader/i386/bsdXX.c (grub_freebsd_load_elfmodule_obj): | ||||
| 	Initialize variable, shdr. | ||||
| 	(grub_freebsd_load_elfmodule): Likewise. | ||||
| 	(grub_freebsd_load_elf_meta): Likewise. | ||||
| 
 | ||||
| 2010-04-13  BVK Chaitanya  <bvk.groups@gmail.com> | ||||
| 
 | ||||
| 	Fix for escaped dollar in double quoted strings. | ||||
| 
 | ||||
| 	* script/yylex.l: Updated flex rules. | ||||
| 	* conf/tests.rmk: Rule for new testcase. | ||||
| 	* tests/grub_script_dollar.in: New testcase. | ||||
| 
 | ||||
| 2010-04-13  Carles Pina i Estany  <carles@pina.cat> | ||||
| 2010-04-13  Colin Watson  <cjwatson@ubuntu.com> | ||||
| 
 | ||||
| 	Enclose all translated strings in grub.cfg in single quotes, and | ||||
| 	escape them appropriately (Ubuntu bug #552921). | ||||
| 
 | ||||
| 	* util/grub-mkconfig_lib.in (gettext_quoted): New function. | ||||
| 	* util/grub.d/10_hurd.in: Use it. | ||||
| 	* util/grub.d/10_kfreebsd.in (kfreebsd_entry): Likewise. | ||||
| 	* util/grub.d/10_linux.in (linux_entry): Likewise. | ||||
| 
 | ||||
| 2010-04-11  Vladimir Serbinenko  <phcoder@gmail.com> | ||||
| 
 | ||||
| 	Fix cygwin compilation. | ||||
|  |  | |||
|  | @ -35,6 +35,7 @@ sysconfdir = @sysconfdir@ | |||
| sharedstatedir = @sharedstatedir@ | ||||
| localstatedir = @localstatedir@ | ||||
| libdir = @libdir@ | ||||
| localedir = @localedir@ | ||||
| infodir = @infodir@ | ||||
| mandir = @mandir@ | ||||
| includedir = @includedir@ | ||||
|  | @ -89,7 +90,7 @@ GNULIB_CFLAGS = $(GNULIB_UTIL_CFLAGS) $(POSIX_CFLAGS) | |||
| ASFLAGS = @ASFLAGS@ | ||||
| LDFLAGS = @LDFLAGS@ $(LIBS) | ||||
| CPPFLAGS = @CPPFLAGS@ -I$(builddir) -I$(builddir)/include -I$(srcdir)/gnulib -I$(srcdir)/include -Wall -W \
 | ||||
| 	 -DGRUB_LIBDIR=\"$(pkglibdir)\" -DLOCALEDIR=\"$(localedir)\" | ||||
| 	 -DGRUB_LIBDIR=\"$(libdir)\" -DLOCALEDIR=\"$(localedir)\" | ||||
| TARGET_CC = @TARGET_CC@ | ||||
| TARGET_CFLAGS = -ffreestanding @TARGET_CFLAGS@ | ||||
| TARGET_ASFLAGS = -nostdinc -fno-builtin @TARGET_ASFLAGS@ | ||||
|  | @ -98,12 +99,12 @@ TARGET_APPLE_CC = @TARGET_APPLE_CC@ | |||
| OBJCONV = @OBJCONV@ | ||||
| TARGET_CPPFLAGS = @TARGET_CPPFLAGS@ -I$(srcdir)/include -I$(builddir) -I$(builddir)/include \
 | ||||
| 	-Wall -W | ||||
| TARGET_LDFLAGS = -nostdlib @TARGET_LDFLAGS@ | ||||
| TARGET_LDFLAGS = -nostdlib -static-libgcc @TARGET_LDFLAGS@ | ||||
| TARGET_IMG_LDSCRIPT = @TARGET_IMG_LDSCRIPT@ | ||||
| TARGET_IMG_LDFLAGS = -nostdlib @TARGET_IMG_LDFLAGS@ | ||||
| TARGET_IMG_CFLAGS = @TARGET_IMG_CFLAGS@ | ||||
| TARGET_OBJ2ELF = @TARGET_OBJ2ELF@ | ||||
| kernel_img_LDFLAGS = -static-libgcc -lgcc | ||||
| kernel_img_LDFLAGS = -lgcc | ||||
| EXEEXT = @EXEEXT@ | ||||
| OBJCOPY = @OBJCOPY@ | ||||
| STRIP = @STRIP@ | ||||
|  | @ -286,7 +287,7 @@ build_env.mk: Makefile | |||
| 	echo "TARGET_CC=$(TARGET_CC)" ; \
 | ||||
| 	echo "TARGET_CFLAGS=$(TARGET_CFLAGS)" ; \
 | ||||
| 	echo "TARGET_ASFLAGS=$(TARGET_ASFLAGS)" ; \
 | ||||
| 	echo "TARGET_CPPFLAGS=$(TARGET_CPPFLAGS) -I$(pkglibdir) -I$(includedir)" ; \
 | ||||
| 	echo "TARGET_CPPFLAGS=$(TARGET_CPPFLAGS) -I$(libdir) -I$(includedir)" ; \
 | ||||
| 	echo "STRIP=$(STRIP)" ; \
 | ||||
| 	echo "OBJCONV=$(OBJCONV)" ; \
 | ||||
| 	echo "TARGET_MODULE_FORMAT=$(TARGET_MODULE_FORMAT)" ; \
 | ||||
|  |  | |||
|  | @ -93,7 +93,7 @@ else | |||
| fi | ||||
| grub_cv_prog_objcopy_absolute=yes | ||||
| for link_addr in 0x2000 0x8000 0x7C00; do | ||||
|   if AC_TRY_COMMAND([${CC-cc} ${CFLAGS} -nostdlib ${TARGET_IMG_LDFLAGS_AC} -Wl,-Ttext -Wl,$link_addr conftest.o -o conftest.exec]); then : | ||||
|   if AC_TRY_COMMAND([${CC-cc} ${CFLAGS} -nostdlib ${TARGET_IMG_LDFLAGS_AC}$link_addr conftest.o -o conftest.exec]); then : | ||||
|   else | ||||
|     AC_MSG_ERROR([${CC-cc} cannot link at address $link_addr]) | ||||
|   fi | ||||
|  |  | |||
|  | @ -31,7 +31,7 @@ _start: | |||
| 
 | ||||
| 	jmp	1f | ||||
| 
 | ||||
| 	. = _start + GRUB_BOOT_MACHINE_CORE_ENTRY_ADDR | ||||
| 	. = _start + GRUB_BOOT_I386_QEMU_CORE_ENTRY_ADDR | ||||
| VARIABLE(grub_core_entry_addr) | ||||
| 	.long	0
 | ||||
| 1: | ||||
|  |  | |||
|  | @ -45,8 +45,9 @@ boot_version:		.byte	GRUB_BOOT_VERSION_MAJOR, GRUB_BOOT_VERSION_MINOR | |||
| 	 * load address plus the size of the prepended A.OUT header (32 bytes). | ||||
| 	 */ | ||||
| boot_path: | ||||
| 	. = _start + GRUB_BOOT_MACHINE_KERNEL_SECTOR | ||||
| kernel_sector:		.xword 2 | ||||
| 	. = _start + GRUB_BOOT_MACHINE_KERNEL_BYTE | ||||
| boot_path_end: | ||||
| kernel_byte:		.xword (2 << 9) | ||||
| kernel_address:		.word  GRUB_BOOT_MACHINE_KERNEL_ADDR | ||||
| 
 | ||||
| prom_finddev_name:	.asciz "finddevice" | ||||
|  | @ -77,10 +78,22 @@ prom_error: | |||
| 	/* %o0: OF call name | ||||
| 	 * %o1: input arg 1 | ||||
| 	 */ | ||||
| prom_call_1_1: | ||||
| prom_call_1_1_o2: | ||||
| 	clr	%o2 | ||||
| 	ba	prom_call_x_1 | ||||
| 	 mov	1, %g1 | ||||
| 	ba	prom_call | ||||
| 	 mov	1, %o5 | ||||
| 
 | ||||
| prom_call_getprop: | ||||
| 	mov	4, %g1 | ||||
| 	stx	%g1, [%l1 + 256] | ||||
| 	mov	CHOSEN_NODE_REG, %o1 | ||||
| 	ba	prom_call_x_1 | ||||
| 	 GET_ABS(prom_getprop_name, %o0) | ||||
| 
 | ||||
| prom_call_3_1_o1: | ||||
| 	ba prom_call_3_1 | ||||
| 	 mov	BOOTDEV_REG, %o1 | ||||
| 
 | ||||
| 	 | ||||
| 	/* %o2: message string | ||||
| 	 * %o3: message length | ||||
|  | @ -97,6 +110,7 @@ console_write: | |||
| 	 */ | ||||
| prom_call_3_1:	 | ||||
| 	mov	3, %g1 | ||||
| prom_call_x_1: | ||||
| 	mov	1, %o5 | ||||
| 	/* fallthru */ | ||||
| 
 | ||||
|  | @ -126,23 +140,17 @@ boot_continue: | |||
| 	 * chosen_node = prom_finddevice("/chosen") | ||||
| 	 */ | ||||
| 	GET_ABS(prom_finddev_name, %o0) | ||||
| 	call	prom_call_1_1_o2 | ||||
| 	 GET_ABS(prom_chosen_path, %o1) | ||||
| 	call	prom_call_1_1 | ||||
| 	 clr	%o2 | ||||
| 
 | ||||
| 	ldx	[%l1 + 0x20], CHOSEN_NODE_REG | ||||
| 	brz	CHOSEN_NODE_REG, prom_error | ||||
| 
 | ||||
| 	/* getprop(chosen_node, "stdout", &buffer, buffer_size) */ | ||||
| 	 GET_ABS(prom_getprop_name, %o0) | ||||
| 	mov	4, %g1 | ||||
| 	mov	1, %o5 | ||||
| 	mov	CHOSEN_NODE_REG, %o1 | ||||
| 	 GET_ABS(prom_stdout_name, %o2) | ||||
| 	add	%l1, 256, %o3 | ||||
| 	call	prom_call_getprop | ||||
| 	 mov	1024, %o4 | ||||
| 	call	prom_call | ||||
| 	 stx	%g1, [%l1 + 256] | ||||
| 
 | ||||
| 	lduw	[%l1 + 256], STDOUT_NODE_REG | ||||
| 	brz,pn	STDOUT_NODE_REG, prom_error | ||||
|  | @ -152,15 +160,25 @@ boot_continue: | |||
| 	call	console_write | ||||
| 	 mov	GRUB_NAME_LEN, %o3 | ||||
| 
 | ||||
| 	GET_ABS(boot_path, %o3) | ||||
| 	ldub	[%o3], %o1 | ||||
| 	brnz,pn	%o1, bootpath_known | ||||
| 
 | ||||
| 	/* getprop(chosen_node, "bootpath", &buffer, buffer_size) */ | ||||
| 	 GET_ABS(prom_bootpath_name, %o2) | ||||
| 	call	prom_call_getprop | ||||
| 	 mov	(boot_path_end - boot_path), %o4 | ||||
| 
 | ||||
| bootpath_known:	 | ||||
| 
 | ||||
| 	/* Open up the boot_path, and use that handle to read the | ||||
| 	 * first block of the GRUB kernel image. | ||||
| 	 * | ||||
| 	 * bootdev_handle = open(boot_path) | ||||
| 	 */ | ||||
| 	GET_ABS(prom_open_name, %o0) | ||||
| 	call	prom_call_1_1_o2 | ||||
| 	 GET_ABS(boot_path, %o1) | ||||
| 	call	prom_call_1_1 | ||||
| 	 clr	%o2 | ||||
| 
 | ||||
| 	ldx	[%l1 + 0x20], BOOTDEV_REG | ||||
| 	brz,pn	BOOTDEV_REG, prom_open_error | ||||
|  | @ -168,28 +186,23 @@ boot_continue: | |||
| 	/* Since we have 64-bit cells, the high cell of the seek offset | ||||
| 	 * is zero and the low cell is the entire value. | ||||
| 	 * | ||||
| 	 * seek(bootdev, 0, *kernel_sector << 9) | ||||
| 	 * seek(bootdev, 0, *kernel_byte) | ||||
| 	 */ | ||||
| 	 GET_ABS(prom_seek_name, %o0) | ||||
| 	mov	BOOTDEV_REG, %o1 | ||||
| 	clr	%o2 | ||||
| 	LDX_ABS(kernel_sector, 0x00, %o3) | ||||
| 	call	prom_call_3_1 | ||||
| 	 sllx	%o3, 9, %o3 | ||||
| 	call	prom_call_3_1_o1 | ||||
| 	 LDX_ABS(kernel_byte, 0x00, %o3) | ||||
| 
 | ||||
| 	/* read(bootdev, *kernel_address, 512) */ | ||||
| 	GET_ABS(prom_read_name, %o0) | ||||
| 	mov	BOOTDEV_REG, %o1 | ||||
| 	LDUW_ABS(kernel_address, 0x00, %o2) | ||||
| 	call	prom_call_3_1 | ||||
| 	call	prom_call_3_1_o1 | ||||
| 	 mov	512, %o3 | ||||
| 
 | ||||
| 	LDUW_ABS(kernel_address, 0x00, %o2) | ||||
| 	jmpl	%o2, %o7 | ||||
| 	 nop | ||||
| 
 | ||||
| 1:	ba,a	1b | ||||
| 
 | ||||
| 	. = _start + GRUB_BOOT_MACHINE_CODE_END | ||||
| 
 | ||||
| /* the last 4 bytes in the sector 0 contain the signature */ | ||||
|  |  | |||
|  | @ -19,6 +19,7 @@ | |||
| 
 | ||||
| #include <grub/boot.h> | ||||
| #include <grub/machine/boot.h> | ||||
| #include <grub/offsets.h> | ||||
| 
 | ||||
| 	.text | ||||
| 	.align	4
 | ||||
|  | @ -87,8 +88,8 @@ after_info_block: | |||
| 	call	console_write | ||||
| 	 mov	NOTIFICATION_STRING_LEN, %o3 | ||||
| 
 | ||||
| 	GET_ABS(firstlist - GRUB_BOOT_MACHINE_LIST_SIZE, %l2) | ||||
| 	set	GRUB_BOOT_MACHINE_IMAGE_ADDRESS, %l3 | ||||
| 	GET_ABS(firstlist - GRUB_BOOT_SPARC64_IEEE1275_LIST_SIZE, %l2) | ||||
| 	set	GRUB_BOOT_SPARC64_IEEE1275_IMAGE_ADDRESS, %l3 | ||||
| bootloop: | ||||
| 	lduw	[%l2 + 0x08], %o0 | ||||
| 	brz	%o0, bootit | ||||
|  | @ -115,7 +116,7 @@ bootloop: | |||
| 	 mov	NOTIFICATION_STEP_LEN, %o3 | ||||
| 
 | ||||
| 	ba	bootloop | ||||
| 	 sub	%l2, GRUB_BOOT_MACHINE_LIST_SIZE, %l2 | ||||
| 	 sub	%l2, GRUB_BOOT_SPARC64_IEEE1275_LIST_SIZE, %l2 | ||||
| 
 | ||||
| bootit: | ||||
| 	GET_ABS(prom_close_name, %o0) | ||||
|  | @ -127,8 +128,8 @@ bootit: | |||
| 	GET_ABS(notification_done, %o2) | ||||
| 	call	console_write | ||||
| 	 mov	NOTIFICATION_DONE_LEN, %o3 | ||||
| 	sethi	%hi(GRUB_BOOT_MACHINE_IMAGE_ADDRESS), %o2 | ||||
| 	jmpl	%o2 + %lo(GRUB_BOOT_MACHINE_IMAGE_ADDRESS), %o7 | ||||
| 	sethi	%hi(GRUB_BOOT_SPARC64_IEEE1275_IMAGE_ADDRESS), %o2 | ||||
| 	jmpl	%o2 + %lo(GRUB_BOOT_SPARC64_IEEE1275_IMAGE_ADDRESS), %o7 | ||||
| 	 mov	CIF_REG, %o4 | ||||
| 1:	ba,a	1b | ||||
| 
 | ||||
|  | @ -136,7 +137,7 @@ lastlist: | |||
| 	.word	0
 | ||||
| 	.word	0
 | ||||
| 
 | ||||
| 	. = _start + (0x200 - GRUB_BOOT_MACHINE_LIST_SIZE) | ||||
| 	. = _start + (0x200 - GRUB_BOOT_SPARC64_IEEE1275_LIST_SIZE) | ||||
| blocklist_default_start: | ||||
| 	.word	0
 | ||||
| 	.word	2
 | ||||
|  |  | |||
|  | @ -14,7 +14,7 @@ kernel_img_SOURCES = kern/device.c kern/disk.c kern/dl.c kern/env.c	\ | |||
| 	util/hostdisk.c util/getroot.c util/mm.c util/time.c		\ | ||||
| 	\ | ||||
| 	gnulib/progname.c util/hostfs.c disk/host.c | ||||
| kernel_img_HEADERS += datetime.h | ||||
| kernel_img_HEADERS += datetime.h util/misc.h | ||||
| kernel_img_CFLAGS = $(TARGET_CPPFLAGS) $(TARGET_CFLAGS) -Wno-undef -I$(srcdir)/gnulib | ||||
| kernel_img_LDFLAGS = $(COMMON_LDFLAGS) | ||||
| TARGET_NO_STRIP = yes | ||||
|  | @ -88,6 +88,7 @@ pkglib_MODULES += pci.mod | |||
| pci_mod_SOURCES = util/pci.c commands/lspci.c | ||||
| pci_mod_LDFLAGS = $(COMMON_LDFLAGS) | ||||
| grub_emu_LDFLAGS += $(LIBPCIACCESS) | ||||
| kernel_img_HEADERS += libpciaccess.h | ||||
| endif | ||||
| 
 | ||||
| include $(srcdir)/conf/common.mk | ||||
|  |  | |||
|  | @ -14,12 +14,11 @@ else | |||
| grub_mkdevicemap_SOURCES += util/devicemap.c | ||||
| endif | ||||
| 
 | ||||
| # For grub-mkelfimage. | ||||
| bin_UTILITIES += grub-mkelfimage | ||||
| grub_mkelfimage_SOURCES = gnulib/progname.c \ | ||||
| 	util/elf/grub-mkimage.c util/misc.c \ | ||||
| 	util/resolve.c | ||||
| util/elf/grub-mkimage.c_DEPENDENCIES = Makefile | ||||
| # For grub-mkimage. | ||||
| bin_UTILITIES += grub-mkimage | ||||
| grub_mkimage_SOURCES = gnulib/progname.c util/grub-mkimage.c util/misc.c \ | ||||
| 	util/resolve.c lib/LzmaEnc.c lib/LzFind.c | ||||
| util/grub-mkimage.c_DEPENDENCIES = Makefile | ||||
| 
 | ||||
| # For grub-probe. | ||||
| sbin_UTILITIES += grub-probe | ||||
|  | @ -31,9 +30,9 @@ grub_probe_SOURCES = gnulib/progname.c util/grub-probe.c	\ | |||
| 	\ | ||||
| 	fs/affs.c fs/cpio.c fs/fat.c fs/ext2.c fs/hfs.c		\ | ||||
| 	fs/hfsplus.c fs/iso9660.c fs/udf.c fs/jfs.c fs/minix.c	\ | ||||
| 	fs/ntfs.c fs/ntfscomp.c fs/reiserfs.c fs/sfs.c		\ | ||||
| 	fs/ufs.c fs/ufs2.c fs/xfs.c fs/afs.c fs/afs_be.c	\ | ||||
| 	fs/befs.c fs/befs_be.c fs/tar.c		\ | ||||
| 	fs/nilfs2.c fs/ntfs.c fs/ntfscomp.c fs/reiserfs.c	\ | ||||
| 	fs/sfs.c fs/ufs.c fs/ufs2.c fs/xfs.c fs/afs.c		\ | ||||
| 	fs/afs_be.c fs/befs.c fs/befs_be.c fs/tar.c		\ | ||||
| 	\ | ||||
| 	partmap/msdos.c partmap/bsdlabel.c partmap/apple.c \ | ||||
| 	partmap/sun.c partmap/sunpc.c partmap/gpt.c \ | ||||
|  | @ -69,7 +68,7 @@ grub_fstest_SOURCES = gnulib/progname.c util/grub-fstest.c util/hostfs.c \ | |||
| 	\ | ||||
| 	fs/affs.c fs/cpio.c fs/fat.c fs/ext2.c fs/hfs.c			\ | ||||
| 	fs/hfsplus.c fs/iso9660.c fs/udf.c fs/jfs.c fs/minix.c		\ | ||||
| 	fs/ntfs.c fs/ntfscomp.c fs/reiserfs.c fs/sfs.c			\ | ||||
| 	fs/nilfs2.c fs/ntfs.c fs/ntfscomp.c fs/reiserfs.c fs/sfs.c	\ | ||||
| 	fs/ufs.c fs/ufs2.c fs/xfs.c fs/afs.c fs/afs_be.c fs/befs.c 	\ | ||||
| 	fs/befs_be.c fs/tar.c			\ | ||||
| 	\ | ||||
|  | @ -119,7 +118,7 @@ kernel_img_HEADERS += boot.h cache.h device.h disk.h dl.h elf.h elfload.h \ | |||
| 	list.h handler.h command.h i18n.h env_private.h libgcc.h | ||||
| 
 | ||||
| ifneq ($(platform), emu) | ||||
| kernel_img_HEADERS += machine/memory.h machine/loader.h machine/kernel.h | ||||
| kernel_img_HEADERS += machine/memory.h machine/loader.h | ||||
| endif | ||||
| 
 | ||||
| symlist.c: $(addprefix include/grub/,$(kernel_img_HEADERS)) config.h gensymlist.sh | ||||
|  | @ -298,6 +297,12 @@ minix_mod_SOURCES = fs/minix.c | |||
| minix_mod_CFLAGS = $(COMMON_CFLAGS) | ||||
| minix_mod_LDFLAGS = $(COMMON_LDFLAGS) | ||||
| 
 | ||||
| # For nilfs2.mod. | ||||
| pkglib_MODULES += nilfs2.mod | ||||
| nilfs2_mod_SOURCES = fs/nilfs2.c | ||||
| nilfs2_mod_CFLAGS = $(COMMON_CFLAGS) | ||||
| nilfs2_mod_LDFLAGS = $(COMMON_LDFLAGS) | ||||
| 
 | ||||
| # For hfs.mod. | ||||
| hfs_mod_SOURCES = fs/hfs.c | ||||
| hfs_mod_CFLAGS = $(COMMON_CFLAGS) | ||||
|  |  | |||
|  | @ -4,8 +4,6 @@ COMMON_CFLAGS = -mrtd -mregparm=3 | |||
| 
 | ||||
| # Images. | ||||
| 
 | ||||
| GRUB_KERNEL_MACHINE_LINK_ADDR	= 0x8200 | ||||
| 
 | ||||
| pkglib_PROGRAMS += kernel.img | ||||
| kernel_img_SOURCES = kern/i386/coreboot/startup.S \ | ||||
| 	kern/i386/misc.S \ | ||||
|  | @ -26,7 +24,7 @@ kernel_img_SOURCES = kern/i386/coreboot/startup.S \ | |||
| 	symlist.c | ||||
| kernel_img_CFLAGS = $(COMMON_CFLAGS) | ||||
| kernel_img_ASFLAGS = $(COMMON_ASFLAGS) | ||||
| kernel_img_LDFLAGS += $(COMMON_LDFLAGS) -Wl,-N,-S,-Ttext,$(GRUB_KERNEL_MACHINE_LINK_ADDR),-Bstatic | ||||
| kernel_img_LDFLAGS += $(COMMON_LDFLAGS) -Wl,-N,-S,-Ttext,0x8200,-Bstatic | ||||
| 
 | ||||
| sbin_SCRIPTS += grub-install | ||||
| grub_install_SOURCES = util/grub-install.in | ||||
|  |  | |||
|  | @ -1,12 +1,9 @@ | |||
| # -*- makefile -*- | ||||
| 
 | ||||
| GRUB_KERNEL_MACHINE_LINK_ADDR = 0x8200 | ||||
| 
 | ||||
| COMMON_CFLAGS = -mrtd -mregparm=3 | ||||
| 
 | ||||
| # Images. | ||||
| pkglib_IMAGES = boot.img cdboot.img diskboot.img kernel.img lnxboot.img \ | ||||
| 	pxeboot.img | ||||
| pkglib_IMAGES = boot.img cdboot.img diskboot.img lnxboot.img pxeboot.img | ||||
| 
 | ||||
| # For boot.img. | ||||
| boot_img_SOURCES = boot/i386/pc/boot.S | ||||
|  | @ -39,6 +36,7 @@ cdboot_img_LDFLAGS = $(COMMON_LDFLAGS) $(TARGET_IMG_LDFLAGS)0x7C00 | |||
| cdboot_img_FORMAT = binary | ||||
| 
 | ||||
| # For kernel.img. | ||||
| pkglib_PROGRAMS = kernel.img | ||||
| kernel_img_SOURCES = kern/i386/pc/startup.S \ | ||||
| 	kern/i386/misc.S \ | ||||
| 	kern/main.c kern/device.c \ | ||||
|  | @ -55,22 +53,14 @@ kernel_img_SOURCES = kern/i386/pc/startup.S \ | |||
| 	term/i386/pc/console.c term/i386/vga_common.c \ | ||||
| 	symlist.c | ||||
| kernel_img_HEADERS += machine/biosdisk.h machine/vga.h machine/vbe.h \ | ||||
| 	machine/pxe.h i386/pit.h | ||||
| 	machine/pxe.h i386/pit.h machine/kernel.h | ||||
| kernel_img_CFLAGS = $(COMMON_CFLAGS)  $(TARGET_IMG_CFLAGS) | ||||
| kernel_img_ASFLAGS = $(COMMON_ASFLAGS) | ||||
| kernel_img_LDFLAGS += $(COMMON_LDFLAGS) $(TARGET_IMG_LDFLAGS)$(GRUB_KERNEL_MACHINE_LINK_ADDR) $(COMMON_CFLAGS) | ||||
| kernel_img_FORMAT = binary | ||||
| kernel_img_LDFLAGS += $(COMMON_LDFLAGS) $(TARGET_IMG_LDFLAGS)0x8200 $(COMMON_CFLAGS) | ||||
| 
 | ||||
| # Utilities. | ||||
| bin_UTILITIES = grub-mkimage | ||||
| sbin_UTILITIES = grub-setup | ||||
| 
 | ||||
| # For grub-mkimage. | ||||
| grub_mkimage_SOURCES = gnulib/progname.c util/grub-mkrawimage.c util/misc.c \ | ||||
| 	util/resolve.c lib/LzmaEnc.c lib/LzFind.c | ||||
| grub_mkimage_CFLAGS = -DGRUB_KERNEL_MACHINE_LINK_ADDR=$(GRUB_KERNEL_MACHINE_LINK_ADDR) | ||||
| util/grub-mkrawimage.c_DEPENDENCIES = Makefile | ||||
| 
 | ||||
| # For grub-setup. | ||||
| util/i386/pc/grub-setup.c_DEPENDENCIES = grub_setup_init.h | ||||
| grub_setup_SOURCES = gnulib/progname.c \ | ||||
|  | @ -82,9 +72,9 @@ grub_setup_SOURCES = gnulib/progname.c \ | |||
| 	\ | ||||
| 	fs/affs.c fs/cpio.c fs/ext2.c fs/fat.c fs/hfs.c		 \ | ||||
| 	fs/hfsplus.c fs/iso9660.c fs/udf.c fs/jfs.c fs/minix.c	 \ | ||||
| 	fs/ntfs.c fs/ntfscomp.c fs/reiserfs.c fs/sfs.c		 \ | ||||
| 	fs/ufs.c fs/ufs2.c fs/xfs.c fs/afs.c fs/afs_be.c	 \ | ||||
| 	fs/befs.c fs/befs_be.c fs/tar.c			\ | ||||
| 	fs/nilfs2.c fs/ntfs.c fs/ntfscomp.c fs/reiserfs.c	\ | ||||
| 	fs/sfs.c fs/ufs.c fs/ufs2.c fs/xfs.c fs/afs.c		\ | ||||
| 	fs/afs_be.c fs/befs.c fs/befs_be.c fs/tar.c		\ | ||||
| 	\ | ||||
| 	partmap/msdos.c partmap/bsdlabel.c partmap/sunpc.c	\ | ||||
| 	partmap/gpt.c		\ | ||||
|  |  | |||
|  | @ -13,13 +13,7 @@ boot_img_ASFLAGS = $(COMMON_ASFLAGS) -DGRUB_BOOT_MACHINE_LINK_ADDR=$(GRUB_BOOT_M | |||
| boot_img_LDFLAGS = $(COMMON_LDFLAGS) $(TARGET_IMG_LDFLAGS)$(GRUB_BOOT_MACHINE_LINK_ADDR) | ||||
| boot_img_FORMAT = binary | ||||
| 
 | ||||
| bin_UTILITIES += grub-mkimage | ||||
| grub_mkimage_SOURCES = util/grub-mkrawimage.c util/misc.c \ | ||||
| 	util/resolve.c gnulib/progname.c | ||||
| grub_mkimage_CFLAGS = -DGRUB_KERNEL_MACHINE_LINK_ADDR=$(GRUB_KERNEL_MACHINE_LINK_ADDR) | ||||
| util/grub-mkrawimage.c_DEPENDENCIES = Makefile | ||||
| 
 | ||||
| pkglib_IMAGES += kernel.img | ||||
| pkglib_PROGRAMS += kernel.img | ||||
| kernel_img_SOURCES = kern/i386/qemu/startup.S \ | ||||
| 	kern/i386/misc.S \ | ||||
| 	kern/i386/coreboot/init.c \ | ||||
|  |  | |||
|  | @ -5,7 +5,7 @@ COMMON_CFLAGS += -march=mips3 | |||
| COMMON_ASFLAGS += -march=mips3 | ||||
| include $(srcdir)/conf/mips.mk | ||||
| 
 | ||||
| pkglib_IMAGES = kernel.img | ||||
| pkglib_PROGRAMS = kernel.img | ||||
| kernel_img_SOURCES = kern/$(target_cpu)/startup.S \ | ||||
| 	kern/main.c kern/device.c kern/$(target_cpu)/init.c \ | ||||
| 	kern/$(target_cpu)/$(target_machine)/init.c 		\ | ||||
|  |  | |||
|  | @ -8,7 +8,7 @@ kernel_img_HEADERS += pci.h bitmap.h video.h gfxterm.h font.h bitmap_scale.h buf | |||
| 
 | ||||
| include $(srcdir)/conf/mips.mk | ||||
| 
 | ||||
| pkglib_IMAGES = kernel.img | ||||
| pkglib_PROGRAMS = kernel.img | ||||
| kernel_img_SOURCES = kern/$(target_cpu)/startup.S \ | ||||
| 	kern/main.c kern/device.c kern/$(target_cpu)/init.c \ | ||||
| 	kern/$(target_cpu)/$(target_machine)/init.c 		\ | ||||
|  |  | |||
|  | @ -10,13 +10,6 @@ kernel_img_HEADERS += cpu/cache.h | |||
| sbin_SCRIPTS =  | ||||
| bin_SCRIPTS =  | ||||
| 
 | ||||
| # For grub-mkimage. | ||||
| bin_UTILITIES += grub-mkimage | ||||
| grub_mkimage_SOURCES = gnulib/progname.c util/grub-mkrawimage.c util/misc.c \ | ||||
| 	util/resolve.c lib/LzmaEnc.c lib/LzFind.c | ||||
| grub_mkimage_CFLAGS = -DGRUB_KERNEL_MACHINE_LINK_ADDR=$(LINK_BASE) | ||||
| util/grub-mkrawimage.c_DEPENDENCIES = Makefile | ||||
| 
 | ||||
| # For serial.mod. | ||||
| pkglib_MODULES += serial.mod | ||||
| serial_mod_SOURCES = term/serial.c | ||||
|  |  | |||
|  | @ -5,7 +5,8 @@ COMMON_CFLAGS = -mno-app-regs | |||
| COMMON_LDFLAGS = -melf64_sparc -mno-relax | ||||
| 
 | ||||
| # Images. | ||||
| pkglib_IMAGES = boot.img diskboot.img kernel.img | ||||
| pkglib_IMAGES = boot.img diskboot.img | ||||
| pkglib_PROGRAMS = kernel.img | ||||
| 
 | ||||
| # For boot.img. | ||||
| boot_img_SOURCES = boot/sparc64/ieee1275/boot.S | ||||
|  | @ -40,16 +41,12 @@ kernel_img_LDFLAGS += -nostdlib -Wl,-N,-Ttext,0x4400,-Bstatic,-melf64_sparc | |||
| kernel_img_FORMAT = binary | ||||
| 
 | ||||
| # Utilities. | ||||
| bin_UTILITIES = grub-mkimage | ||||
| sbin_UTILITIES = grub-setup grub-ofpathname | ||||
| 
 | ||||
| # For grub-mkimage. | ||||
| grub_mkimage_SOURCES = util/grub-mkrawimage.c util/misc.c \ | ||||
|         util/resolve.c gnulib/progname.c | ||||
| 
 | ||||
| # For grub-setup. | ||||
| util/sparc64/ieee1275/grub-setup.c_DEPENDENCIES = grub_setup_init.h | ||||
| grub_setup_SOURCES = util/sparc64/ieee1275/grub-setup.c util/hostdisk.c	\ | ||||
| 	util/ieee1275/ofpath.c \ | ||||
| 	util/misc.c util/getroot.c kern/device.c kern/disk.c	\ | ||||
| 	kern/err.c kern/misc.c kern/parser.c kern/partition.c	\ | ||||
| 	kern/file.c kern/fs.c kern/env.c kern/list.c		\ | ||||
|  | @ -57,9 +54,9 @@ grub_setup_SOURCES = util/sparc64/ieee1275/grub-setup.c util/hostdisk.c	\ | |||
| 	\ | ||||
| 	fs/affs.c fs/cpio.c fs/ext2.c fs/fat.c fs/hfs.c		\ | ||||
| 	fs/hfsplus.c fs/iso9660.c fs/udf.c fs/jfs.c fs/minix.c	\ | ||||
| 	fs/ntfs.c fs/ntfscomp.c fs/reiserfs.c fs/sfs.c		\ | ||||
| 	fs/ufs.c fs/ufs2.c fs/xfs.c fs/afs.c fs/afs_be.c	\ | ||||
| 	fs/befs.c fs/befs_be.c fs/tar.c			\ | ||||
| 	fs/nilfs2.c fs/ntfs.c fs/ntfscomp.c fs/reiserfs.c	\ | ||||
| 	fs/sfs.c fs/ufs.c fs/ufs2.c fs/xfs.c fs/afs.c		\ | ||||
| 	fs/afs_be.c fs/befs.c fs/befs_be.c fs/tar.c		\ | ||||
| 	\ | ||||
| 	partmap/amiga.c	partmap/apple.c partmap/msdos.c 	\ | ||||
| 	partmap/bsdlabel.c partmap/sun.c partmap/acorn.c	\ | ||||
|  | @ -69,7 +66,7 @@ grub_setup_SOURCES = util/sparc64/ieee1275/grub-setup.c util/hostdisk.c	\ | |||
| 	grub_setup_init.c | ||||
| 
 | ||||
| # For grub-ofpathname. | ||||
| grub_ofpathname_SOURCES = util/sparc64/ieee1275/grub-ofpathname.c \ | ||||
| grub_ofpathname_SOURCES = util/ieee1275/grub-ofpathname.c \ | ||||
| 	util/ieee1275/ofpath.c util/misc.c gnulib/progname.c | ||||
| 
 | ||||
| # Scripts. | ||||
|  |  | |||
|  | @ -65,6 +65,9 @@ grub_script_blanklines_SOURCES = tests/grub_script_blanklines.in | |||
| check_SCRIPTS += grub_script_final_semicolon | ||||
| grub_script_final_semicolon_SOURCES = tests/grub_script_final_semicolon.in | ||||
| 
 | ||||
| check_SCRIPTS += grub_script_dollar | ||||
| grub_script_dollar_SOURCES = tests/grub_script_dollar.in | ||||
| 
 | ||||
| # List of tests to execute on "make check" | ||||
| # SCRIPTED_TESTS    = example_scripted_test | ||||
| # SCRIPTED_TESTS   += example_grub_script_test | ||||
|  | @ -79,7 +82,7 @@ SCRIPTED_TESTS += grub_script_while1 | |||
| SCRIPTED_TESTS += grub_script_if | ||||
| SCRIPTED_TESTS += grub_script_blanklines | ||||
| SCRIPTED_TESTS += grub_script_final_semicolon | ||||
| 
 | ||||
| SCRIPTED_TESTS += grub_script_dollar | ||||
| 
 | ||||
| # dependencies between tests and testing-tools | ||||
| $(SCRIPTED_TESTS): grub-shell grub-shell-tester | ||||
|  |  | |||
|  | @ -1,13 +1,5 @@ | |||
| # -*- makefile -*- | ||||
| 
 | ||||
| # Utilities. | ||||
| bin_UTILITIES = grub-mkimage | ||||
| 
 | ||||
| # For grub-mkimage. | ||||
| grub_mkimage_SOURCES = gnulib/progname.c util/i386/efi/grub-mkimage.c \ | ||||
| 	util/misc.c util/resolve.c | ||||
| util/i386/efi/grub-mkimage.c_DEPENDENCIES = Makefile | ||||
| 
 | ||||
| # Scripts. | ||||
| sbin_SCRIPTS = grub-install | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										17
									
								
								configure.ac
									
										
									
									
									
								
							
							
						
						
									
										17
									
								
								configure.ac
									
										
									
									
									
								
							|  | @ -148,6 +148,7 @@ case "$target_cpu" in | |||
|   mips)      	machine_CFLAGS="$machine_CFLAGS -DGRUB_MACHINE_MIPS=1" ;; | ||||
|   sparc64)      machine_CFLAGS="$machine_CFLAGS -DGRUB_MACHINE_SPARC64=1" ;; | ||||
| esac | ||||
| machine_CFLAGS="$machine_CFLAGS -DMACHINE=`echo ${target_cpu}_$platform | sed y,abcdefghijklmnopqrstuvwxyz,ABCDEFGHIJKLMNOPQRSTUVWXYZ,`" | ||||
| 
 | ||||
| CFLAGS="$CFLAGS $machine_CFLAGS" | ||||
| TARGET_ASFLAGS="$TARGET_ASFLAGS $machine_CFLAGS" | ||||
|  | @ -360,7 +361,7 @@ else | |||
| if test -f "${srcdir}/conf/${target_cpu}-${platform}-${host_os}-img-ld.sc"; then | ||||
|   TARGET_IMG_LDSCRIPT='$(top_srcdir)'"/conf/${target_cpu}-${platform}-${host_os}-img-ld.sc" | ||||
|   TARGET_IMG_LDFLAGS="-Wl,-T${TARGET_IMG_LDSCRIPT}  -Wl,-Ttext," | ||||
|   TARGET_IMG_LDFLAGS_AC="-Wl,-T${srcdir}/conf/${target_cpu}-${platform}-${host_os}-img-ld.sc" | ||||
|   TARGET_IMG_LDFLAGS_AC="-Wl,-T${srcdir}/conf/${target_cpu}-${platform}-${host_os}-img-ld.sc  -Wl,-Ttext," | ||||
| else | ||||
|   TARGET_IMG_LDSCRIPT= | ||||
|   TARGET_IMG_LDFLAGS='-Wl,-N  -Wl,-Ttext,' | ||||
|  | @ -413,9 +414,7 @@ if test "$target_cpu"-"$platform" = x86_64-efi; then | |||
| 		      [grub_cv_cc_mcmodel=no]) | ||||
|   ]) | ||||
|   if test "x$grub_cv_cc_mcmodel" = xno; then | ||||
|     CFLAGS="$SAVED_CFLAGS -m64 -DMCMODEL_SMALL=1" | ||||
|     TARGET_CFLAGS="$TARGET_CFLAGS -DMCMODEL_SMALL=1" | ||||
|     AC_MSG_WARN([-mcmodel=large not supported. You won't be able to use the memory over 4GiB. Upgrade your gcc]) | ||||
|     AC_MSG_ERROR([-mcmodel=large not supported. Upgrade your gcc.]) | ||||
|   else | ||||
|     TARGET_CFLAGS="$TARGET_CFLAGS -mcmodel=large" | ||||
|   fi | ||||
|  | @ -513,11 +512,11 @@ grub_PROG_OBJCOPY_ABSOLUTE | |||
| fi | ||||
| grub_PROG_LD_BUILD_ID_NONE | ||||
| if test "x$target_cpu" = xi386; then | ||||
|   if test "$platform" != emu && test "x$TARGET_APPLE_CC" != x1 ; then | ||||
|     if test ! -z "$TARGET_IMG_LDSCRIPT"; then | ||||
|       # Check symbols provided by linker script. | ||||
|     CFLAGS="$TARGET_CFLAGS -nostdlib $TARGET_IMG_LDFLAGS_AC -Wl,-Ttext,8000,--defsym,___main=0x8100" | ||||
|       CFLAGS="$TARGET_CFLAGS -nostdlib ${TARGET_IMG_LDFLAGS_AC}8000 -Wl,--defsym,___main=0x8100" | ||||
|     fi | ||||
|   if test "x$TARGET_APPLE_CC" != x1 ; then | ||||
|     grub_CHECK_BSS_START_SYMBOL | ||||
|     grub_CHECK_END_SYMBOL | ||||
|   fi | ||||
|  | @ -637,6 +636,12 @@ else | |||
| fi | ||||
| AC_SUBST(TARGET_NO_MODULES) | ||||
| 
 | ||||
| if test "$TARGET_NO_MODULES" = yes ; then | ||||
|   # Do not convert modules, otherwise linkage may fail (Cygwin only). | ||||
|   # FIXME: Should be checked above before TARGET_OBJ2ELF is set first. | ||||
|   TARGET_OBJ2ELF= | ||||
| fi | ||||
| 
 | ||||
| if test x"$enable_grub_emu_usb" = xno ; then | ||||
|   grub_emu_usb_excuse="explicitly disabled" | ||||
| fi | ||||
|  |  | |||
|  | @ -24,6 +24,10 @@ | |||
| #include <grub/misc.h> | ||||
| #include <grub/lvm.h> | ||||
| 
 | ||||
| #ifdef GRUB_UTIL | ||||
| #include <grub/util/misc.h> | ||||
| #endif | ||||
| 
 | ||||
| static struct grub_lvm_vg *vg_list; | ||||
| static int lv_count; | ||||
| 
 | ||||
|  | @ -68,6 +72,9 @@ grub_lvm_memberlist (grub_disk_t disk) | |||
|   if (lv->vg->pvs) | ||||
|     for (pv = lv->vg->pvs; pv; pv = pv->next) | ||||
|       { | ||||
| 	if (!pv->disk) | ||||
| 	  grub_util_error ("Couldn't find PV %s. Check your device.map", | ||||
| 			   pv->name); | ||||
| 	tmp = grub_malloc (sizeof (*tmp)); | ||||
| 	tmp->disk = pv->disk; | ||||
| 	tmp->next = list; | ||||
|  |  | |||
							
								
								
									
										1133
									
								
								fs/nilfs2.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1133
									
								
								fs/nilfs2.c
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										31
									
								
								fs/udf.c
									
										
									
									
									
								
							
							
						
						
									
										31
									
								
								fs/udf.c
									
										
									
									
									
								
							|  | @ -25,6 +25,7 @@ | |||
| #include <grub/dl.h> | ||||
| #include <grub/types.h> | ||||
| #include <grub/fshelp.h> | ||||
| #include <grub/charset.h> | ||||
| 
 | ||||
| #define GRUB_UDF_MAX_PDS		2 | ||||
| #define GRUB_UDF_MAX_PMS		6 | ||||
|  | @ -745,20 +746,42 @@ grub_udf_iterate_dir (grub_fshelp_node_t dir, | |||
|       else | ||||
| 	{ | ||||
| 	  enum grub_fshelp_filetype type; | ||||
| 	  char filename[dirent.file_ident_length + 1]; | ||||
| 	  grub_uint8_t raw[dirent.file_ident_length]; | ||||
| 	  grub_uint16_t utf16[dirent.file_ident_length - 1]; | ||||
| 	  grub_uint8_t filename[dirent.file_ident_length * 2]; | ||||
| 	  grub_size_t utf16len = 0; | ||||
| 
 | ||||
| 	  type = ((dirent.characteristics & GRUB_UDF_FID_CHAR_DIRECTORY) ? | ||||
| 		  (GRUB_FSHELP_DIR) : (GRUB_FSHELP_REG)); | ||||
| 
 | ||||
| 	  if ((grub_udf_read_file (dir, 0, offset, | ||||
| 				   dirent.file_ident_length, filename)) | ||||
| 				   dirent.file_ident_length, | ||||
| 				   (char *) raw)) | ||||
| 	      != dirent.file_ident_length) | ||||
| 	    return 0; | ||||
| 
 | ||||
| 	  filename[dirent.file_ident_length] = 0; | ||||
| 	  if (hook (&filename[1], type, child)) | ||||
| 	  if (raw[0] == 8) | ||||
| 	    { | ||||
| 	      unsigned i; | ||||
| 	      utf16len = dirent.file_ident_length - 1; | ||||
| 	      for (i = 0; i < utf16len; i++) | ||||
| 		utf16[i] = raw[i + 1]; | ||||
| 	    } | ||||
| 	  if (raw[0] == 16) | ||||
| 	    { | ||||
| 	      unsigned i; | ||||
| 	      utf16len = (dirent.file_ident_length - 1) / 2; | ||||
| 	      for (i = 0; i < utf16len; i++) | ||||
| 		utf16[i] = (raw[2 * i + 1] << 8) | raw[2*i + 2]; | ||||
| 	    } | ||||
| 	  if (raw[0] == 8 || raw[0] == 16) | ||||
| 	    { | ||||
| 	      *grub_utf16_to_utf8 (filename, utf16, utf16len) = '\0'; | ||||
| 	   | ||||
| 	      if (hook ((char *) filename, type, child)) | ||||
| 		return 1; | ||||
| 	    } | ||||
| 	} | ||||
| 
 | ||||
|       /* Align to dword boundary.  */ | ||||
|       offset = (offset + dirent.file_ident_length + 3) & (~3); | ||||
|  |  | |||
|  | @ -99,12 +99,8 @@ struct grub_pe32_optional_header | |||
|   grub_uint32_t entry_addr; | ||||
|   grub_uint32_t code_base; | ||||
| 
 | ||||
| #if GRUB_TARGET_SIZEOF_VOID_P == 4 | ||||
|   grub_uint32_t data_base; | ||||
|   grub_uint32_t image_base; | ||||
| #else | ||||
|   grub_uint64_t image_base; | ||||
| #endif | ||||
| 
 | ||||
|   grub_uint32_t section_alignment; | ||||
|   grub_uint32_t file_alignment; | ||||
|  | @ -121,22 +117,11 @@ struct grub_pe32_optional_header | |||
|   grub_uint16_t subsystem; | ||||
|   grub_uint16_t dll_characteristics; | ||||
| 
 | ||||
| #if GRUB_TARGET_SIZEOF_VOID_P == 4 | ||||
| 
 | ||||
|   grub_uint32_t stack_reserve_size; | ||||
|   grub_uint32_t stack_commit_size; | ||||
|   grub_uint32_t heap_reserve_size; | ||||
|   grub_uint32_t heap_commit_size; | ||||
| 
 | ||||
| #else | ||||
| 
 | ||||
|   grub_uint64_t stack_reserve_size; | ||||
|   grub_uint64_t stack_commit_size; | ||||
|   grub_uint64_t heap_reserve_size; | ||||
|   grub_uint64_t heap_commit_size; | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
|   grub_uint32_t loader_flags; | ||||
|   grub_uint32_t num_data_directories; | ||||
| 
 | ||||
|  | @ -159,15 +144,63 @@ struct grub_pe32_optional_header | |||
|   struct grub_pe32_data_directory reserved_entry; | ||||
| }; | ||||
| 
 | ||||
| #if GRUB_TARGET_SIZEOF_VOID_P == 4 | ||||
| struct grub_pe64_optional_header | ||||
| { | ||||
|   grub_uint16_t magic; | ||||
|   grub_uint8_t major_linker_version; | ||||
|   grub_uint8_t minor_linker_version; | ||||
|   grub_uint32_t code_size; | ||||
|   grub_uint32_t data_size; | ||||
|   grub_uint32_t bss_size; | ||||
|   grub_uint32_t entry_addr; | ||||
|   grub_uint32_t code_base; | ||||
| 
 | ||||
|   grub_uint64_t image_base; | ||||
| 
 | ||||
|   grub_uint32_t section_alignment; | ||||
|   grub_uint32_t file_alignment; | ||||
|   grub_uint16_t major_os_version; | ||||
|   grub_uint16_t minor_os_version; | ||||
|   grub_uint16_t major_image_version; | ||||
|   grub_uint16_t minor_image_version; | ||||
|   grub_uint16_t major_subsystem_version; | ||||
|   grub_uint16_t minor_subsystem_version; | ||||
|   grub_uint32_t reserved; | ||||
|   grub_uint32_t image_size; | ||||
|   grub_uint32_t header_size; | ||||
|   grub_uint32_t checksum; | ||||
|   grub_uint16_t subsystem; | ||||
|   grub_uint16_t dll_characteristics; | ||||
| 
 | ||||
|   grub_uint64_t stack_reserve_size; | ||||
|   grub_uint64_t stack_commit_size; | ||||
|   grub_uint64_t heap_reserve_size; | ||||
|   grub_uint64_t heap_commit_size; | ||||
| 
 | ||||
|   grub_uint32_t loader_flags; | ||||
|   grub_uint32_t num_data_directories; | ||||
| 
 | ||||
|   /* Data directories.  */ | ||||
|   struct grub_pe32_data_directory export_table; | ||||
|   struct grub_pe32_data_directory import_table; | ||||
|   struct grub_pe32_data_directory resource_table; | ||||
|   struct grub_pe32_data_directory exception_table; | ||||
|   struct grub_pe32_data_directory certificate_table; | ||||
|   struct grub_pe32_data_directory base_relocation_table; | ||||
|   struct grub_pe32_data_directory debug; | ||||
|   struct grub_pe32_data_directory architecture; | ||||
|   struct grub_pe32_data_directory global_ptr; | ||||
|   struct grub_pe32_data_directory tls_table; | ||||
|   struct grub_pe32_data_directory load_config_table; | ||||
|   struct grub_pe32_data_directory bound_import; | ||||
|   struct grub_pe32_data_directory iat; | ||||
|   struct grub_pe32_data_directory delay_import_descriptor; | ||||
|   struct grub_pe32_data_directory com_runtime_header; | ||||
|   struct grub_pe32_data_directory reserved_entry; | ||||
| }; | ||||
| 
 | ||||
| #define GRUB_PE32_PE32_MAGIC	0x10b | ||||
| 
 | ||||
| #else | ||||
| 
 | ||||
| #define GRUB_PE32_PE32_MAGIC	0x20b | ||||
| 
 | ||||
| #endif | ||||
| #define GRUB_PE32_PE64_MAGIC	0x20b | ||||
| 
 | ||||
| #define GRUB_PE32_SUBSYSTEM_EFI_APPLICATION	10 | ||||
| 
 | ||||
|  | @ -205,6 +238,7 @@ struct grub_pe32_section_table | |||
| #define GRUB_PE32_SCN_ALIGN_SHIFT		20 | ||||
| #define GRUB_PE32_SCN_ALIGN_MASK		7 | ||||
| 
 | ||||
| #define GRUB_PE32_SIGNATURE_SIZE 4 | ||||
| 
 | ||||
| struct grub_pe32_header | ||||
| { | ||||
|  | @ -212,13 +246,18 @@ struct grub_pe32_header | |||
|   grub_uint8_t msdos_stub[GRUB_PE32_MSDOS_STUB_SIZE]; | ||||
| 
 | ||||
|   /* This is always PE\0\0.  */ | ||||
|   char signature[4]; | ||||
|   char signature[GRUB_PE32_SIGNATURE_SIZE]; | ||||
| 
 | ||||
|   /* The COFF file header.  */ | ||||
|   struct grub_pe32_coff_header coff_header; | ||||
| 
 | ||||
| #if GRUB_TARGET_SIZEOF_VOID_P == 8 | ||||
|   /* The Optional header.  */ | ||||
|   struct grub_pe64_optional_header optional_header; | ||||
| #else | ||||
|   /* The Optional header.  */ | ||||
|   struct grub_pe32_optional_header optional_header; | ||||
| #endif | ||||
| }; | ||||
| 
 | ||||
| struct grub_pe32_fixup_block | ||||
|  |  | |||
|  | @ -555,6 +555,7 @@ typedef struct | |||
| #define	PT_NUM		8		/* Number of defined types */ | ||||
| #define PT_LOOS		0x60000000	/* Start of OS-specific */ | ||||
| #define PT_GNU_EH_FRAME	0x6474e550	/* GCC .eh_frame_hdr segment */ | ||||
| #define PT_GNU_STACK	0x6474e551      /* GCC stack segment  */ | ||||
| #define PT_LOSUNW	0x6ffffffa | ||||
| #define PT_SUNWBSS	0x6ffffffa	/* Sun Specific segment */ | ||||
| #define PT_SUNWSTACK	0x6ffffffb	/* Stack segment */ | ||||
|  |  | |||
|  | @ -1,33 +0,0 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2002,2003,2007  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #ifndef GRUB_MACHINE_KERNEL_HEADER | ||||
| #define GRUB_MACHINE_KERNEL_HEADER   1 | ||||
| 
 | ||||
| /* The prefix which points to the directory where GRUB modules and its
 | ||||
|    configuration file are located.  */ | ||||
| extern char grub_prefix[]; | ||||
| 
 | ||||
| /* The offset of GRUB_PREFIX.  */ | ||||
| #define GRUB_KERNEL_MACHINE_PREFIX		0x8 | ||||
| 
 | ||||
| /* End of the data section. */ | ||||
| #define GRUB_KERNEL_MACHINE_DATA_END		0x50 | ||||
| 
 | ||||
| #endif /* ! GRUB_MACHINE_KERNEL_HEADER */ | ||||
| 
 | ||||
|  | @ -1 +0,0 @@ | |||
| #include <grub/powerpc/ieee1275/kernel.h> | ||||
|  | @ -1,35 +0,0 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2005,2006,2007,2008,2009  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #ifndef GRUB_KERNEL_CPU_HEADER | ||||
| #define GRUB_KERNEL_CPU_HEADER	1 | ||||
| 
 | ||||
| 
 | ||||
| #ifdef GRUB_MACHINE_IEEE1275 | ||||
| #define GRUB_MOD_ALIGN	0x1000 | ||||
| #else | ||||
| #define GRUB_MOD_ALIGN	0x1 | ||||
| #endif | ||||
| 
 | ||||
| /* Non-zero value is only needed for PowerMacs.  */ | ||||
| #define GRUB_MOD_GAP 0x0 | ||||
| 
 | ||||
| #define GRUB_KERNEL_CPU_PREFIX	0x2 | ||||
| #define GRUB_KERNEL_CPU_DATA_END	0x42 | ||||
| 
 | ||||
| #endif | ||||
|  | @ -19,6 +19,8 @@ | |||
| #ifndef GRUB_BOOT_MACHINE_HEADER | ||||
| #define GRUB_BOOT_MACHINE_HEADER	1 | ||||
| 
 | ||||
| #include <grub/offsets.h> | ||||
| 
 | ||||
| /* The signature for bootloader.  */ | ||||
| #define GRUB_BOOT_MACHINE_SIGNATURE	0xaa55 | ||||
| 
 | ||||
|  | @ -57,9 +59,6 @@ | |||
|    floppy.  */ | ||||
| #define GRUB_BOOT_MACHINE_BIOS_HD_FLAG	0x80 | ||||
| 
 | ||||
| /* The segment where the kernel is loaded.  */ | ||||
| #define GRUB_BOOT_MACHINE_KERNEL_SEG	0x800 | ||||
| 
 | ||||
| /* The address where the kernel is loaded.  */ | ||||
| #define GRUB_BOOT_MACHINE_KERNEL_ADDR	(GRUB_BOOT_MACHINE_KERNEL_SEG << 4) | ||||
| 
 | ||||
|  | @ -68,16 +67,7 @@ | |||
| 
 | ||||
| #define GRUB_BOOT_MACHINE_PXE_DL	0x7f | ||||
| 
 | ||||
| #ifndef ASM_FILE | ||||
| 
 | ||||
| /* This is the blocklist used in the diskboot image.  */ | ||||
| struct grub_boot_blocklist | ||||
| { | ||||
|   grub_uint64_t start; | ||||
|   grub_uint16_t len; | ||||
|   grub_uint16_t segment; | ||||
| } __attribute__ ((packed)); | ||||
| 
 | ||||
| #endif /* ! ASM_FILE */ | ||||
| #define grub_boot_blocklist grub_pc_bios_boot_blocklist | ||||
| 
 | ||||
| #endif /* ! BOOT_MACHINE_HEADER */ | ||||
|  |  | |||
|  | @ -19,29 +19,7 @@ | |||
| #ifndef KERNEL_MACHINE_HEADER | ||||
| #define KERNEL_MACHINE_HEADER	1 | ||||
| 
 | ||||
| /* The offset of GRUB_TOTAL_MODULE_SIZE.  */ | ||||
| #define GRUB_KERNEL_MACHINE_TOTAL_MODULE_SIZE	0x8 | ||||
| 
 | ||||
| /* The offset of GRUB_KERNEL_IMAGE_SIZE.  */ | ||||
| #define GRUB_KERNEL_MACHINE_KERNEL_IMAGE_SIZE	0xc | ||||
| 
 | ||||
| /* The offset of GRUB_COMPRESSED_SIZE.  */ | ||||
| #define GRUB_KERNEL_MACHINE_COMPRESSED_SIZE	0x10 | ||||
| 
 | ||||
| /* The offset of GRUB_INSTALL_DOS_PART.  */ | ||||
| #define GRUB_KERNEL_MACHINE_INSTALL_DOS_PART	0x14 | ||||
| 
 | ||||
| /* The offset of GRUB_INSTALL_BSD_PART.  */ | ||||
| #define GRUB_KERNEL_MACHINE_INSTALL_BSD_PART	0x18 | ||||
| 
 | ||||
| /* The offset of GRUB_PREFIX.  */ | ||||
| #define GRUB_KERNEL_MACHINE_PREFIX		0x1c | ||||
| 
 | ||||
| /* End of the data section. */ | ||||
| #define GRUB_KERNEL_MACHINE_DATA_END		0x5c | ||||
| 
 | ||||
| /* The size of the first region which won't be compressed.  */ | ||||
| #define GRUB_KERNEL_MACHINE_RAW_SIZE		(GRUB_KERNEL_MACHINE_DATA_END + 0x5F0) | ||||
| #include <grub/offsets.h> | ||||
| 
 | ||||
| /* Enable LZMA compression */ | ||||
| #define ENABLE_LZMA	1 | ||||
|  | @ -63,10 +41,6 @@ extern grub_int32_t grub_install_dos_part; | |||
| /* The BSD partition number of the installed partition.  */ | ||||
| extern grub_int32_t grub_install_bsd_part; | ||||
| 
 | ||||
| /* The prefix which points to the directory where GRUB modules and its
 | ||||
|    configuration file are located.  */ | ||||
| extern char grub_prefix[]; | ||||
| 
 | ||||
| /* The boot BIOS drive number.  */ | ||||
| extern grub_uint8_t EXPORT_VAR(grub_boot_drive); | ||||
| 
 | ||||
|  |  | |||
|  | @ -29,6 +29,8 @@ | |||
| 
 | ||||
| #include <grub/i386/memory.h> | ||||
| 
 | ||||
| #include <grub/offsets.h> | ||||
| 
 | ||||
| /* The scratch buffer used in real mode code.  */ | ||||
| #define GRUB_MEMORY_MACHINE_SCRATCH_ADDR	0x68000 | ||||
| #define GRUB_MEMORY_MACHINE_SCRATCH_SEG	(GRUB_MEMORY_MACHINE_SCRATCH_ADDR >> 4) | ||||
|  | @ -40,9 +42,6 @@ | |||
| /* The size of the protect mode stack.  */ | ||||
| #define GRUB_MEMORY_MACHINE_PROT_STACK_SIZE	0x8000 | ||||
| 
 | ||||
| /* The upper memory area (starting at 640 kiB).  */ | ||||
| #define GRUB_MEMORY_MACHINE_UPPER		0xa0000 | ||||
| 
 | ||||
| /* The protected mode stack.  */ | ||||
| #define GRUB_MEMORY_MACHINE_PROT_STACK	\ | ||||
| 	(GRUB_MEMORY_MACHINE_SCRATCH_ADDR + GRUB_MEMORY_MACHINE_SCRATCH_SIZE \ | ||||
|  |  | |||
|  | @ -22,7 +22,4 @@ | |||
| /* The size of boot.img.  */ | ||||
| #define GRUB_BOOT_MACHINE_SIZE			(0x100000 - GRUB_BOOT_MACHINE_LINK_ADDR) | ||||
| 
 | ||||
| /* The offset of GRUB_CORE_ENTRY_ADDR.  */ | ||||
| #define GRUB_BOOT_MACHINE_CORE_ENTRY_ADDR	0x4 | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -19,17 +19,7 @@ | |||
| #ifndef GRUB_KERNEL_MACHINE_HEADER | ||||
| #define GRUB_KERNEL_MACHINE_HEADER	1 | ||||
| 
 | ||||
| /* The offset of GRUB_CORE_ENTRY_ADDR.  */ | ||||
| #define GRUB_KERNEL_MACHINE_CORE_ENTRY_ADDR	0x8 | ||||
| 
 | ||||
| /* The offset of GRUB_KERNEL_IMAGE_SIZE.  */ | ||||
| #define GRUB_KERNEL_MACHINE_KERNEL_IMAGE_SIZE	0xc | ||||
| 
 | ||||
| /* The offset of GRUB_PREFIX.  */ | ||||
| #define GRUB_KERNEL_MACHINE_PREFIX		0x10 | ||||
| 
 | ||||
| /* End of the data section. */ | ||||
| #define GRUB_KERNEL_MACHINE_DATA_END		0x50 | ||||
| #include <grub/offsets.h> | ||||
| 
 | ||||
| #ifndef ASM_FILE | ||||
| 
 | ||||
|  | @ -44,10 +34,6 @@ extern grub_int32_t grub_kernel_image_size; | |||
| /* The total size of module images following the kernel.  */ | ||||
| extern grub_int32_t grub_total_module_size; | ||||
| 
 | ||||
| /* The prefix which points to the directory where GRUB modules and its
 | ||||
|    configuration file are located.  */ | ||||
| extern char grub_prefix[]; | ||||
| 
 | ||||
| #endif /* ! ASM_FILE */ | ||||
| 
 | ||||
| #endif /* ! GRUB_KERNEL_MACHINE_HEADER */ | ||||
|  |  | |||
|  | @ -42,19 +42,33 @@ struct grub_module_header | |||
| /* "gmim" (GRUB Module Info Magic).  */ | ||||
| #define GRUB_MODULE_MAGIC 0x676d696d | ||||
| 
 | ||||
| struct grub_module_info | ||||
| struct grub_module_info32 | ||||
| { | ||||
|   /* Magic number so we know we have modules present.  */ | ||||
|   grub_uint32_t magic; | ||||
| #if GRUB_TARGET_SIZEOF_VOID_P == 8 | ||||
|   grub_uint32_t padding; | ||||
| #endif | ||||
|   /* The offset of the modules.  */ | ||||
|   grub_target_off_t offset; | ||||
|   grub_uint32_t offset; | ||||
|   /* The size of all modules plus this header.  */ | ||||
|   grub_target_size_t size; | ||||
|   grub_uint32_t size; | ||||
| }; | ||||
| 
 | ||||
| struct grub_module_info64 | ||||
| { | ||||
|   /* Magic number so we know we have modules present.  */ | ||||
|   grub_uint32_t magic; | ||||
|   grub_uint32_t padding; | ||||
|   /* The offset of the modules.  */ | ||||
|   grub_uint64_t offset; | ||||
|   /* The size of all modules plus this header.  */ | ||||
|   grub_uint64_t size; | ||||
| }; | ||||
| 
 | ||||
| #if GRUB_TARGET_SIZEOF_VOID_P == 8 | ||||
| #define grub_module_info grub_module_info64 | ||||
| #else | ||||
| #define grub_module_info grub_module_info32 | ||||
| #endif | ||||
| 
 | ||||
| extern grub_addr_t grub_arch_modules_addr (void); | ||||
| 
 | ||||
| extern void EXPORT_FUNC(grub_module_iterate) (int (*hook) (struct grub_module_header *)); | ||||
|  | @ -76,4 +90,8 @@ void grub_machine_set_prefix (void); | |||
| /* Register all the exported symbols. This is automatically generated.  */ | ||||
| void grub_register_exported_symbols (void); | ||||
| 
 | ||||
| #if ! defined (ASM_FILE) && !defined (GRUB_MACHINE_EMU) | ||||
| extern char grub_prefix[]; | ||||
| #endif | ||||
| 
 | ||||
| #endif /* ! GRUB_KERNEL_HEADER */ | ||||
|  |  | |||
|  | @ -1,6 +1,6 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2005,2006,2007,2008  Free Software Foundation, Inc. | ||||
|  *  Copyright (C) 2010  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  | @ -16,13 +16,11 @@ | |||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #ifndef GRUB_KERNEL_MACHINE_HEADER | ||||
| #define GRUB_KERNEL_MACHINE_HEADER	1 | ||||
| 
 | ||||
| #include <grub/symbol.h> | ||||
| 
 | ||||
| #ifndef ASM_FILE | ||||
| extern char grub_prefix[]; | ||||
| #endif | ||||
| 
 | ||||
| #endif /* ! GRUB_KERNEL_MACHINE_HEADER */ | ||||
| void EXPORT_FUNC (pci_slot_match_iterator_create) (void); | ||||
| void EXPORT_FUNC (pci_system_cleanup) (void); | ||||
| void EXPORT_FUNC (pci_device_unmap_range) (void); | ||||
| void EXPORT_FUNC (pci_iterator_destroy) (void); | ||||
| void EXPORT_FUNC (pci_device_map_range) (void); | ||||
| void EXPORT_FUNC (pci_device_cfg_read_u32) (void); | ||||
| void EXPORT_FUNC (pci_device_next) (void); | ||||
| void EXPORT_FUNC (pci_system_init) (void); | ||||
|  | @ -1,65 +0,0 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2005,2006,2007,2008  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #ifndef GRUB_KERNEL_CPU_HEADER | ||||
| #define GRUB_KERNEL_CPU_HEADER	1 | ||||
| 
 | ||||
| #define GRUB_MOD_ALIGN 0x1 | ||||
| /* Non-zero value is only needed for PowerMacs.  */ | ||||
| #define GRUB_MOD_GAP   0x0 | ||||
| 
 | ||||
| #define GRUB_KERNEL_MACHINE_LINK_ALIGN  32 | ||||
| 
 | ||||
| #define GRUB_KERNEL_CPU_RAW_SIZE        0x200 | ||||
| #define GRUB_KERNEL_CPU_COMPRESSED_SIZE        0x8 | ||||
| #define GRUB_KERNEL_CPU_TOTAL_MODULE_SIZE      0xc | ||||
| #define GRUB_KERNEL_CPU_KERNEL_IMAGE_SIZE      0x10 | ||||
| 
 | ||||
| #define GRUB_KERNEL_CPU_PREFIX	        GRUB_KERNEL_CPU_RAW_SIZE | ||||
| #define GRUB_KERNEL_CPU_DATA_END	GRUB_KERNEL_CPU_RAW_SIZE + 0x48 | ||||
| 
 | ||||
| #define GRUB_KERNEL_MACHINE_RAW_SIZE GRUB_KERNEL_CPU_RAW_SIZE | ||||
| 
 | ||||
| #define GRUB_KERNEL_MACHINE_PREFIX	GRUB_KERNEL_CPU_PREFIX | ||||
| #define GRUB_KERNEL_MACHINE_DATA_END	GRUB_KERNEL_CPU_DATA_END | ||||
| #define GRUB_KERNEL_MACHINE_KERNEL_IMAGE_SIZE GRUB_KERNEL_CPU_KERNEL_IMAGE_SIZE | ||||
| #define GRUB_KERNEL_MACHINE_TOTAL_MODULE_SIZE GRUB_KERNEL_CPU_TOTAL_MODULE_SIZE | ||||
| #define GRUB_KERNEL_MACHINE_COMPRESSED_SIZE GRUB_KERNEL_CPU_COMPRESSED_SIZE | ||||
| 
 | ||||
| #define GRUB_PLATFORM_IMAGE_FORMATS     "raw, elf" | ||||
| #define GRUB_PLATFORM_IMAGE_DEFAULT_FORMAT     "raw" | ||||
| 
 | ||||
| #define GRUB_PLATFORM_IMAGE_DEFAULT GRUB_PLATFORM_IMAGE_RAW | ||||
| 
 | ||||
| #ifndef ASM_FILE | ||||
| 
 | ||||
| typedef enum { | ||||
|   GRUB_PLATFORM_IMAGE_RAW, | ||||
|   GRUB_PLATFORM_IMAGE_ELF | ||||
| } | ||||
|   grub_platform_image_format_t; | ||||
| #define GRUB_PLATFORM_IMAGE_RAW GRUB_PLATFORM_IMAGE_RAW | ||||
| #define GRUB_PLATFORM_IMAGE_ELF GRUB_PLATFORM_IMAGE_ELF | ||||
| 
 | ||||
| /* The prefix which points to the directory where GRUB modules and its
 | ||||
|    configuration file are located.  */ | ||||
| extern char grub_prefix[]; | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| #endif | ||||
|  | @ -27,10 +27,6 @@ | |||
| void EXPORT_FUNC (grub_reboot) (void); | ||||
| void EXPORT_FUNC (grub_halt) (void); | ||||
| 
 | ||||
| /* The prefix which points to the directory where GRUB modules and its
 | ||||
|    configuration file are located.  */ | ||||
| extern char grub_prefix[]; | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| #endif /* ! GRUB_KERNEL_MACHINE_HEADER */ | ||||
|  |  | |||
|  | @ -20,7 +20,6 @@ | |||
| #define GRUB_KERNEL_MACHINE_HEADER	1 | ||||
| 
 | ||||
| #include <grub/symbol.h> | ||||
| #include <grub/cpu/kernel.h> | ||||
| 
 | ||||
| #ifndef ASM_FILE | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										173
									
								
								include/grub/offsets.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										173
									
								
								include/grub/offsets.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,173 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2002,2003,2007,2008  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #ifndef OFFSETS_HEADER | ||||
| #define OFFSETS_HEADER	1 | ||||
| 
 | ||||
| /* The offset of GRUB_TOTAL_MODULE_SIZE.  */ | ||||
| #define GRUB_KERNEL_I386_PC_TOTAL_MODULE_SIZE	0x8 | ||||
| 
 | ||||
| /* The offset of GRUB_KERNEL_IMAGE_SIZE.  */ | ||||
| #define GRUB_KERNEL_I386_PC_KERNEL_IMAGE_SIZE	0xc | ||||
| 
 | ||||
| /* The offset of GRUB_COMPRESSED_SIZE.  */ | ||||
| #define GRUB_KERNEL_I386_PC_COMPRESSED_SIZE	0x10 | ||||
| 
 | ||||
| /* The offset of GRUB_INSTALL_DOS_PART.  */ | ||||
| #define GRUB_KERNEL_I386_PC_INSTALL_DOS_PART	0x14 | ||||
| 
 | ||||
| /* The offset of GRUB_INSTALL_BSD_PART.  */ | ||||
| #define GRUB_KERNEL_I386_PC_INSTALL_BSD_PART	0x18 | ||||
| 
 | ||||
| /* The offset of GRUB_PREFIX.  */ | ||||
| #define GRUB_KERNEL_I386_PC_PREFIX		0x1c | ||||
| 
 | ||||
| /* End of the data section. */ | ||||
| #define GRUB_KERNEL_I386_PC_DATA_END		0x5c | ||||
| 
 | ||||
| /* The size of the first region which won't be compressed.  */ | ||||
| #define GRUB_KERNEL_I386_PC_RAW_SIZE		(GRUB_KERNEL_I386_PC_DATA_END + 0x5F0) | ||||
| 
 | ||||
| /* The segment where the kernel is loaded.  */ | ||||
| #define GRUB_BOOT_I386_PC_KERNEL_SEG	0x800 | ||||
| 
 | ||||
| #define GRUB_KERNEL_I386_PC_LINK_ADDR  0x8200 | ||||
| 
 | ||||
| /* The upper memory area (starting at 640 kiB).  */ | ||||
| #define GRUB_MEMORY_I386_PC_UPPER		0xa0000 | ||||
| #define GRUB_MEMORY_I386_QEMU_UPPER		GRUB_MEMORY_I386_PC_UPPER | ||||
| 
 | ||||
| /* The offset of GRUB_CORE_ENTRY_ADDR.  */ | ||||
| #define GRUB_BOOT_I386_QEMU_CORE_ENTRY_ADDR	0x4 | ||||
| 
 | ||||
| /* The offset of GRUB_CORE_ENTRY_ADDR.  */ | ||||
| #define GRUB_KERNEL_I386_QEMU_CORE_ENTRY_ADDR	0x8 | ||||
| 
 | ||||
| /* The offset of GRUB_KERNEL_IMAGE_SIZE.  */ | ||||
| #define GRUB_KERNEL_I386_QEMU_KERNEL_IMAGE_SIZE	0xc | ||||
| 
 | ||||
| /* The offset of GRUB_PREFIX.  */ | ||||
| #define GRUB_KERNEL_I386_QEMU_PREFIX		0x10 | ||||
| 
 | ||||
| /* End of the data section. */ | ||||
| #define GRUB_KERNEL_I386_QEMU_DATA_END		0x50 | ||||
| 
 | ||||
| #define GRUB_KERNEL_I386_QEMU_LINK_ADDR         0x8200 | ||||
| 
 | ||||
| /* The offset of GRUB_TOTAL_MODULE_SIZE.  */ | ||||
| #define GRUB_KERNEL_SPARC64_IEEE1275_TOTAL_MODULE_SIZE	0x8 | ||||
| 
 | ||||
| /* The offset of GRUB_KERNEL_IMAGE_SIZE.  */ | ||||
| #define GRUB_KERNEL_SPARC64_IEEE1275_KERNEL_IMAGE_SIZE	0xc | ||||
| 
 | ||||
| /* The offset of GRUB_COMPRESSED_SIZE.  */ | ||||
| #define GRUB_KERNEL_SPARC64_IEEE1275_COMPRESSED_SIZE	0x10 | ||||
| 
 | ||||
| /* The offset of GRUB_PREFIX.  */ | ||||
| #define GRUB_KERNEL_SPARC64_IEEE1275_PREFIX		0x14 | ||||
| 
 | ||||
| /* End of the data section. */ | ||||
| #define GRUB_KERNEL_SPARC64_IEEE1275_DATA_END		0x114 | ||||
| 
 | ||||
| #define GRUB_BOOT_SPARC64_IEEE1275_LIST_SIZE	12 | ||||
| 
 | ||||
| #define GRUB_BOOT_SPARC64_IEEE1275_IMAGE_ADDRESS	0x4400 | ||||
| #define GRUB_KERNEL_SPARC64_IEEE1275_RAW_SIZE                   0 | ||||
| #define GRUB_KERNEL_SPARC64_IEEE1275_LINK_ADDR 0x4400 | ||||
| 
 | ||||
| #define GRUB_KERNEL_POWERPC_IEEE1275_PREFIX		0x4 | ||||
| #define GRUB_KERNEL_POWERPC_IEEE1275_DATA_END	0x44 | ||||
| #define GRUB_KERNEL_POWERPC_IEEE1275_LINK_ALIGN 4 | ||||
| #define GRUB_KERNEL_POWERPC_IEEE1275_LINK_ADDR 0x200000 | ||||
| 
 | ||||
| #define GRUB_KERNEL_MIPS_YEELOONG_LINK_ADDR         0x80200000 | ||||
| 
 | ||||
| #define GRUB_KERNEL_MIPS_YEELOONG_LINK_ALIGN  32 | ||||
| 
 | ||||
| #define GRUB_KERNEL_MIPS_YEELOONG_RAW_SIZE        0x200 | ||||
| #define GRUB_KERNEL_MIPS_YEELOONG_COMPRESSED_SIZE        0x8 | ||||
| #define GRUB_KERNEL_MIPS_YEELOONG_TOTAL_MODULE_SIZE      0xc | ||||
| #define GRUB_KERNEL_MIPS_YEELOONG_KERNEL_IMAGE_SIZE      0x10 | ||||
| 
 | ||||
| #define GRUB_KERNEL_MIPS_YEELOONG_PREFIX	        GRUB_KERNEL_MIPS_YEELOONG_RAW_SIZE | ||||
| #define GRUB_KERNEL_MIPS_YEELOONG_DATA_END	GRUB_KERNEL_MIPS_YEELOONG_RAW_SIZE + 0x48 | ||||
| 
 | ||||
| /* The offset of GRUB_PREFIX.  */ | ||||
| #define GRUB_KERNEL_I386_EFI_PREFIX		0x8 | ||||
| 
 | ||||
| /* End of the data section. */ | ||||
| #define GRUB_KERNEL_I386_EFI_DATA_END		0x50 | ||||
| 
 | ||||
| /* The offset of GRUB_PREFIX.  */ | ||||
| #define GRUB_KERNEL_X86_64_EFI_PREFIX		0x8 | ||||
| 
 | ||||
| /* End of the data section. */ | ||||
| #define GRUB_KERNEL_X86_64_EFI_DATA_END		0x50 | ||||
| 
 | ||||
| #define GRUB_KERNEL_I386_COREBOOT_PREFIX	0x2 | ||||
| #define GRUB_KERNEL_I386_COREBOOT_DATA_END	0x42 | ||||
| #define GRUB_KERNEL_I386_COREBOOT_LINK_ADDR	0x8200 | ||||
| 
 | ||||
| #define GRUB_KERNEL_I386_IEEE1275_PREFIX	0x2 | ||||
| #define GRUB_KERNEL_I386_IEEE1275_DATA_END	0x42 | ||||
| #define GRUB_KERNEL_I386_IEEE1275_LINK_ADDR	0x10000 | ||||
| 
 | ||||
| #define GRUB_KERNEL_I386_IEEE1275_MOD_ALIGN	0x1000 | ||||
| #define GRUB_KERNEL_I386_COREBOOT_MOD_ALIGN	0x1 | ||||
| 
 | ||||
| /* Non-zero value is only needed for PowerMacs.  */ | ||||
| #define GRUB_KERNEL_I386_IEEE1275_MOD_GAP 0x0 | ||||
| #define GRUB_KERNEL_I386_COREBOOT_MOD_GAP 0x0 | ||||
| 
 | ||||
| #define GRUB_KERNEL_POWERPC_IEEE1275_MOD_ALIGN 0x1000 | ||||
| 
 | ||||
| #define GRUB_KERNEL_MIPS_YEELOONG_MOD_ALIGN 0x1 | ||||
| 
 | ||||
| /* Minimal gap between _end and the start of the modules.  It's a hack
 | ||||
|    for PowerMac to prevent "CLAIM failed" error.  The real fix is to | ||||
|    rewrite grub-mkimage to generate valid ELF files.  */ | ||||
| #define GRUB_KERNEL_POWERPC_IEEE1275_MOD_GAP 0x8000 | ||||
| 
 | ||||
| #ifdef MACHINE | ||||
| #define GRUB_OFFSETS_CONCAT_(a,b,c) a ## b ## c | ||||
| #define GRUB_OFFSETS_CONCAT(a,b,c) GRUB_OFFSETS_CONCAT_(a,b,c) | ||||
| #define GRUB_KERNEL_MACHINE_MOD_ALIGN GRUB_OFFSETS_CONCAT (GRUB_KERNEL_, MACHINE, _MOD_ALIGN) | ||||
| #define GRUB_KERNEL_MACHINE_MOD_GAP GRUB_OFFSETS_CONCAT (GRUB_KERNEL_, MACHINE, _MOD_GAP) | ||||
| #define GRUB_KERNEL_MACHINE_TOTAL_MODULE_SIZE GRUB_OFFSETS_CONCAT (GRUB_KERNEL_, MACHINE, _TOTAL_MODULE_SIZE) | ||||
| #define GRUB_KERNEL_MACHINE_KERNEL_IMAGE_SIZE GRUB_OFFSETS_CONCAT (GRUB_KERNEL_, MACHINE, _KERNEL_IMAGE_SIZE) | ||||
| #define GRUB_KERNEL_MACHINE_COMPRESSED_SIZE GRUB_OFFSETS_CONCAT (GRUB_KERNEL_, MACHINE, _COMPRESSED_SIZE) | ||||
| 
 | ||||
| #define GRUB_KERNEL_MACHINE_PREFIX GRUB_OFFSETS_CONCAT (GRUB_KERNEL_, MACHINE, _PREFIX) | ||||
| #define GRUB_KERNEL_MACHINE_DATA_END GRUB_OFFSETS_CONCAT (GRUB_KERNEL_, MACHINE, _DATA_END) | ||||
| #define GRUB_BOOT_MACHINE_KERNEL_SEG GRUB_OFFSETS_CONCAT (GRUB_BOOT_, MACHINE, _KERNEL_SEG) | ||||
| #define GRUB_MEMORY_MACHINE_UPPER GRUB_OFFSETS_CONCAT (GRUB_MEMORY_, MACHINE, _UPPER) | ||||
| #define GRUB_KERNEL_MACHINE_RAW_SIZE GRUB_OFFSETS_CONCAT (GRUB_KERNEL_, MACHINE, _RAW_SIZE) | ||||
| #define GRUB_KERNEL_MACHINE_INSTALL_BSD_PART GRUB_OFFSETS_CONCAT (GRUB_KERNEL_, MACHINE, _INSTALL_BSD_PART) | ||||
| #define GRUB_KERNEL_MACHINE_INSTALL_DOS_PART GRUB_OFFSETS_CONCAT (GRUB_KERNEL_, MACHINE, _INSTALL_DOS_PART) | ||||
| #endif | ||||
| 
 | ||||
| #ifndef ASM_FILE | ||||
| struct grub_pc_bios_boot_blocklist | ||||
| { | ||||
|   grub_uint64_t start; | ||||
|   grub_uint16_t len; | ||||
|   grub_uint16_t segment; | ||||
| } __attribute__ ((packed)); | ||||
| #endif | ||||
| 
 | ||||
| #endif | ||||
|  | @ -1,32 +0,0 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2005,2006,2007,2008  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #ifndef GRUB_KERNEL_MACHINE_HEADER | ||||
| #define GRUB_KERNEL_MACHINE_HEADER	1 | ||||
| 
 | ||||
| #include <grub/symbol.h> | ||||
| 
 | ||||
| #ifndef ASM_FILE | ||||
| 
 | ||||
| /* The prefix which points to the directory where GRUB modules and its
 | ||||
|    configuration file are located.  */ | ||||
| extern char grub_prefix[]; | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| #endif /* ! GRUB_KERNEL_MACHINE_HEADER */ | ||||
|  | @ -19,14 +19,4 @@ | |||
| #ifndef GRUB_KERNEL_CPU_HEADER | ||||
| #define GRUB_KERNEL_CPU_HEADER	1 | ||||
| 
 | ||||
| #define GRUB_MOD_ALIGN 0x1000 | ||||
| 
 | ||||
| /* Minimal gap between _end and the start of the modules.  It's a hack
 | ||||
|    for PowerMac to prevent "CLAIM failed" error.  The real fix is to | ||||
|    rewrite grub-mkimage to generate valid ELF files.  */ | ||||
| #define GRUB_MOD_GAP 0x8000 | ||||
| 
 | ||||
| #define GRUB_KERNEL_CPU_PREFIX		0x4 | ||||
| #define GRUB_KERNEL_CPU_DATA_END	0x44 | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -45,15 +45,11 @@ | |||
| 
 | ||||
| #define GRUB_BOOT_MACHINE_BOOT_DEVPATH_END 0x80 | ||||
| 
 | ||||
| #define GRUB_BOOT_MACHINE_KERNEL_SECTOR 0x88 | ||||
| #define GRUB_BOOT_MACHINE_KERNEL_BYTE 0x80 | ||||
| 
 | ||||
| #define GRUB_BOOT_MACHINE_CODE_END \ | ||||
| 	(0x1fc - GRUB_BOOT_AOUT_HEADER_SIZE) | ||||
| 
 | ||||
| #define GRUB_BOOT_MACHINE_LIST_SIZE	12 | ||||
| 
 | ||||
| #define GRUB_BOOT_MACHINE_IMAGE_ADDRESS	0x4400 | ||||
| 
 | ||||
| #define GRUB_BOOT_MACHINE_KERNEL_ADDR 0x4200 | ||||
| 
 | ||||
| #endif /* ! BOOT_MACHINE_HEADER */ | ||||
|  |  | |||
|  | @ -19,44 +19,10 @@ | |||
| #ifndef GRUB_KERNEL_MACHINE_HEADER | ||||
| #define GRUB_KERNEL_MACHINE_HEADER	1 | ||||
| 
 | ||||
| #define GRUB_MOD_ALIGN 0x2000 | ||||
| 
 | ||||
| /* Non-zero value is only needed for PowerMacs.  */ | ||||
| #define GRUB_MOD_GAP 0x0 | ||||
| 
 | ||||
| /* The offset of GRUB_TOTAL_MODULE_SIZE.  */ | ||||
| #define GRUB_KERNEL_MACHINE_TOTAL_MODULE_SIZE	0x8 | ||||
| 
 | ||||
| /* The offset of GRUB_KERNEL_IMAGE_SIZE.  */ | ||||
| #define GRUB_KERNEL_MACHINE_KERNEL_IMAGE_SIZE	0xc | ||||
| 
 | ||||
| /* The offset of GRUB_COMPRESSED_SIZE.  */ | ||||
| #define GRUB_KERNEL_MACHINE_COMPRESSED_SIZE	0x10 | ||||
| 
 | ||||
| /* The offset of GRUB_PREFIX.  */ | ||||
| #define GRUB_KERNEL_MACHINE_PREFIX		0x14 | ||||
| 
 | ||||
| /* End of the data section. */ | ||||
| #define GRUB_KERNEL_MACHINE_DATA_END		0x114 | ||||
| 
 | ||||
| #define GRUB_KERNEL_MACHINE_RAW_SIZE                   0 | ||||
| #define GRUB_KERNEL_MACHINE_STACK_SIZE          0x40000 | ||||
| 
 | ||||
| #define GRUB_PLATFORM_IMAGE_FORMATS     "raw, aout" | ||||
| #define GRUB_PLATFORM_IMAGE_DEFAULT_FORMAT     "raw" | ||||
| 
 | ||||
| #define GRUB_PLATFORM_IMAGE_DEFAULT GRUB_PLATFORM_IMAGE_RAW | ||||
| 
 | ||||
| #ifndef ASM_FILE | ||||
| 
 | ||||
| typedef enum { | ||||
|   GRUB_PLATFORM_IMAGE_RAW, | ||||
|   GRUB_PLATFORM_IMAGE_AOUT | ||||
| } | ||||
|   grub_platform_image_format_t; | ||||
| #define GRUB_PLATFORM_IMAGE_RAW GRUB_PLATFORM_IMAGE_RAW | ||||
| #define GRUB_PLATFORM_IMAGE_AOUT GRUB_PLATFORM_IMAGE_AOUT | ||||
| 
 | ||||
| #include <grub/symbol.h> | ||||
| #include <grub/types.h> | ||||
| 
 | ||||
|  | @ -66,10 +32,6 @@ extern grub_int32_t grub_kernel_image_size; | |||
| /* The total size of module images following the kernel.  */ | ||||
| extern grub_int32_t grub_total_module_size; | ||||
| 
 | ||||
| /* The prefix which points to the directory where GRUB modules and its
 | ||||
|    configuration file are located.  */ | ||||
| extern char grub_prefix[]; | ||||
| 
 | ||||
| #endif /* ! ASM_FILE */ | ||||
| 
 | ||||
| #endif /* ! GRUB_KERNEL_MACHINE_HEADER */ | ||||
|  |  | |||
|  | @ -1,30 +0,0 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2005,2006,2007,2008  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #ifndef GRUB_KERNEL_CPU_HEADER | ||||
| #define GRUB_KERNEL_CPU_HEADER	1 | ||||
| 
 | ||||
| #define GRUB_MOD_ALIGN 0x2000 | ||||
| 
 | ||||
| /* Non-zero value is only needed for PowerMacs.  */ | ||||
| #define GRUB_MOD_GAP 0x0 | ||||
| 
 | ||||
| #define GRUB_KERNEL_CPU_PREFIX	0x2 | ||||
| #define GRUB_KERNEL_CPU_DATA_END	0x42 | ||||
| 
 | ||||
| #endif | ||||
|  | @ -178,21 +178,6 @@ static inline grub_uint64_t grub_swap_bytes64(grub_uint64_t x) | |||
| # define grub_be_to_cpu16(x)	((grub_uint16_t) (x)) | ||||
| # define grub_be_to_cpu32(x)	((grub_uint32_t) (x)) | ||||
| # define grub_be_to_cpu64(x)	((grub_uint64_t) (x)) | ||||
| # ifdef GRUB_TARGET_WORDS_BIGENDIAN | ||||
| #  define grub_target_to_host16(x)	((grub_uint16_t) (x)) | ||||
| #  define grub_target_to_host32(x)	((grub_uint32_t) (x)) | ||||
| #  define grub_target_to_host64(x)	((grub_uint64_t) (x)) | ||||
| #  define grub_host_to_target16(x)	((grub_uint16_t) (x)) | ||||
| #  define grub_host_to_target32(x)	((grub_uint32_t) (x)) | ||||
| #  define grub_host_to_target64(x)	((grub_uint64_t) (x)) | ||||
| # else /* ! GRUB_TARGET_WORDS_BIGENDIAN */ | ||||
| #  define grub_target_to_host16(x)	grub_swap_bytes16(x) | ||||
| #  define grub_target_to_host32(x)	grub_swap_bytes32(x) | ||||
| #  define grub_target_to_host64(x)	grub_swap_bytes64(x) | ||||
| #  define grub_host_to_target16(x)	grub_swap_bytes16(x) | ||||
| #  define grub_host_to_target32(x)	grub_swap_bytes32(x) | ||||
| #  define grub_host_to_target64(x)	grub_swap_bytes64(x) | ||||
| # endif | ||||
| #else /* ! WORDS_BIGENDIAN */ | ||||
| # define grub_cpu_to_le16(x)	((grub_uint16_t) (x)) | ||||
| # define grub_cpu_to_le32(x)	((grub_uint32_t) (x)) | ||||
|  | @ -206,27 +191,6 @@ static inline grub_uint64_t grub_swap_bytes64(grub_uint64_t x) | |||
| # define grub_be_to_cpu16(x)	grub_swap_bytes16(x) | ||||
| # define grub_be_to_cpu32(x)	grub_swap_bytes32(x) | ||||
| # define grub_be_to_cpu64(x)	grub_swap_bytes64(x) | ||||
| # ifdef GRUB_TARGET_WORDS_BIGENDIAN | ||||
| #  define grub_target_to_host16(x)	grub_swap_bytes16(x) | ||||
| #  define grub_target_to_host32(x)	grub_swap_bytes32(x) | ||||
| #  define grub_target_to_host64(x)	grub_swap_bytes64(x) | ||||
| #  define grub_host_to_target16(x)	grub_swap_bytes16(x) | ||||
| #  define grub_host_to_target32(x)	grub_swap_bytes32(x) | ||||
| #  define grub_host_to_target64(x)	grub_swap_bytes64(x) | ||||
| # else /* ! GRUB_TARGET_WORDS_BIGENDIAN */ | ||||
| #  define grub_target_to_host16(x)	((grub_uint16_t) (x)) | ||||
| #  define grub_target_to_host32(x)	((grub_uint32_t) (x)) | ||||
| #  define grub_target_to_host64(x)	((grub_uint64_t) (x)) | ||||
| #  define grub_host_to_target16(x)	((grub_uint16_t) (x)) | ||||
| #  define grub_host_to_target32(x)	((grub_uint32_t) (x)) | ||||
| #  define grub_host_to_target64(x)	((grub_uint64_t) (x)) | ||||
| # endif | ||||
| #endif /* ! WORDS_BIGENDIAN */ | ||||
| 
 | ||||
| #if GRUB_TARGET_SIZEOF_VOID_P == 8 | ||||
| #  define grub_host_to_target_addr(x) grub_host_to_target64(x) | ||||
| #else | ||||
| #  define grub_host_to_target_addr(x) grub_host_to_target32(x) | ||||
| #endif | ||||
| 
 | ||||
| #endif /* ! GRUB_TYPES_HEADER */ | ||||
|  |  | |||
|  | @ -20,8 +20,11 @@ | |||
| #ifndef GRUB_BIOSDISK_MACHINE_UTIL_HEADER | ||||
| #define GRUB_BIOSDISK_MACHINE_UTIL_HEADER	1 | ||||
| 
 | ||||
| #include <grub/disk.h> | ||||
| 
 | ||||
| void grub_util_biosdisk_init (const char *dev_map); | ||||
| void grub_util_biosdisk_fini (void); | ||||
| char *grub_util_biosdisk_get_grub_dev (const char *os_dev); | ||||
| const char *grub_util_biosdisk_get_osdev (grub_disk_t disk); | ||||
| 
 | ||||
| #endif /* ! GRUB_BIOSDISK_MACHINE_UTIL_HEADER */ | ||||
|  |  | |||
|  | @ -27,6 +27,7 @@ | |||
| 
 | ||||
| #include <config.h> | ||||
| #include <grub/types.h> | ||||
| #include <grub/symbol.h> | ||||
| 
 | ||||
| #ifdef __NetBSD__ | ||||
| /* NetBSD uses /boot for its boot block.  */ | ||||
|  | @ -40,9 +41,9 @@ | |||
| extern char *progname; | ||||
| extern int verbosity; | ||||
| 
 | ||||
| void grub_util_warn (const char *fmt, ...); | ||||
| void grub_util_info (const char *fmt, ...); | ||||
| void grub_util_error (const char *fmt, ...) __attribute__ ((noreturn)); | ||||
| void EXPORT_FUNC(grub_util_warn) (const char *fmt, ...); | ||||
| void EXPORT_FUNC(grub_util_info) (const char *fmt, ...); | ||||
| void EXPORT_FUNC(grub_util_error) (const char *fmt, ...) __attribute__ ((noreturn)); | ||||
| 
 | ||||
| void *xmalloc (size_t size); | ||||
| void *xrealloc (void *ptr, size_t size); | ||||
|  |  | |||
|  | @ -1,6 +1,6 @@ | |||
| #ifndef GRUB_OFPATH_MACHINE_UTIL_HEADER | ||||
| #define GRUB_OFPATH_MACHINE_UTIL_HEADER	1 | ||||
| 
 | ||||
| char *grub_util_devname_to_ofpath (char *devname); | ||||
| char *grub_util_devname_to_ofpath (const char *devname); | ||||
| 
 | ||||
| #endif /* ! GRUB_OFPATH_MACHINE_UTIL_HEADER */ | ||||
|  |  | |||
|  | @ -1,33 +0,0 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2002,2003,2007  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #ifndef GRUB_MACHINE_KERNEL_HEADER | ||||
| #define GRUB_MACHINE_KERNEL_HEADER   1 | ||||
| 
 | ||||
| /* The prefix which points to the directory where GRUB modules and its
 | ||||
|    configuration file are located.  */ | ||||
| extern char grub_prefix[]; | ||||
| 
 | ||||
| /* The offset of GRUB_PREFIX.  */ | ||||
| #define GRUB_KERNEL_MACHINE_PREFIX		0x8 | ||||
| 
 | ||||
| /* End of the data section. */ | ||||
| #define GRUB_KERNEL_MACHINE_DATA_END		0x50 | ||||
| 
 | ||||
| #endif /* ! GRUB_MACHINE_KERNEL_HEADER */ | ||||
| 
 | ||||
|  | @ -1 +0,0 @@ | |||
| #include <grub/i386/kernel.h> | ||||
|  | @ -24,7 +24,6 @@ | |||
| #include <grub/misc.h> | ||||
| #include <grub/env.h> | ||||
| #include <grub/mm.h> | ||||
| #include <grub/machine/kernel.h> | ||||
| 
 | ||||
| void | ||||
| grub_efi_init (void) | ||||
|  |  | |||
|  | @ -22,7 +22,6 @@ | |||
| #include <grub/machine/init.h> | ||||
| #include <grub/machine/memory.h> | ||||
| #include <grub/machine/console.h> | ||||
| #include <grub/machine/kernel.h> | ||||
| #include <grub/types.h> | ||||
| #include <grub/err.h> | ||||
| #include <grub/dl.h> | ||||
|  | @ -33,8 +32,10 @@ | |||
| #include <grub/time.h> | ||||
| #include <grub/symbol.h> | ||||
| #include <grub/cpu/io.h> | ||||
| #include <grub/cpu/kernel.h> | ||||
| #include <grub/cpu/tsc.h> | ||||
| #ifdef GRUB_MACHINE_QEMU | ||||
| #include <grub/machine/kernel.h> | ||||
| #endif | ||||
| 
 | ||||
| #define GRUB_FLOPPY_REG_DIGITAL_OUTPUT		0x3f2 | ||||
| 
 | ||||
|  | @ -144,6 +145,6 @@ grub_arch_modules_addr (void) | |||
| #ifdef GRUB_MACHINE_QEMU | ||||
|   return grub_core_entry_addr + grub_kernel_image_size; | ||||
| #else | ||||
|   return ALIGN_UP((grub_addr_t) _end, GRUB_MOD_ALIGN); | ||||
|   return ALIGN_UP((grub_addr_t) _end, GRUB_KERNEL_MACHINE_MOD_ALIGN); | ||||
| #endif | ||||
| } | ||||
|  |  | |||
|  | @ -19,7 +19,7 @@ | |||
| #include <grub/symbol.h> | ||||
| #include <grub/machine/memory.h> | ||||
| #include <grub/cpu/linux.h> | ||||
| #include <grub/cpu/kernel.h> | ||||
| #include <grub/offsets.h> | ||||
| #include <multiboot.h> | ||||
| #include <multiboot2.h> | ||||
| 
 | ||||
|  | @ -42,7 +42,7 @@ _start: | |||
| 	 *  This is a special data area at a fixed offset from the beginning. | ||||
| 	 */ | ||||
| 
 | ||||
| 	. = _start + GRUB_KERNEL_CPU_PREFIX | ||||
| 	. = _start + GRUB_KERNEL_MACHINE_PREFIX | ||||
| 
 | ||||
| VARIABLE(grub_prefix) | ||||
| 	/* to be filled by grub-mkimage */ | ||||
|  | @ -51,7 +51,7 @@ VARIABLE(grub_prefix) | |||
| 	 *  Leave some breathing room for the prefix. | ||||
| 	 */ | ||||
| 
 | ||||
| 	. = _start + GRUB_KERNEL_CPU_DATA_END | ||||
| 	. = _start + GRUB_KERNEL_MACHINE_DATA_END | ||||
| 
 | ||||
| /* | ||||
|  *  Support for booting GRUB from a Multiboot boot loader (e.g. GRUB itself). | ||||
|  |  | |||
|  | @ -19,7 +19,6 @@ | |||
| #include <grub/symbol.h> | ||||
| #include <grub/machine/memory.h> | ||||
| #include <grub/cpu/linux.h> | ||||
| #include <grub/cpu/kernel.h> | ||||
| #include <multiboot.h> | ||||
| #include <multiboot2.h> | ||||
| 
 | ||||
|  | @ -43,7 +42,7 @@ _start: | |||
| 	 *  This is a special data area at a fixed offset from the beginning. | ||||
| 	 */ | ||||
| 
 | ||||
| 	. = _start + GRUB_KERNEL_CPU_PREFIX | ||||
| 	. = _start + GRUB_KERNEL_MACHINE_PREFIX | ||||
| 
 | ||||
| VARIABLE(grub_prefix) | ||||
| 	/* to be filled by grub-mkimage */ | ||||
|  | @ -52,7 +51,7 @@ VARIABLE(grub_prefix) | |||
| 	 *  Leave some breathing room for the prefix. | ||||
| 	 */ | ||||
| 
 | ||||
| 	. = _start + GRUB_KERNEL_CPU_DATA_END | ||||
| 	. = _start + GRUB_KERNEL_MACHINE_DATA_END | ||||
| 
 | ||||
| codestart: | ||||
| 	movl %eax, EXT_C(grub_ieee1275_entry_fn) | ||||
|  |  | |||
|  | @ -27,7 +27,7 @@ | |||
| _start: | ||||
| 	jmp	codestart | ||||
| 
 | ||||
| 	. = _start + GRUB_KERNEL_MACHINE_CORE_ENTRY_ADDR | ||||
| 	. = _start + GRUB_KERNEL_I386_QEMU_CORE_ENTRY_ADDR | ||||
| VARIABLE(grub_core_entry_addr) | ||||
| 	.long	0
 | ||||
| VARIABLE(grub_kernel_image_size) | ||||
|  |  | |||
|  | @ -20,7 +20,6 @@ | |||
| #include <grub/kernel.h> | ||||
| #include <grub/misc.h> | ||||
| #include <grub/types.h> | ||||
| #include <grub/machine/kernel.h> | ||||
| #include <grub/ieee1275/ieee1275.h> | ||||
| 
 | ||||
| int (*grub_ieee1275_entry_fn) (void *); | ||||
|  |  | |||
|  | @ -29,10 +29,9 @@ | |||
| #include <grub/misc.h> | ||||
| #include <grub/time.h> | ||||
| #include <grub/machine/console.h> | ||||
| #include <grub/machine/kernel.h> | ||||
| #include <grub/cpu/kernel.h> | ||||
| #include <grub/ieee1275/ofdisk.h> | ||||
| #include <grub/ieee1275/ieee1275.h> | ||||
| #include <grub/offsets.h> | ||||
| 
 | ||||
| /* The minimal heap size we can live with. */ | ||||
| #define HEAP_MIN_SIZE		(unsigned long) (2 * 1024 * 1024) | ||||
|  | @ -284,5 +283,5 @@ grub_get_rtc (void) | |||
| grub_addr_t | ||||
| grub_arch_modules_addr (void) | ||||
| { | ||||
|   return ALIGN_UP((grub_addr_t) _end + GRUB_MOD_GAP, GRUB_MOD_ALIGN); | ||||
|   return ALIGN_UP((grub_addr_t) _end + GRUB_KERNEL_MACHINE_MOD_GAP, GRUB_KERNEL_MACHINE_MOD_ALIGN); | ||||
| } | ||||
|  |  | |||
|  | @ -21,7 +21,6 @@ | |||
| #include <grub/err.h> | ||||
| #include <grub/misc.h> | ||||
| #include <grub/mm.h> | ||||
| #include <grub/machine/kernel.h> | ||||
| #include <grub/ieee1275/ieee1275.h> | ||||
| 
 | ||||
| enum grub_ieee1275_parse_type | ||||
|  |  | |||
|  | @ -18,7 +18,6 @@ | |||
| 
 | ||||
| #include <grub/kernel.h> | ||||
| #include <grub/env.h> | ||||
| #include <grub/mips/kernel.h> | ||||
| 
 | ||||
| void | ||||
| grub_machine_set_prefix (void) | ||||
|  |  | |||
|  | @ -18,8 +18,9 @@ | |||
|  */ | ||||
| 
 | ||||
| #include <grub/symbol.h> | ||||
| #include <grub/cpu/kernel.h> | ||||
| #include <grub/offsets.h> | ||||
| #include <grub/machine/memory.h> | ||||
| #include <grub/offsets.h> | ||||
| 
 | ||||
| #define BASE_ADDR 8 | ||||
| 	 | ||||
|  | @ -32,13 +33,13 @@ _start: | |||
| start:	 | ||||
| 	bal codestart | ||||
| base:	 | ||||
| 	. = _start + GRUB_KERNEL_CPU_COMPRESSED_SIZE | ||||
| 	. = _start + GRUB_KERNEL_MACHINE_COMPRESSED_SIZE | ||||
| compressed_size: | ||||
| 	.long 0
 | ||||
| 	. = _start + GRUB_KERNEL_CPU_TOTAL_MODULE_SIZE | ||||
| 	. = _start + GRUB_KERNEL_MACHINE_TOTAL_MODULE_SIZE | ||||
| total_module_size: | ||||
| 	.long 0
 | ||||
| 	. = _start + GRUB_KERNEL_CPU_KERNEL_IMAGE_SIZE | ||||
| 	. = _start + GRUB_KERNEL_MACHINE_KERNEL_IMAGE_SIZE | ||||
| kernel_image_size:	 | ||||
| 	.long	0
 | ||||
| codestart: | ||||
|  | @ -105,10 +106,10 @@ argdone: | |||
| #endif | ||||
| 
 | ||||
| 	/* Decompress the payload. */ | ||||
| 	addiu $a0, $s0, GRUB_KERNEL_CPU_RAW_SIZE - BASE_ADDR | ||||
| 	addiu $a0, $s0, GRUB_KERNEL_MACHINE_RAW_SIZE - BASE_ADDR | ||||
| 	lui $a1, %hi(compressed) | ||||
| 	addiu $a1, %lo(compressed) | ||||
| 	lw $a2, (GRUB_KERNEL_CPU_COMPRESSED_SIZE - BASE_ADDR)($s0) | ||||
| 	lw $a2, (GRUB_KERNEL_MACHINE_COMPRESSED_SIZE - BASE_ADDR)($s0) | ||||
| 	move $s1, $a1 | ||||
| 
 | ||||
| 	/* $a0 contains source compressed address, $a1 is destination, | ||||
|  | @ -134,9 +135,9 @@ reloccont: | |||
| 	addiu $t1, %lo(cont) | ||||
| 
 | ||||
| 	jr $t1 | ||||
| 	. = _start + GRUB_KERNEL_CPU_RAW_SIZE | ||||
| 	. = _start + GRUB_KERNEL_MACHINE_RAW_SIZE | ||||
| compressed:	 | ||||
| 	. = _start + GRUB_KERNEL_CPU_PREFIX | ||||
| 	. = _start + GRUB_KERNEL_MACHINE_PREFIX | ||||
| 
 | ||||
| VARIABLE(grub_prefix) | ||||
| 
 | ||||
|  | @ -146,7 +147,7 @@ VARIABLE(grub_prefix) | |||
| 	 *  Leave some breathing room for the prefix. | ||||
| 	 */ | ||||
| 
 | ||||
| 	. = _start + GRUB_KERNEL_CPU_DATA_END | ||||
| 	. = _start + GRUB_KERNEL_MACHINE_DATA_END | ||||
| #ifdef GRUB_MACHINE_MIPS_YEELOONG | ||||
| VARIABLE (grub_arch_busclock) | ||||
| 	.long 0
 | ||||
|  | @ -171,17 +172,17 @@ cont: | |||
| 	/* Move the modules out of BSS.  */ | ||||
| 	lui $t1, %hi(_start) | ||||
| 	addiu $t1, %lo(_start) | ||||
| 	lw $t2, (GRUB_KERNEL_CPU_KERNEL_IMAGE_SIZE - BASE_ADDR)($s0) | ||||
| 	lw $t2, (GRUB_KERNEL_MACHINE_KERNEL_IMAGE_SIZE - BASE_ADDR)($s0) | ||||
| 	addu $t2, $t1, $t2 | ||||
| 	 | ||||
| 	lui $t1, %hi(_end) | ||||
| 	addiu $t1, %lo(_end) | ||||
| 	addiu $t1, (GRUB_MOD_ALIGN-1) | ||||
| 	li $t3, (GRUB_MOD_ALIGN-1) | ||||
| 	addiu $t1, (GRUB_KERNEL_MACHINE_MOD_ALIGN-1) | ||||
| 	li $t3, (GRUB_KERNEL_MACHINE_MOD_ALIGN-1) | ||||
| 	nor $t3, $t3, $0 | ||||
| 	and $t1, $t1, $t3 | ||||
| 	 | ||||
| 	lw $t3, (GRUB_KERNEL_CPU_TOTAL_MODULE_SIZE - BASE_ADDR)($s0) | ||||
| 	lw $t3, (GRUB_KERNEL_MACHINE_TOTAL_MODULE_SIZE - BASE_ADDR)($s0) | ||||
| 
 | ||||
| 	/* Backward copy.  */ | ||||
| 	add $t1, $t1, $t3 | ||||
|  |  | |||
|  | @ -26,7 +26,6 @@ | |||
| #include <grub/time.h> | ||||
| #include <grub/machine/kernel.h> | ||||
| #include <grub/machine/memory.h> | ||||
| #include <grub/cpu/kernel.h> | ||||
| 
 | ||||
| extern void grub_video_sm712_init (void); | ||||
| extern void grub_video_init (void); | ||||
|  |  | |||
|  | @ -18,7 +18,7 @@ | |||
|  */ | ||||
| 
 | ||||
| #include <grub/symbol.h> | ||||
| #include <grub/cpu/kernel.h> | ||||
| #include <grub/offsets.h> | ||||
| 
 | ||||
| .extern __bss_start
 | ||||
| .extern _end
 | ||||
|  | @ -30,7 +30,7 @@ start: | |||
| _start: | ||||
| 	b	codestart | ||||
| 
 | ||||
| 	. = _start + GRUB_KERNEL_CPU_PREFIX | ||||
| 	. = _start + GRUB_KERNEL_MACHINE_PREFIX | ||||
| 
 | ||||
| VARIABLE(grub_prefix) | ||||
| 	/* to be filled by grub-mkelfimage */ | ||||
|  | @ -39,7 +39,7 @@ VARIABLE(grub_prefix) | |||
| 	 *  Leave some breathing room for the prefix. | ||||
| 	 */ | ||||
| 
 | ||||
| 	. = _start + GRUB_KERNEL_CPU_DATA_END | ||||
| 	. = _start + GRUB_KERNEL_MACHINE_DATA_END | ||||
| 
 | ||||
| codestart: | ||||
| 	li      2, 0 | ||||
|  |  | |||
|  | @ -18,6 +18,7 @@ | |||
|  */ | ||||
| #include <grub/symbol.h> | ||||
| #include <grub/machine/kernel.h> | ||||
| #include <grub/offsets.h> | ||||
| 
 | ||||
| 	.text | ||||
| 	.align	4
 | ||||
|  |  | |||
|  | @ -80,7 +80,7 @@ SUFFIX (grub_freebsd_load_elfmodule_obj) (grub_file_t file, int argc, | |||
| { | ||||
|   Elf_Ehdr e; | ||||
|   Elf_Shdr *s; | ||||
|   char *shdr; | ||||
|   char *shdr = 0; | ||||
|   grub_addr_t curload, module; | ||||
|   grub_err_t err; | ||||
| 
 | ||||
|  | @ -148,7 +148,7 @@ SUFFIX (grub_freebsd_load_elfmodule) (grub_file_t file, int argc, char *argv[], | |||
| { | ||||
|   Elf_Ehdr e; | ||||
|   Elf_Shdr *s; | ||||
|   char *shdr; | ||||
|   char *shdr = 0; | ||||
|   grub_addr_t curload, module; | ||||
|   grub_err_t err; | ||||
| 
 | ||||
|  | @ -223,7 +223,7 @@ SUFFIX (grub_freebsd_load_elf_meta) (grub_file_t file, grub_addr_t *kern_end) | |||
|   grub_err_t err; | ||||
|   Elf_Ehdr e; | ||||
|   Elf_Shdr *s; | ||||
|   char *shdr; | ||||
|   char *shdr = 0; | ||||
|   unsigned symoff, stroff, symsize, strsize; | ||||
|   grub_addr_t curload; | ||||
|   grub_freebsd_addr_t symstart, symend, symentsize, dynamic; | ||||
|  |  | |||
|  | @ -62,7 +62,7 @@ loader/i386/linux.c | |||
| loader/i386/pc/chainloader.c | ||||
| loader/i386/pc/linux.c | ||||
| loader/i386/xnu.c | ||||
| loader/multiboot_loader.c | ||||
| loader/multiboot.c | ||||
| loader/powerpc/ieee1275/linux.c | ||||
| loader/sparc64/ieee1275/linux.c | ||||
| loader/xnu.c | ||||
|  |  | |||
|  | @ -2,3 +2,4 @@ | |||
| # Shell language are included here. | ||||
| util/grub.d/10_kfreebsd.in | ||||
| util/grub.d/10_linux.in | ||||
| util/grub.d/10_netbsd.in | ||||
|  |  | |||
|  | @ -211,7 +211,7 @@ WORD            ({CHAR}|{DQSTR}|{SQSTR}|{ESC}|{VARIABLE})+ | |||
|                   ARG (GRUB_SCRIPT_ARG_TYPE_TEXT); | ||||
|                 } | ||||
|   \\            | | ||||
|   [^\"\'$\\]+   { COPY (yytext, yyleng); } | ||||
|   [^\"\'\$\\]+  { COPY (yytext, yyleng); } | ||||
|   <<EOF>>       { | ||||
|                   yy_pop_state (yyscanner); | ||||
|                   yypop_buffer_state (yyscanner); | ||||
|  | @ -254,6 +254,11 @@ WORD            ({CHAR}|{DQSTR}|{SQSTR}|{ESC}|{VARIABLE})+ | |||
| } | ||||
| 
 | ||||
| <DQUOTE>{ | ||||
|   \\\$          { COPY ("$", 1); } | ||||
|   \\\\          { COPY ("\\", 1); } | ||||
|   \\\"          { COPY ("\"", 1); } | ||||
|   \\\n          { /* ignore */ } | ||||
|   [^\"\$\\\n]+  { COPY (yytext, yyleng); } | ||||
|   \"            { | ||||
|                   yy_pop_state (yyscanner); | ||||
|                   ARG (GRUB_SCRIPT_ARG_TYPE_DQSTR); | ||||
|  | @ -262,10 +267,6 @@ WORD            ({CHAR}|{DQSTR}|{SQSTR}|{ESC}|{VARIABLE})+ | |||
|                   yy_push_state (VAR, yyscanner); | ||||
|                   ARG (GRUB_SCRIPT_ARG_TYPE_DQSTR); | ||||
|                 } | ||||
|   \\\\          { COPY ("\\", 1); } | ||||
|   \\\"          { COPY ("\"", 1); } | ||||
|   \\\n          { /* ignore */ } | ||||
|   [^\"$\\\n]+   { COPY (yytext, yyleng); } | ||||
|   (.|\n)        { COPY (yytext, yyleng); } | ||||
| } | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										5
									
								
								tests/grub_script_dollar.in
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								tests/grub_script_dollar.in
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,5 @@ | |||
| #! /bin/sh -e | ||||
| 
 | ||||
| @builddir@/grub-script-check << EOF | ||||
| echo "\\\$" | ||||
| EOF | ||||
|  | @ -1,462 +0,0 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2004,2005,2006,2007,2008,2009,2010  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| #include <stdio.h> | ||||
| #include <stdint.h> | ||||
| #include <unistd.h> | ||||
| #include <fcntl.h> | ||||
| #include <getopt.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| #include <grub/elf.h> | ||||
| #include <grub/misc.h> | ||||
| #include <grub/util/misc.h> | ||||
| #include <grub/util/resolve.h> | ||||
| #include <grub/kernel.h> | ||||
| #include <grub/cpu/kernel.h> | ||||
| #include <grub/i18n.h> | ||||
| 
 | ||||
| #include "progname.h" | ||||
| 
 | ||||
| #define GRUB_IEEE1275_NOTE_NAME "PowerPC" | ||||
| #define GRUB_IEEE1275_NOTE_TYPE 0x1275 | ||||
| 
 | ||||
| /* These structures are defined according to the CHRP binding to IEEE1275,
 | ||||
|    "Client Program Format" section.  */ | ||||
| 
 | ||||
| struct grub_ieee1275_note_hdr | ||||
| { | ||||
|   grub_uint32_t namesz; | ||||
|   grub_uint32_t descsz; | ||||
|   grub_uint32_t type; | ||||
|   char name[sizeof (GRUB_IEEE1275_NOTE_NAME)]; | ||||
| }; | ||||
| 
 | ||||
| struct grub_ieee1275_note_desc | ||||
| { | ||||
|   grub_uint32_t real_mode; | ||||
|   grub_uint32_t real_base; | ||||
|   grub_uint32_t real_size; | ||||
|   grub_uint32_t virt_base; | ||||
|   grub_uint32_t virt_size; | ||||
|   grub_uint32_t load_base; | ||||
| }; | ||||
| 
 | ||||
| struct grub_ieee1275_note | ||||
| { | ||||
|   struct grub_ieee1275_note_hdr header; | ||||
|   struct grub_ieee1275_note_desc descriptor; | ||||
| }; | ||||
| 
 | ||||
| void | ||||
| load_note (Elf32_Phdr *phdr, FILE *out) | ||||
| { | ||||
|   struct grub_ieee1275_note note; | ||||
|   int note_size = sizeof (struct grub_ieee1275_note); | ||||
| 
 | ||||
|   grub_util_info ("adding CHRP NOTE segment"); | ||||
| 
 | ||||
|   note.header.namesz = grub_host_to_target32 (sizeof (GRUB_IEEE1275_NOTE_NAME)); | ||||
|   note.header.descsz = grub_host_to_target32 (note_size); | ||||
|   note.header.type = grub_host_to_target32 (GRUB_IEEE1275_NOTE_TYPE); | ||||
|   strcpy (note.header.name, GRUB_IEEE1275_NOTE_NAME); | ||||
|   note.descriptor.real_mode = grub_host_to_target32 (0xffffffff); | ||||
|   note.descriptor.real_base = grub_host_to_target32 (0x00c00000); | ||||
|   note.descriptor.real_size = grub_host_to_target32 (0xffffffff); | ||||
|   note.descriptor.virt_base = grub_host_to_target32 (0xffffffff); | ||||
|   note.descriptor.virt_size = grub_host_to_target32 (0xffffffff); | ||||
|   note.descriptor.load_base = grub_host_to_target32 (0x00004000); | ||||
| 
 | ||||
|   /* Write the note data to the new segment.  */ | ||||
|   grub_util_write_image_at (¬e, note_size, | ||||
| 			    grub_target_to_host32 (phdr->p_offset), out); | ||||
| 
 | ||||
|   /* Fill in the rest of the segment header.  */ | ||||
|   phdr->p_type = grub_host_to_target32 (PT_NOTE); | ||||
|   phdr->p_flags = grub_host_to_target32 (PF_R); | ||||
|   phdr->p_align = grub_host_to_target32 (GRUB_TARGET_SIZEOF_LONG); | ||||
|   phdr->p_vaddr = 0; | ||||
|   phdr->p_paddr = 0; | ||||
|   phdr->p_filesz = grub_host_to_target32 (note_size); | ||||
|   phdr->p_memsz = 0; | ||||
| } | ||||
| 
 | ||||
| void | ||||
| load_modules (grub_addr_t modbase, Elf32_Phdr *phdr, const char *dir, | ||||
| 	      char *mods[], FILE *out, char *memdisk_path, char *config_path) | ||||
| { | ||||
|   char *module_img; | ||||
|   struct grub_util_path_list *path_list; | ||||
|   struct grub_util_path_list *p; | ||||
|   struct grub_module_info *modinfo; | ||||
|   size_t offset; | ||||
|   size_t total_module_size; | ||||
|   size_t memdisk_size = 0; | ||||
|   size_t config_size = 0; | ||||
| 
 | ||||
|   path_list = grub_util_resolve_dependencies (dir, "moddep.lst", mods); | ||||
| 
 | ||||
|   offset = sizeof (struct grub_module_info); | ||||
|   total_module_size = sizeof (struct grub_module_info); | ||||
| 
 | ||||
|   if (memdisk_path) | ||||
|     { | ||||
|       memdisk_size = ALIGN_UP(grub_util_get_image_size (memdisk_path), 512); | ||||
|       grub_util_info ("the size of memory disk is 0x%x", memdisk_size); | ||||
|       total_module_size += memdisk_size + sizeof (struct grub_module_header); | ||||
|     } | ||||
| 
 | ||||
|   if (config_path) | ||||
|     { | ||||
|       config_size = ALIGN_UP(grub_util_get_image_size (config_path), 512); | ||||
|       grub_util_info ("the size of memory disk is 0x%x", config_size); | ||||
|       total_module_size += config_size + sizeof (struct grub_module_header); | ||||
|     } | ||||
| 
 | ||||
|   for (p = path_list; p; p = p->next) | ||||
|     { | ||||
|       total_module_size += (grub_util_get_image_size (p->name) | ||||
| 	  + sizeof (struct grub_module_header)); | ||||
|     } | ||||
| 
 | ||||
|   grub_util_info ("the total module size is 0x%x", total_module_size); | ||||
| 
 | ||||
|   module_img = xmalloc (total_module_size); | ||||
|   modinfo = (struct grub_module_info *) module_img; | ||||
|   modinfo->magic = grub_host_to_target32 (GRUB_MODULE_MAGIC); | ||||
|   modinfo->offset = grub_host_to_target32 (sizeof (struct grub_module_info)); | ||||
|   modinfo->size = grub_host_to_target32 (total_module_size); | ||||
| 
 | ||||
|   /* Load all the modules, with headers, into module_img.  */ | ||||
|   for (p = path_list; p; p = p->next) | ||||
|     { | ||||
|       struct grub_module_header *header; | ||||
|       size_t mod_size; | ||||
| 
 | ||||
|       grub_util_info ("adding module %s", p->name); | ||||
| 
 | ||||
|       mod_size = grub_util_get_image_size (p->name); | ||||
| 
 | ||||
|       header = (struct grub_module_header *) (module_img + offset); | ||||
|       header->type = OBJ_TYPE_ELF; | ||||
|       header->size = grub_host_to_target32 (mod_size + sizeof (*header)); | ||||
| 
 | ||||
|       grub_util_load_image (p->name, module_img + offset + sizeof (*header)); | ||||
| 
 | ||||
|       offset += sizeof (*header) + mod_size; | ||||
|     } | ||||
| 
 | ||||
|   if (memdisk_path) | ||||
|     { | ||||
|       struct grub_module_header *header; | ||||
| 
 | ||||
|       header = (struct grub_module_header *) (module_img + offset); | ||||
|       header->type = OBJ_TYPE_MEMDISK; | ||||
|       header->size = grub_host_to_target32 (memdisk_size + sizeof (*header)); | ||||
|       offset += sizeof (*header); | ||||
| 
 | ||||
|       grub_util_load_image (memdisk_path, module_img + offset); | ||||
|       offset += memdisk_size; | ||||
|     } | ||||
| 
 | ||||
|   if (config_path) | ||||
|     { | ||||
|       struct grub_module_header *header; | ||||
| 
 | ||||
|       header = (struct grub_module_header *) (module_img + offset); | ||||
|       header->type = OBJ_TYPE_CONFIG; | ||||
|       header->size = grub_host_to_target32 (config_size + sizeof (*header)); | ||||
|       offset += sizeof (*header); | ||||
| 
 | ||||
|       grub_util_load_image (config_path, module_img + offset); | ||||
|       offset += config_size; | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|   /* Write the module data to the new segment.  */ | ||||
|   grub_util_write_image_at (module_img, total_module_size, | ||||
| 			    grub_host_to_target32 (phdr->p_offset), out); | ||||
| 
 | ||||
|   /* Fill in the rest of the segment header.  */ | ||||
|   phdr->p_type = grub_host_to_target32 (PT_LOAD); | ||||
|   phdr->p_flags = grub_host_to_target32 (PF_R | PF_W | PF_X); | ||||
|   phdr->p_align = grub_host_to_target32 (GRUB_TARGET_SIZEOF_LONG); | ||||
|   phdr->p_vaddr = grub_host_to_target32 (modbase); | ||||
|   phdr->p_paddr = grub_host_to_target32 (modbase); | ||||
|   phdr->p_filesz = grub_host_to_target32 (total_module_size); | ||||
|   phdr->p_memsz = grub_host_to_target32 (total_module_size); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| add_segments (char *dir, char *prefix, FILE *out, int chrp, char *mods[], char *memdisk_path, char *config_path) | ||||
| { | ||||
|   Elf32_Ehdr ehdr; | ||||
|   Elf32_Phdr *phdrs = NULL; | ||||
|   Elf32_Phdr *phdr; | ||||
|   FILE *in; | ||||
|   char *kernel_path; | ||||
|   grub_addr_t grub_end = 0; | ||||
|   off_t offset, first_segment; | ||||
|   int i, phdr_size; | ||||
| 
 | ||||
|   /* Read ELF header.  */ | ||||
|   kernel_path = grub_util_get_path (dir, "kernel.img"); | ||||
|   in = fopen (kernel_path, "rb"); | ||||
|   if (! in) | ||||
|     grub_util_error ("cannot open %s", kernel_path); | ||||
| 
 | ||||
|   grub_util_read_at (&ehdr, sizeof (ehdr), 0, in); | ||||
| 
 | ||||
|   offset = ALIGN_UP (sizeof (ehdr), GRUB_TARGET_SIZEOF_LONG); | ||||
|   ehdr.e_phoff = grub_host_to_target32 (offset); | ||||
| 
 | ||||
|   phdr_size = (grub_target_to_host16 (ehdr.e_phentsize) * | ||||
|                grub_target_to_host16 (ehdr.e_phnum)); | ||||
| 
 | ||||
|   if (mods[0] != NULL) | ||||
|     phdr_size += grub_target_to_host16 (ehdr.e_phentsize); | ||||
| 
 | ||||
|   if (chrp) | ||||
|     phdr_size += grub_target_to_host16 (ehdr.e_phentsize); | ||||
| 
 | ||||
|   phdrs = xmalloc (phdr_size); | ||||
|   offset += ALIGN_UP (phdr_size, GRUB_TARGET_SIZEOF_LONG); | ||||
| 
 | ||||
|   first_segment = offset; | ||||
| 
 | ||||
|   /* Copy all existing segments.  */ | ||||
|   for (i = 0; i < grub_target_to_host16 (ehdr.e_phnum); i++) | ||||
|     { | ||||
|       char *segment_img; | ||||
|       grub_size_t segment_end; | ||||
| 
 | ||||
|       phdr = phdrs + i; | ||||
| 
 | ||||
|       /* Read segment header.  */ | ||||
|       grub_util_read_at (phdr, sizeof (Elf32_Phdr), | ||||
| 			 (grub_target_to_host32 (ehdr.e_phoff) | ||||
| 			  + (i * grub_target_to_host16 (ehdr.e_phentsize))), | ||||
| 			 in); | ||||
|       grub_util_info ("copying segment %d, type %d", i, | ||||
| 		      grub_target_to_host32 (phdr->p_type)); | ||||
| 
 | ||||
|       /* Locate _end.  */ | ||||
|       segment_end = grub_target_to_host32 (phdr->p_paddr) | ||||
| 		    + grub_target_to_host32 (phdr->p_memsz); | ||||
|       grub_util_info ("segment %u end 0x%lx", i, segment_end); | ||||
|       if (segment_end > grub_end) | ||||
| 	grub_end = segment_end; | ||||
| 
 | ||||
|       /* Read segment data and write it to new file.  */ | ||||
|       segment_img = xmalloc (grub_target_to_host32 (phdr->p_filesz)); | ||||
| 
 | ||||
|       grub_util_read_at (segment_img, grub_target_to_host32 (phdr->p_filesz), | ||||
| 			 grub_target_to_host32 (phdr->p_offset), in); | ||||
| 
 | ||||
|       phdr->p_offset = grub_host_to_target32 (offset); | ||||
|       grub_util_write_image_at (segment_img, grub_target_to_host32 (phdr->p_filesz), | ||||
| 				offset, out); | ||||
|       offset += ALIGN_UP (grub_target_to_host32 (phdr->p_filesz), | ||||
| 			  GRUB_TARGET_SIZEOF_LONG); | ||||
| 
 | ||||
|       free (segment_img); | ||||
|     } | ||||
| 
 | ||||
|   if (mods[0] != NULL) | ||||
|     { | ||||
|       grub_addr_t modbase; | ||||
| 
 | ||||
|       /* Place modules just after grub segment.  */ | ||||
|       modbase = ALIGN_UP(grub_end + GRUB_MOD_GAP, GRUB_MOD_ALIGN); | ||||
| 
 | ||||
|       /* Construct new segment header for modules.  */ | ||||
|       phdr = phdrs + grub_target_to_host16 (ehdr.e_phnum); | ||||
|       ehdr.e_phnum = grub_host_to_target16 (grub_target_to_host16 (ehdr.e_phnum) + 1); | ||||
| 
 | ||||
|       /* Fill in p_offset so the callees know where to write.  */ | ||||
|       phdr->p_offset = grub_host_to_target32 (ALIGN_UP (grub_util_get_fp_size (out), | ||||
| 							GRUB_TARGET_SIZEOF_LONG)); | ||||
| 
 | ||||
|       load_modules (modbase, phdr, dir, mods, out, memdisk_path, config_path); | ||||
|     } | ||||
| 
 | ||||
|   if (chrp) | ||||
|     { | ||||
|       /* Construct new segment header for the CHRP note.  */ | ||||
|       phdr = phdrs + grub_target_to_host16 (ehdr.e_phnum); | ||||
|       ehdr.e_phnum = grub_host_to_target16 (grub_target_to_host16 (ehdr.e_phnum) + 1); | ||||
| 
 | ||||
|       /* Fill in p_offset so the callees know where to write.  */ | ||||
|       phdr->p_offset = grub_host_to_target32 (ALIGN_UP (grub_util_get_fp_size (out), | ||||
| 							GRUB_TARGET_SIZEOF_LONG)); | ||||
| 
 | ||||
|       load_note (phdr, out); | ||||
|     } | ||||
| 
 | ||||
|   /* Don't bother preserving the section headers.  */ | ||||
|   ehdr.e_shoff = 0; | ||||
|   ehdr.e_shnum = 0; | ||||
|   ehdr.e_shstrndx = 0; | ||||
| 
 | ||||
|   /* Write entire segment table to the file.  */ | ||||
|   grub_util_write_image_at (phdrs, phdr_size, grub_target_to_host32 (ehdr.e_phoff), out); | ||||
| 
 | ||||
|   /* Write ELF header.  */ | ||||
|   grub_util_write_image_at (&ehdr, sizeof (ehdr), 0, out); | ||||
| 
 | ||||
|   if (prefix) | ||||
|     { | ||||
|       if (GRUB_KERNEL_CPU_PREFIX + strlen (prefix) + 1 > GRUB_KERNEL_CPU_DATA_END) | ||||
|         grub_util_error ("prefix too long"); | ||||
|       grub_util_write_image_at (prefix, strlen (prefix) + 1, first_segment + GRUB_KERNEL_CPU_PREFIX, out); | ||||
|     } | ||||
| 
 | ||||
|   free (phdrs); | ||||
|   free (kernel_path); | ||||
| } | ||||
| 
 | ||||
| static struct option options[] = | ||||
|   { | ||||
|     {"directory", required_argument, 0, 'd'}, | ||||
|     {"prefix", required_argument, 0, 'p'}, | ||||
|     {"memdisk", required_argument, 0, 'm'}, | ||||
|     {"config", required_argument, 0, 'c'}, | ||||
|     {"output", required_argument, 0, 'o'}, | ||||
|     {"help", no_argument, 0, 'h'}, | ||||
|     {"note", no_argument, 0, 'n'}, | ||||
|     {"version", no_argument, 0, 'V'}, | ||||
|     {"verbose", no_argument, 0, 'v'}, | ||||
|     { 0, 0, 0, 0 }, | ||||
|   }; | ||||
| 
 | ||||
| static void | ||||
| usage (int status) | ||||
| { | ||||
|   if (status) | ||||
|     fprintf (stderr, "Try `%s --help' for more information.\n", program_name); | ||||
|   else | ||||
|     printf ("\
 | ||||
| Usage: %s -o FILE [OPTION]... [MODULES]\n\ | ||||
| \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\n\ | ||||
|   -m, --memdisk=FILE      embed FILE as a memdisk image\n\ | ||||
|   -c, --config=FILE       embed FILE as boot config\n\ | ||||
|   -o, --output=FILE       output a generated image to FILE\n\ | ||||
|   -h, --help              display this message and exit\n\ | ||||
|   -n, --note              add NOTE segment for CHRP Open Firmware\n\ | ||||
|   -V, --version           print version information and exit\n\ | ||||
|   -v, --verbose           print verbose messages\n\ | ||||
| \n\ | ||||
| Report bugs to <%s>.\n\ | ||||
| ", program_name, GRUB_LIBDIR, PACKAGE_BUGREPORT); | ||||
| 
 | ||||
|   exit (status); | ||||
| } | ||||
| 
 | ||||
| int | ||||
| main (int argc, char *argv[]) | ||||
| { | ||||
|   FILE *fp; | ||||
|   char *output = NULL; | ||||
|   char *dir = NULL; | ||||
|   char *prefix = NULL; | ||||
|   char *memdisk = NULL; | ||||
|   char *config = NULL; | ||||
|   int chrp = 0; | ||||
| 
 | ||||
|   set_program_name (argv[0]); | ||||
| 
 | ||||
|   grub_util_init_nls (); | ||||
| 
 | ||||
|   while (1) | ||||
|     { | ||||
|       int c = getopt_long (argc, argv, "d:p:m:c:o:hVvn", options, 0); | ||||
|       if (c == -1) | ||||
| 	break; | ||||
| 
 | ||||
|       switch (c) | ||||
| 	{ | ||||
| 	  case 'd': | ||||
| 	    if (dir) | ||||
| 	      free (dir); | ||||
| 	    dir = xstrdup (optarg); | ||||
| 	    break; | ||||
| 	  case 'p': | ||||
| 	    if (prefix) | ||||
| 	      free (prefix); | ||||
| 	    prefix = xstrdup (optarg); | ||||
| 	    break; | ||||
| 	  case 'm': | ||||
| 	    if (memdisk) | ||||
| 	      free (memdisk); | ||||
| 	    memdisk = xstrdup (optarg); | ||||
| 
 | ||||
| 	    if (prefix) | ||||
| 	      free (prefix); | ||||
| 	    prefix = xstrdup ("(memdisk)/boot/grub"); | ||||
| 
 | ||||
| 	    break; | ||||
| 	  case 'c': | ||||
| 	    if (config) | ||||
| 	      free (config); | ||||
| 	    config = xstrdup (optarg); | ||||
| 
 | ||||
| 	    break; | ||||
| 
 | ||||
| 	  case 'h': | ||||
| 	    usage (0); | ||||
| 	    break; | ||||
| 	  case 'n': | ||||
| 	    chrp = 1; | ||||
| 	    break; | ||||
| 	  case 'o': | ||||
| 	    if (output) | ||||
| 	      free (output); | ||||
| 	    output = xstrdup (optarg); | ||||
| 	    break; | ||||
| 	  case 'V': | ||||
| 	    printf ("grub-mkimage (%s) %s\n", PACKAGE_NAME, PACKAGE_VERSION); | ||||
| 	    return 0; | ||||
| 	  case 'v': | ||||
| 	    verbosity++; | ||||
| 	    break; | ||||
| 	  default: | ||||
| 	    usage (1); | ||||
| 	    break; | ||||
| 	} | ||||
|   } | ||||
| 
 | ||||
|   if (!output) | ||||
|     usage (1); | ||||
| 
 | ||||
|   fp = fopen (output, "wb"); | ||||
|   if (! fp) | ||||
|     grub_util_error ("cannot open %s", output); | ||||
| 
 | ||||
|   add_segments (dir ? : GRUB_LIBDIR, prefix, fp, chrp, argv + optind, memdisk, | ||||
| 		config); | ||||
| 
 | ||||
|   fclose (fp); | ||||
| 
 | ||||
|   return 0; | ||||
| } | ||||
|  | @ -35,11 +35,7 @@ pkglibdir=${libdir}/`echo ${PACKAGE_TARNAME}/${target_cpu}-${platform} | sed ${t | |||
| localedir=@datadir@/locale | ||||
| 
 | ||||
| grub_setup=${sbindir}/`echo grub-setup | sed ${transform}` | ||||
| if [ "${target_cpu}-${platform}" = "i386-pc" ] || [ "${target_cpu}-${platform}" = "sparc64-ieee1275" ] || [ "${target_cpu}-${platform}" = "mips-yeeloong" ] ; then | ||||
|     grub_mkimage=${bindir}/`echo grub-mkimage | sed ${transform}` | ||||
| else | ||||
|     grub_mkimage=${bindir}/`echo grub-mkelfimage | sed ${transform}` | ||||
| fi | ||||
| grub_mkimage=${bindir}/`echo grub-mkimage | sed ${transform}` | ||||
| grub_mkdevicemap=${sbindir}/`echo grub-mkdevicemap | sed ${transform}` | ||||
| grub_probe=${sbindir}/`echo grub-probe | sed ${transform}` | ||||
| grub_editenv=${bindir}/`echo grub-editenv | sed ${transform}` | ||||
|  | @ -346,16 +342,23 @@ else | |||
|     prefix_drive=`$grub_probe --target=drive --device ${grub_device}` || exit 1 | ||||
| fi | ||||
| 
 | ||||
| case "${target_cpu}-${platform}" | ||||
|     i386-pc) mkimage_target=i386-pc ;; | ||||
|     sparc64-ieee1275) mkimage_target=sparc64-ieee1275-raw ;; | ||||
|     mips-yeeloong) mkimage_target=mipsel-yeeloong-elf ;; | ||||
|     *) mkimage_target=i386-coreboot; | ||||
| esac | ||||
| 
 | ||||
| if [ "${target_cpu}-${platform}" = "i386-pc" ] || [ "${target_cpu}-${platform}" = "sparc64-ieee1275" ] ; then | ||||
|     $grub_mkimage ${config_opt} --output=${grubdir}/core.img --prefix=${prefix_drive}${relative_grubdir} $modules || exit 1 | ||||
|     $grub_mkimage ${config_opt} -O ${mkimage_target} --output=${grubdir}/core.img --prefix=${prefix_drive}${relative_grubdir} $modules || exit 1 | ||||
| 
 | ||||
|     # Now perform the installation. | ||||
|     $grub_setup ${setup_verbose} ${setup_force} --directory=${grubdir} --device-map=${device_map} \ | ||||
|         ${install_device} || exit 1 | ||||
| elif [ "${target_cpu}-${platform}" = "mips-yeeloong" ] ; then | ||||
|     $grub_mkimage ${config_opt} -f ${font} -d ${pkglibdir} -O elf --output=/boot/grub.elf --prefix=${prefix_drive}${relative_grubdir} $modules || exit 1 | ||||
|     $grub_mkimage ${config_opt} -f ${font} -d ${pkglibdir} -O ${mkimage_target} --output=/boot/grub.elf --prefix=${prefix_drive}${relative_grubdir} $modules || exit 1 | ||||
| else | ||||
|     $grub_mkimage ${config_opt} -d ${pkglibdir} --output=/boot/multiboot.img --prefix=${prefix_drive}${relative_grubdir} $modules || exit 1 | ||||
|     $grub_mkimage -O ${mkimage_target} ${config_opt} -d ${pkglibdir} --output=/boot/multiboot.img --prefix=${prefix_drive}${relative_grubdir} $modules || exit 1 | ||||
| fi | ||||
| 
 | ||||
| echo "Installation finished. No error reported." | ||||
|  |  | |||
|  | @ -24,10 +24,10 @@ sbindir=@sbindir@ | |||
| libdir=@libdir@ | ||||
| sysconfdir=@sysconfdir@ | ||||
| package_version=@PACKAGE_VERSION@ | ||||
| host_os=@host_os@ | ||||
| datarootdir=@datarootdir@ | ||||
| datadir=@datadir@ | ||||
| pkgdatadir=${datadir}/`echo @PACKAGE_TARNAME@ | sed "${transform}"` | ||||
| grub_prefix=`echo /boot/grub | sed ${transform}` | ||||
| grub_cfg="" | ||||
| grub_mkconfig_dir=${sysconfdir}/grub.d | ||||
| 
 | ||||
|  | @ -75,6 +75,18 @@ done | |||
| 
 | ||||
| . ${libdir}/grub/grub-mkconfig_lib | ||||
| 
 | ||||
| case "$host_os" in | ||||
| netbsd* | openbsd*) | ||||
|     # Because /boot is used for the boot block in NetBSD and OpenBSD, use /grub | ||||
|     # instead of /boot/grub. | ||||
|     grub_prefix=`echo /grub | sed ${transform}` | ||||
|     ;; | ||||
| *) | ||||
|     # Use /boot/grub by default. | ||||
|     grub_prefix=`echo /boot/grub | sed ${transform}` | ||||
|     ;; | ||||
| esac | ||||
| 
 | ||||
| if [ "x$EUID" = "x" ] ; then | ||||
|   EUID=`id -u` | ||||
| fi | ||||
|  | @ -141,13 +153,13 @@ if [ "x${GRUB_TERMINAL}" != "x" ] ; then | |||
| fi | ||||
| 
 | ||||
| termoutdefault=0 | ||||
| if [ "x${GRUB_TERMINAL_OUTPUT}" == x ]; then | ||||
| if [ "x${GRUB_TERMINAL_OUTPUT}" = "x" ]; then | ||||
|     GRUB_TERMINAL_OUTPUT=gfxterm; | ||||
|     termoutdefault=1; | ||||
| fi | ||||
| 
 | ||||
| for x in ${GRUB_TERMINAL_OUTPUT}; do | ||||
|     if [ x${x} == xgfxterm ]; then | ||||
|     if [ "x${x}" = "xgfxterm" ]; then | ||||
|         # If this platform supports gfxterm, try to use it. | ||||
| 	if ! test -e ${grub_prefix}/gfxterm.mod ; then | ||||
| 	    if [ "x$termoutdefault" != "x1" ]; then | ||||
|  | @ -227,11 +239,14 @@ export GRUB_DEFAULT \ | |||
|   GRUB_DISTRIBUTOR \ | ||||
|   GRUB_CMDLINE_LINUX \ | ||||
|   GRUB_CMDLINE_LINUX_DEFAULT \ | ||||
|   GRUB_CMDLINE_NETBSD \ | ||||
|   GRUB_CMDLINE_NETBSD_DEFAULT \ | ||||
|   GRUB_TERMINAL_INPUT \ | ||||
|   GRUB_TERMINAL_OUTPUT \ | ||||
|   GRUB_SERIAL_COMMAND \ | ||||
|   GRUB_DISABLE_LINUX_UUID \ | ||||
|   GRUB_DISABLE_LINUX_RECOVERY \ | ||||
|   GRUB_DISABLE_NETBSD_RECOVERY \ | ||||
|   GRUB_GFXMODE \ | ||||
|   GRUB_BACKGROUND \ | ||||
|   GRUB_THEME \ | ||||
|  |  | |||
|  | @ -31,6 +31,12 @@ if test "x$grub_mkrelpath" = x; then | |||
|   grub_mkrelpath=${bindir}/`echo grub-mkrelpath | sed ${transform}` | ||||
| fi | ||||
| 
 | ||||
| if $(which gettext >/dev/null 2>/dev/null) ; then | ||||
|   gettext="gettext" | ||||
| else | ||||
|   gettext="echo" | ||||
| fi | ||||
| 
 | ||||
| grub_warn () | ||||
| { | ||||
|   echo "Warning: $@" >&2 | ||||
|  | @ -188,3 +194,7 @@ version_find_latest () | |||
|   done | ||||
|   echo "$a" | ||||
| } | ||||
| 
 | ||||
| gettext_quoted () { | ||||
|   $gettext "$@" | sed "s/'/'\\\\''/g" | ||||
| } | ||||
|  |  | |||
							
								
								
									
										1340
									
								
								util/grub-mkimage.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1340
									
								
								util/grub-mkimage.c
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										756
									
								
								util/grub-mkimagexx.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										756
									
								
								util/grub-mkimagexx.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,756 @@ | |||
| /* grub-mkimage.c - make a bootable image */ | ||||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2002,2003,2004,2005,2006,2007,2008,2009,2010  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #undef ELF_R_SYM | ||||
| #undef ELF_R_TYPE | ||||
| 
 | ||||
| #if defined(MKIMAGE_ELF32) | ||||
| # define SUFFIX(x)	x ## 32 | ||||
| # define ELFCLASSXX	ELFCLASS32 | ||||
| # define Elf_Ehdr	Elf32_Ehdr | ||||
| # define Elf_Phdr	Elf32_Phdr | ||||
| # define Elf_Addr	Elf32_Addr | ||||
| # define Elf_Sym	Elf32_Sym | ||||
| # define Elf_Off	Elf32_Off | ||||
| # define Elf_Shdr	Elf32_Shdr | ||||
| # define Elf_Rela       Elf32_Rela | ||||
| # define Elf_Rel        Elf32_Rel | ||||
| # define ELF_R_SYM(val)		ELF32_R_SYM(val) | ||||
| # define ELF_R_TYPE(val)		ELF32_R_TYPE(val) | ||||
| #elif defined(MKIMAGE_ELF64) | ||||
| # define SUFFIX(x)	x ## 64 | ||||
| # define ELFCLASSXX	ELFCLASS64 | ||||
| # define Elf_Ehdr	Elf64_Ehdr | ||||
| # define Elf_Phdr	Elf64_Phdr | ||||
| # define Elf_Addr	Elf64_Addr | ||||
| # define Elf_Sym	Elf64_Sym | ||||
| # define Elf_Off	Elf64_Off | ||||
| # define Elf_Shdr	Elf64_Shdr | ||||
| # define Elf_Rela       Elf64_Rela | ||||
| # define Elf_Rel        Elf64_Rel | ||||
| # define ELF_R_SYM(val)		ELF64_R_SYM(val) | ||||
| # define ELF_R_TYPE(val)		ELF64_R_TYPE(val) | ||||
| #else | ||||
| #error "I'm confused" | ||||
| #endif | ||||
| 
 | ||||
| /* Relocate symbols; note that this function overwrites the symbol table.
 | ||||
|    Return the address of a start symbol.  */ | ||||
| static Elf_Addr | ||||
| SUFFIX (relocate_symbols) (Elf_Ehdr *e, Elf_Shdr *sections, | ||||
| 			   Elf_Shdr *symtab_section, Elf_Addr *section_addresses, | ||||
| 			   Elf_Half section_entsize, Elf_Half num_sections, | ||||
| 			   struct image_target_desc *image_target) | ||||
| { | ||||
|   Elf_Word symtab_size, sym_size, num_syms; | ||||
|   Elf_Off symtab_offset; | ||||
|   Elf_Addr start_address = 0; | ||||
|   Elf_Sym *sym; | ||||
|   Elf_Word i; | ||||
|   Elf_Shdr *strtab_section; | ||||
|   const char *strtab; | ||||
| 
 | ||||
|   strtab_section | ||||
|     = (Elf_Shdr *) ((char *) sections | ||||
| 		      + (grub_target_to_host32 (symtab_section->sh_link) | ||||
| 			 * section_entsize)); | ||||
|   strtab = (char *) e + grub_target_to_host (strtab_section->sh_offset); | ||||
| 
 | ||||
|   symtab_size = grub_target_to_host (symtab_section->sh_size); | ||||
|   sym_size = grub_target_to_host (symtab_section->sh_entsize); | ||||
|   symtab_offset = grub_target_to_host (symtab_section->sh_offset); | ||||
|   num_syms = symtab_size / sym_size; | ||||
| 
 | ||||
|   for (i = 0, sym = (Elf_Sym *) ((char *) e + symtab_offset); | ||||
|        i < num_syms; | ||||
|        i++, sym = (Elf_Sym *) ((char *) sym + sym_size)) | ||||
|     { | ||||
|       Elf_Section index; | ||||
|       const char *name; | ||||
| 
 | ||||
|       name = strtab + grub_target_to_host32 (sym->st_name); | ||||
| 
 | ||||
|       index = grub_target_to_host16 (sym->st_shndx); | ||||
|       if (index == STN_ABS) | ||||
|         { | ||||
|           continue; | ||||
|         } | ||||
|       else if ((index == STN_UNDEF)) | ||||
| 	{ | ||||
| 	  if (sym->st_name) | ||||
| 	    grub_util_error ("undefined symbol %s", name); | ||||
| 	  else | ||||
| 	    continue; | ||||
| 	} | ||||
|       else if (index >= num_sections) | ||||
| 	grub_util_error ("section %d does not exist", index); | ||||
| 
 | ||||
|       sym->st_value = (grub_target_to_host32 (sym->st_value) | ||||
| 		       + section_addresses[index]); | ||||
|       grub_util_info ("locating %s at 0x%x", name, sym->st_value); | ||||
| 
 | ||||
|       if (! start_address) | ||||
| 	if (strcmp (name, "_start") == 0 || strcmp (name, "start") == 0) | ||||
| 	  start_address = sym->st_value; | ||||
|     } | ||||
| 
 | ||||
|   return start_address; | ||||
| } | ||||
| 
 | ||||
| /* Return the address of a symbol at the index I in the section S.  */ | ||||
| static Elf_Addr | ||||
| SUFFIX (get_symbol_address) (Elf_Ehdr *e, Elf_Shdr *s, Elf_Word i, | ||||
| 			     struct image_target_desc *image_target) | ||||
| { | ||||
|   Elf_Sym *sym; | ||||
| 
 | ||||
|   sym = (Elf_Sym *) ((char *) e | ||||
| 		       + grub_target_to_host32 (s->sh_offset) | ||||
| 		       + i * grub_target_to_host32 (s->sh_entsize)); | ||||
|   return sym->st_value; | ||||
| } | ||||
| 
 | ||||
| /* Return the address of a modified value.  */ | ||||
| static Elf_Addr * | ||||
| SUFFIX (get_target_address) (Elf_Ehdr *e, Elf_Shdr *s, Elf_Addr offset, | ||||
| 		    struct image_target_desc *image_target) | ||||
| { | ||||
|   return (Elf_Addr *) ((char *) e + grub_target_to_host32 (s->sh_offset) + offset); | ||||
| } | ||||
| 
 | ||||
| /* Deal with relocation information. This function relocates addresses
 | ||||
|    within the virtual address space starting from 0. So only relative | ||||
|    addresses can be fully resolved. Absolute addresses must be relocated | ||||
|    again by a PE32 relocator when loaded.  */ | ||||
| static void | ||||
| SUFFIX (relocate_addresses) (Elf_Ehdr *e, Elf_Shdr *sections, | ||||
| 			     Elf_Addr *section_addresses, | ||||
| 			     Elf_Half section_entsize, Elf_Half num_sections, | ||||
| 			     const char *strtab, struct image_target_desc *image_target) | ||||
| { | ||||
|   Elf_Half i; | ||||
|   Elf_Shdr *s; | ||||
| 
 | ||||
|   for (i = 0, s = sections; | ||||
|        i < num_sections; | ||||
|        i++, s = (Elf_Shdr *) ((char *) s + section_entsize)) | ||||
|     if ((s->sh_type == grub_host_to_target32 (SHT_REL)) || | ||||
|         (s->sh_type == grub_host_to_target32 (SHT_RELA))) | ||||
|       { | ||||
| 	Elf_Rela *r; | ||||
| 	Elf_Word rtab_size, r_size, num_rs; | ||||
| 	Elf_Off rtab_offset; | ||||
| 	Elf_Shdr *symtab_section; | ||||
| 	Elf_Word target_section_index; | ||||
| 	Elf_Addr target_section_addr; | ||||
| 	Elf_Shdr *target_section; | ||||
| 	Elf_Word j; | ||||
| 
 | ||||
| 	symtab_section = (Elf_Shdr *) ((char *) sections | ||||
| 					 + (grub_target_to_host32 (s->sh_link) | ||||
| 					    * section_entsize)); | ||||
| 	target_section_index = grub_target_to_host32 (s->sh_info); | ||||
| 	target_section_addr = section_addresses[target_section_index]; | ||||
| 	target_section = (Elf_Shdr *) ((char *) sections | ||||
| 					 + (target_section_index | ||||
| 					    * section_entsize)); | ||||
| 
 | ||||
| 	grub_util_info ("dealing with the relocation section %s for %s", | ||||
| 			strtab + grub_target_to_host32 (s->sh_name), | ||||
| 			strtab + grub_target_to_host32 (target_section->sh_name)); | ||||
| 
 | ||||
| 	rtab_size = grub_target_to_host32 (s->sh_size); | ||||
| 	r_size = grub_target_to_host32 (s->sh_entsize); | ||||
| 	rtab_offset = grub_target_to_host32 (s->sh_offset); | ||||
| 	num_rs = rtab_size / r_size; | ||||
| 
 | ||||
| 	for (j = 0, r = (Elf_Rela *) ((char *) e + rtab_offset); | ||||
| 	     j < num_rs; | ||||
| 	     j++, r = (Elf_Rela *) ((char *) r + r_size)) | ||||
| 	  { | ||||
|             Elf_Addr info; | ||||
| 	    Elf_Addr offset; | ||||
| 	    Elf_Addr sym_addr; | ||||
| 	    Elf_Addr *target; | ||||
| 	    Elf_Addr addend; | ||||
| 
 | ||||
| 	    offset = grub_target_to_host (r->r_offset); | ||||
| 	    target = SUFFIX (get_target_address) (e, target_section, | ||||
| 						  offset, image_target); | ||||
| 	    info = grub_target_to_host (r->r_info); | ||||
| 	    sym_addr = SUFFIX (get_symbol_address) (e, symtab_section, | ||||
| 						    ELF_R_SYM (info), image_target); | ||||
| 
 | ||||
|             addend = (s->sh_type == grub_target_to_host32 (SHT_RELA)) ? | ||||
| 	      r->r_addend : 0; | ||||
| 
 | ||||
| 	    if (image_target->voidp_sizeof == 4) | ||||
| 	      switch (ELF_R_TYPE (info)) | ||||
| 		{ | ||||
| 		case R_386_NONE: | ||||
| 		  break; | ||||
| 
 | ||||
| 		case R_386_32: | ||||
| 		  /* This is absolute.  */ | ||||
| 		  *target = grub_host_to_target32 (grub_target_to_host32 (*target) | ||||
| 						   + addend + sym_addr); | ||||
| 		  grub_util_info ("relocating an R_386_32 entry to 0x%x at the offset 0x%x", | ||||
| 				  *target, offset); | ||||
| 		  break; | ||||
| 
 | ||||
| 		case R_386_PC32: | ||||
| 		  /* This is relative.  */ | ||||
| 		  *target = grub_host_to_target32 (grub_target_to_host32 (*target) | ||||
| 						   + addend + sym_addr | ||||
| 						   - target_section_addr - offset | ||||
| 						   - image_target->vaddr_offset); | ||||
| 		  grub_util_info ("relocating an R_386_PC32 entry to 0x%x at the offset 0x%x", | ||||
| 				  *target, offset); | ||||
| 		  break; | ||||
| 		default: | ||||
| 		  grub_util_error ("unknown relocation type %d", | ||||
| 				   ELF_R_TYPE (info)); | ||||
| 		  break; | ||||
| 		} | ||||
| 	    else | ||||
| 	      switch (ELF_R_TYPE (info)) | ||||
| 		{ | ||||
| 
 | ||||
| 		case R_X86_64_NONE: | ||||
| 		  break; | ||||
| 
 | ||||
| 		case R_X86_64_64: | ||||
| 		  *target = grub_host_to_target64 (grub_target_to_host64 (*target) | ||||
| 						   + addend + sym_addr); | ||||
| 		  grub_util_info ("relocating an R_X86_64_64 entry to 0x%llx at the offset 0x%llx", | ||||
| 				  *target, offset); | ||||
| 		  break; | ||||
| 
 | ||||
| 		case R_X86_64_PC32: | ||||
| 		  { | ||||
| 		    grub_uint32_t *t32 = (grub_uint32_t *) target; | ||||
| 		    *t32 = grub_host_to_target64 (grub_target_to_host32 (*t32) | ||||
| 						  + addend + sym_addr | ||||
| 						  - target_section_addr - offset | ||||
| 						  - image_target->vaddr_offset); | ||||
| 		    grub_util_info ("relocating an R_X86_64_PC32 entry to 0x%x at the offset 0x%llx", | ||||
| 				    *t32, offset); | ||||
| 		    break; | ||||
| 		  } | ||||
| 
 | ||||
| 		case R_X86_64_32: | ||||
| 		case R_X86_64_32S: | ||||
| 		  { | ||||
| 		    grub_uint32_t *t32 = (grub_uint32_t *) target; | ||||
| 		    *t32 = grub_host_to_target64 (grub_target_to_host32 (*t32) | ||||
| 						  + addend + sym_addr); | ||||
| 		    grub_util_info ("relocating an R_X86_64_32(S) entry to 0x%x at the offset 0x%llx", | ||||
| 				    *t32, offset); | ||||
| 		    break; | ||||
| 		  } | ||||
| 
 | ||||
| 		default: | ||||
| 		  grub_util_error ("unknown relocation type %d", | ||||
| 				   ELF_R_TYPE (info)); | ||||
| 		  break; | ||||
| 		} | ||||
| 	  } | ||||
|       } | ||||
| } | ||||
| 
 | ||||
| /* Add a PE32's fixup entry for a relocation. Return the resulting address
 | ||||
|    after having written to the file OUT.  */ | ||||
| static Elf_Addr | ||||
| SUFFIX (add_fixup_entry) (struct fixup_block_list **cblock, grub_uint16_t type, | ||||
| 			  Elf_Addr addr, int flush, Elf_Addr current_address, | ||||
| 			  struct image_target_desc *image_target) | ||||
| { | ||||
|   struct grub_pe32_fixup_block *b; | ||||
| 
 | ||||
|   b = &((*cblock)->b); | ||||
| 
 | ||||
|   /* First, check if it is necessary to write out the current block.  */ | ||||
|   if ((*cblock)->state) | ||||
|     { | ||||
|       if (flush || addr < b->page_rva || b->page_rva + 0x1000 <= addr) | ||||
| 	{ | ||||
| 	  grub_uint32_t size; | ||||
| 
 | ||||
| 	  if (flush) | ||||
| 	    { | ||||
| 	      /* Add as much padding as necessary to align the address
 | ||||
| 		 with a section boundary.  */ | ||||
| 	      Elf_Addr next_address; | ||||
| 	      unsigned padding_size; | ||||
|               size_t index; | ||||
| 
 | ||||
| 	      next_address = current_address + b->block_size; | ||||
| 	      padding_size = ((ALIGN_UP (next_address, image_target->section_align) | ||||
| 			       - next_address) | ||||
| 			      >> 1); | ||||
|               index = ((b->block_size - sizeof (*b)) >> 1); | ||||
|               grub_util_info ("adding %d padding fixup entries", padding_size); | ||||
| 	      while (padding_size--) | ||||
| 		{ | ||||
| 		  b->entries[index++] = 0; | ||||
| 		  b->block_size += 2; | ||||
| 		} | ||||
| 	    } | ||||
|           else if (b->block_size & (8 - 1)) | ||||
|             { | ||||
| 	      /* If not aligned with a 32-bit boundary, add
 | ||||
| 		 a padding entry.  */ | ||||
|               size_t index; | ||||
| 
 | ||||
|               grub_util_info ("adding a padding fixup entry"); | ||||
|               index = ((b->block_size - sizeof (*b)) >> 1); | ||||
|               b->entries[index] = 0; | ||||
|               b->block_size += 2; | ||||
|             } | ||||
| 
 | ||||
|           /* Flush it.  */ | ||||
|           grub_util_info ("writing %d bytes of a fixup block starting at 0x%x", | ||||
|                           b->block_size, b->page_rva); | ||||
|           size = b->block_size; | ||||
| 	  current_address += size; | ||||
| 	  b->page_rva = grub_host_to_target32 (b->page_rva); | ||||
| 	  b->block_size = grub_host_to_target32 (b->block_size); | ||||
| 	  (*cblock)->next = xmalloc (sizeof (**cblock) + 2 * 0x1000); | ||||
| 	  memset ((*cblock)->next, 0, sizeof (**cblock) + 2 * 0x1000); | ||||
| 	  *cblock = (*cblock)->next; | ||||
| 	} | ||||
|     } | ||||
| 
 | ||||
|   b = &((*cblock)->b); | ||||
| 
 | ||||
|   if (! flush) | ||||
|     { | ||||
|       grub_uint16_t entry; | ||||
|       size_t index; | ||||
| 
 | ||||
|       /* If not allocated yet, allocate a block with enough entries.  */ | ||||
|       if (! (*cblock)->state) | ||||
| 	{ | ||||
| 	  (*cblock)->state = 1; | ||||
| 
 | ||||
| 	  /* The spec does not mention the requirement of a Page RVA.
 | ||||
| 	     Here, align the address with a 4K boundary for safety.  */ | ||||
| 	  b->page_rva = (addr & ~(0x1000 - 1)); | ||||
| 	  b->block_size = sizeof (*b); | ||||
| 	} | ||||
| 
 | ||||
|       /* Sanity check.  */ | ||||
|       if (b->block_size >= sizeof (*b) + 2 * 0x1000) | ||||
| 	grub_util_error ("too many fixup entries"); | ||||
| 
 | ||||
|       /* Add a new entry.  */ | ||||
|       index = ((b->block_size - sizeof (*b)) >> 1); | ||||
|       entry = GRUB_PE32_FIXUP_ENTRY (type, addr - b->page_rva); | ||||
|       b->entries[index] = grub_host_to_target16 (entry); | ||||
|       b->block_size += 2; | ||||
|     } | ||||
| 
 | ||||
|   return current_address; | ||||
| } | ||||
| 
 | ||||
| /* Make a .reloc section.  */ | ||||
| static Elf_Addr | ||||
| SUFFIX (make_reloc_section) (Elf_Ehdr *e, void **out, | ||||
| 			     Elf_Addr *section_addresses, Elf_Shdr *sections, | ||||
| 			     Elf_Half section_entsize, Elf_Half num_sections, | ||||
| 			     const char *strtab, struct image_target_desc *image_target) | ||||
| { | ||||
|   Elf_Half i; | ||||
|   Elf_Shdr *s; | ||||
|   struct fixup_block_list *lst, *lst0; | ||||
|   Elf_Addr current_address = 0; | ||||
| 
 | ||||
|   lst = lst0 = xmalloc (sizeof (*lst) + 2 * 0x1000); | ||||
|   memset (lst, 0, sizeof (*lst) + 2 * 0x1000); | ||||
| 
 | ||||
|   for (i = 0, s = sections; | ||||
|        i < num_sections; | ||||
|        i++, s = (Elf_Shdr *) ((char *) s + section_entsize)) | ||||
|     if ((s->sh_type == grub_cpu_to_le32 (SHT_REL)) || | ||||
|         (s->sh_type == grub_cpu_to_le32 (SHT_RELA))) | ||||
|       { | ||||
| 	Elf_Rel *r; | ||||
| 	Elf_Word rtab_size, r_size, num_rs; | ||||
| 	Elf_Off rtab_offset; | ||||
| 	Elf_Addr section_address; | ||||
| 	Elf_Word j; | ||||
| 
 | ||||
| 	grub_util_info ("translating the relocation section %s", | ||||
| 			strtab + grub_le_to_cpu32 (s->sh_name)); | ||||
| 
 | ||||
| 	rtab_size = grub_le_to_cpu32 (s->sh_size); | ||||
| 	r_size = grub_le_to_cpu32 (s->sh_entsize); | ||||
| 	rtab_offset = grub_le_to_cpu32 (s->sh_offset); | ||||
| 	num_rs = rtab_size / r_size; | ||||
| 
 | ||||
| 	section_address = section_addresses[grub_le_to_cpu32 (s->sh_info)]; | ||||
| 
 | ||||
| 	for (j = 0, r = (Elf_Rel *) ((char *) e + rtab_offset); | ||||
| 	     j < num_rs; | ||||
| 	     j++, r = (Elf_Rel *) ((char *) r + r_size)) | ||||
| 	  { | ||||
| 	    Elf_Addr info; | ||||
| 	    Elf_Addr offset; | ||||
| 
 | ||||
| 	    offset = grub_le_to_cpu32 (r->r_offset); | ||||
| 	    info = grub_le_to_cpu32 (r->r_info); | ||||
| 
 | ||||
| 	    /* Necessary to relocate only absolute addresses.  */ | ||||
| 	    if (image_target->voidp_sizeof == 4) | ||||
| 	      { | ||||
| 		if (ELF_R_TYPE (info) == R_386_32) | ||||
| 		  { | ||||
| 		    Elf_Addr addr; | ||||
| 
 | ||||
| 		    addr = section_address + offset; | ||||
| 		    grub_util_info ("adding a relocation entry for 0x%x", addr); | ||||
| 		    current_address | ||||
| 		      = SUFFIX (add_fixup_entry) (&lst, | ||||
| 						  GRUB_PE32_REL_BASED_HIGHLOW, | ||||
| 						  addr, 0, current_address, | ||||
| 						  image_target); | ||||
| 		  } | ||||
| 	      } | ||||
| 	    else | ||||
| 	      { | ||||
| 		if ((ELF_R_TYPE (info) == R_X86_64_32) || | ||||
| 		    (ELF_R_TYPE (info) == R_X86_64_32S)) | ||||
| 		  { | ||||
| 		    grub_util_error ("can\'t add fixup entry for R_X86_64_32(S)"); | ||||
| 		  } | ||||
| 		else if (ELF_R_TYPE (info) == R_X86_64_64) | ||||
| 		  { | ||||
| 		    Elf_Addr addr; | ||||
| 
 | ||||
| 		    addr = section_address + offset; | ||||
| 		    grub_util_info ("adding a relocation entry for 0x%llx", addr); | ||||
| 		    current_address | ||||
| 		      = SUFFIX (add_fixup_entry) (&lst, | ||||
| 						  GRUB_PE32_REL_BASED_DIR64, | ||||
| 						  addr, | ||||
| 						  0, current_address, | ||||
| 						  image_target); | ||||
| 		  } | ||||
| 	      } | ||||
| 	  } | ||||
|       } | ||||
| 
 | ||||
|   current_address = SUFFIX (add_fixup_entry) (&lst, 0, 0, 1, current_address, image_target); | ||||
| 
 | ||||
|   { | ||||
|     grub_uint8_t *ptr; | ||||
|     ptr = *out = xmalloc (current_address); | ||||
|     for (lst = lst0; lst; lst = lst->next) | ||||
|       if (lst->state) | ||||
| 	{ | ||||
| 	  memcpy (ptr, &lst->b, grub_target_to_host32 (lst->b.block_size)); | ||||
| 	  ptr += grub_target_to_host32 (lst->b.block_size); | ||||
| 	} | ||||
|     if (current_address + *out != ptr) | ||||
|       { | ||||
| 	grub_util_error ("Bug detected %d != %d\n", ptr - (grub_uint8_t *) *out, | ||||
| 			 current_address); | ||||
|       } | ||||
|   } | ||||
| 
 | ||||
|   return current_address; | ||||
| } | ||||
| 
 | ||||
| /* Determine if this section is a text section. Return false if this
 | ||||
|    section is not allocated.  */ | ||||
| static int | ||||
| SUFFIX (is_text_section) (Elf_Shdr *s, struct image_target_desc *image_target) | ||||
| { | ||||
|   if (image_target->id != IMAGE_EFI  | ||||
|       && grub_target_to_host32 (s->sh_type) != SHT_PROGBITS) | ||||
|     return 0; | ||||
|   return ((grub_target_to_host (s->sh_flags) & (SHF_EXECINSTR | SHF_ALLOC)) | ||||
| 	  == (SHF_EXECINSTR | SHF_ALLOC)); | ||||
| } | ||||
| 
 | ||||
| /* Determine if this section is a data section. This assumes that
 | ||||
|    BSS is also a data section, since the converter initializes BSS | ||||
|    when producing PE32 to avoid a bug in EFI implementations.  */ | ||||
| static int | ||||
| SUFFIX (is_data_section) (Elf_Shdr *s, struct image_target_desc *image_target) | ||||
| { | ||||
|   if (image_target->id != IMAGE_EFI  | ||||
|       && grub_target_to_host32 (s->sh_type) != SHT_PROGBITS) | ||||
|     return 0; | ||||
|   return ((grub_target_to_host (s->sh_flags) & (SHF_EXECINSTR | SHF_ALLOC)) | ||||
| 	  == SHF_ALLOC); | ||||
| } | ||||
| 
 | ||||
| /* Return if the ELF header is valid.  */ | ||||
| static int | ||||
| SUFFIX (check_elf_header) (Elf_Ehdr *e, size_t size, struct image_target_desc *image_target) | ||||
| { | ||||
|   if (size < sizeof (*e) | ||||
|       || e->e_ident[EI_MAG0] != ELFMAG0 | ||||
|       || e->e_ident[EI_MAG1] != ELFMAG1 | ||||
|       || e->e_ident[EI_MAG2] != ELFMAG2 | ||||
|       || e->e_ident[EI_MAG3] != ELFMAG3 | ||||
|       || e->e_ident[EI_VERSION] != EV_CURRENT | ||||
|       || e->e_ident[EI_CLASS] != ELFCLASSXX | ||||
|       || e->e_version != grub_host_to_target32 (EV_CURRENT)) | ||||
|     return 0; | ||||
| 
 | ||||
|   return 1; | ||||
| } | ||||
| 
 | ||||
| /* Locate section addresses by merging code sections and data sections
 | ||||
|    into .text and .data, respectively. Return the array of section | ||||
|    addresses.  */ | ||||
| static Elf_Addr * | ||||
| SUFFIX (locate_sections) (Elf_Shdr *sections, Elf_Half section_entsize, | ||||
| 			  Elf_Half num_sections, const char *strtab, | ||||
| 			  grub_size_t *exec_size, grub_size_t *kernel_sz, | ||||
| 			  grub_size_t *all_align, | ||||
| 			  struct image_target_desc *image_target) | ||||
| { | ||||
|   int i; | ||||
|   Elf_Addr current_address; | ||||
|   Elf_Addr *section_addresses; | ||||
|   Elf_Shdr *s; | ||||
| 
 | ||||
|   *all_align = 1; | ||||
| 
 | ||||
|   section_addresses = xmalloc (sizeof (*section_addresses) * num_sections); | ||||
|   memset (section_addresses, 0, sizeof (*section_addresses) * num_sections); | ||||
| 
 | ||||
|   current_address = 0; | ||||
| 
 | ||||
|   for (i = 0, s = sections; | ||||
|        i < num_sections; | ||||
|        i++, s = (Elf_Shdr *) ((char *) s + section_entsize)) | ||||
|     if ((grub_target_to_host (s->sh_flags) & SHF_ALLOC)  | ||||
| 	&& grub_host_to_target32 (s->sh_addralign) > *all_align) | ||||
|       *all_align = grub_host_to_target32 (s->sh_addralign); | ||||
| 
 | ||||
| 
 | ||||
|   /* .text */ | ||||
|   for (i = 0, s = sections; | ||||
|        i < num_sections; | ||||
|        i++, s = (Elf_Shdr *) ((char *) s + section_entsize)) | ||||
|     if (SUFFIX (is_text_section) (s, image_target)) | ||||
|       { | ||||
| 	Elf_Word align = grub_host_to_target32 (s->sh_addralign); | ||||
| 	const char *name = strtab + grub_host_to_target32 (s->sh_name); | ||||
| 	if (align) | ||||
| 	  current_address = ALIGN_UP (current_address + image_target->vaddr_offset, | ||||
| 				      align) - image_target->vaddr_offset; | ||||
| 	grub_util_info ("locating the section %s at 0x%x", | ||||
| 			name, current_address); | ||||
| 	section_addresses[i] = current_address; | ||||
| 	current_address += grub_host_to_target_addr (s->sh_size); | ||||
|       } | ||||
| 
 | ||||
|   current_address = ALIGN_UP (current_address + image_target->vaddr_offset, | ||||
| 			      image_target->section_align) | ||||
|     - image_target->vaddr_offset; | ||||
|   *exec_size = current_address; | ||||
| 
 | ||||
|   /* .data */ | ||||
|   for (i = 0, s = sections; | ||||
|        i < num_sections; | ||||
|        i++, s = (Elf_Shdr *) ((char *) s + section_entsize)) | ||||
|     if (SUFFIX (is_data_section) (s, image_target)) | ||||
|       { | ||||
| 	Elf_Word align = grub_host_to_target32 (s->sh_addralign); | ||||
| 	const char *name = strtab + grub_host_to_target32 (s->sh_name); | ||||
| 
 | ||||
| 	if (align) | ||||
| 	  current_address = ALIGN_UP (current_address + image_target->vaddr_offset, | ||||
| 				      align) | ||||
| 	    - image_target->vaddr_offset; | ||||
| 
 | ||||
| 	grub_util_info ("locating the section %s at 0x%x", | ||||
| 			name, current_address); | ||||
| 	section_addresses[i] = current_address; | ||||
| 	current_address += grub_host_to_target_addr (s->sh_size); | ||||
|       } | ||||
| 
 | ||||
|   current_address = ALIGN_UP (current_address + image_target->vaddr_offset, | ||||
| 			      image_target->section_align) - image_target->vaddr_offset; | ||||
|   *kernel_sz = current_address; | ||||
|   return section_addresses; | ||||
| } | ||||
| 
 | ||||
| static char * | ||||
| SUFFIX (load_image) (const char *kernel_path, grub_size_t *exec_size,  | ||||
| 		     grub_size_t *kernel_sz, grub_size_t *bss_size, | ||||
| 		     grub_size_t total_module_size, grub_uint64_t *start, | ||||
| 		     void **reloc_section, grub_size_t *reloc_size, | ||||
| 		     grub_size_t *align, | ||||
| 		     struct image_target_desc *image_target) | ||||
| { | ||||
|   char *kernel_img, *out_img; | ||||
|   const char *strtab; | ||||
|   Elf_Ehdr *e; | ||||
|   Elf_Shdr *sections; | ||||
|   Elf_Addr *section_addresses; | ||||
|   Elf_Addr *section_vaddresses; | ||||
|   int i; | ||||
|   Elf_Shdr *s; | ||||
|   Elf_Half num_sections; | ||||
|   Elf_Off section_offset; | ||||
|   Elf_Half section_entsize; | ||||
|   grub_size_t kernel_size; | ||||
|   Elf_Shdr *symtab_section; | ||||
| 
 | ||||
|   *start = 0; | ||||
| 
 | ||||
|   kernel_size = grub_util_get_image_size (kernel_path); | ||||
|   kernel_img = xmalloc (kernel_size); | ||||
|   grub_util_load_image (kernel_path, kernel_img); | ||||
| 
 | ||||
|   e = (Elf_Ehdr *) kernel_img; | ||||
|   if (! SUFFIX (check_elf_header) (e, kernel_size, image_target)) | ||||
|     grub_util_error ("invalid ELF header"); | ||||
| 
 | ||||
|   section_offset = grub_target_to_host (e->e_shoff); | ||||
|   section_entsize = grub_target_to_host16 (e->e_shentsize); | ||||
|   num_sections = grub_target_to_host16 (e->e_shnum); | ||||
| 
 | ||||
|   if (kernel_size < section_offset + section_entsize * num_sections) | ||||
|     grub_util_error ("invalid ELF format"); | ||||
| 
 | ||||
|   sections = (Elf_Shdr *) (kernel_img + section_offset); | ||||
| 
 | ||||
|   /* Relocate sections then symbols in the virtual address space.  */ | ||||
|   s = (Elf_Shdr *) ((char *) sections | ||||
| 		      + grub_host_to_target16 (e->e_shstrndx) * section_entsize); | ||||
|   strtab = (char *) e + grub_host_to_target32 (s->sh_offset); | ||||
| 
 | ||||
|   section_addresses = SUFFIX (locate_sections) (sections, section_entsize, | ||||
| 						num_sections, strtab, | ||||
| 						exec_size, kernel_sz, align, | ||||
| 						image_target); | ||||
| 
 | ||||
|   section_vaddresses = xmalloc (sizeof (*section_addresses) * num_sections); | ||||
| 
 | ||||
|   for (i = 0; i < num_sections; i++) | ||||
|     section_vaddresses[i] = section_addresses[i] + image_target->vaddr_offset; | ||||
| 
 | ||||
|   if (image_target->id != IMAGE_EFI) | ||||
|     { | ||||
|       Elf_Addr current_address = *kernel_sz; | ||||
| 
 | ||||
|       for (i = 0, s = sections; | ||||
| 	   i < num_sections; | ||||
| 	   i++, s = (Elf_Shdr *) ((char *) s + section_entsize)) | ||||
| 	if (grub_target_to_host32 (s->sh_type) == SHT_NOBITS) | ||||
| 	  { | ||||
| 	    Elf_Word align = grub_host_to_target32 (s->sh_addralign); | ||||
| 	    const char *name = strtab + grub_host_to_target32 (s->sh_name); | ||||
| 
 | ||||
| 	    if (align) | ||||
| 	      current_address = ALIGN_UP (current_address | ||||
| 					  + image_target->vaddr_offset, align) | ||||
| 		- image_target->vaddr_offset; | ||||
| 	 | ||||
| 	    grub_util_info ("locating the section %s at 0x%x", | ||||
| 			    name, current_address); | ||||
| 	    section_vaddresses[i] = current_address | ||||
| 	      + image_target->vaddr_offset; | ||||
| 	    current_address += grub_host_to_target_addr (s->sh_size); | ||||
| 	  } | ||||
|       current_address = ALIGN_UP (current_address + image_target->vaddr_offset, | ||||
| 				  image_target->section_align) | ||||
| 	- image_target->vaddr_offset; | ||||
|       *bss_size = current_address - *kernel_sz; | ||||
|     } | ||||
|   else | ||||
|     *bss_size = 0; | ||||
| 
 | ||||
|   if (image_target->id == IMAGE_EFI) | ||||
|     { | ||||
|       symtab_section = NULL; | ||||
|       for (i = 0, s = sections; | ||||
| 	   i < num_sections; | ||||
| 	   i++, s = (Elf_Shdr *) ((char *) s + section_entsize)) | ||||
| 	if (s->sh_type == grub_host_to_target32 (SHT_SYMTAB)) | ||||
| 	  { | ||||
| 	    symtab_section = s; | ||||
| 	    break; | ||||
| 	  } | ||||
| 
 | ||||
|       if (! symtab_section) | ||||
| 	grub_util_error ("no symbol table"); | ||||
| 
 | ||||
|       *start = SUFFIX (relocate_symbols) (e, sections, symtab_section, | ||||
| 					  section_vaddresses, section_entsize, | ||||
| 					  num_sections, image_target); | ||||
|       if (*start == 0) | ||||
| 	grub_util_error ("start symbol is not defined"); | ||||
|        | ||||
|       /* Resolve addresses in the virtual address space.  */ | ||||
|       SUFFIX (relocate_addresses) (e, sections, section_addresses, section_entsize, | ||||
| 				   num_sections, strtab, image_target); | ||||
| 	   | ||||
|       *reloc_size = SUFFIX (make_reloc_section) (e, reloc_section, | ||||
| 						 section_vaddresses, sections, | ||||
| 						 section_entsize, num_sections, | ||||
| 						 strtab, image_target); | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       *reloc_size = 0; | ||||
|       *reloc_section = NULL; | ||||
|     } | ||||
| 
 | ||||
|   out_img = xmalloc (*kernel_sz + total_module_size); | ||||
| 
 | ||||
|   for (i = 0, s = sections; | ||||
|        i < num_sections; | ||||
|        i++, s = (Elf_Shdr *) ((char *) s + section_entsize)) | ||||
|     if (SUFFIX (is_data_section) (s, image_target) | ||||
| 	|| SUFFIX (is_text_section) (s, image_target)) | ||||
|       { | ||||
| 	if (grub_target_to_host32 (s->sh_type) == SHT_NOBITS) | ||||
| 	  memset (out_img + section_addresses[i], 0, | ||||
| 		  grub_host_to_target_addr (s->sh_size)); | ||||
| 	else | ||||
| 	  memcpy (out_img + section_addresses[i], | ||||
| 		  kernel_img + grub_host_to_target_addr (s->sh_offset), | ||||
| 		  grub_host_to_target_addr (s->sh_size)); | ||||
|       } | ||||
|   free (kernel_img); | ||||
| 
 | ||||
|   return out_img; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| #undef SUFFIX | ||||
| #undef ELFCLASSXX | ||||
| #undef Elf_Ehdr | ||||
| #undef Elf_Phdr | ||||
| #undef Elf_Shdr | ||||
| #undef Elf_Addr | ||||
| #undef Elf_Sym | ||||
| #undef Elf_Off | ||||
| #undef Elf_Rela | ||||
| #undef Elf_Rel | ||||
| #undef ELF_R_TYPE | ||||
| #undef ELF_R_SYM | ||||
|  | @ -1,648 +0,0 @@ | |||
| /* grub-mkimage.c - make a bootable image */ | ||||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2002,2003,2004,2005,2006,2007,2008,2009,2010  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include <config.h> | ||||
| #include <grub/types.h> | ||||
| #include <grub/machine/boot.h> | ||||
| #include <grub/machine/kernel.h> | ||||
| #include <grub/machine/memory.h> | ||||
| #include <grub/elf.h> | ||||
| #include <grub/aout.h> | ||||
| #include <grub/i18n.h> | ||||
| #include <grub/kernel.h> | ||||
| #include <grub/disk.h> | ||||
| #include <grub/util/misc.h> | ||||
| #include <grub/util/resolve.h> | ||||
| #include <grub/misc.h> | ||||
| 
 | ||||
| #include <stdio.h> | ||||
| #include <unistd.h> | ||||
| #include <string.h> | ||||
| #include <stdlib.h> | ||||
| #include <assert.h> | ||||
| 
 | ||||
| #define _GNU_SOURCE	1 | ||||
| #include <getopt.h> | ||||
| 
 | ||||
| #include "progname.h" | ||||
| 
 | ||||
| #define ALIGN_ADDR(x) (ALIGN_UP((x), GRUB_TARGET_SIZEOF_VOID_P)) | ||||
| 
 | ||||
| #ifdef ENABLE_LZMA | ||||
| #include <grub/lib/LzmaEnc.h> | ||||
| 
 | ||||
| static void *SzAlloc(void *p, size_t size) { p = p; return xmalloc(size); } | ||||
| static void SzFree(void *p, void *address) { p = p; free(address); } | ||||
| static ISzAlloc g_Alloc = { SzAlloc, SzFree }; | ||||
| 
 | ||||
| static void | ||||
| compress_kernel (char *kernel_img, size_t kernel_size, | ||||
| 		 char **core_img, size_t *core_size) | ||||
| { | ||||
|   CLzmaEncProps props; | ||||
|   unsigned char out_props[5]; | ||||
|   size_t out_props_size = 5; | ||||
| 
 | ||||
|   LzmaEncProps_Init(&props); | ||||
|   props.dictSize = 1 << 16; | ||||
|   props.lc = 3; | ||||
|   props.lp = 0; | ||||
|   props.pb = 2; | ||||
|   props.numThreads = 1; | ||||
| 
 | ||||
|   if (kernel_size < GRUB_KERNEL_MACHINE_RAW_SIZE) | ||||
|     grub_util_error (_("the core image is too small")); | ||||
| 
 | ||||
|   *core_img = xmalloc (kernel_size); | ||||
|   memcpy (*core_img, kernel_img, GRUB_KERNEL_MACHINE_RAW_SIZE); | ||||
| 
 | ||||
|   *core_size = kernel_size - GRUB_KERNEL_MACHINE_RAW_SIZE; | ||||
|   if (LzmaEncode((unsigned char *) *core_img + GRUB_KERNEL_MACHINE_RAW_SIZE, | ||||
|                  core_size, | ||||
|                  (unsigned char *) kernel_img + GRUB_KERNEL_MACHINE_RAW_SIZE, | ||||
|                  kernel_size - GRUB_KERNEL_MACHINE_RAW_SIZE, | ||||
|                  &props, out_props, &out_props_size, | ||||
|                  0, NULL, &g_Alloc, &g_Alloc) != SZ_OK) | ||||
|     grub_util_error (_("cannot compress the kernel image")); | ||||
| 
 | ||||
|   *core_size += GRUB_KERNEL_MACHINE_RAW_SIZE; | ||||
| } | ||||
| 
 | ||||
| #else	/* No lzma compression */ | ||||
| 
 | ||||
| static void | ||||
| compress_kernel (char *kernel_img, size_t kernel_size, | ||||
|                char **core_img, size_t *core_size) | ||||
| { | ||||
|   *core_img = xmalloc (kernel_size); | ||||
|   memcpy (*core_img, kernel_img, kernel_size); | ||||
|   *core_size = kernel_size; | ||||
| } | ||||
| 
 | ||||
| #endif	/* No lzma compression */ | ||||
| 
 | ||||
| static void | ||||
| generate_image (const char *dir, char *prefix, FILE *out, char *mods[], | ||||
| 		char *memdisk_path, char *font_path, char *config_path, | ||||
| #ifdef GRUB_PLATFORM_IMAGE_DEFAULT | ||||
| 		grub_platform_image_format_t format | ||||
| #else | ||||
| 		int dummy __attribute__ ((unused)) | ||||
| #endif | ||||
| 
 | ||||
| ) | ||||
| { | ||||
|   char *kernel_img, *core_img; | ||||
|   size_t kernel_size, total_module_size, core_size; | ||||
|   size_t memdisk_size = 0, font_size = 0, config_size = 0, config_size_pure = 0; | ||||
|   char *kernel_path; | ||||
|   size_t offset; | ||||
|   struct grub_util_path_list *path_list, *p, *next; | ||||
|   struct grub_module_info *modinfo; | ||||
| 
 | ||||
|   path_list = grub_util_resolve_dependencies (dir, "moddep.lst", mods); | ||||
| 
 | ||||
|   kernel_path = grub_util_get_path (dir, "kernel.img"); | ||||
|   kernel_size = grub_util_get_image_size (kernel_path); | ||||
| 
 | ||||
|   total_module_size = sizeof (struct grub_module_info); | ||||
| 
 | ||||
|   if (memdisk_path) | ||||
|     { | ||||
|       memdisk_size = ALIGN_UP(grub_util_get_image_size (memdisk_path), 512); | ||||
|       grub_util_info ("the size of memory disk is 0x%x", memdisk_size); | ||||
|       total_module_size += memdisk_size + sizeof (struct grub_module_header); | ||||
|     } | ||||
| 
 | ||||
|   if (font_path) | ||||
|     { | ||||
|       font_size = ALIGN_ADDR (grub_util_get_image_size (font_path)); | ||||
|       total_module_size += font_size + sizeof (struct grub_module_header); | ||||
|     } | ||||
| 
 | ||||
|   if (config_path) | ||||
|     { | ||||
|       config_size_pure = grub_util_get_image_size (config_path) + 1; | ||||
|       config_size = ALIGN_ADDR (config_size_pure); | ||||
|       grub_util_info ("the size of config file is 0x%x", config_size); | ||||
|       total_module_size += config_size + sizeof (struct grub_module_header); | ||||
|     } | ||||
| 
 | ||||
|   for (p = path_list; p; p = p->next) | ||||
|     total_module_size += (ALIGN_ADDR (grub_util_get_image_size (p->name)) | ||||
| 			  + sizeof (struct grub_module_header)); | ||||
| 
 | ||||
|   grub_util_info ("the total module size is 0x%x", total_module_size); | ||||
| 
 | ||||
|   kernel_img = xmalloc (kernel_size + total_module_size); | ||||
|   grub_util_load_image (kernel_path, kernel_img); | ||||
| 
 | ||||
|   if (GRUB_KERNEL_MACHINE_PREFIX + strlen (prefix) + 1 > GRUB_KERNEL_MACHINE_DATA_END) | ||||
|     grub_util_error (_("prefix is too long")); | ||||
|   strcpy (kernel_img + GRUB_KERNEL_MACHINE_PREFIX, prefix); | ||||
| 
 | ||||
|   /* Fill in the grub_module_info structure.  */ | ||||
|   modinfo = (struct grub_module_info *) (kernel_img + kernel_size); | ||||
|   memset (modinfo, 0, sizeof (struct grub_module_info)); | ||||
|   modinfo->magic = grub_host_to_target32 (GRUB_MODULE_MAGIC); | ||||
|   modinfo->offset = grub_host_to_target_addr (sizeof (struct grub_module_info)); | ||||
|   modinfo->size = grub_host_to_target_addr (total_module_size); | ||||
| 
 | ||||
|   offset = kernel_size + sizeof (struct grub_module_info); | ||||
|   for (p = path_list; p; p = p->next) | ||||
|     { | ||||
|       struct grub_module_header *header; | ||||
|       size_t mod_size, orig_size; | ||||
| 
 | ||||
|       orig_size = grub_util_get_image_size (p->name); | ||||
|       mod_size = ALIGN_ADDR (orig_size); | ||||
| 
 | ||||
|       header = (struct grub_module_header *) (kernel_img + offset); | ||||
|       memset (header, 0, sizeof (struct grub_module_header)); | ||||
|       header->type = grub_host_to_target32 (OBJ_TYPE_ELF); | ||||
|       header->size = grub_host_to_target32 (mod_size + sizeof (*header)); | ||||
|       offset += sizeof (*header); | ||||
|       memset (kernel_img + offset + orig_size, 0, mod_size - orig_size); | ||||
| 
 | ||||
|       grub_util_load_image (p->name, kernel_img + offset); | ||||
|       offset += mod_size; | ||||
|     } | ||||
| 
 | ||||
|   if (memdisk_path) | ||||
|     { | ||||
|       struct grub_module_header *header; | ||||
| 
 | ||||
|       header = (struct grub_module_header *) (kernel_img + offset); | ||||
|       memset (header, 0, sizeof (struct grub_module_header)); | ||||
|       header->type = grub_host_to_target32 (OBJ_TYPE_MEMDISK); | ||||
|       header->size = grub_host_to_target32 (memdisk_size + sizeof (*header)); | ||||
|       offset += sizeof (*header); | ||||
| 
 | ||||
|       grub_util_load_image (memdisk_path, kernel_img + offset); | ||||
|       offset += memdisk_size; | ||||
|     } | ||||
| 
 | ||||
|   if (font_path) | ||||
|     { | ||||
|       struct grub_module_header *header; | ||||
| 
 | ||||
|       header = (struct grub_module_header *) (kernel_img + offset); | ||||
|       memset (header, 0, sizeof (struct grub_module_header)); | ||||
|       header->type = grub_host_to_target32 (OBJ_TYPE_FONT); | ||||
|       header->size = grub_host_to_target32 (font_size + sizeof (*header)); | ||||
|       offset += sizeof (*header); | ||||
| 
 | ||||
|       grub_util_load_image (font_path, kernel_img + offset); | ||||
|       offset += font_size; | ||||
|     } | ||||
| 
 | ||||
|   if (config_path) | ||||
|     { | ||||
|       struct grub_module_header *header; | ||||
| 
 | ||||
|       header = (struct grub_module_header *) (kernel_img + offset); | ||||
|       memset (header, 0, sizeof (struct grub_module_header)); | ||||
|       header->type = grub_host_to_target32 (OBJ_TYPE_CONFIG); | ||||
|       header->size = grub_host_to_target32 (config_size + sizeof (*header)); | ||||
|       offset += sizeof (*header); | ||||
| 
 | ||||
|       grub_util_load_image (config_path, kernel_img + offset); | ||||
|       *(kernel_img + offset + config_size_pure - 1) = 0; | ||||
|       offset += config_size; | ||||
|     } | ||||
| 
 | ||||
|   grub_util_info ("kernel_img=%p, kernel_size=0x%x", kernel_img, kernel_size); | ||||
|   compress_kernel (kernel_img, kernel_size + total_module_size, | ||||
| 		   &core_img, &core_size); | ||||
| 
 | ||||
|   grub_util_info ("the core size is 0x%x", core_size); | ||||
| 
 | ||||
| #ifdef GRUB_KERNEL_MACHINE_TOTAL_MODULE_SIZE | ||||
|   *((grub_uint32_t *) (core_img + GRUB_KERNEL_MACHINE_TOTAL_MODULE_SIZE)) | ||||
|     = grub_host_to_target32 (total_module_size); | ||||
| #endif | ||||
|   *((grub_uint32_t *) (core_img + GRUB_KERNEL_MACHINE_KERNEL_IMAGE_SIZE)) | ||||
|     = grub_host_to_target32 (kernel_size); | ||||
| #ifdef GRUB_KERNEL_MACHINE_COMPRESSED_SIZE | ||||
|   *((grub_uint32_t *) (core_img + GRUB_KERNEL_MACHINE_COMPRESSED_SIZE)) | ||||
|     = grub_host_to_target32 (core_size - GRUB_KERNEL_MACHINE_RAW_SIZE); | ||||
| #endif | ||||
| 
 | ||||
| #if defined(GRUB_KERNEL_MACHINE_INSTALL_DOS_PART) && defined(GRUB_KERNEL_MACHINE_INSTALL_BSD_PART) | ||||
|   /* If we included a drive in our prefix, let GRUB know it doesn't have to
 | ||||
|      prepend the drive told by BIOS.  */ | ||||
|   if (prefix[0] == '(') | ||||
|     { | ||||
|       *((grub_int32_t *) (core_img + GRUB_KERNEL_MACHINE_INSTALL_DOS_PART)) | ||||
| 	= grub_host_to_target32 (-2); | ||||
|       *((grub_int32_t *) (core_img + GRUB_KERNEL_MACHINE_INSTALL_BSD_PART)) | ||||
| 	= grub_host_to_target32 (-2); | ||||
|     } | ||||
| #endif | ||||
| 
 | ||||
| #ifdef GRUB_MACHINE_PCBIOS | ||||
|   if (GRUB_KERNEL_MACHINE_LINK_ADDR + core_size > GRUB_MEMORY_MACHINE_UPPER) | ||||
|     grub_util_error (_("core image is too big (%p > %p)"), | ||||
|  		     GRUB_KERNEL_MACHINE_LINK_ADDR + core_size, | ||||
| 		     GRUB_MEMORY_MACHINE_UPPER); | ||||
| #endif | ||||
| 
 | ||||
| #if defined(GRUB_MACHINE_PCBIOS) | ||||
|   { | ||||
|     unsigned num; | ||||
|     char *boot_path, *boot_img; | ||||
|     size_t boot_size; | ||||
|     num = ((core_size + GRUB_DISK_SECTOR_SIZE - 1) >> GRUB_DISK_SECTOR_BITS); | ||||
|     if (num > 0xffff) | ||||
|       grub_util_error (_("the core image is too big")); | ||||
| 
 | ||||
|     boot_path = grub_util_get_path (dir, "diskboot.img"); | ||||
|     boot_size = grub_util_get_image_size (boot_path); | ||||
|     if (boot_size != GRUB_DISK_SECTOR_SIZE) | ||||
|       grub_util_error (_("diskboot.img size must be %u bytes"), | ||||
| 		       GRUB_DISK_SECTOR_SIZE); | ||||
| 
 | ||||
|     boot_img = grub_util_read_image (boot_path); | ||||
| 
 | ||||
|     { | ||||
|       struct grub_boot_blocklist *block; | ||||
|       block = (struct grub_boot_blocklist *) (boot_img | ||||
| 					      + GRUB_DISK_SECTOR_SIZE | ||||
| 					      - sizeof (*block)); | ||||
|       block->len = grub_host_to_target16 (num); | ||||
| 
 | ||||
|       /* This is filled elsewhere.  Verify it just in case.  */ | ||||
|       assert (block->segment | ||||
| 	      == grub_host_to_target16 (GRUB_BOOT_MACHINE_KERNEL_SEG | ||||
| 					+ (GRUB_DISK_SECTOR_SIZE >> 4))); | ||||
|     } | ||||
| 
 | ||||
|     grub_util_write_image (boot_img, boot_size, out); | ||||
|     free (boot_img); | ||||
|     free (boot_path); | ||||
|   } | ||||
| #elif defined(GRUB_MACHINE_QEMU) | ||||
|   { | ||||
|     char *rom_img; | ||||
|     size_t rom_size; | ||||
|     char *boot_path, *boot_img; | ||||
|     size_t boot_size; | ||||
| 
 | ||||
|     boot_path = grub_util_get_path (dir, "boot.img"); | ||||
|     boot_size = grub_util_get_image_size (boot_path); | ||||
|     boot_img = grub_util_read_image (boot_path); | ||||
| 
 | ||||
|     /* Rom sizes must be 64k-aligned.  */ | ||||
|     rom_size = ALIGN_UP (core_size + boot_size, 64 * 1024); | ||||
| 
 | ||||
|     rom_img = xmalloc (rom_size); | ||||
|     memset (rom_img, 0, rom_size); | ||||
| 
 | ||||
|     *((grub_int32_t *) (core_img + GRUB_KERNEL_MACHINE_CORE_ENTRY_ADDR)) | ||||
|       = grub_host_to_target32 ((grub_uint32_t) -rom_size); | ||||
| 
 | ||||
|     memcpy (rom_img, core_img, core_size); | ||||
| 
 | ||||
|     *((grub_int32_t *) (boot_img + GRUB_BOOT_MACHINE_CORE_ENTRY_ADDR)) | ||||
|       = grub_host_to_target32 ((grub_uint32_t) -rom_size); | ||||
| 
 | ||||
|     memcpy (rom_img + rom_size - boot_size, boot_img, boot_size); | ||||
| 
 | ||||
|     free (core_img); | ||||
|     core_img = rom_img; | ||||
|     core_size = rom_size; | ||||
| 
 | ||||
|     free (boot_img); | ||||
|     free (boot_path); | ||||
|   } | ||||
| #elif defined (GRUB_MACHINE_SPARC64) | ||||
|   if (format == GRUB_PLATFORM_IMAGE_AOUT) | ||||
|     { | ||||
|       void *aout_img; | ||||
|       size_t aout_size; | ||||
|       struct grub_aout32_header *aout_head; | ||||
| 
 | ||||
|       aout_size = core_size + sizeof (*aout_head); | ||||
|       aout_img = xmalloc (aout_size); | ||||
|       aout_head = aout_img; | ||||
|       aout_head->a_midmag = grub_host_to_target32 ((AOUT_MID_SUN << 16) | ||||
| 						   | AOUT32_OMAGIC); | ||||
|       aout_head->a_text = grub_host_to_target32 (core_size); | ||||
|       aout_head->a_entry | ||||
| 	= grub_host_to_target32 (GRUB_BOOT_MACHINE_IMAGE_ADDRESS); | ||||
|       memcpy (aout_img + sizeof (*aout_head), core_img, core_size); | ||||
| 
 | ||||
|       free (core_img); | ||||
|       core_img = aout_img; | ||||
|       core_size = aout_size; | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       unsigned int num; | ||||
|       char *boot_path, *boot_img; | ||||
|       size_t boot_size; | ||||
| 
 | ||||
|       num = ((core_size + GRUB_DISK_SECTOR_SIZE - 1) >> GRUB_DISK_SECTOR_BITS); | ||||
|       num <<= GRUB_DISK_SECTOR_BITS; | ||||
| 
 | ||||
|       boot_path = grub_util_get_path (dir, "diskboot.img"); | ||||
|       boot_size = grub_util_get_image_size (boot_path); | ||||
|       if (boot_size != GRUB_DISK_SECTOR_SIZE) | ||||
| 	grub_util_error ("diskboot.img is not one sector size"); | ||||
| 
 | ||||
|       boot_img = grub_util_read_image (boot_path); | ||||
| 
 | ||||
|       *((grub_uint32_t *) (boot_img + GRUB_DISK_SECTOR_SIZE | ||||
| 			   - GRUB_BOOT_MACHINE_LIST_SIZE + 8)) | ||||
| 	= grub_host_to_target32 (num); | ||||
| 
 | ||||
|       grub_util_write_image (boot_img, boot_size, out); | ||||
|       free (boot_img); | ||||
|       free (boot_path); | ||||
|     } | ||||
| #elif defined(GRUB_MACHINE_MIPS) | ||||
|   if (format == GRUB_PLATFORM_IMAGE_ELF) | ||||
|     { | ||||
|       char *elf_img; | ||||
|       size_t program_size; | ||||
|       Elf32_Ehdr *ehdr; | ||||
|       Elf32_Phdr *phdr; | ||||
|       grub_uint32_t target_addr; | ||||
| 
 | ||||
|       program_size = ALIGN_ADDR (core_size); | ||||
| 
 | ||||
|       elf_img = xmalloc (program_size + sizeof (*ehdr) + sizeof (*phdr)); | ||||
|       memset (elf_img, 0, program_size + sizeof (*ehdr) + sizeof (*phdr)); | ||||
|       memcpy (elf_img  + sizeof (*ehdr) + sizeof (*phdr), core_img, core_size); | ||||
|       ehdr = (void *) elf_img; | ||||
|       phdr = (void *) (elf_img + sizeof (*ehdr)); | ||||
|       memcpy (ehdr->e_ident, ELFMAG, SELFMAG); | ||||
|       ehdr->e_ident[EI_CLASS] = ELFCLASS32; | ||||
| #ifdef GRUB_CPU_MIPSEL | ||||
|       ehdr->e_ident[EI_DATA] = ELFDATA2LSB; | ||||
| #else | ||||
|       ehdr->e_ident[EI_DATA] = ELFDATA2MSB; | ||||
| #endif | ||||
|       ehdr->e_ident[EI_VERSION] = EV_CURRENT; | ||||
|       ehdr->e_ident[EI_OSABI] = ELFOSABI_NONE; | ||||
|       ehdr->e_type = grub_host_to_target16 (ET_EXEC); | ||||
|       ehdr->e_machine = grub_host_to_target16 (EM_MIPS); | ||||
|       ehdr->e_version = grub_host_to_target32 (EV_CURRENT); | ||||
| 
 | ||||
|       ehdr->e_phoff = grub_host_to_target32 ((char *) phdr - (char *) ehdr); | ||||
|       ehdr->e_phentsize = grub_host_to_target16 (sizeof (*phdr)); | ||||
|       ehdr->e_phnum = grub_host_to_target16 (1); | ||||
| 
 | ||||
|       /* No section headers.  */ | ||||
|       ehdr->e_shoff = grub_host_to_target32 (0); | ||||
|       ehdr->e_shentsize = grub_host_to_target16 (0); | ||||
|       ehdr->e_shnum = grub_host_to_target16 (0); | ||||
|       ehdr->e_shstrndx = grub_host_to_target16 (0); | ||||
| 
 | ||||
|       ehdr->e_ehsize = grub_host_to_target16 (sizeof (*ehdr)); | ||||
| 
 | ||||
|       phdr->p_type = grub_host_to_target32 (PT_LOAD); | ||||
|       phdr->p_offset = grub_host_to_target32 (sizeof (*ehdr) + sizeof (*phdr)); | ||||
|       phdr->p_flags = grub_host_to_target32 (PF_R | PF_W | PF_X); | ||||
| 
 | ||||
|       target_addr = ALIGN_UP (GRUB_KERNEL_MACHINE_LINK_ADDR  | ||||
| 			      + kernel_size + total_module_size, 32); | ||||
|       ehdr->e_entry = grub_host_to_target32 (target_addr); | ||||
|       phdr->p_vaddr = grub_host_to_target32 (target_addr); | ||||
|       phdr->p_paddr = grub_host_to_target32 (target_addr); | ||||
|       phdr->p_align = grub_host_to_target32 (GRUB_KERNEL_MACHINE_LINK_ALIGN); | ||||
|       ehdr->e_flags = grub_host_to_target32 (0x1000 | EF_MIPS_NOREORDER  | ||||
| 					     | EF_MIPS_PIC | EF_MIPS_CPIC); | ||||
|       phdr->p_filesz = grub_host_to_target32 (core_size); | ||||
|       phdr->p_memsz = grub_host_to_target32 (core_size); | ||||
| 
 | ||||
|       free (core_img); | ||||
|       core_img = elf_img; | ||||
|       core_size = program_size  + sizeof (*ehdr) + sizeof (*phdr); | ||||
|   } | ||||
| #endif | ||||
| 
 | ||||
|   grub_util_write_image (core_img, core_size, out); | ||||
|   free (kernel_img); | ||||
|   free (core_img); | ||||
|   free (kernel_path); | ||||
| 
 | ||||
|   while (path_list) | ||||
|     { | ||||
|       next = path_list->next; | ||||
|       free ((void *) path_list->name); | ||||
|       free (path_list); | ||||
|       path_list = next; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
|  | ||||
| 
 | ||||
| static struct option options[] = | ||||
|   { | ||||
|     {"directory", required_argument, 0, 'd'}, | ||||
|     {"prefix", required_argument, 0, 'p'}, | ||||
|     {"memdisk", required_argument, 0, 'm'}, | ||||
|     {"font", required_argument, 0, 'f'}, | ||||
|     {"config", required_argument, 0, 'c'}, | ||||
|     {"output", required_argument, 0, 'o'}, | ||||
| #ifdef GRUB_PLATFORM_IMAGE_DEFAULT | ||||
|     {"format", required_argument, 0, 'O'}, | ||||
| #endif | ||||
|     {"help", no_argument, 0, 'h'}, | ||||
|     {"version", no_argument, 0, 'V'}, | ||||
|     {"verbose", no_argument, 0, 'v'}, | ||||
|     {0, 0, 0, 0} | ||||
|   }; | ||||
| 
 | ||||
| static void | ||||
| usage (int status) | ||||
| { | ||||
|   if (status) | ||||
|     fprintf (stderr, _("Try `%s --help' for more information.\n"), program_name); | ||||
|   else | ||||
|     printf (_("\
 | ||||
| Usage: %s [OPTION]... [MODULES]\n\ | ||||
| \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\ | ||||
|   -m, --memdisk=FILE      embed FILE as a memdisk image\n\ | ||||
|   -f, --font=FILE         embed FILE as a boot font\n\ | ||||
|   -c, --config=FILE       embed FILE as boot config\n\ | ||||
|   -o, --output=FILE       output a generated image to FILE [default=stdout]\n" | ||||
| #ifdef GRUB_PLATFORM_IMAGE_DEFAULT | ||||
| 	    "\
 | ||||
|   -O, --format=FORMAT     generate an image in format [default=%s]\n\ | ||||
|                           available formats: %s\n" | ||||
| #endif | ||||
| 	    "\
 | ||||
|   -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\ | ||||
| "),  | ||||
| program_name, GRUB_LIBDIR, DEFAULT_DIRECTORY, | ||||
| #ifdef GRUB_PLATFORM_IMAGE_DEFAULT | ||||
|   GRUB_PLATFORM_IMAGE_DEFAULT_FORMAT, GRUB_PLATFORM_IMAGE_FORMATS, | ||||
| #endif | ||||
| PACKAGE_BUGREPORT); | ||||
| 
 | ||||
|   exit (status); | ||||
| } | ||||
| 
 | ||||
| int | ||||
| main (int argc, char *argv[]) | ||||
| { | ||||
|   char *output = NULL; | ||||
|   char *dir = NULL; | ||||
|   char *prefix = NULL; | ||||
|   char *memdisk = NULL; | ||||
|   char *font = NULL; | ||||
|   char *config = NULL; | ||||
|   FILE *fp = stdout; | ||||
| #ifdef GRUB_PLATFORM_IMAGE_DEFAULT | ||||
|   grub_platform_image_format_t format = GRUB_PLATFORM_IMAGE_DEFAULT; | ||||
| #endif | ||||
| 
 | ||||
|   set_program_name (argv[0]); | ||||
| 
 | ||||
|   grub_util_init_nls (); | ||||
| 
 | ||||
|   while (1) | ||||
|     { | ||||
|       int c = getopt_long (argc, argv, "d:p:m:c:o:O:f:hVv", options, 0); | ||||
| 
 | ||||
|       if (c == -1) | ||||
| 	break; | ||||
|       else | ||||
| 	switch (c) | ||||
| 	  { | ||||
| 	  case 'o': | ||||
| 	    if (output) | ||||
| 	      free (output); | ||||
| 
 | ||||
| 	    output = xstrdup (optarg); | ||||
| 	    break; | ||||
| 
 | ||||
| #ifdef GRUB_PLATFORM_IMAGE_DEFAULT | ||||
| 	  case 'O': | ||||
| #ifdef GRUB_PLATFORM_IMAGE_RAW | ||||
| 	    if (strcmp (optarg, "raw") == 0) | ||||
| 	      format = GRUB_PLATFORM_IMAGE_RAW; | ||||
| 	    else  | ||||
| #endif | ||||
| #ifdef GRUB_PLATFORM_IMAGE_ELF | ||||
| 	    if (strcmp (optarg, "elf") == 0) | ||||
| 	      format = GRUB_PLATFORM_IMAGE_ELF; | ||||
| 	    else  | ||||
| #endif | ||||
| #ifdef GRUB_PLATFORM_IMAGE_AOUT | ||||
| 	    if (strcmp (optarg, "aout") == 0) | ||||
| 	      format = GRUB_PLATFORM_IMAGE_AOUT; | ||||
| 	    else  | ||||
| #endif | ||||
| 	      usage (1); | ||||
| 	    break; | ||||
| #endif | ||||
| 
 | ||||
| 	  case 'd': | ||||
| 	    if (dir) | ||||
| 	      free (dir); | ||||
| 
 | ||||
| 	    dir = xstrdup (optarg); | ||||
| 	    break; | ||||
| 
 | ||||
| 	  case 'm': | ||||
| 	    if (memdisk) | ||||
| 	      free (memdisk); | ||||
| 
 | ||||
| 	    memdisk = xstrdup (optarg); | ||||
| 
 | ||||
| 	    if (prefix) | ||||
| 	      free (prefix); | ||||
| 
 | ||||
| 	    prefix = xstrdup ("(memdisk)/boot/grub"); | ||||
| 	    break; | ||||
| 
 | ||||
| 	  case 'f': | ||||
| 	    if (font) | ||||
| 	      free (font); | ||||
| 
 | ||||
| 	    font = xstrdup (optarg); | ||||
| 	    break; | ||||
| 
 | ||||
| 	  case 'c': | ||||
| 	    if (config) | ||||
| 	      free (config); | ||||
| 
 | ||||
| 	    config = xstrdup (optarg); | ||||
| 	    break; | ||||
| 
 | ||||
| 	  case 'h': | ||||
| 	    usage (0); | ||||
| 	    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; | ||||
| 
 | ||||
| 	  case 'v': | ||||
| 	    verbosity++; | ||||
| 	    break; | ||||
| 
 | ||||
| 	  default: | ||||
| 	    usage (1); | ||||
| 	    break; | ||||
| 	  } | ||||
|     } | ||||
| 
 | ||||
|   if (output) | ||||
|     { | ||||
|       fp = fopen (output, "wb"); | ||||
|       if (! fp) | ||||
| 	grub_util_error (_("cannot open %s"), output); | ||||
|       free (output); | ||||
|     } | ||||
| 
 | ||||
|   generate_image (dir ? : GRUB_LIBDIR, prefix ? : DEFAULT_DIRECTORY, fp, | ||||
| 		  argv + optind, memdisk, font, config, | ||||
| #ifdef GRUB_PLATFORM_IMAGE_DEFAULT | ||||
| 		  format | ||||
| #else | ||||
| 		  0 | ||||
| #endif | ||||
| 		  ); | ||||
| 
 | ||||
|   fclose (fp); | ||||
| 
 | ||||
|   if (dir) | ||||
|     free (dir); | ||||
| 
 | ||||
|   return 0; | ||||
| } | ||||
|  | @ -172,7 +172,7 @@ EOF | |||
| 
 | ||||
|     tar -C ${memdisk_dir} -cf ${memdisk_img} boot | ||||
|     rm -rf ${memdisk_dir} | ||||
|     grub-mkelfimage -d ${coreboot_dir}/ -m ${memdisk_img} -o ${iso9660_dir}/boot/multiboot.img \ | ||||
|     grub-mkimage -O i386-coreboot -d ${coreboot_dir}/ -m ${memdisk_img} -o ${iso9660_dir}/boot/multiboot.img \ | ||||
|         memdisk tar search iso9660 configfile sh \ | ||||
|         ata at_keyboard | ||||
|     rm -f ${memdisk_img} | ||||
|  | @ -183,7 +183,7 @@ fi | |||
| if test -e "${pc_dir}" ; then | ||||
|     echo "Enabling BIOS support ..." | ||||
|     core_img=`mktemp "$MKTEMP_TEMPLATE"` | ||||
|     grub-mkimage -d ${pc_dir}/ -o ${core_img} --prefix=/boot/grub/i386-pc \ | ||||
|     grub-mkimage -O i386-pc -d ${pc_dir}/ -O i386-pc -o ${core_img} --prefix=/boot/grub/i386-pc \ | ||||
|         iso9660 biosdisk | ||||
|     cat ${pc_dir}/cdboot.img ${core_img} > ${iso9660_dir}/boot/grub/i386-pc/eltorito.img | ||||
| 
 | ||||
|  | @ -213,7 +213,7 @@ fi | |||
| # build bootx64.efi | ||||
| if test -e "${efi64_dir}" ; then | ||||
|     echo "Enabling EFI64 support ..." | ||||
|     grub-mkimage -d "${efi64_dir}" -o "${efi_dir}"/efi/boot/bootx64.efi --prefix=/boot/grub/x86_64-efi \ | ||||
|     grub-mkimage -O x86_64-efi -d "${efi64_dir}" -o "${efi_dir}"/efi/boot/bootx64.efi --prefix=/boot/grub/x86_64-efi \ | ||||
|         search iso9660 configfile sh  | ||||
| 
 | ||||
|     modules="$(cat "${efi64_dir}"/partmap.lst) ${modules}" | ||||
|  |  | |||
|  | @ -76,13 +76,13 @@ menuentry "${OS}" ${CLASS} { | |||
| EOF | ||||
| prepare_grub_to_access_device ${GRUB_DEVICE_BOOT} | sed -e "s/^/\t/" | ||||
| cat << EOF | ||||
| 	echo		$(gettext "Loading GNU Mach ...") | ||||
| 	echo		'$(gettext_quoted "Loading GNU Mach ...")' | ||||
| 	multiboot	${kernel} root=device:${GRUB_DEVICE#/dev/} | ||||
| EOF | ||||
| save_default_entry | sed -e "s/^/\t/" | ||||
| prepare_grub_to_access_device ${GRUB_DEVICE} | sed -e "s/^/\t/" | ||||
| cat << EOF | ||||
| 	echo		$(gettext "Loading the Hurd ...") | ||||
| 	echo		'$(gettext_quoted "Loading the Hurd ...")' | ||||
| 	module		/hurd/${hurd_fs}.static ${hurd_fs} --readonly \\ | ||||
| 			--multiboot-command-line='\${kernel-command-line}' \\ | ||||
| 			--host-priv-port='\${host-port}' \\ | ||||
|  | @ -98,13 +98,13 @@ menuentry "${OS} (recovery mode)" { | |||
| EOF | ||||
| prepare_grub_to_access_device ${GRUB_DEVICE_BOOT} | sed -e "s/^/\t/" | ||||
| cat << EOF | ||||
| 	echo		$(gettext "Loading GNU Mach ...") | ||||
| 	echo		'$(gettext_quoted "Loading GNU Mach ...")' | ||||
| 	multiboot	${kernel} root=device:${GRUB_DEVICE#/dev/} -s | ||||
| EOF | ||||
| save_default_entry | sed -e "s/^/\t/" | ||||
| prepare_grub_to_access_device ${GRUB_DEVICE} | sed -e "s/^/\t/" | ||||
| cat << EOF | ||||
| 	echo		$(gettext "Loading the Hurd ...") | ||||
| 	echo		'$(gettext_quoted "Loading the Hurd ...")' | ||||
| 	module		/hurd/${hurd_fs}.static ${hurd_fs} \\ | ||||
| 			--multiboot-command-line='\${kernel-command-line}' \\ | ||||
| 			--host-priv-port='\${host-port}' \\ | ||||
|  |  | |||
|  | @ -23,7 +23,7 @@ libdir=@libdir@ | |||
| . ${libdir}/grub/grub-mkconfig_lib | ||||
| 
 | ||||
| export TEXTDOMAIN=@PACKAGE@ | ||||
| export TEXTDOMAINDIR=@LOCALEDIR@ | ||||
| export TEXTDOMAINDIR=@localedir@ | ||||
| 
 | ||||
| CLASS="--class os" | ||||
| 
 | ||||
|  | @ -44,15 +44,15 @@ kfreebsd_entry () | |||
|   version="$2" | ||||
|   recovery="$3"	# not used yet | ||||
|   args="$4"	# not used yet | ||||
|   title="$(gettext "%s, with kFreeBSD %s")" | ||||
|   printf "menuentry \"${title}\" ${CLASS} {\n" "${os}" "${version}" | ||||
|   title="$(gettext_quoted "%s, with kFreeBSD %s")" | ||||
|   printf "menuentry '${title}' ${CLASS} {\n" "${os}" "${version}" | ||||
|   save_default_entry | sed -e "s/^/\t/" | ||||
|   if [ -z "${prepare_boot_cache}" ]; then | ||||
|     prepare_boot_cache="$(prepare_grub_to_access_device ${GRUB_DEVICE_BOOT} | sed -e "s/^/\t/")" | ||||
|   fi | ||||
|   printf '%s\n' "${prepare_boot_cache}" | ||||
|   cat << EOF | ||||
| 	echo			$(printf "$(gettext "Loading kernel of FreeBSD %s ...")" ${version}) | ||||
| 	echo			'$(printf "$(gettext_quoted "Loading kernel of FreeBSD %s ...")" ${version})' | ||||
| 	kfreebsd		${rel_dirname}/${basename} | ||||
| EOF | ||||
| 
 | ||||
|  |  | |||
|  | @ -23,7 +23,7 @@ libdir=@libdir@ | |||
| . ${libdir}/grub/grub-mkconfig_lib | ||||
| 
 | ||||
| export TEXTDOMAIN=@PACKAGE@ | ||||
| export TEXTDOMAINDIR=@LOCALEDIR@ | ||||
| export TEXTDOMAINDIR=@localedir@ | ||||
| 
 | ||||
| CLASS="--class gnu-linux --class gnu --class os" | ||||
| 
 | ||||
|  | @ -56,11 +56,11 @@ linux_entry () | |||
|   recovery="$3" | ||||
|   args="$4" | ||||
|   if ${recovery} ; then | ||||
|     title="$(gettext "%s, with Linux %s (recovery mode)")" | ||||
|     title="$(gettext_quoted "%s, with Linux %s (recovery mode)")" | ||||
|   else | ||||
|     title="$(gettext "%s, with Linux %s")" | ||||
|     title="$(gettext_quoted "%s, with Linux %s")" | ||||
|   fi | ||||
|   printf "menuentry \"${title}\" ${CLASS} {\n" "${os}" "${version}" | ||||
|   printf "menuentry '${title}' ${CLASS} {\n" "${os}" "${version}" | ||||
|   save_default_entry | sed -e "s/^/\t/" | ||||
| 
 | ||||
|   # Use ELILO's generic "efifb" when it's known to be available. | ||||
|  | @ -83,12 +83,12 @@ EOF | |||
|   fi | ||||
|   printf '%s\n' "${prepare_boot_cache}" | ||||
|   cat << EOF | ||||
| 	echo	$(printf "$(gettext "Loading Linux %s ...")" ${version}) | ||||
| 	echo	'$(printf "$(gettext_quoted "Loading Linux %s ...")" ${version})' | ||||
| 	linux	${rel_dirname}/${basename} root=${linux_root_device_thisversion} ro ${args} | ||||
| EOF | ||||
|   if test -n "${initrd}" ; then | ||||
|     cat << EOF | ||||
| 	echo	$(gettext "Loading initial ramdisk ...") | ||||
| 	echo	'$(gettext_quoted "Loading initial ramdisk ...")' | ||||
| 	initrd	${rel_dirname}/${initrd} | ||||
| EOF | ||||
|   fi | ||||
|  |  | |||
							
								
								
									
										86
									
								
								util/grub.d/10_netbsd.in
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								util/grub.d/10_netbsd.in
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,86 @@ | |||
| #! /bin/sh -e | ||||
| 
 | ||||
| # grub-mkconfig helper script. | ||||
| # Copyright (C) 2006,2007,2008,2009,2010  Free Software Foundation, Inc. | ||||
| # | ||||
| # GRUB is free software: you can redistribute it and/or modify | ||||
| # it under the terms of the GNU General Public License as published by | ||||
| # the Free Software Foundation, either version 3 of the License, or | ||||
| # (at your option) any later version. | ||||
| # | ||||
| # GRUB is distributed in the hope that it will be useful, | ||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| # GNU General Public License for more details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License | ||||
| # along with GRUB.  If not, see <http://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| prefix=@prefix@ | ||||
| exec_prefix=@exec_prefix@ | ||||
| bindir=@bindir@ | ||||
| libdir=@libdir@ | ||||
| . ${libdir}/grub/grub-mkconfig_lib | ||||
| 
 | ||||
| export TEXTDOMAIN=@PACKAGE@ | ||||
| export TEXTDOMAINDIR=@localedir@ | ||||
| 
 | ||||
| if [ "x${GRUB_DISTRIBUTOR}" = "x" ] ; then | ||||
|   OS=NetBSD | ||||
| else | ||||
|   OS="${GRUB_DISTRIBUTOR} NetBSD" | ||||
| fi | ||||
| 
 | ||||
| netbsd_entry () | ||||
| { | ||||
|   loader="$1"	# "knetbsd" or "multiboot" | ||||
|   kernel="$2"	# absolute path to the kernel file | ||||
|   recovery="$3"	# is this is a recovery entry? | ||||
|   args="$4"	# extra arguments appended to loader command | ||||
| 
 | ||||
|   kroot_device="$(echo ${GRUB_DEVICE} | sed -e 's,^/dev/r,,')" | ||||
|   if ${recovery} ; then | ||||
|     title="$(gettext_quoted "%s, with kernel %s (via %s, recovery mode)")" | ||||
|   else | ||||
|     title="$(gettext_quoted "%s, with kernel %s (via %s)")" | ||||
|   fi | ||||
| 
 | ||||
|   printf "menuentry \"${title}\" {\n" \ | ||||
|     "${OS}" "$(echo ${kernel} | sed -e 's,^.*/,,')" "${loader}" | ||||
|   printf "%s\n" "${prepare_boot_cache}" | ||||
|   case "${loader}" in | ||||
|     knetbsd) | ||||
|       printf "\tknetbsd %s -r %s %s\n" \ | ||||
|         "${kernel}" "${kroot_device}" "${GRUB_CMDLINE_NETBSD} ${args}" | ||||
|       ;; | ||||
|     multiboot) | ||||
|       printf "\tmultiboot %s %s root=%s %s\n" \ | ||||
|         "${kernel}" "${kernel}" "${kroot_device}" "${GRUB_CMDLINE_NETBSD} ${args}" | ||||
|       ;; | ||||
|   esac | ||||
|   printf "}\n" | ||||
| } | ||||
| 
 | ||||
| prepare_boot_cache="$(prepare_grub_to_access_device ${GRUB_DEVICE} | sed -e 's,^,	,')" | ||||
| 
 | ||||
| # We look for NetBSD kernels in / but not in subdirectories.  We simply | ||||
| # pick all statically linked ELF executable files (or links) in / with a | ||||
| # name that starts with `netbsd'. | ||||
| pattern="^ELF[^,]*executable.*statically linked" | ||||
| for k in $(ls -t /netbsd*) ; do | ||||
|   if ! grub_file_is_not_garbage "$k" ; then | ||||
|     continue | ||||
|   fi | ||||
|   if ! ((file -bL "$k" | grep -q "${pattern}") || | ||||
|         (zcat "$k" | file -bL - | grep -q "${pattern}")) 2>/dev/null ; then | ||||
|     continue | ||||
|   fi | ||||
| 
 | ||||
|   echo "Found NetBSD kernel: $k" >&2 | ||||
|   netbsd_entry "knetbsd"   "$k" false "${GRUB_CMDLINE_NETBSD_DEFAULT}" | ||||
|   netbsd_entry "multiboot" "$k" false "${GRUB_CMDLINE_NETBSD_DEFAULT}" | ||||
|   if [ "x${GRUB_DISABLE_NETBSD_RECOVERY}" != "xtrue" ]; then | ||||
|     netbsd_entry "knetbsd"   "$k" true "-s" | ||||
|     netbsd_entry "multiboot" "$k" true "-s" | ||||
|   fi | ||||
| done | ||||
|  | @ -861,7 +861,7 @@ make_device_name (int drive, int dos_part, int bsd_part) | |||
|     dos_part_str = xasprintf (",%d", dos_part + 1); | ||||
| 
 | ||||
|   if (bsd_part >= 0) | ||||
|     bsd_part_str = xasprintf (",%c", bsd_part + 'a'); | ||||
|     bsd_part_str = xasprintf (",%d", bsd_part + 1); | ||||
| 
 | ||||
|   ret = xasprintf ("%s%s%s", map[drive].drive, | ||||
|                    dos_part_str ? : "", | ||||
|  | @ -1352,3 +1352,9 @@ grub_util_biosdisk_get_grub_dev (const char *os_dev) | |||
|   return make_device_name (drive, -1, -1); | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
| const char * | ||||
| grub_util_biosdisk_get_osdev (grub_disk_t disk) | ||||
| { | ||||
|   return map[disk->id].device; | ||||
| } | ||||
|  |  | |||
|  | @ -213,7 +213,7 @@ devabstraction_module=`$grub_probe --target=abstraction --device-map=${device_ma | |||
| # The order in this list is critical.  Be careful when modifying it. | ||||
| modules="$modules $fs_module $partmap_module $devabstraction_module" | ||||
| 
 | ||||
| $grub_mkimage --output=${grubdir}/grub.efi $modules || exit 1 | ||||
| $grub_mkimage -O ${target_cpu}-efi --output=${grubdir}/grub.efi $modules || exit 1 | ||||
| 
 | ||||
| # Prompt the user to check if the device map is correct. | ||||
| echo "Installation finished. No error reported." | ||||
|  |  | |||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -57,6 +57,13 @@ static const grub_gpt_part_type_t grub_gpt_partition_type_bios_boot = GRUB_GPT_P | |||
| #define DEFAULT_BOOT_FILE	"boot.img" | ||||
| #define DEFAULT_CORE_FILE	"core.img" | ||||
| 
 | ||||
| #define grub_target_to_host16(x)	grub_le_to_cpu16(x) | ||||
| #define grub_target_to_host32(x)	grub_le_to_cpu32(x) | ||||
| #define grub_target_to_host64(x)	grub_le_to_cpu64(x) | ||||
| #define grub_host_to_target16(x)	grub_cpu_to_le16(x) | ||||
| #define grub_host_to_target32(x)	grub_cpu_to_le32(x) | ||||
| #define grub_host_to_target64(x)	grub_cpu_to_le64(x) | ||||
| 
 | ||||
| void | ||||
| grub_putchar (int c) | ||||
| { | ||||
|  |  | |||
|  | @ -34,7 +34,7 @@ target_cpu=@target_cpu@ | |||
| platform=@platform@ | ||||
| pkglibdir=${libdir}/`echo ${PACKAGE_TARNAME}/${target_cpu}-${platform} | sed ${transform}` | ||||
| 
 | ||||
| grub_mkimage=${bindir}/`echo grub-mkelfimage | sed ${transform}` | ||||
| grub_mkimage=${bindir}/`echo grub-mkimage | sed ${transform}` | ||||
| grub_mkdevicemap=${sbindir}/`echo grub-mkdevicemap | sed ${transform}` | ||||
| grub_probe=${sbindir}/`echo grub-probe | sed ${transform}` | ||||
| grub_editenv=${bindir}/`echo grub-editenv | sed ${transform}` | ||||
|  | @ -189,7 +189,7 @@ devabstraction_module=`$grub_probe --target=abstraction --device-map=${device_ma | |||
| modules="$modules $fs_module $partmap_module $devabstraction_module" | ||||
| 
 | ||||
| # Now perform the installation. | ||||
| "$grub_mkimage" --directory=${pkglibdir} --output=${grubdir}/grub $modules || exit 1 | ||||
| "$grub_mkimage" -O ${target_cpu}-ieee1275 --directory=${pkglibdir} --output=${grubdir}/grub $modules || exit 1 | ||||
| 
 | ||||
| if test $update_nvram = yes; then | ||||
|     set $ofpathname dummy | ||||
|  |  | |||
|  | @ -368,7 +368,7 @@ strip_trailing_digits (const char *p) | |||
| } | ||||
| 
 | ||||
| char * | ||||
| grub_util_devname_to_ofpath (char *devname) | ||||
| grub_util_devname_to_ofpath (const char *devname) | ||||
| { | ||||
|   char *name_buf, *device, *devnode, *devicenode, *ofpath; | ||||
| 
 | ||||
|  |  | |||
|  | @ -30,7 +30,7 @@ target_cpu=@target_cpu@ | |||
| platform=@platform@ | ||||
| pkglibdir=${libdir}/`echo ${PACKAGE_TARNAME}/${target_cpu}-${platform} | sed ${transform}` | ||||
| 
 | ||||
| grub_mkimage=${bindir}/`echo grub-mkelfimage | sed ${transform}` | ||||
| grub_mkimage=${bindir}/`echo grub-mkimage | sed ${transform}` | ||||
| 
 | ||||
| # Usage: usage | ||||
| # Print the usage. | ||||
|  | @ -104,7 +104,7 @@ boot_dir=${iso_dir}/boot/grub | |||
| mkdir ${iso_dir}/boot | ||||
| mkdir ${boot_dir} | ||||
| core_img=${boot_dir}/grub.img | ||||
| ${grub_mkimage} -n -d ${input_dir}/ -o ${core_img} ${modules} | ||||
| ${grub_mkimage} -O powerpc-ieee1275 -n -d ${input_dir}/ -o ${core_img} ${modules} | ||||
| genisoimage -hfs -part -no-desktop -r -J -o ${output_image} \ | ||||
|  -map ${map_file} -hfs-bless ${boot_dir} -chrp-boot -sysid PPC \ | ||||
|  ${iso_dir} | ||||
|  |  | |||
|  | @ -35,6 +35,7 @@ | |||
| #include <grub/term.h> | ||||
| #include <grub/util/raid.h> | ||||
| #include <grub/util/lvm.h> | ||||
| #include <grub/util/ofpath.h> | ||||
| 
 | ||||
| #include <grub_setup_init.h> | ||||
| 
 | ||||
|  | @ -75,6 +76,13 @@ | |||
| #define DEFAULT_BOOT_FILE	"boot.img" | ||||
| #define DEFAULT_CORE_FILE	"core.img" | ||||
| 
 | ||||
| #define grub_target_to_host16(x)	grub_be_to_cpu16(x) | ||||
| #define grub_target_to_host32(x)	grub_be_to_cpu32(x) | ||||
| #define grub_target_to_host64(x)	grub_be_to_cpu64(x) | ||||
| #define grub_host_to_target16(x)	grub_cpu_to_be16(x) | ||||
| #define grub_host_to_target32(x)	grub_cpu_to_be32(x) | ||||
| #define grub_host_to_target64(x)	grub_cpu_to_be64(x) | ||||
| 
 | ||||
| /* This is the blocklist used in the diskboot image.  */ | ||||
| struct boot_blocklist | ||||
| { | ||||
|  | @ -103,28 +111,6 @@ grub_refresh (void) | |||
|   fflush (stdout); | ||||
| } | ||||
| 
 | ||||
| static char *compute_dest_ofpath (const char *dest) | ||||
| { | ||||
|   int len = strlen (dest); | ||||
|   char *res, *p, c; | ||||
| 
 | ||||
|   res = xmalloc (len); | ||||
|   p = res; | ||||
|   while ((c = *dest++) != '\0') | ||||
|     { | ||||
|       if (c == '\\' && *dest == ',') | ||||
| 	{ | ||||
| 	  *p++ = ','; | ||||
| 	  dest++; | ||||
| 	} | ||||
|       else | ||||
| 	*p++ = c; | ||||
|     } | ||||
|   *p++ = '\0'; | ||||
| 
 | ||||
|   return res; | ||||
| } | ||||
| 
 | ||||
| static void | ||||
| setup (const char *prefix, const char *dir, | ||||
|        const char *boot_file, const char *core_file, | ||||
|  | @ -135,8 +121,8 @@ setup (const char *prefix, const char *dir, | |||
|   size_t boot_size, core_size; | ||||
|   grub_uint16_t core_sectors; | ||||
|   grub_device_t root_dev, dest_dev; | ||||
|   char *boot_devpath, *dest_ofpath; | ||||
|   grub_disk_addr_t *kernel_sector; | ||||
|   char *boot_devpath; | ||||
|   grub_disk_addr_t *kernel_byte; | ||||
|   struct boot_blocklist *first_block, *block; | ||||
|   char *tmp_img; | ||||
|   int i; | ||||
|  | @ -195,8 +181,6 @@ setup (const char *prefix, const char *dir, | |||
|       last_length = length; | ||||
|     } | ||||
| 
 | ||||
|   dest_ofpath = compute_dest_ofpath (dest); | ||||
| 
 | ||||
|   /* Read the boot image by the OS service.  */ | ||||
|   boot_path = grub_util_get_path (dir, boot_file); | ||||
|   boot_size = grub_util_get_image_size (boot_path); | ||||
|  | @ -210,9 +194,9 @@ setup (const char *prefix, const char *dir, | |||
|   boot_devpath = (char *) (boot_img | ||||
| 			   + GRUB_BOOT_AOUT_HEADER_SIZE | ||||
| 			   + GRUB_BOOT_MACHINE_BOOT_DEVPATH); | ||||
|   kernel_sector = (grub_disk_addr_t *) (boot_img | ||||
|   kernel_byte = (grub_disk_addr_t *) (boot_img | ||||
| 				      + GRUB_BOOT_AOUT_HEADER_SIZE | ||||
| 					+ GRUB_BOOT_MACHINE_KERNEL_SECTOR); | ||||
| 				      + GRUB_BOOT_MACHINE_KERNEL_BYTE); | ||||
| 
 | ||||
|   core_path = grub_util_get_path (dir, core_file); | ||||
|   core_size = grub_util_get_image_size (core_path); | ||||
|  | @ -229,8 +213,7 @@ setup (const char *prefix, const char *dir, | |||
| 					   + GRUB_DISK_SECTOR_SIZE | ||||
| 					   - sizeof (*block)); | ||||
| 
 | ||||
|   grub_util_info ("root is `%s', dest is `%s', and dest_ofpath is `%s'", | ||||
| 		  root, dest, dest_ofpath); | ||||
|   grub_util_info ("root is `%s', dest is `%s'", root, dest); | ||||
| 
 | ||||
|   /* Open the root device and the destination device.  */ | ||||
|   grub_util_info ("Opening root"); | ||||
|  | @ -351,14 +334,30 @@ setup (const char *prefix, const char *dir, | |||
|       != (grub_ssize_t) core_size - GRUB_DISK_SECTOR_SIZE) | ||||
|     grub_util_error ("failed to read the rest sectors of the core image"); | ||||
| 
 | ||||
|   if (file->device->disk->id != dest_dev->disk->id) | ||||
|     { | ||||
|       const char *dest_ofpath; | ||||
|       dest_ofpath | ||||
| 	= grub_util_devname_to_ofpath (grub_util_biosdisk_get_osdev (file->device->disk)); | ||||
|       grub_util_info ("dest_ofpath is `%s'", dest_ofpath); | ||||
|       strncpy (boot_devpath, dest_ofpath, GRUB_BOOT_MACHINE_BOOT_DEVPATH_END | ||||
| 	       - GRUB_BOOT_MACHINE_BOOT_DEVPATH - 1); | ||||
|       boot_devpath[GRUB_BOOT_MACHINE_BOOT_DEVPATH_END | ||||
| 		   - GRUB_BOOT_MACHINE_BOOT_DEVPATH - 1] = 0; | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       grub_util_info ("non cross-disk install"); | ||||
|       memset (boot_devpath, 0, GRUB_BOOT_MACHINE_BOOT_DEVPATH_END | ||||
| 	      - GRUB_BOOT_MACHINE_BOOT_DEVPATH); | ||||
|     } | ||||
| 
 | ||||
|   grub_file_close (file); | ||||
| 
 | ||||
|   free (core_path); | ||||
|   free (tmp_img); | ||||
| 
 | ||||
|   *kernel_sector = grub_cpu_to_be64 (first_sector); | ||||
| 
 | ||||
|   strcpy(boot_devpath, dest_ofpath); | ||||
|   *kernel_byte = grub_cpu_to_be64 (first_sector << GRUB_DISK_SECTOR_BITS); | ||||
| 
 | ||||
|   grub_util_info ("boot device path %s, prefix is %s, dest is %s", | ||||
| 		  boot_devpath, prefix, dest); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue