synced with mainstream
This commit is contained in:
		
						commit
						4fe6aa0961
					
				
					 220 changed files with 54340 additions and 18150 deletions
				
			
		|  | @ -144,7 +144,7 @@ load_modules (grub_addr_t modbase, Elf32_Phdr *phdr, const char *dir, | |||
|       mod_size = grub_util_get_image_size (p->name); | ||||
| 
 | ||||
|       header = (struct grub_module_header *) (module_img + offset); | ||||
|       header->type = grub_host_to_target32 (OBJ_TYPE_ELF); | ||||
|       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)); | ||||
|  | @ -157,8 +157,8 @@ load_modules (grub_addr_t modbase, Elf32_Phdr *phdr, const char *dir, | |||
|       struct grub_module_header *header; | ||||
| 
 | ||||
|       header = (struct grub_module_header *) (module_img + offset); | ||||
|       header->type = grub_cpu_to_le32 (OBJ_TYPE_MEMDISK); | ||||
|       header->size = grub_cpu_to_le32 (memdisk_size + sizeof (*header)); | ||||
|       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); | ||||
|  |  | |||
|  | @ -30,6 +30,12 @@ | |||
| # define DEV_CYGDRIVE_MAJOR 98 | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __GNU__ | ||||
| #include <hurd.h> | ||||
| #include <hurd/lookup.h> | ||||
| #include <hurd/fs.h> | ||||
| #endif | ||||
| 
 | ||||
| #include <grub/util/misc.h> | ||||
| #include <grub/util/hostdisk.h> | ||||
| #include <grub/util/getroot.h> | ||||
|  | @ -378,8 +384,65 @@ find_cygwin_root_device (const char *path, dev_t dev) | |||
| char * | ||||
| grub_guess_root_device (const char *dir) | ||||
| { | ||||
|   struct stat st; | ||||
|   char *os_dev; | ||||
| #ifdef __GNU__ | ||||
|   file_t file; | ||||
|   mach_port_t *ports; | ||||
|   int *ints; | ||||
|   loff_t *offsets; | ||||
|   char *data; | ||||
|   error_t err; | ||||
|   mach_msg_type_number_t num_ports = 0, num_ints = 0, num_offsets = 0, data_len = 0; | ||||
|   size_t name_len; | ||||
| 
 | ||||
|   file = file_name_lookup (dir, 0, 0); | ||||
|   if (file == MACH_PORT_NULL) | ||||
|     return 0; | ||||
| 
 | ||||
|   err = file_get_storage_info (file, | ||||
| 			       &ports, &num_ports, | ||||
| 			       &ints, &num_ints, | ||||
| 			       &offsets, &num_offsets, | ||||
| 			       &data, &data_len); | ||||
| 
 | ||||
|   if (num_ints < 1) | ||||
|     grub_util_error ("Storage info for `%s' does not include type", dir); | ||||
|   if (ints[0] != STORAGE_DEVICE) | ||||
|     grub_util_error ("Filesystem of `%s' is not stored on local disk", dir); | ||||
| 
 | ||||
|   if (num_ints < 5) | ||||
|     grub_util_error ("Storage info for `%s' does not include name", dir); | ||||
|   name_len = ints[4]; | ||||
|   if (name_len < data_len) | ||||
|     grub_util_error ("Bogus name length for storage info for `%s'", dir); | ||||
|   if (data[name_len - 1] != '\0') | ||||
|     grub_util_error ("Storage name for `%s' not NUL-terminated", dir); | ||||
| 
 | ||||
|   os_dev = xmalloc (strlen ("/dev/") + data_len); | ||||
|   memcpy (os_dev, "/dev/", strlen ("/dev/")); | ||||
|   memcpy (os_dev + strlen ("/dev/"), data, data_len); | ||||
| 
 | ||||
|   if (ports && num_ports > 0) | ||||
|     { | ||||
|       mach_msg_type_number_t i; | ||||
|       for (i = 0; i < num_ports; i++) | ||||
|         { | ||||
| 	  mach_port_t port = ports[i]; | ||||
| 	  if (port != MACH_PORT_NULL) | ||||
| 	    mach_port_deallocate (mach_task_self(), port); | ||||
|         } | ||||
|       munmap ((caddr_t) ports, num_ports * sizeof (*ports)); | ||||
|     } | ||||
| 
 | ||||
|   if (ints && num_ints > 0) | ||||
|     munmap ((caddr_t) ints, num_ints * sizeof (*ints)); | ||||
|   if (offsets && num_offsets > 0) | ||||
|     munmap ((caddr_t) offsets, num_offsets * sizeof (*offsets)); | ||||
|   if (data && data_len > 0) | ||||
|     munmap (data, data_len); | ||||
|   mach_port_deallocate (mach_task_self (), file); | ||||
| #else /* !__GNU__ */ | ||||
|   struct stat st; | ||||
| 
 | ||||
|   if (stat (dir, &st) < 0) | ||||
|     grub_util_error ("Cannot stat `%s'", dir); | ||||
|  | @ -393,6 +456,7 @@ grub_guess_root_device (const char *dir) | |||
|   /* This might be truly slow, but is there any better way?  */ | ||||
|   os_dev = find_root_device ("/dev", st.st_dev); | ||||
| #endif | ||||
| #endif /* !__GNU__ */ | ||||
| 
 | ||||
|   return os_dev; | ||||
| } | ||||
|  |  | |||
|  | @ -1,58 +0,0 @@ | |||
| #! /bin/sh | ||||
| # | ||||
| # Copyright (C) 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/>. | ||||
| 
 | ||||
| # Usage: usage | ||||
| # Print the usage. | ||||
| usage () { | ||||
|     cat <<EOF | ||||
| Usage: $0 [OPTION] | ||||
| Create vbios and int10 dump | ||||
| 
 | ||||
|   -o, --output=DIR        set output directory | ||||
|   -h, --help              print this message and exit | ||||
|   -v, --version           print the version information and exit | ||||
| 
 | ||||
| Report bugs to <bug-grub@gnu.org>. | ||||
| EOF | ||||
| } | ||||
| 
 | ||||
| # Check the arguments. | ||||
| for option in "$@"; do | ||||
|     case "$option" in | ||||
|     -h | --help) | ||||
| 	usage | ||||
| 	exit 0 ;; | ||||
|     -v | --version) | ||||
| 	echo "$0 (GNU GRUB @PACKAGE_VERSION@)" | ||||
| 	exit 0 ;; | ||||
|     -o) | ||||
| 	shift | ||||
| 	output_dir=$1 | ||||
| 	;; | ||||
|     --output=) | ||||
| 	output_dir=`echo "$option" | sed 's/--output=//'` | ||||
| 	;; | ||||
|     -*) | ||||
| 	echo "Unrecognized option \`$option'" 1>&2 | ||||
| 	usage | ||||
| 	exit 1 | ||||
| 	;; | ||||
|     esac | ||||
| done | ||||
| 
 | ||||
| dd if=/dev/mem of=${output_dir}vbios.bin bs=65536 skip=12 count=1 | ||||
| dd if=/dev/mem of=${output_dir}int10.bin bs=4 skip=16 count=1 | ||||
|  | @ -72,7 +72,7 @@ usage (int status) | |||
|     fprintf (stderr, "Try ``grub-editenv --help'' for more information.\n"); | ||||
|   else | ||||
|     printf ("\
 | ||||
| Usage: grub-editenv [OPTIONS] FILENAME COMMAND\n\ | ||||
| Usage: grub-editenv [OPTIONS] [FILENAME] COMMAND\n\ | ||||
| \n\ | ||||
| Tool to edit environment block.\n\ | ||||
| \nCommands:\n\ | ||||
|  | @ -85,7 +85,10 @@ Tool to edit environment block.\n\ | |||
|   -V, --version             print version information and exit\n\ | ||||
|   -v, --verbose             print verbose messages\n\ | ||||
| \n\ | ||||
| Report bugs to <%s>.\n", PACKAGE_BUGREPORT); | ||||
| If not given explicitly, FILENAME defaults to %s.\n\ | ||||
| \n\ | ||||
| Report bugs to <%s>.\n", | ||||
| DEFAULT_DIRECTORY "/" GRUB_ENVBLK_DEFCFG, PACKAGE_BUGREPORT); | ||||
| 
 | ||||
|   exit (status); | ||||
| } | ||||
|  | @ -95,25 +98,31 @@ create_envblk_file (const char *name) | |||
| { | ||||
|   FILE *fp; | ||||
|   char *buf; | ||||
|   char *namenew; | ||||
| 
 | ||||
|   buf = malloc (DEFAULT_ENVBLK_SIZE); | ||||
|   if (! buf) | ||||
|     grub_util_error ("out of memory"); | ||||
| 
 | ||||
|   fp = fopen (name, "wb"); | ||||
|   asprintf (&namenew, "%s.new", name); | ||||
|   fp = fopen (namenew, "wb"); | ||||
|   if (! fp) | ||||
|     grub_util_error ("cannot open the file %s", name); | ||||
|     grub_util_error ("cannot open the file %s", namenew); | ||||
| 
 | ||||
|   memcpy (buf, GRUB_ENVBLK_SIGNATURE, sizeof (GRUB_ENVBLK_SIGNATURE) - 1); | ||||
|   memset (buf + sizeof (GRUB_ENVBLK_SIGNATURE) - 1, '#', | ||||
|           DEFAULT_ENVBLK_SIZE - sizeof (GRUB_ENVBLK_SIGNATURE) + 1); | ||||
| 
 | ||||
|   if (fwrite (buf, 1, DEFAULT_ENVBLK_SIZE, fp) != DEFAULT_ENVBLK_SIZE) | ||||
|     grub_util_error ("cannot write to the file %s", name); | ||||
|     grub_util_error ("cannot write to the file %s", namenew); | ||||
| 
 | ||||
|   fsync (fileno (fp)); | ||||
|   free (buf); | ||||
|   fclose (fp); | ||||
| 
 | ||||
|   if (rename (namenew, name) < 0) | ||||
|     grub_util_error ("cannot rename the file %s to %s", namenew, name); | ||||
|   free (namenew); | ||||
| } | ||||
| 
 | ||||
| static grub_envblk_t | ||||
|  | @ -282,12 +291,14 @@ main (int argc, char *argv[]) | |||
| 
 | ||||
|   if (optind + 1 >= argc) | ||||
|     { | ||||
|       fprintf (stderr, "no command specified\n"); | ||||
|       usage (1); | ||||
|       filename = DEFAULT_DIRECTORY "/" GRUB_ENVBLK_DEFCFG; | ||||
|       command = argv[optind]; | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       filename = argv[optind]; | ||||
|       command = argv[optind + 1]; | ||||
|     } | ||||
| 
 | ||||
|   filename = argv[optind]; | ||||
|   command = argv[optind + 1]; | ||||
| 
 | ||||
|   if (strcmp (command, "create") == 0) | ||||
|     create_envblk_file (filename); | ||||
|  |  | |||
|  | @ -326,14 +326,7 @@ else | |||
|     $grub_mkimage ${config_opt} -d ${pkglibdir} --output=/boot/multiboot.img --prefix=${prefix_drive}${relative_grubdir} $modules || exit 1 | ||||
| fi | ||||
| 
 | ||||
| # Prompt the user to check if the device map is correct. | ||||
| echo "Installation finished. No error reported." | ||||
| echo "This is the contents of the device map $device_map." | ||||
| echo "Check if this is correct or not. If any of the lines is incorrect," | ||||
| echo "fix it and re-run the script \`grub-install'." | ||||
| echo | ||||
| 
 | ||||
| cat $device_map | ||||
| 
 | ||||
| # Bye. | ||||
| exit 0 | ||||
|  | @ -157,7 +157,7 @@ grub_file_is_not_garbage () | |||
| { | ||||
|   if test -f "$1" ; then | ||||
|     case "$1" in | ||||
|       *.dpkg-dist|*.dpkg-old|*.dpkg-tmp) return 1 ;; # debian dpkg | ||||
|       *.dpkg-*) return 1 ;; # debian dpkg | ||||
|     esac | ||||
|   else | ||||
|     return 1 | ||||
|  |  | |||
							
								
								
									
										175
									
								
								util/grub-mkrescue.in
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										175
									
								
								util/grub-mkrescue.in
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,175 @@ | |||
| #! /bin/sh -e | ||||
| 
 | ||||
| # Make GRUB rescue image | ||||
| # Copyright (C) 1999,2000,2001,2002,2003,2004,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/>. | ||||
| 
 | ||||
| # Initialize some variables. | ||||
| transform="@program_transform_name@" | ||||
| 
 | ||||
| prefix=@prefix@ | ||||
| exec_prefix=@exec_prefix@ | ||||
| bindir=@bindir@ | ||||
| libdir=@libdir@ | ||||
| PACKAGE_NAME=@PACKAGE_NAME@ | ||||
| PACKAGE_TARNAME=@PACKAGE_TARNAME@ | ||||
| PACKAGE_VERSION=@PACKAGE_VERSION@ | ||||
| target_cpu=@target_cpu@ | ||||
| native_platform=@platform@ | ||||
| 
 | ||||
| coreboot_dir=${libdir}/$(echo ${PACKAGE_TARNAME} | sed ${transform})/${target_cpu}-coreboot | ||||
| pc_dir=${libdir}/$(echo ${PACKAGE_TARNAME} | sed ${transform})/${target_cpu}-pc | ||||
| 
 | ||||
| # Usage: usage | ||||
| # Print the usage. | ||||
| usage () { | ||||
|     cat <<EOF | ||||
| Usage: $0 [OPTION] SOURCE... | ||||
| Make GRUB rescue image. | ||||
| 
 | ||||
|   -h, --help              print this message and exit | ||||
|   -v, --version           print the version information and exit | ||||
|   --modules=MODULES       pre-load specified modules MODULES | ||||
|   --output=FILE           save output in FILE [required] | ||||
| 
 | ||||
| $0 generates a bootable rescue image with specified source files or directories. | ||||
| 
 | ||||
| Report bugs to <bug-grub@gnu.org>. | ||||
| EOF | ||||
| } | ||||
| 
 | ||||
| # Check the arguments. | ||||
| for option in "$@"; do | ||||
|     case "$option" in | ||||
|     -h | --help) | ||||
| 	usage | ||||
| 	exit 0 ;; | ||||
|     -v | --version) | ||||
| 	echo "$0 (GNU GRUB ${PACKAGE_VERSION})" | ||||
| 	exit 0 ;; | ||||
|     --modules=*) | ||||
| 	modules=`echo "$option" | sed 's/--modules=//'` ;; | ||||
|     --output=*) | ||||
| 	output_image=`echo "$option" | sed 's/--output=//'` ;; | ||||
|     # Intentionally undocumented | ||||
|     --override-directory=*) | ||||
| 	override_dir=`echo "${option}/" | sed 's/--override-directory=//'` | ||||
| 	PATH=${override_dir}:$PATH | ||||
| 	export PATH | ||||
| 	;; | ||||
|     -*) | ||||
| 	echo "Unrecognized option \`$option'" 1>&2 | ||||
| 	usage | ||||
| 	exit 1 | ||||
| 	;; | ||||
|     *) | ||||
| 	source="${source} ${option}" ;; | ||||
|     esac | ||||
| done | ||||
| 
 | ||||
| if [ "x${output_image}" = x ] ; then | ||||
|   echo "output file must be given" >&2 | ||||
|   usage | ||||
|   exit 1 | ||||
| fi | ||||
| 
 | ||||
| iso9660_dir=`mktemp -d` | ||||
| mkdir -p ${iso9660_dir}/boot/grub | ||||
| 
 | ||||
| process_input_dir () | ||||
| { | ||||
|     input_dir="$1" | ||||
|     platform="$2" | ||||
|     mkdir -p ${iso9660_dir}/boot/grub/${target_cpu}-${platform} | ||||
|     for file in ${input_dir}/*.mod ${input_dir}/efiemu??.o \ | ||||
|         ${input_dir}/command.lst ${input_dir}/moddep.lst ${input_dir}/fs.lst \ | ||||
|         ${input_dir}/handler.lst ${input_dir}/parttool.lst; do | ||||
|         if test -f "$file"; then | ||||
|             cp -f "$file" ${iso9660_dir}/boot/grub/${target_cpu}-${platform}/ | ||||
|         fi | ||||
|     done | ||||
| } | ||||
| 
 | ||||
| if [ "${override_dir}" = "" ] ; then | ||||
|     if test -e "${coreboot_dir}" ; then | ||||
|         process_input_dir ${coreboot_dir} coreboot | ||||
|     fi | ||||
|     if test -e "${pc_dir}" ; then | ||||
|         process_input_dir ${pc_dir} pc | ||||
|     fi | ||||
| else | ||||
|     process_input_dir ${override_dir} ${native_platform} | ||||
|     coreboot_dir= | ||||
|     pc_dir= | ||||
|     case "${native_platform}" in | ||||
|         coreboot) coreboot_dir=${override_dir} ;; | ||||
|         pc) pc_dir=${override_dir} ;; | ||||
|     esac | ||||
| fi | ||||
| 
 | ||||
| # build coreboot core.img | ||||
| if test -e "${coreboot_dir}" ; then | ||||
|     echo "Generates coreboot" | ||||
|     memdisk_img=`mktemp` | ||||
|     memdisk_dir=`mktemp -d` | ||||
|     mkdir -p ${memdisk_dir}/boot/grub | ||||
|     # obtain date-based UUID | ||||
|     iso_uuid=$(date +%Y-%m-%d-%H-%M-%S-00) | ||||
| 
 | ||||
|     modules="$(cat ${coreboot_dir}/partmap.lst) ${modules}" | ||||
|     cat << EOF > ${memdisk_dir}/boot/grub/grub.cfg | ||||
| search --fs-uuid --set ${iso_uuid} | ||||
| set prefix=(\${root})/boot/grub/${target_cpu}-coreboot | ||||
| EOF | ||||
|     (for i in ${modules} ; do | ||||
|         echo "insmod $i" | ||||
|     done ; \ | ||||
|     echo "source /boot/grub/grub.cfg") \ | ||||
|     > ${iso9660_dir}/boot/grub/i386-pc/grub.cfg | ||||
| 
 | ||||
|     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 \ | ||||
|         memdisk tar search iso9660 configfile sh \ | ||||
|         ata at_keyboard | ||||
|     rm -f ${memdisk_img} | ||||
|     grub_mkisofs_arguments="${grub_mkisofs_arguments} --modification-date=$(echo ${iso_uuid} | sed -e s/-//g)" | ||||
| fi | ||||
| 
 | ||||
| # build eltorito core.img | ||||
| if test -e "${pc_dir}" ; then | ||||
|     echo "Generates eltorito" | ||||
|     core_img=`mktemp` | ||||
|     grub-mkimage -d ${pc_dir}/ -o ${core_img} --prefix=/boot/grub/i386-pc \ | ||||
|         memdisk tar search iso9660 configfile sh \ | ||||
|         biosdisk | ||||
|     cat ${pc_dir}/cdboot.img ${core_img} > ${iso9660_dir}/boot/grub/i386-pc/eltorito.img | ||||
|     rm -f ${core_img} | ||||
| 
 | ||||
|     modules="$(cat ${pc_dir}/partmap.lst) ${modules}" | ||||
|     (for i in ${modules} ; do | ||||
|         echo "insmod $i" | ||||
|     done ; \ | ||||
|     echo "source /boot/grub/grub.cfg") \ | ||||
|     > ${iso9660_dir}/boot/grub/i386-pc/grub.cfg | ||||
| 
 | ||||
|     grub_mkisofs_arguments="${grub_mkisofs_arguments} -b boot/grub/i386-pc/eltorito.img -boot-info-table" | ||||
| fi | ||||
| 
 | ||||
| # build iso image | ||||
| grub-mkisofs ${grub_mkisofs_arguments} -o ${output_image} -r ${iso9660_dir} ${source} | ||||
| rm -rf ${iso9660_dir} | ||||
| 
 | ||||
| exit 0 | ||||
|  | @ -1,76 +0,0 @@ | |||
| #! /bin/sh -e | ||||
| 
 | ||||
| # grub-mkconfig helper script. | ||||
| # Copyright (C) 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/>. | ||||
| 
 | ||||
| prefix=@prefix@ | ||||
| exec_prefix=@exec_prefix@ | ||||
| libdir=@libdir@ | ||||
| . ${libdir}/grub/grub-mkconfig_lib | ||||
| 
 | ||||
| case "${GRUB_DISTRIBUTOR}" in | ||||
|   Debian)	OS="${GRUB_DISTRIBUTOR} GNU/kFreeBSD" ;; | ||||
|   *)		OS="FreeBSD" ;; | ||||
| esac | ||||
| 
 | ||||
| if test -e /boot/device.hints ; then | ||||
|   devices=/boot/device.hints | ||||
| fi | ||||
| 
 | ||||
| if test -e /boot/kernel/kernel ; then | ||||
|   kfreebsd=/boot/kernel/kernel | ||||
| fi | ||||
| if test -e /boot/kernel/kernel.gz ; then | ||||
|   kfreebsd=/boot/kernel/kernel.gz | ||||
| fi | ||||
| 
 | ||||
| if [ "x$kfreebsd" != "x" ] ; then | ||||
|   echo "Found kernel of FreeBSD: $kfreebsd" >&2 | ||||
| 
 | ||||
|   kfreebsd_basename=`basename $kfreebsd` | ||||
|   kfreebsd_dirname=`dirname $kfreebsd` | ||||
|   kfreebsd_rel_dirname=`make_system_path_relative_to_its_root $kfreebsd_dirname` | ||||
| 
 | ||||
|   if [ x"$devices" != "x" ] ; then | ||||
|     devices_basename=`basename $devices` | ||||
|     devices_dirname=`dirname $devices` | ||||
|     devices_rel_dirname=`make_system_path_relative_to_its_root $devices_dirname` | ||||
|   fi | ||||
| 
 | ||||
|   case ${GRUB_FS} in | ||||
|     ufs1 | ufs2)	kfreebsd_fs=ufs ;; | ||||
|     *)			kfreebsd_fs=${GRUB_FS} ;; | ||||
|   esac | ||||
| 
 | ||||
|   cat << EOF | ||||
| menuentry "${OS}" { | ||||
| EOF | ||||
|   prepare_grub_to_access_device ${GRUB_DEVICE_BOOT} | sed -e "s/^/\t/" | ||||
|   cat << EOF | ||||
| 	freebsd			${kfreebsd_rel_dirname}/${kfreebsd_basename} | ||||
| EOF | ||||
| 
 | ||||
|   if [ x"$devices" != "x" ] ; then | ||||
|     cat << EOF | ||||
| 	freebsd_loadenv		${devices_rel_dirname}/${devices_basename} | ||||
| EOF | ||||
|   fi | ||||
|   cat << EOF | ||||
| 	set FreeBSD.vfs.root.mountfrom=${kfreebsd_fs}:${GRUB_DEVICE} | ||||
| 	set FreeBSD.vfs.root.mountfrom.options=rw | ||||
| } | ||||
| EOF | ||||
| fi | ||||
|  | @ -71,15 +71,18 @@ fi | |||
| cat << EOF | ||||
| menuentry "${OS}" { | ||||
| EOF | ||||
| prepare_grub_to_access_device ${GRUB_DEVICE_BOOT} | sed -e "s/^/\t/" | ||||
| cat << EOF | ||||
| 	multiboot ${kernel} root=device:${GRUB_DEVICE#/dev/} | ||||
| EOF | ||||
| prepare_grub_to_access_device ${GRUB_DEVICE} | sed -e "s/^/\t/" | ||||
| cat << EOF | ||||
| 	multiboot ${kernel} root=device:${GRUB_DEVICE} | ||||
| 	module /hurd/${hurd_fs}.static --readonly \\ | ||||
| 	module /hurd/${hurd_fs}.static ${hurd_fs} --readonly \\ | ||||
| 			--multiboot-command-line='\${kernel-command-line}' \\ | ||||
| 			--host-priv-port='\${host-port}' \\ | ||||
| 			--device-master-port='\${device-port}' \\ | ||||
| 			--exec-server-task='\${exec-task}' -T typed '\${root}' \\ | ||||
| 			'\$(task-create)' '\$(task-resume)' | ||||
| 	module /lib/ld.so.1 /hurd/exec '\$(exec-task=task-create)' | ||||
| 	module /lib/ld.so.1 exec /hurd/exec '\$(exec-task=task-create)' | ||||
| } | ||||
| EOF | ||||
|  |  | |||
							
								
								
									
										114
									
								
								util/grub.d/10_kfreebsd.in
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										114
									
								
								util/grub.d/10_kfreebsd.in
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,114 @@ | |||
| #! /bin/sh -e | ||||
| 
 | ||||
| # grub-mkconfig helper script. | ||||
| # Copyright (C) 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/>. | ||||
| 
 | ||||
| prefix=@prefix@ | ||||
| exec_prefix=@exec_prefix@ | ||||
| bindir=@bindir@ | ||||
| libdir=@libdir@ | ||||
| . ${libdir}/grub/grub-mkconfig_lib | ||||
| 
 | ||||
| . ${bindir}/gettext.sh | ||||
| export TEXTDOMAIN=@PACKAGE@ | ||||
| export TEXTDOMAINDIR=@LOCALEDIR@ | ||||
| 
 | ||||
| case "${GRUB_DISTRIBUTOR}" in | ||||
|   Debian)	OS="${GRUB_DISTRIBUTOR} GNU/kFreeBSD" ;; | ||||
|   *)		OS="FreeBSD" ;; | ||||
| esac | ||||
| 
 | ||||
| kfreebsd_entry () | ||||
| { | ||||
|   os="$1" | ||||
|   version="$2" | ||||
|   recovery="$3"	# not used yet | ||||
|   args="$4"	# not used yet | ||||
|   title="$(gettext "%s, with kFreeBSD %s")" | ||||
|   printf "menuentry \"${title}\" {" ${os} ${version} | ||||
|   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 | ||||
| 	kfreebsd			${rel_dirname}/${basename} | ||||
| EOF | ||||
| 
 | ||||
|   if test -n "${devices}" ; then | ||||
|     cat << EOF | ||||
| 	kfreebsd_loadenv		${devices_rel_dirname}/${devices_basename} | ||||
| EOF | ||||
|   fi | ||||
| 
 | ||||
|   if test -n "${acpi_ko}" ; then | ||||
|     cat << EOF | ||||
| 	kfreebsd_module_elf	${acpi_ko_rel_dirname}/${acpi_ko_basename} | ||||
| EOF | ||||
|   fi | ||||
| 
 | ||||
|   cat << EOF | ||||
| 	set kFreeBSD.vfs.root.mountfrom=${kfreebsd_fs}:${GRUB_DEVICE} | ||||
| 	set kFreeBSD.vfs.root.mountfrom.options=rw | ||||
| } | ||||
| EOF | ||||
| } | ||||
| 
 | ||||
| list=`for i in /boot/kfreebsd-* /boot/kernel/kernel ; do | ||||
|         if grub_file_is_not_garbage "$i" ; then echo -n "$i " ; fi | ||||
|       done` | ||||
| prepare_boot_cache= | ||||
| 
 | ||||
| while [ "x$list" != "x" ] ; do | ||||
|   kfreebsd=`version_find_latest $list` | ||||
|   echo "Found kernel of FreeBSD: $kfreebsd" >&2 | ||||
|   basename=`basename $kfreebsd` | ||||
|   dirname=`dirname $kfreebsd` | ||||
|   rel_dirname=`make_system_path_relative_to_its_root $dirname` | ||||
| 
 | ||||
|   if [ -f /boot/device.hints ] ; then | ||||
|     devices=/boot/device.hints | ||||
|     devices_basename=`basename $devices` | ||||
|     devices_dirname=`dirname $devices` | ||||
|     devices_rel_dirname=`make_system_path_relative_to_its_root $devices_dirname` | ||||
|   fi | ||||
| 
 | ||||
|   case ${GRUB_FS} in | ||||
|     ufs1 | ufs2)        kfreebsd_fs=ufs ;; | ||||
|     *)                  kfreebsd_fs=${GRUB_FS} ;; | ||||
|   esac | ||||
| 
 | ||||
|   version=`echo $basename | sed -e "s,^[^0-9]*-,,g;s/\.gz$//g"` | ||||
|   alt_version=`echo $version | sed -e "s,\.old$,,g"` | ||||
| 
 | ||||
|   acpi_ko= | ||||
|   for i in "/lib/modules/${version}/acpi.ko" "/lib/modules/${alt_version}/acpi.ko" \ | ||||
|       "/boot/kernel/acpi.ko"; do | ||||
|     if test -e "$i" ; then | ||||
|       acpi_ko="$i" | ||||
|       break | ||||
|     fi | ||||
|   done | ||||
|   if test -n "${acpi_ko}" ; then | ||||
|     echo "Found ACPI module: ${acpi_ko}" >&2 | ||||
|     acpi_ko_basename=`basename ${acpi_ko}` | ||||
|     acpi_ko_dirname=`dirname ${acpi_ko}` | ||||
|     acpi_ko_rel_dirname=`make_system_path_relative_to_its_root $acpi_ko_dirname` | ||||
|   fi | ||||
| 
 | ||||
|   kfreebsd_entry "${OS}" "${version}" | ||||
| 
 | ||||
|   list=`echo $list | tr ' ' '\n' | grep -vx $kfreebsd | tr '\n' ' '` | ||||
| done | ||||
|  | @ -18,9 +18,14 @@ | |||
| 
 | ||||
| prefix=@prefix@ | ||||
| exec_prefix=@exec_prefix@ | ||||
| bindir=@bindir@ | ||||
| libdir=@libdir@ | ||||
| . ${libdir}/grub/grub-mkconfig_lib | ||||
| 
 | ||||
| . ${bindir}/gettext.sh | ||||
| export TEXTDOMAIN=@PACKAGE@ | ||||
| export TEXTDOMAINDIR=@LOCALEDIR@ | ||||
| 
 | ||||
| if [ "x${GRUB_DISTRIBUTOR}" = "x" ] ; then | ||||
|   OS=GNU/Linux | ||||
| else | ||||
|  | @ -44,12 +49,22 @@ fi | |||
| 
 | ||||
| linux_entry () | ||||
| { | ||||
|   os="$1" | ||||
|   version="$2" | ||||
|   recovery="$3" | ||||
|   args="$4" | ||||
|   if ${recovery} ; then | ||||
|     title="$(gettext "%s, with Linux %s (recovery mode)")" | ||||
|   else | ||||
|     title="$(gettext "%s, with Linux %s")" | ||||
|   fi | ||||
|   printf "menuentry \"${title}\" {" ${os} ${version} | ||||
|   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 | ||||
| menuentry "$1" { | ||||
| EOF | ||||
|   prepare_grub_to_access_device ${GRUB_DEVICE_BOOT} | sed -e "s/^/\t/" | ||||
|   cat << EOF | ||||
| 	linux	${rel_dirname}/${basename} root=${linux_root_device_thisversion} ro $2 | ||||
| 	linux	${rel_dirname}/${basename} root=${linux_root_device_thisversion} ro ${args} | ||||
| EOF | ||||
|   if test -n "${initrd}" ; then | ||||
|     cat << EOF | ||||
|  | @ -64,6 +79,7 @@ EOF | |||
| list=`for i in /boot/vmlinu[xz]-* /vmlinu[xz]-* ; do | ||||
|         if grub_file_is_not_garbage "$i" ; then echo -n "$i " ; fi | ||||
|       done` | ||||
| prepare_boot_cache= | ||||
| 
 | ||||
| while [ "x$list" != "x" ] ; do | ||||
|   linux=`version_find_latest $list` | ||||
|  | @ -91,10 +107,10 @@ while [ "x$list" != "x" ] ; do | |||
|     linux_root_device_thisversion=${GRUB_DEVICE} | ||||
|   fi | ||||
| 
 | ||||
|   linux_entry "${OS}, Linux ${version}" \ | ||||
|   linux_entry "${OS}" "${version}" false \ | ||||
|       "${GRUB_CMDLINE_LINUX} ${GRUB_CMDLINE_LINUX_DEFAULT}" | ||||
|   if [ "x${GRUB_DISABLE_LINUX_RECOVERY}" != "xtrue" ]; then | ||||
|     linux_entry "${OS}, Linux ${version} (recovery mode)" \ | ||||
|     linux_entry "${OS}" "${version}" true \ | ||||
| 	"single ${GRUB_CMDLINE_LINUX}" | ||||
|   fi | ||||
| 
 | ||||
|  |  | |||
|  | @ -74,6 +74,7 @@ EOF | |||
|     ;; | ||||
|     linux) | ||||
|       LINUXPROBED="`linux-boot-prober ${DEVICE} 2> /dev/null | tr ' ' '^' | paste -s -d ' '`" | ||||
|       prepare_boot_cache= | ||||
| 
 | ||||
|       for LINUX in ${LINUXPROBED} ; do | ||||
|         LROOT="`echo ${LINUX} | cut -d ':' -f 1`" | ||||
|  | @ -87,10 +88,18 @@ EOF | |||
|           LLABEL="${LONGNAME}" | ||||
|         fi | ||||
| 
 | ||||
| 	if [ "${LROOT}" != "${LBOOT}" ]; then | ||||
| 	  LKERNEL="${LKERNEL#/boot}" | ||||
| 	  LINITRD="${LINITRD#/boot}" | ||||
| 	fi | ||||
| 
 | ||||
|         cat << EOF | ||||
| menuentry "${LLABEL} (on ${DEVICE})" { | ||||
| EOF | ||||
| 	prepare_grub_to_access_device ${DEVICE} | sed -e "s/^/\t/" | ||||
| 	if [ -z "${prepare_boot_cache}" ]; then | ||||
| 	  prepare_boot_cache="$(prepare_grub_to_access_device ${LBOOT} | sed -e "s/^/\t/")" | ||||
| 	fi | ||||
| 	printf '%s\n' "${prepare_boot_cache}" | ||||
| 	cat <<  EOF | ||||
| 	linux ${LKERNEL} ${LPARAMS} | ||||
| EOF | ||||
|  | @ -154,7 +163,31 @@ EOF | |||
| } | ||||
| EOF | ||||
|     ;; | ||||
|     hurd|*) | ||||
|     hurd) | ||||
|       cat << EOF | ||||
| menuentry "${LONGNAME} (on ${DEVICE})" { | ||||
| EOF | ||||
|       prepare_grub_to_access_device ${DEVICE} | sed -e "s/^/\t/" | ||||
|       grub_device="`${grub_probe} --device ${DEVICE} --target=drive`" | ||||
|       mach_device="`echo "${grub_device}" | tr -d '()' | tr , s`" | ||||
|       grub_fs="`${grub_probe} --device ${DEVICE} --target=fs`" | ||||
|       case "${grub_fs}" in | ||||
| 	*fs)	hurd_fs="${grub_fs}" ;; | ||||
| 	*)	hurd_fs="${grub_fs}fs" ;; | ||||
|       esac | ||||
|       cat << EOF | ||||
| 	multiboot /boot/gnumach.gz root=device:${mach_device} | ||||
| 	module /hurd/${hurd_fs}.static ${hurd_fs} --readonly \\ | ||||
| 			--multiboot-command-line='\${kernel-command-line}' \\ | ||||
| 			--host-priv-port='\${host-port}' \\ | ||||
| 			--device-master-port='\${device-port}' \\ | ||||
| 			--exec-server-task='\${exec-task}' -T typed '\${root}' \\ | ||||
| 			'\$(task-create)' '\$(task-resume)' | ||||
| 	module /lib/ld.so.1 exec /hurd/exec '\$(exec-task=task-create)' | ||||
| } | ||||
| EOF | ||||
|     ;; | ||||
|     *) | ||||
|       echo "  ${LONGNAME} is not yet supported by grub-mkconfig." >&2 | ||||
|     ;; | ||||
|   esac | ||||
|  |  | |||
|  | @ -1057,7 +1057,7 @@ grub_util_biosdisk_get_grub_dev (const char *os_dev) | |||
| 	n = strtol (p, &q, 10); | ||||
| 	if (p != q && n != GRUB_LONG_MIN && n != GRUB_LONG_MAX) | ||||
| 	  { | ||||
| 	    dos_part = (int) n; | ||||
| 	    dos_part = (int) n - 1; | ||||
| 
 | ||||
| 	    if (*q >= 'a' && *q <= 'g') | ||||
| 	      bsd_part = *q - 'a'; | ||||
|  |  | |||
|  | @ -683,8 +683,8 @@ make_mods_section (FILE *out, Elf_Addr current_address, | |||
|       grub_util_info ("adding module %s", p->name); | ||||
| 
 | ||||
|       mod_size = grub_util_get_image_size (p->name); | ||||
|       header.type = grub_cpu_to_le32 (OBJ_TYPE_ELF); | ||||
|       header.size = grub_cpu_to_le32 (mod_size + sizeof (header)); | ||||
|       header.type = OBJ_TYPE_ELF; | ||||
|       header.size = grub_host_to_target32 (mod_size + sizeof (header)); | ||||
| 
 | ||||
|       mod_image = grub_util_read_image (p->name); | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										116
									
								
								util/i386/pc/grub-mkfloppy.in
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								util/i386/pc/grub-mkfloppy.in
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,116 @@ | |||
| #! /bin/sh -e | ||||
| 
 | ||||
| # Make GRUB rescue floppy | ||||
| # Copyright (C) 1999,2000,2001,2002,2003,2004,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/>. | ||||
| 
 | ||||
| # Initialize some variables. | ||||
| transform="@program_transform_name@" | ||||
| 
 | ||||
| prefix=@prefix@ | ||||
| exec_prefix=@exec_prefix@ | ||||
| bindir=@bindir@ | ||||
| libdir=@libdir@ | ||||
| PACKAGE_NAME=@PACKAGE_NAME@ | ||||
| PACKAGE_TARNAME=@PACKAGE_TARNAME@ | ||||
| PACKAGE_VERSION=@PACKAGE_VERSION@ | ||||
| target_cpu=@target_cpu@ | ||||
| platform=@platform@ | ||||
| pkglibdir=${libdir}/`echo ${PACKAGE_TARNAME}/${target_cpu}-${platform} | sed ${transform}` | ||||
| 
 | ||||
| # Usage: usage | ||||
| # Print the usage. | ||||
| usage () { | ||||
|     cat <<EOF | ||||
| Usage: $0 [OPTION] output_image | ||||
| Make GRUB rescue floppy. | ||||
| 
 | ||||
|   -h, --help              print this message and exit | ||||
|   -v, --version           print the version information and exit | ||||
|   --modules=MODULES       pre-load specified modules MODULES | ||||
|   --output=FILE           save output in FILE | ||||
| 
 | ||||
| $0 generates a bootable rescue floppy. | ||||
| 
 | ||||
| Report bugs to <bug-grub@gnu.org>. | ||||
| EOF | ||||
| } | ||||
| 
 | ||||
| input_dir=${pkglibdir} | ||||
| 
 | ||||
| # Check the arguments. | ||||
| for option in "$@"; do | ||||
|     case "$option" in | ||||
|     -h | --help) | ||||
| 	usage | ||||
| 	exit 0 ;; | ||||
|     -v | --version) | ||||
| 	echo "$0 (GNU GRUB ${PACKAGE_VERSION})" | ||||
| 	exit 0 ;; | ||||
|     --modules=*) | ||||
| 	modules=`echo "$option" | sed 's/--modules=//'` ;; | ||||
|     --output=*) | ||||
| 	output_image=`echo "$option" | sed 's/--output=//'` ;; | ||||
|     -*) | ||||
| 	echo "Unrecognized option \`$option'" 1>&2 | ||||
| 	usage | ||||
| 	exit 1 | ||||
| 	;; | ||||
|     *) | ||||
| 	if test "x$output_image" != x; then | ||||
| 	    echo "Unrecognized option \`$option'" 1>&2 | ||||
| 	    usage | ||||
| 	    exit 1 | ||||
| 	fi | ||||
| 	output_image="${option}" ;; | ||||
|     esac | ||||
| done | ||||
| 
 | ||||
| if test "x$output_image" = x; then | ||||
|   usage | ||||
|   exit 1 | ||||
| fi | ||||
| 
 | ||||
| aux_dir=`mktemp -d` | ||||
| mkdir -p ${aux_dir}/boot/grub | ||||
| 
 | ||||
| for file in ${input_dir}/*.mod ${input_dir}/efiemu??.o \ | ||||
|   ${input_dir}/command.lst ${input_dir}/moddep.lst ${input_dir}/fs.lst \ | ||||
|   ${input_dir}/handler.lst ${input_dir}/parttool.lst; do | ||||
|   if test -f "$file"; then | ||||
|     cp -f "$file" ${aux_dir}/boot/grub/ | ||||
|   fi | ||||
| done | ||||
| 
 | ||||
| modules="$(cat ${input_dir}/partmap.lst) ${modules}" | ||||
| for i in ${modules} ; do | ||||
|   echo "insmod $i" | ||||
| done > ${aux_dir}/boot/grub/grub.cfg | ||||
| 
 | ||||
| # build memdisk | ||||
| memdisk_img=`mktemp` | ||||
| tar -C ${aux_dir} -cf ${memdisk_img} boot | ||||
| rm -rf ${aux_dir} | ||||
| 
 | ||||
| # build core.img | ||||
| core_img=`mktemp` | ||||
| grub-mkimage -d ${input_dir}/ -m ${memdisk_img} -o ${core_img} memdisk tar biosdisk | ||||
| rm -f ${memdisk_img} | ||||
| 
 | ||||
| # build floppy image | ||||
| cat ${input_dir}/boot.img ${core_img} /dev/zero | dd bs=1024 count=1440 > ${output_image} | ||||
| rm -f ${core_img} | ||||
| 
 | ||||
| exit 0 | ||||
|  | @ -22,6 +22,7 @@ | |||
| #include <grub/machine/boot.h> | ||||
| #include <grub/machine/kernel.h> | ||||
| #include <grub/machine/memory.h> | ||||
| #include <grub/i18n.h> | ||||
| #include <grub/kernel.h> | ||||
| #include <grub/disk.h> | ||||
| #include <grub/util/misc.h> | ||||
|  | @ -36,6 +37,8 @@ | |||
| #define _GNU_SOURCE	1 | ||||
| #include <getopt.h> | ||||
| 
 | ||||
| #include "progname.h" | ||||
| 
 | ||||
| #ifdef ENABLE_LZMA | ||||
| #include <grub/lib/LzmaEnc.h> | ||||
| 
 | ||||
|  | @ -59,7 +62,7 @@ compress_kernel (char *kernel_img, size_t kernel_size, | |||
|   props.numThreads = 1; | ||||
| 
 | ||||
|   if (kernel_size < GRUB_KERNEL_MACHINE_RAW_SIZE) | ||||
|     grub_util_error ("the core image is too small"); | ||||
|     grub_util_error (_("the core image is too small")); | ||||
| 
 | ||||
|   *core_img = xmalloc (kernel_size); | ||||
|   memcpy (*core_img, kernel_img, GRUB_KERNEL_MACHINE_RAW_SIZE); | ||||
|  | @ -71,7 +74,7 @@ compress_kernel (char *kernel_img, size_t kernel_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"); | ||||
|     grub_util_error (_("cannot compress the kernel image")); | ||||
| 
 | ||||
|   *core_size += GRUB_KERNEL_MACHINE_RAW_SIZE; | ||||
| } | ||||
|  | @ -97,7 +100,6 @@ generate_image (const char *dir, char *prefix, FILE *out, char *mods[], | |||
|   size_t kernel_size, boot_size, total_module_size, core_size; | ||||
|   size_t memdisk_size = 0, config_size = 0; | ||||
|   char *kernel_path, *boot_path; | ||||
|   unsigned num; | ||||
|   size_t offset; | ||||
|   struct grub_util_path_list *path_list, *p, *next; | ||||
|   struct grub_module_info *modinfo; | ||||
|  | @ -133,7 +135,7 @@ generate_image (const char *dir, char *prefix, FILE *out, char *mods[], | |||
|   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 too long"); | ||||
|     grub_util_error (_("prefix is too long")); | ||||
|   strcpy (kernel_img + GRUB_KERNEL_MACHINE_PREFIX, prefix); | ||||
| 
 | ||||
|   /* Fill in the grub_module_info structure.  */ | ||||
|  | @ -153,8 +155,8 @@ generate_image (const char *dir, char *prefix, FILE *out, char *mods[], | |||
| 
 | ||||
|       header = (struct grub_module_header *) (kernel_img + offset); | ||||
|       memset (header, 0, sizeof (struct grub_module_header)); | ||||
|       header->type = grub_cpu_to_le32 (OBJ_TYPE_ELF); | ||||
|       header->size = grub_cpu_to_le32 (mod_size + sizeof (*header)); | ||||
|       header->type = OBJ_TYPE_ELF; | ||||
|       header->size = grub_host_to_target32 (mod_size + sizeof (*header)); | ||||
|       offset += sizeof (*header); | ||||
| 
 | ||||
|       grub_util_load_image (p->name, kernel_img + offset); | ||||
|  | @ -167,8 +169,8 @@ generate_image (const char *dir, char *prefix, FILE *out, char *mods[], | |||
| 
 | ||||
|       header = (struct grub_module_header *) (kernel_img + offset); | ||||
|       memset (header, 0, sizeof (struct grub_module_header)); | ||||
|       header->type = grub_cpu_to_le32 (OBJ_TYPE_MEMDISK); | ||||
|       header->size = grub_cpu_to_le32 (memdisk_size + sizeof (*header)); | ||||
|       header->type = 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); | ||||
|  | @ -181,8 +183,8 @@ generate_image (const char *dir, char *prefix, FILE *out, char *mods[], | |||
| 
 | ||||
|       header = (struct grub_module_header *) (kernel_img + offset); | ||||
|       memset (header, 0, sizeof (struct grub_module_header)); | ||||
|       header->type = grub_cpu_to_le32 (OBJ_TYPE_CONFIG); | ||||
|       header->size = grub_cpu_to_le32 (config_size + sizeof (*header)); | ||||
|       header->type = 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); | ||||
|  | @ -196,30 +198,30 @@ generate_image (const char *dir, char *prefix, FILE *out, char *mods[], | |||
| 
 | ||||
|   grub_util_info ("the core size is 0x%x", core_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"); | ||||
| 
 | ||||
| #if defined(GRUB_MACHINE_PCBIOS) | ||||
| 
 | ||||
|   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); | ||||
| 
 | ||||
|   /* i386 is a little endian architecture.  */ | ||||
|   *((grub_uint16_t *) (boot_img + GRUB_DISK_SECTOR_SIZE | ||||
| 		       - GRUB_BOOT_MACHINE_LIST_SIZE + 8)) | ||||
|     = grub_cpu_to_le16 (num); | ||||
| 
 | ||||
|   grub_util_write_image (boot_img, boot_size, out); | ||||
|   free (boot_img); | ||||
|   free (boot_path); | ||||
| 
 | ||||
|   { | ||||
|     unsigned num; | ||||
|     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); | ||||
|      | ||||
|     /* i386 is a little endian architecture.  */ | ||||
|     *((grub_uint16_t *) (boot_img + GRUB_DISK_SECTOR_SIZE | ||||
| 			 - GRUB_BOOT_MACHINE_LIST_SIZE + 8)) | ||||
|       = grub_cpu_to_le16 (num); | ||||
|      | ||||
|     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; | ||||
|  | @ -279,7 +281,7 @@ generate_image (const char *dir, char *prefix, FILE *out, char *mods[], | |||
| 
 | ||||
| #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)\n", | ||||
|     grub_util_error (_("Core image is too big (%p > %p)\n"), | ||||
|  		     GRUB_KERNEL_MACHINE_LINK_ADDR + core_size, GRUB_MEMORY_MACHINE_UPPER); | ||||
| #endif | ||||
| 
 | ||||
|  | @ -316,9 +318,9 @@ static void | |||
| usage (int status) | ||||
| { | ||||
|   if (status) | ||||
|     fprintf (stderr, "Try ``grub-mkimage --help'' for more information.\n"); | ||||
|     fprintf (stderr, _("Try ``%s --help'' for more information.\n"), program_name); | ||||
|   else | ||||
|     printf ("\
 | ||||
|     printf (_("\
 | ||||
| Usage: grub-mkimage [OPTION]... [MODULES]\n\ | ||||
| \n\ | ||||
| Make a bootable image of GRUB.\n\ | ||||
|  | @ -333,7 +335,7 @@ Make a bootable image of GRUB.\n\ | |||
|   -v, --verbose           print verbose messages\n\ | ||||
| \n\ | ||||
| Report bugs to <%s>.\n\ | ||||
| ", GRUB_LIBDIR, DEFAULT_DIRECTORY, PACKAGE_BUGREPORT); | ||||
| "), GRUB_LIBDIR, DEFAULT_DIRECTORY, PACKAGE_BUGREPORT); | ||||
| 
 | ||||
|   exit (status); | ||||
| } | ||||
|  | @ -348,7 +350,10 @@ main (int argc, char *argv[]) | |||
|   char *config = NULL; | ||||
|   FILE *fp = stdout; | ||||
| 
 | ||||
|   progname = "grub-mkimage"; | ||||
|   set_program_name (argv[0]); | ||||
|   setlocale (LC_ALL, ""); | ||||
|   bindtextdomain (PACKAGE, LOCALEDIR); | ||||
|   textdomain (PACKAGE); | ||||
| 
 | ||||
|   while (1) | ||||
|     { | ||||
|  | @ -421,7 +426,7 @@ main (int argc, char *argv[]) | |||
|     { | ||||
|       fp = fopen (output, "wb"); | ||||
|       if (! fp) | ||||
| 	grub_util_error ("cannot open %s", output); | ||||
| 	grub_util_error (_("cannot open %s"), output); | ||||
|       free (output); | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,180 +0,0 @@ | |||
| #! /bin/sh -e | ||||
| 
 | ||||
| # Make GRUB rescue image | ||||
| # Copyright (C) 1999,2000,2001,2002,2003,2004,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/>. | ||||
| 
 | ||||
| # Initialize some variables. | ||||
| transform="@program_transform_name@" | ||||
| 
 | ||||
| prefix=@prefix@ | ||||
| exec_prefix=@exec_prefix@ | ||||
| bindir=@bindir@ | ||||
| libdir=@libdir@ | ||||
| PACKAGE_NAME=@PACKAGE_NAME@ | ||||
| PACKAGE_TARNAME=@PACKAGE_TARNAME@ | ||||
| PACKAGE_VERSION=@PACKAGE_VERSION@ | ||||
| target_cpu=@target_cpu@ | ||||
| platform=@platform@ | ||||
| pkglibdir=${libdir}/`echo ${PACKAGE_TARNAME}/${target_cpu}-${platform} | sed ${transform}` | ||||
| 
 | ||||
| grub_mkimage=${bindir}/`echo grub-mkimage | sed ${transform}` | ||||
| 
 | ||||
| # Usage: usage | ||||
| # Print the usage. | ||||
| usage () { | ||||
|     cat <<EOF | ||||
| Usage: grub-mkrescue [OPTION] output_image | ||||
| Make GRUB rescue image. | ||||
| 
 | ||||
|   -h, --help              print this message and exit | ||||
|   -v, --version           print the version information and exit | ||||
|   --modules=MODULES       pre-load specified modules MODULES | ||||
|   --overlay=DIR           overlay directory DIR in the memdisk image | ||||
|                           (may be specified multiple times) | ||||
|   --pkglibdir=DIR         use images from directory DIR instead of ${pkglibdir} | ||||
|   --grub-mkimage=FILE     use FILE as grub-mkimage | ||||
|   --image-type=TYPE       select floppy or cdrom (default) | ||||
|   --emulation=TYPE        select El Torito boot emulation type floppy | ||||
|                           or none (default) (cdrom only) | ||||
| 
 | ||||
| grub-mkimage generates a bootable rescue image of the specified type. | ||||
| 
 | ||||
| Report bugs to <bug-grub@gnu.org>. | ||||
| EOF | ||||
| } | ||||
| 
 | ||||
| image_type=cdrom | ||||
| input_dir=${pkglibdir} | ||||
| emulation=none | ||||
| 
 | ||||
| # Check the arguments. | ||||
| for option in "$@"; do | ||||
|     case "$option" in | ||||
|     -h | --help) | ||||
| 	usage | ||||
| 	exit 0 ;; | ||||
|     -v | --version) | ||||
| 	echo "grub-mkrescue (GNU GRUB ${PACKAGE_VERSION})" | ||||
| 	exit 0 ;; | ||||
|     --modules=*) | ||||
| 	modules=`echo "$option" | sed 's/--modules=//'` ;; | ||||
|     --overlay=*) | ||||
| 	overlay=${overlay}${overlay:+ }`echo "$option" | sed 's/--overlay=//'` ;; | ||||
|     --pkglibdir=*) | ||||
| 	input_dir=`echo "$option" | sed 's/--pkglibdir=//'` ;; | ||||
|     --grub-mkimage=*) | ||||
| 	grub_mkimage=`echo "$option" | sed 's/--grub-mkimage=//'` ;; | ||||
|     --image-type=*) | ||||
|     	image_type=`echo "$option" | sed 's/--image-type=//'` | ||||
|         case "$image_type" in | ||||
|           floppy|cdrom) ;; | ||||
|           *) | ||||
|             echo "Unknown image type \`$image_type'" 1>&2 | ||||
|             exit 1 ;; | ||||
|         esac ;; | ||||
|     --emulation=*) | ||||
|     	emulation=`echo "$option" | sed 's/--emulation=//'` | ||||
|         case "$emulation" in | ||||
|           floppy|none) ;; | ||||
|           *) | ||||
|             echo "Unknown emulation type \`$emulation'" 1>&2 | ||||
|             exit 1 ;; | ||||
|         esac ;; | ||||
|     -*) | ||||
| 	echo "Unrecognized option \`$option'" 1>&2 | ||||
| 	usage | ||||
| 	exit 1 | ||||
| 	;; | ||||
|     *) | ||||
| 	if test "x$output_image" != x; then | ||||
| 	    echo "Unrecognized option \`$option'" 1>&2 | ||||
| 	    usage | ||||
| 	    exit 1 | ||||
| 	fi | ||||
| 	output_image="${option}" ;; | ||||
|     esac | ||||
| done | ||||
| 
 | ||||
| if test "x$output_image" = x; then | ||||
|   usage | ||||
|   exit 1 | ||||
| fi | ||||
| 
 | ||||
| aux_dir=`mktemp -d` | ||||
| mkdir -p ${aux_dir}/boot/grub | ||||
| 
 | ||||
| for file in ${input_dir}/*.mod ${input_dir}/efiemu??.o \ | ||||
|   ${input_dir}/command.lst ${input_dir}/moddep.lst ${input_dir}/fs.lst \ | ||||
|   ${input_dir}/handler.lst ${input_dir}/parttool.lst; do | ||||
|   if test -f "$file"; then | ||||
|     cp -f "$file" ${aux_dir}/boot/grub/ | ||||
|   fi | ||||
| done | ||||
| 
 | ||||
| modules="biosdisk `cat ${input_dir}/partmap.lst` ${modules}" | ||||
| for i in ${modules} ; do | ||||
|   echo "insmod $i" | ||||
| done > ${aux_dir}/boot/grub/grub.cfg | ||||
| 
 | ||||
| for d in ${overlay}; do | ||||
|   echo "Overlaying $d" | ||||
|   cp -dpR "${d}"/* "${aux_dir}"/ | ||||
| done | ||||
| 
 | ||||
| if [ "x${image_type}" = xfloppy -o "x${emulation}" = xfloppy ] ; then | ||||
|   # build memdisk | ||||
|   memdisk_img=`mktemp` | ||||
|   tar -C ${aux_dir} -cf ${memdisk_img} boot | ||||
|   rm -rf ${aux_dir} | ||||
| 
 | ||||
|   # build core.img | ||||
|   core_img=`mktemp` | ||||
|   ${grub_mkimage} -d ${input_dir}/ -m ${memdisk_img} -o ${core_img} memdisk tar | ||||
|   rm -f ${memdisk_img} | ||||
| 
 | ||||
|   # build floppy image | ||||
|   if [ "x${image_type}" = xcdrom ] ; then | ||||
|     floppy_dir=`mktemp -d` | ||||
|     floppy_img=${floppy_dir}/grub_floppy.img | ||||
|   else | ||||
|     floppy_img=${output_image} | ||||
|   fi | ||||
|   cat ${input_dir}/boot.img ${core_img} /dev/zero | dd bs=1024 count=1440 > ${floppy_img} | ||||
|   rm -f ${core_img} | ||||
| 
 | ||||
|   if [ "x${image_type}" = xcdrom ] ; then | ||||
|     # build iso image | ||||
|     genisoimage -b grub_floppy.img \ | ||||
|       -o ${output_image} -r -J ${floppy_dir} | ||||
|     rm -rf ${floppy_dir} | ||||
|   fi | ||||
| else | ||||
|   # build core.img | ||||
|   core_img=`mktemp` | ||||
|   ${grub_mkimage} -d ${input_dir}/ -o ${core_img} biosdisk iso9660 | ||||
| 
 | ||||
|   # build grub_eltorito image | ||||
|   cat ${input_dir}/cdboot.img ${core_img} > ${aux_dir}/boot/grub/grub_eltorito | ||||
|   rm -f ${core_img} | ||||
| 
 | ||||
|   # build iso image | ||||
|   genisoimage -b boot/grub/grub_eltorito \ | ||||
|     -no-emul-boot -boot-load-size 4 -boot-info-table \ | ||||
|     -o ${output_image} -r -J ${aux_dir} | ||||
|   rm -rf ${aux_dir} | ||||
| fi | ||||
| 
 | ||||
| exit 0 | ||||
|  | @ -1,7 +1,7 @@ | |||
| /* grub-setup.c - make GRUB usable */ | ||||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 1999,2000,2001,2002,2003,2004,2005,2006,2007,2008  Free Software Foundation, Inc. | ||||
|  *  Copyright (C) 1999,2000,2001,2002,2003,2004,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 | ||||
|  | @ -32,8 +32,10 @@ | |||
| #include <grub/machine/boot.h> | ||||
| #include <grub/machine/kernel.h> | ||||
| #include <grub/term.h> | ||||
| #include <grub/i18n.h> | ||||
| #include <grub/util/raid.h> | ||||
| #include <grub/util/lvm.h> | ||||
| #include <grub/util/getroot.h> | ||||
| 
 | ||||
| static const grub_gpt_part_type_t grub_gpt_partition_type_bios_boot = GRUB_GPT_PARTITION_TYPE_BIOS_BOOT; | ||||
| 
 | ||||
|  | @ -46,7 +48,7 @@ static const grub_gpt_part_type_t grub_gpt_partition_type_bios_boot = GRUB_GPT_P | |||
| #include <sys/types.h> | ||||
| #include <sys/stat.h> | ||||
| #include <dirent.h> | ||||
| #include <grub/util/getroot.h> | ||||
| #include "progname.h" | ||||
| 
 | ||||
| #define _GNU_SOURCE	1 | ||||
| #include <getopt.h> | ||||
|  | @ -86,7 +88,7 @@ grub_refresh (void) | |||
| static void | ||||
| setup (const char *dir, | ||||
|        const char *boot_file, const char *core_file, | ||||
|        const char *root, const char *dest, int must_embed, int force) | ||||
|        const char *root, const char *dest, int must_embed, int force, int fs_probe) | ||||
| { | ||||
|   char *boot_path, *core_path, *core_path_dev; | ||||
|   char *boot_img, *core_img; | ||||
|  | @ -161,7 +163,7 @@ setup (const char *dir, | |||
| 		      sector, offset, length); | ||||
| 
 | ||||
|       if (offset != 0 || length != GRUB_DISK_SECTOR_SIZE) | ||||
| 	grub_util_error ("The first sector of the core file is not sector-aligned"); | ||||
| 	grub_util_error (_("The first sector of the core file is not sector-aligned")); | ||||
| 
 | ||||
|       first_sector = sector; | ||||
|     } | ||||
|  | @ -175,7 +177,7 @@ setup (const char *dir, | |||
| 		      sector, offset, length, (unsigned) current_segment); | ||||
| 
 | ||||
|       if (offset != 0 || last_length != GRUB_DISK_SECTOR_SIZE) | ||||
| 	grub_util_error ("Non-sector-aligned data is found in the core file"); | ||||
| 	grub_util_error (_("Non-sector-aligned data is found in the core file")); | ||||
| 
 | ||||
|       if (block != first_block | ||||
| 	  && (grub_le_to_cpu64 (prev->start) | ||||
|  | @ -189,7 +191,7 @@ setup (const char *dir, | |||
| 
 | ||||
| 	  block--; | ||||
| 	  if (block->len) | ||||
| 	    grub_util_error ("The sectors of the core file are too fragmented"); | ||||
| 	    grub_util_error (_("The sectors of the core file are too fragmented")); | ||||
| 	} | ||||
| 
 | ||||
|       last_length = length; | ||||
|  | @ -200,7 +202,7 @@ setup (const char *dir, | |||
|   boot_path = grub_util_get_path (dir, boot_file); | ||||
|   boot_size = grub_util_get_image_size (boot_path); | ||||
|   if (boot_size != GRUB_DISK_SECTOR_SIZE) | ||||
|     grub_util_error ("The size of `%s' is not %d", | ||||
|     grub_util_error (_("The size of `%s' is not %u"), | ||||
| 		     boot_path, GRUB_DISK_SECTOR_SIZE); | ||||
|   boot_img = grub_util_read_image (boot_path); | ||||
|   free (boot_path); | ||||
|  | @ -217,9 +219,9 @@ setup (const char *dir, | |||
|   core_sectors = ((core_size + GRUB_DISK_SECTOR_SIZE - 1) | ||||
| 		  >> GRUB_DISK_SECTOR_BITS); | ||||
|   if (core_size < GRUB_DISK_SECTOR_SIZE) | ||||
|     grub_util_error ("The size of `%s' is too small", core_path); | ||||
|     grub_util_error (_("The size of `%s' is too small"), core_path); | ||||
|   else if (core_size > 0xFFFF * GRUB_DISK_SECTOR_SIZE) | ||||
|     grub_util_error ("The size of `%s' is too large", core_path); | ||||
|     grub_util_error (_("The size of `%s' is too large"), core_path); | ||||
| 
 | ||||
|   core_img = grub_util_read_image (core_path); | ||||
| 
 | ||||
|  | @ -251,6 +253,22 @@ setup (const char *dir, | |||
|   if (grub_disk_read (dest_dev->disk, 0, 0, GRUB_DISK_SECTOR_SIZE, tmp_img)) | ||||
|     grub_util_error ("%s", grub_errmsg); | ||||
| 
 | ||||
|   if (dest_dev->disk->partition && fs_probe) | ||||
|     { | ||||
|       grub_fs_t fs; | ||||
|       fs = grub_fs_probe (dest_dev); | ||||
|       if (! fs) | ||||
| 	grub_util_error (_("Unable to identify a filesystem in %s; safety check can't be performed"), | ||||
| 			 dest_dev->disk->name); | ||||
| 
 | ||||
|       if (! fs->reserved_first_sector) | ||||
| 	grub_util_error (_("%s appears to contain a %s filesystem which isn't known to " | ||||
| 			   "reserve space for DOS-style boot.  Installing GRUB there could " | ||||
| 			   "result in FILESYSTEM DESTRUCTION if valuable data is overwritten " | ||||
| 			   "by grub-setup (--skip-fs-probe disables this " | ||||
| 			   "check, use at your own risk)"), dest_dev->disk->name, fs->name); | ||||
|     } | ||||
| 
 | ||||
|   /* Copy the possible DOS BPB.  */ | ||||
|   memcpy (boot_img + GRUB_BOOT_MACHINE_BPB_START, | ||||
| 	  tmp_img + GRUB_BOOT_MACHINE_BPB_START, | ||||
|  | @ -293,7 +311,7 @@ setup (const char *dir, | |||
| 	      bsd_part = -1; | ||||
| 	    } | ||||
| 	  else | ||||
| 	    grub_util_error ("No PC style partitions found"); | ||||
| 	    grub_util_error (_("No DOS-style partitions found")); | ||||
| 	} | ||||
|       else | ||||
| 	dos_part = bsd_part = -1; | ||||
|  | @ -309,13 +327,13 @@ setup (const char *dir, | |||
| 
 | ||||
|   if (! dest_dev->disk->has_partitions) | ||||
|     { | ||||
|       grub_util_warn ("Attempting to install GRUB to a partitionless disk.  This is a BAD idea."); | ||||
|       grub_util_warn (_("Attempting to install GRUB to a partitionless disk.  This is a BAD idea.")); | ||||
|       goto unable_to_embed; | ||||
|     } | ||||
| 
 | ||||
|   if (dest_dev->disk->partition) | ||||
|     { | ||||
|       grub_util_warn ("Attempting to install GRUB to a partition instead of the MBR.  This is a BAD idea."); | ||||
|       grub_util_warn (_("Attempting to install GRUB to a partition instead of the MBR.  This is a BAD idea.")); | ||||
|       goto unable_to_embed; | ||||
|     } | ||||
| 
 | ||||
|  | @ -334,7 +352,7 @@ setup (const char *dir, | |||
| 
 | ||||
|   if (! dest_partmap) | ||||
|     { | ||||
|       grub_util_warn ("Attempting to install GRUB to a partitionless disk.  This is a BAD idea."); | ||||
|       grub_util_warn (_("Attempting to install GRUB to a partitionless disk.  This is a BAD idea.")); | ||||
|       goto unable_to_embed; | ||||
|     } | ||||
| 
 | ||||
|  | @ -344,25 +362,23 @@ setup (const char *dir, | |||
|   if (embed_region.end == embed_region.start) | ||||
|     { | ||||
|       if (! strcmp (dest_partmap, "part_msdos")) | ||||
| 	grub_util_warn ("This msdos-style partition label has no post-MBR gap; embedding won't be possible!"); | ||||
| 	grub_util_warn (_("This msdos-style partition label has no post-MBR gap; embedding won't be possible!")); | ||||
|       else | ||||
| 	grub_util_warn ("This GPT partition label has no BIOS Boot Partition; embedding won't be possible!"); | ||||
| 	grub_util_warn (_("This GPT partition label has no BIOS Boot Partition; embedding won't be possible!")); | ||||
|       goto unable_to_embed; | ||||
|     } | ||||
| 
 | ||||
|   if ((unsigned long) core_sectors > embed_region.end - embed_region.start) | ||||
|     { | ||||
|       if (core_sectors > 62) | ||||
| 	grub_util_warn ("Your core.img is unusually large.  It won't fit in the embedding area."); | ||||
|       else if (embed_region.end - embed_region.start < 62) | ||||
| 	grub_util_warn ("Your embedding area is unusually small.  core.img won't fit in it."); | ||||
|       else | ||||
| 	grub_util_warn ("Embedding area is too small for core.img."); | ||||
| 	grub_util_warn (_("Your core.img is unusually large.  It won't fit in the embedding area.")); | ||||
|       else /* embed_region.end - embed_region.start < 62 */ | ||||
| 	grub_util_warn (_("Your embedding area is unusually small.  core.img won't fit in it.")); | ||||
|       goto unable_to_embed; | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|   grub_util_info ("will embed the core image at sector 0x%llx", embed_region.start); | ||||
|   grub_util_info ("the core image will be embedded at sector 0x%llx", embed_region.start); | ||||
| 
 | ||||
|   *install_dos_part = grub_cpu_to_le32 (dos_part); | ||||
|   *install_bsd_part = grub_cpu_to_le32 (bsd_part); | ||||
|  | @ -399,14 +415,14 @@ setup (const char *dir, | |||
| unable_to_embed: | ||||
| 
 | ||||
|   if (must_embed) | ||||
|     grub_util_error ("Embedding is not possible, but this is required when " | ||||
| 		     "the root device is on a RAID array or LVM volume."); | ||||
|     grub_util_error (_("Embedding is not possible, but this is required when " | ||||
| 		       "the root device is on a RAID array or LVM volume.")); | ||||
| 
 | ||||
|   grub_util_warn ("Embedding is not possible.  GRUB can only be installed in this " | ||||
| 		  "setup by using blocklists.  However, blocklists are UNRELIABLE and " | ||||
| 		  "its use is discouraged."); | ||||
|   grub_util_warn (_("Embedding is not possible.  GRUB can only be installed in this " | ||||
| 		    "setup by using blocklists.  However, blocklists are UNRELIABLE and " | ||||
| 		    "its use is discouraged.")); | ||||
|   if (! force) | ||||
|     grub_util_error ("If you really want blocklists, use --force."); | ||||
|     grub_util_error (_("If you really want blocklists, use --force.")); | ||||
| 
 | ||||
|   /* Make sure that GRUB reads the identical image as the OS.  */ | ||||
|   tmp_img = xmalloc (core_size); | ||||
|  | @ -420,8 +436,9 @@ unable_to_embed: | |||
| 
 | ||||
|   for (i = 0; i < MAX_TRIES; i++) | ||||
|     { | ||||
|       grub_util_info ("attempting to read the core image `%s' from GRUB%s", | ||||
| 		      core_path_dev, (i == 0) ? "" : " again"); | ||||
|       grub_util_info ((i == 0) ? _("attempting to read the core image `%s' from GRUB") | ||||
| 		      : _("attempting to read the core image `%s' from GRUB again"), | ||||
| 		      core_path_dev); | ||||
| 
 | ||||
|       grub_disk_cache_invalidate_all (); | ||||
| 
 | ||||
|  | @ -478,7 +495,7 @@ unable_to_embed: | |||
|     } | ||||
| 
 | ||||
|   if (i == MAX_TRIES) | ||||
|     grub_util_error ("Cannot read `%s' correctly", core_path_dev); | ||||
|     grub_util_error (_("Cannot read `%s' correctly"), core_path_dev); | ||||
| 
 | ||||
|   /* Clean out the blocklists.  */ | ||||
|   block = first_block; | ||||
|  | @ -491,7 +508,7 @@ unable_to_embed: | |||
|       block--; | ||||
| 
 | ||||
|       if ((char *) block <= core_img) | ||||
| 	grub_util_error ("No terminator in the core image"); | ||||
| 	grub_util_error (_("No terminator in the core image")); | ||||
|     } | ||||
| 
 | ||||
|   /* Now read the core image to determine where the sectors are.  */ | ||||
|  | @ -502,13 +519,13 @@ unable_to_embed: | |||
|   file->read_hook = save_first_sector; | ||||
|   if (grub_file_read (file, tmp_img, GRUB_DISK_SECTOR_SIZE) | ||||
|       != GRUB_DISK_SECTOR_SIZE) | ||||
|     grub_util_error ("Failed to read the first sector of the core image"); | ||||
|     grub_util_error (_("Failed to read the first sector of the core image")); | ||||
| 
 | ||||
|   block = first_block; | ||||
|   file->read_hook = save_blocklists; | ||||
|   if (grub_file_read (file, tmp_img, core_size - GRUB_DISK_SECTOR_SIZE) | ||||
|       != (grub_ssize_t) core_size - GRUB_DISK_SECTOR_SIZE) | ||||
|     grub_util_error ("Failed to read the rest sectors of the core image"); | ||||
|     grub_util_error (_("Failed to read the rest sectors of the core image")); | ||||
| 
 | ||||
|   grub_file_close (file); | ||||
| 
 | ||||
|  | @ -527,7 +544,7 @@ unable_to_embed: | |||
|   grub_util_info ("opening the core image `%s'", core_path); | ||||
|   fp = fopen (core_path, "r+b"); | ||||
|   if (! fp) | ||||
|     grub_util_error ("Cannot open `%s'", core_path); | ||||
|     grub_util_error (_("Cannot open `%s'"), core_path); | ||||
| 
 | ||||
|   grub_util_write_image (core_img, GRUB_DISK_SECTOR_SIZE * 2, fp); | ||||
|   fclose (fp); | ||||
|  | @ -556,6 +573,7 @@ static struct option options[] = | |||
|     {"device-map", required_argument, 0, 'm'}, | ||||
|     {"root-device", required_argument, 0, 'r'}, | ||||
|     {"force", no_argument, 0, 'f'}, | ||||
|     {"skip-fs-probe", no_argument, 0, 's'}, | ||||
|     {"help", no_argument, 0, 'h'}, | ||||
|     {"version", no_argument, 0, 'V'}, | ||||
|     {"verbose", no_argument, 0, 'v'}, | ||||
|  | @ -566,9 +584,9 @@ static void | |||
| usage (int status) | ||||
| { | ||||
|   if (status) | ||||
|     fprintf (stderr, "Try ``grub-setup --help'' for more information.\n"); | ||||
|     fprintf (stderr, _("Try ``%s --help'' for more information.\n"), program_name); | ||||
|   else | ||||
|     printf ("\
 | ||||
|     printf (_("\
 | ||||
| Usage: grub-setup [OPTION]... DEVICE\n\ | ||||
| \n\ | ||||
| Set up images to boot from DEVICE.\n\ | ||||
|  | @ -580,12 +598,13 @@ DEVICE must be a GRUB device (e.g. ``(hd0,1)'').\n\ | |||
|   -m, --device-map=FILE   use FILE as the device map [default=%s]\n\ | ||||
|   -r, --root-device=DEV   use DEV as the root device [default=guessed]\n\ | ||||
|   -f, --force             install even if problems are detected\n\ | ||||
|   -s, --skip-fs-probe     do not probe for filesystems in DEVICE\n\ | ||||
|   -h, --help              display this message and exit\n\ | ||||
|   -V, --version           print version information and exit\n\ | ||||
|   -v, --verbose           print verbose messages\n\ | ||||
| \n\ | ||||
| Report bugs to <%s>.\n\ | ||||
| ", | ||||
| "), | ||||
| 	    DEFAULT_BOOT_FILE, DEFAULT_CORE_FILE, DEFAULT_DIRECTORY, | ||||
| 	    DEFAULT_DEVICE_MAP, PACKAGE_BUGREPORT); | ||||
| 
 | ||||
|  | @ -613,9 +632,12 @@ main (int argc, char *argv[]) | |||
|   char *dev_map = 0; | ||||
|   char *root_dev = 0; | ||||
|   char *dest_dev; | ||||
|   int must_embed = 0, force = 0; | ||||
|   int must_embed = 0, force = 0, fs_probe = 1; | ||||
| 
 | ||||
|   progname = "grub-setup"; | ||||
|   set_program_name (argv[0]); | ||||
|   setlocale (LC_ALL, ""); | ||||
|   bindtextdomain (PACKAGE, LOCALEDIR); | ||||
|   textdomain (PACKAGE); | ||||
| 
 | ||||
|   /* Check for options.  */ | ||||
|   while (1) | ||||
|  | @ -666,6 +688,10 @@ main (int argc, char *argv[]) | |||
| 	    force = 1; | ||||
| 	    break; | ||||
| 
 | ||||
| 	  case 's': | ||||
| 	    fs_probe = 0; | ||||
| 	    break; | ||||
| 
 | ||||
| 	  case 'h': | ||||
| 	    usage (0); | ||||
| 	    break; | ||||
|  | @ -690,13 +716,13 @@ main (int argc, char *argv[]) | |||
|   /* Obtain DEST_DEV.  */ | ||||
|   if (optind >= argc) | ||||
|     { | ||||
|       fprintf (stderr, "No device is specified.\n"); | ||||
|       fprintf (stderr, _("No device is specified.\n")); | ||||
|       usage (1); | ||||
|     } | ||||
| 
 | ||||
|   if (optind + 1 != argc) | ||||
|     { | ||||
|       fprintf (stderr, "Unknown extra argument `%s'.\n", argv[optind + 1]); | ||||
|       fprintf (stderr, _("Unknown extra argument `%s'.\n"), argv[optind + 1]); | ||||
|       usage (1); | ||||
|     } | ||||
| 
 | ||||
|  | @ -713,7 +739,7 @@ main (int argc, char *argv[]) | |||
|       dest_dev = grub_util_get_grub_dev (argv[optind]); | ||||
|       if (! dest_dev) | ||||
| 	{ | ||||
| 	  fprintf (stderr, "Invalid device `%s'.\n", argv[optind]); | ||||
| 	  fprintf (stderr, _("Invalid device `%s'.\n"), argv[optind]); | ||||
| 	  usage (1); | ||||
| 	} | ||||
|     } | ||||
|  | @ -726,7 +752,7 @@ main (int argc, char *argv[]) | |||
|       char *tmp = get_device_name (root_dev); | ||||
| 
 | ||||
|       if (! tmp) | ||||
| 	grub_util_error ("Invalid root device `%s'", root_dev); | ||||
| 	grub_util_error (_("Invalid root device `%s'"), root_dev); | ||||
| 
 | ||||
|       tmp = xstrdup (tmp); | ||||
|       free (root_dev); | ||||
|  | @ -739,7 +765,7 @@ main (int argc, char *argv[]) | |||
| 	{ | ||||
| 	  grub_util_info ("guessing the root device failed, because of `%s'", | ||||
| 			  grub_errmsg); | ||||
| 	  grub_util_error ("Cannot guess the root device. Specify the option ``--root-device''."); | ||||
| 	  grub_util_error (_("Cannot guess the root device. Specify the option ``--root-device''.")); | ||||
| 	} | ||||
|     } | ||||
| 
 | ||||
|  | @ -767,7 +793,7 @@ main (int argc, char *argv[]) | |||
| 	  setup (dir ? : DEFAULT_DIRECTORY, | ||||
| 		 boot_file ? : DEFAULT_BOOT_FILE, | ||||
| 		 core_file ? : DEFAULT_CORE_FILE, | ||||
| 		 root_dev, grub_util_get_grub_dev (devicelist[i]), 1, force); | ||||
| 		 root_dev, grub_util_get_grub_dev (devicelist[i]), 1, force, fs_probe); | ||||
| 	} | ||||
|     } | ||||
|   else | ||||
|  | @ -776,7 +802,7 @@ main (int argc, char *argv[]) | |||
|     setup (dir ? : DEFAULT_DIRECTORY, | ||||
| 	   boot_file ? : DEFAULT_BOOT_FILE, | ||||
| 	   core_file ? : DEFAULT_CORE_FILE, | ||||
| 	   root_dev, dest_dev, must_embed, force); | ||||
| 	   root_dev, dest_dev, must_embed, force, fs_probe); | ||||
| 
 | ||||
|   /* Free resources.  */ | ||||
|   grub_fini_all (); | ||||
|  |  | |||
							
								
								
									
										286
									
								
								util/import_gcry.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										286
									
								
								util/import_gcry.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,286 @@ | |||
| #* | ||||
| #*  GRUB  --  GRand Unified Bootloader | ||||
| #*  Copyright (C) 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/>. | ||||
| #* | ||||
| 
 | ||||
| import re | ||||
| import sys | ||||
| import os | ||||
| import datetime | ||||
| 
 | ||||
| if len (sys.argv) < 3: | ||||
|     print ("Usage: %s SOURCE DESTINATION" % sys.argv[0]) | ||||
|     exit (0) | ||||
| indir = sys.argv[1] | ||||
| outdir = sys.argv[2] | ||||
| 
 | ||||
| basedir = os.path.join (outdir, "lib/libgcrypt-grub") | ||||
| try: | ||||
|     os.makedirs (basedir) | ||||
| except: | ||||
|     print ("WARNING: %s already exists" % basedir) | ||||
| cipher_dir_in = os.path.join (indir, "cipher") | ||||
| cipher_dir_out = os.path.join (basedir, "cipher") | ||||
| try: | ||||
|     os.makedirs (cipher_dir_out) | ||||
| except: | ||||
|     print ("WARNING: %s already exists" % cipher_dir_out) | ||||
| 
 | ||||
| cipher_files = os.listdir (cipher_dir_in) | ||||
| conf = open (os.path.join (outdir, "conf", "gcry.rmk"), "w") | ||||
| conf.write ("# -*- makefile -*-\n\n") | ||||
| chlog = "" | ||||
| 
 | ||||
| # Strictly speaking CRC32/CRC24 work on bytes so this value should be 1 | ||||
| # But libgcrypt uses 64. Let's keep the value for compatibility. Since | ||||
| # noone uses CRC24/CRC32 for HMAC this is no problem | ||||
| mdblocksizes = {"_gcry_digest_spec_crc32" : 64, | ||||
|                 "_gcry_digest_spec_crc32_rfc1510" : 64, | ||||
|                 "_gcry_digest_spec_crc24_rfc2440" : 64, | ||||
|                 "_gcry_digest_spec_md4" : 64, | ||||
|                 "_gcry_digest_spec_md5" : 64, | ||||
|                 "_gcry_digest_spec_rmd160" : 64, | ||||
|                 "_gcry_digest_spec_sha1" : 64, | ||||
|                 "_gcry_digest_spec_sha224" : 64, | ||||
|                 "_gcry_digest_spec_sha256" : 64, | ||||
|                 "_gcry_digest_spec_sha384" : 128, | ||||
|                 "_gcry_digest_spec_sha512" : 128, | ||||
|                 "_gcry_digest_spec_tiger" : 64, | ||||
|                 "_gcry_digest_spec_whirlpool" : 64} | ||||
| 
 | ||||
| for cipher_file in cipher_files: | ||||
|     infile = os.path.join (cipher_dir_in, cipher_file) | ||||
|     outfile = os.path.join (cipher_dir_out, cipher_file) | ||||
|     if cipher_file == "ChangeLog": | ||||
|         continue | ||||
|     chlognew = "	* %s" % cipher_file | ||||
|     nch = False | ||||
|     if re.match (".*\.[ch]$", cipher_file): | ||||
|         isc = re.match (".*\.c$", cipher_file) | ||||
|         f = open (infile, "r") | ||||
|         fw = open (outfile, "w") | ||||
|         fw.write ("/* This file was automatically imported with \n") | ||||
|         fw.write ("   import_gcry.py. Please don't modify it */\n"); | ||||
|         ciphernames = [] | ||||
|         mdnames = [] | ||||
|         hold = False | ||||
|         skip = False | ||||
|         skip2 = False | ||||
|         ismd = False | ||||
|         iscomma = False | ||||
|         for line in f: | ||||
|             if skip: | ||||
|                 if line[0] == "}": | ||||
|                     skip = False | ||||
|                 continue | ||||
|             if skip2: | ||||
|                 if not re.search (" *};", line) is None: | ||||
|                     skip2 = False | ||||
|                 continue | ||||
|             if ismd: | ||||
|                 if not re.search (" *};", line) is None: | ||||
|                     if not mdblocksizes.has_key (mdname): | ||||
|                         print ("ERROR: Unknown digest blocksize: %s\n" % mdname) | ||||
|                         exit (1) | ||||
|                     if not iscomma: | ||||
|                         fw.write ("    ,\n") | ||||
|                     fw.write ("    .blocksize = %s\n" % mdblocksizes [mdname]) | ||||
|                     ismd = False | ||||
|                 iscomma = not re.search (",$", line) is None | ||||
|             if hold: | ||||
|                 hold = False | ||||
|                 # We're optimising for size. | ||||
|                 if not re.match ("(run_selftests|selftest|_gcry_aes_c.._..c|_gcry_[a-z0-9]*_hash_buffer)", line) is None: | ||||
|                     skip = True | ||||
|                     fname = re.match ("[a-zA-Z0-9_]*", line).group () | ||||
|                     chmsg = "(%s): Removed." % fname | ||||
|                     if nch: | ||||
|                         chlognew = "%s\n	%s" % (chlognew, chmsg) | ||||
|                     else: | ||||
|                         chlognew = "%s %s" % (chlognew, chmsg) | ||||
|                         nch = True | ||||
|                     continue | ||||
|                 else: | ||||
|                     fw.write (holdline) | ||||
|             m = re.match ("#include <.*>", line) | ||||
|             if not m is None: | ||||
|                 chmsg = "Removed including of %s" % \ | ||||
|                 m.group () [len ("#include <"):len (m.group ()) - 1] | ||||
|                 if nch: | ||||
|                     chlognew = "%s\n	%s" % (chlognew, chmsg) | ||||
|                 else: | ||||
|                     chlognew = "%s: %s" % (chlognew, chmsg) | ||||
|                     nch = True | ||||
|                 continue | ||||
|             m = re.match ("gcry_cipher_spec_t", line) | ||||
|             if isc and not m is None: | ||||
|                 ciphername = line [len ("gcry_cipher_spec_t"):].strip () | ||||
|                 ciphername = re.match("[a-zA-Z0-9_]*",ciphername).group () | ||||
|                 ciphernames.append (ciphername) | ||||
|             m = re.match ("gcry_md_spec_t", line) | ||||
|             if isc and not m is None: | ||||
|                 assert (not ismd) | ||||
|                 mdname = line [len ("gcry_md_spec_t"):].strip () | ||||
|                 mdname = re.match("[a-zA-Z0-9_]*",mdname).group () | ||||
|                 mdnames.append (mdname) | ||||
|                 ismd = True | ||||
|             m = re.match ("static const char \*selftest.*;$", line) | ||||
|             if not m is None: | ||||
|                 fname = line[len ("static const char \*"):] | ||||
|                 fname = re.match ("[a-zA-Z0-9_]*", fname).group () | ||||
|                 chmsg = "(%s): Removed declaration." % fname | ||||
|                 if nch: | ||||
|                     chlognew = "%s\n	%s" % (chlognew, chmsg) | ||||
|                 else: | ||||
|                     chlognew = "%s %s" % (chlognew, chmsg) | ||||
|                     nch = True | ||||
|                 continue | ||||
|             m = re.match ("(static const char( |)\*|static gpg_err_code_t|void)$", line) | ||||
|             if not m is None: | ||||
|                 hold = True | ||||
|                 holdline = line | ||||
|                 continue | ||||
|             m = re.match ("cipher_extra_spec_t", line) | ||||
|             if isc and not m is None: | ||||
|                 skip2 = True | ||||
|                 fname = line[len ("cipher_extra_spec_t "):] | ||||
|                 fname = re.match ("[a-zA-Z0-9_]*", fname).group () | ||||
|                 chmsg = "(%s): Removed." % fname | ||||
|                 if nch: | ||||
|                     chlognew = "%s\n	%s" % (chlognew, chmsg) | ||||
|                 else: | ||||
|                     chlognew = "%s %s" % (chlognew, chmsg) | ||||
|                     nch = True | ||||
|                 continue | ||||
|             m = re.match ("md_extra_spec_t", line) | ||||
|             if isc and not m is None: | ||||
|                 skip2 = True | ||||
|                 fname = line[len ("md_extra_spec_t "):] | ||||
|                 fname = re.match ("[a-zA-Z0-9_]*", fname).group () | ||||
|                 chmsg = "(%s): Removed." % fname | ||||
|                 if nch: | ||||
|                     chlognew = "%s\n	%s" % (chlognew, chmsg) | ||||
|                 else: | ||||
|                     chlognew = "%s %s" % (chlognew, chmsg) | ||||
|                     nch = True | ||||
|                 continue | ||||
|             fw.write (line) | ||||
|         if len (ciphernames) > 0 or len (mdnames) > 0: | ||||
|             modname = cipher_file [0:len(cipher_file) - 2] | ||||
|             if re.match (".*-glue$", modname): | ||||
|                 modfiles = "libgcrypt-grub/cipher/%s libgcrypt-grub/cipher/%s" \ | ||||
|                     % (cipher_file, cipher_file.replace ("-glue.c", ".c")) | ||||
|                 modname = modname.replace ("-glue", "") | ||||
|             else: | ||||
|                 modfiles = "libgcrypt-grub/cipher/%s" % cipher_file | ||||
|             modname = "gcry_%s" % modname | ||||
|             chmsg = "(GRUB_MOD_INIT(%s)): New function\n" % modname | ||||
|             if nch: | ||||
|                 chlognew = "%s\n	%s" % (chlognew, chmsg) | ||||
|             else: | ||||
|                 chlognew = "%s%s" % (chlognew, chmsg) | ||||
|                 nch = True | ||||
|             fw.write ("\n\nGRUB_MOD_INIT(%s)\n" % modname) | ||||
|             fw.write ("{\n") | ||||
|             for ciphername in ciphernames: | ||||
|                 chmsg = "Register cipher %s" % ciphername | ||||
|                 chlognew = "%s\n	%s" % (chlognew, chmsg) | ||||
|                 fw.write ("  grub_cipher_register (&%s);\n" % ciphername) | ||||
|             for mdname in mdnames: | ||||
|                 chmsg = "Register digest %s" % mdname | ||||
|                 chlognew = "%s\n	%s" % (chlognew, chmsg) | ||||
|                 fw.write ("  grub_md_register (&%s);\n" % mdname) | ||||
|             fw.write ("}") | ||||
|             chmsg = "(GRUB_MOD_FINI(%s)): New function\n" % modname | ||||
|             chlognew = "%s\n	%s" % (chlognew, chmsg) | ||||
|             fw.write ("\n\nGRUB_MOD_FINI(%s)\n" % modname) | ||||
|             fw.write ("{\n") | ||||
|             for ciphername in ciphernames: | ||||
|                 chmsg = "Unregister cipher %s" % ciphername | ||||
|                 chlognew = "%s\n	%s" % (chlognew, chmsg) | ||||
|                 fw.write ("  grub_cipher_unregister (&%s);\n" % ciphername) | ||||
|             for mdname in mdnames: | ||||
|                 chmsg = "Unregister MD %s" % mdname | ||||
|                 chlognew = "%s\n	%s" % (chlognew, chmsg) | ||||
|                 fw.write ("  grub_md_unregister (&%s);\n" % mdname) | ||||
|             fw.write ("}\n") | ||||
|             conf.write ("pkglib_MODULES += %s.mod\n" % modname) | ||||
|             conf.write ("%s_mod_SOURCES = %s\n" %\ | ||||
|                             (modname, modfiles)) | ||||
|             conf.write ("%s_mod_CFLAGS = $(COMMON_CFLAGS) -Wno-missing-field-initializers -Wno-error\n" % modname) | ||||
|             conf.write ("%s_mod_LDFLAGS = $(COMMON_LDFLAGS)\n\n" % modname) | ||||
|         elif isc and cipher_file != "camellia.c": | ||||
|             print ("WARNING: C file isn't a module: %s" % cipher_file) | ||||
|         f.close () | ||||
|         fw.close () | ||||
|         if nch: | ||||
|             chlog = "%s%s\n" % (chlog, chlognew) | ||||
|         continue | ||||
|     if re.match ("(Manifest|Makefile\.am)$", cipher_file): | ||||
|         chlog = "%s%sRemoved\n" % (chlog, chlognew) | ||||
|         continue | ||||
|     # Autogenerated files. Not even worth mentionning in ChangeLog | ||||
|     if re.match ("Makefile\.in$", cipher_file): | ||||
|         chlog = "%s%sRemoved\n" % (chlog, chlognew) | ||||
|         continue | ||||
|     chlog = "%s%sSkipped unknown file\n" % (chlog, chlognew) | ||||
|     print ("WARNING: unknown file %s" % cipher_file) | ||||
| 
 | ||||
| outfile = os.path.join (cipher_dir_out, "types.h") | ||||
| fw=open (outfile, "w") | ||||
| fw.write ("#include <grub/types.h>\n") | ||||
| fw.write ("#include <grub/cipher_wrap.h>\n") | ||||
| chlog = "%s	* types.h: New file.\n" % chlog | ||||
| fw.close () | ||||
| 
 | ||||
| outfile = os.path.join (cipher_dir_out, "memory.h") | ||||
| fw=open (outfile, "w") | ||||
| fw.write ("#include <grub/cipher_wrap.h>\n") | ||||
| chlog = "%s	* memory.h: New file.\n" % chlog | ||||
| fw.close () | ||||
| 
 | ||||
| 
 | ||||
| outfile = os.path.join (cipher_dir_out, "cipher.h") | ||||
| fw=open (outfile, "w") | ||||
| fw.write ("#include <grub/crypto.h>\n") | ||||
| fw.write ("#include <grub/cipher_wrap.h>\n") | ||||
| chlog = "%s	* cipher.h: Likewise.\n" % chlog | ||||
| fw.close () | ||||
| 
 | ||||
| outfile = os.path.join (cipher_dir_out, "g10lib.h") | ||||
| fw=open (outfile, "w") | ||||
| fw.write ("#include <grub/cipher_wrap.h>\n") | ||||
| chlog = "%s	* g10lib.h: Likewise.\n" % chlog | ||||
| fw.close () | ||||
| 
 | ||||
| infile = os.path.join (cipher_dir_in, "ChangeLog") | ||||
| outfile = os.path.join (cipher_dir_out, "ChangeLog") | ||||
| 
 | ||||
| 
 | ||||
| f=open (infile, "r") | ||||
| fw=open (outfile, "w") | ||||
| dt = datetime.date.today () | ||||
| fw.write ("%04d-%02d-%02d  Automatic import tool\n" % \ | ||||
|           (dt.year,dt.month, dt.day)) | ||||
| fw.write ("\n") | ||||
| fw.write ("	Imported ciphers to GRUB\n") | ||||
| fw.write ("\n") | ||||
| fw.write (chlog) | ||||
| fw.write ("\n") | ||||
| for line in f: | ||||
|     fw.write (line) | ||||
| f.close () | ||||
| fw.close () | ||||
							
								
								
									
										54
									
								
								util/mkisofs/defaults.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								util/mkisofs/defaults.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,54 @@ | |||
| /*
 | ||||
|  * Header file defaults.h - assorted default values for character strings in | ||||
|  * the volume descriptor. | ||||
|  * | ||||
|  * 	$Id: defaults.h,v 1.8 1999/03/02 03:41:25 eric Exp $ | ||||
|  */ | ||||
| 
 | ||||
| #define  PREPARER_DEFAULT 	NULL | ||||
| #define  PUBLISHER_DEFAULT	NULL | ||||
| #ifndef	APPID_DEFAULT | ||||
| #define  APPID_DEFAULT 		"MKISOFS ISO 9660 FILESYSTEM BUILDER" | ||||
| #endif | ||||
| #define  COPYRIGHT_DEFAULT 	NULL | ||||
| #define  BIBLIO_DEFAULT 	NULL | ||||
| #define  ABSTRACT_DEFAULT 	NULL | ||||
| #define  VOLSET_ID_DEFAULT 	NULL | ||||
| #define  VOLUME_ID_DEFAULT 	"CDROM" | ||||
| #define  BOOT_CATALOG_DEFAULT   "boot.catalog" | ||||
| #define  BOOT_IMAGE_DEFAULT     NULL | ||||
| #ifdef __QNX__ | ||||
| #define  SYSTEM_ID_DEFAULT 	"QNX" | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __osf__ | ||||
| #define  SYSTEM_ID_DEFAULT 	"OSF" | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __sun | ||||
| #ifdef __SVR4 | ||||
| #define  SYSTEM_ID_DEFAULT    "Solaris" | ||||
| #else | ||||
| #define  SYSTEM_ID_DEFAULT    "SunOS" | ||||
| #endif | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __hpux | ||||
| #define  SYSTEM_ID_DEFAULT 	"HP-UX" | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __sgi | ||||
| #define  SYSTEM_ID_DEFAULT 	"SGI" | ||||
| #endif | ||||
| 
 | ||||
| #ifdef _AIX | ||||
| #define  SYSTEM_ID_DEFAULT 	"AIX" | ||||
| #endif | ||||
| 
 | ||||
| #ifdef _WIN | ||||
| #define	SYSTEM_ID_DEFAULT       "Win32" | ||||
| #endif /* _WIN */ | ||||
| 
 | ||||
| #ifndef SYSTEM_ID_DEFAULT | ||||
| #define  SYSTEM_ID_DEFAULT 	"LINUX" | ||||
| #endif | ||||
							
								
								
									
										343
									
								
								util/mkisofs/eltorito.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										343
									
								
								util/mkisofs/eltorito.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,343 @@ | |||
| /*
 | ||||
|  * Program eltorito.c - Handle El Torito specific extensions to iso9660. | ||||
|  *  | ||||
| 
 | ||||
|    Written by Michael Fulbright <msf@redhat.com> (1996). | ||||
| 
 | ||||
|    Copyright 1996 RedHat Software, Incorporated | ||||
| 
 | ||||
|    Copyright (C) 2009  Free Software Foundation, Inc. | ||||
| 
 | ||||
|    Boot Info Table generation based on code from genisoimage.c | ||||
|    (from cdrkit 1.1.9), which was originally licensed under GPLv2+. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program 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 this program; if not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| 
 | ||||
| #include <stdio.h> | ||||
| #include <sys/types.h> | ||||
| #include <sys/stat.h> | ||||
| #include <unistd.h> | ||||
| #include <fcntl.h> | ||||
| #include <stdlib.h> | ||||
| #include <errno.h> | ||||
| 
 | ||||
| #include "config.h" | ||||
| #include "mkisofs.h" | ||||
| #include "iso9660.h" | ||||
| 
 | ||||
| /* used by Win32 for opening binary file - not used by Unix */ | ||||
| #ifndef O_BINARY | ||||
| #define O_BINARY 0 | ||||
| #endif /* O_BINARY */ | ||||
| 
 | ||||
| #undef MIN | ||||
| #define MIN(a, b) (((a) < (b))? (a): (b)) | ||||
| 
 | ||||
| static struct eltorito_validation_entry valid_desc; | ||||
| static struct eltorito_defaultboot_entry default_desc; | ||||
| static struct eltorito_boot_descriptor gboot_desc; | ||||
| 
 | ||||
| static int tvd_write	__PR((FILE * outfile)); | ||||
| 
 | ||||
| /*
 | ||||
|  * Check for presence of boot catalog. If it does not exist then make it  | ||||
|  */ | ||||
| void FDECL1(init_boot_catalog, const char *, path) | ||||
| { | ||||
|     FILE *bcat; | ||||
|     char		* bootpath;                /* filename of boot catalog */ | ||||
|     char		* buf; | ||||
|     struct stat	  statbuf; | ||||
|      | ||||
|     bootpath = (char *) e_malloc(strlen(boot_catalog)+strlen(path)+2); | ||||
|     strcpy(bootpath, path); | ||||
|     if (bootpath[strlen(bootpath)-1] != '/')  | ||||
|     { | ||||
| 	strcat(bootpath,"/"); | ||||
|     } | ||||
|      | ||||
|     strcat(bootpath, boot_catalog); | ||||
|      | ||||
|     /*
 | ||||
|      * check for the file existing  | ||||
|      */ | ||||
| #ifdef DEBUG_TORITO | ||||
|     fprintf(stderr,"Looking for boot catalog file %s\n",bootpath); | ||||
| #endif | ||||
|      | ||||
|     if (!stat_filter(bootpath, &statbuf))  | ||||
|     { | ||||
| 	/*
 | ||||
| 	 * make sure its big enough to hold what we want  | ||||
| 	 */ | ||||
| 	if (statbuf.st_size == 2048)  | ||||
| 	{ | ||||
| 	    /*
 | ||||
| 	     * printf("Boot catalog exists, so we do nothing\n");  | ||||
| 	     */ | ||||
| 	    free(bootpath); | ||||
| 	    return; | ||||
| 	} | ||||
| 	else  | ||||
| 	{ | ||||
| 	  fprintf (stderr, _("A boot catalog exists and appears corrupted.\n")); | ||||
| 	  fprintf (stderr, _("Please check the following file: %s.\n"), bootpath); | ||||
| 	  fprintf (stderr, _("This file must be removed before a bootable CD can be done.\n")); | ||||
| 	  free (bootpath); | ||||
| 	  exit (1); | ||||
| 	} | ||||
|     } | ||||
|      | ||||
|     /*
 | ||||
|      * file does not exist, so we create it  | ||||
|      * make it one CD sector long | ||||
|      */ | ||||
|     bcat = fopen (bootpath, "wb"); | ||||
|     if (bcat == NULL) | ||||
|       error (1, errno, _("Error creating boot catalog (%s)"), bootpath); | ||||
|      | ||||
|     buf = (char *) e_malloc( 2048 ); | ||||
|     if (fwrite (buf, 1, 2048, bcat) != 2048) | ||||
|       error (1, errno, _("Error writing to boot catalog (%s)"), bootpath); | ||||
|     fclose (bcat); | ||||
|     chmod (bootpath, S_IROTH | S_IRGRP | S_IRWXU); | ||||
| 
 | ||||
|     free(bootpath); | ||||
| } /* init_boot_catalog(... */ | ||||
| 
 | ||||
| void FDECL1(get_torito_desc, struct eltorito_boot_descriptor *, boot_desc) | ||||
| { | ||||
|     FILE *bootcat; | ||||
|     int				checksum; | ||||
|     unsigned char		      * checksum_ptr; | ||||
|     struct directory_entry      * de; | ||||
|     struct directory_entry      * de2; | ||||
|     unsigned int		i; | ||||
|     int				nsectors; | ||||
|      | ||||
|     memset(boot_desc, 0, sizeof(*boot_desc)); | ||||
|     boot_desc->id[0] = 0; | ||||
|     memcpy(boot_desc->id2, ISO_STANDARD_ID, sizeof(ISO_STANDARD_ID)); | ||||
|     boot_desc->version[0] = 1; | ||||
|      | ||||
|     memcpy(boot_desc->system_id, EL_TORITO_ID, sizeof(EL_TORITO_ID)); | ||||
|      | ||||
|     /*
 | ||||
|      * search from root of iso fs to find boot catalog  | ||||
|      */ | ||||
|     de2 = search_tree_file(root, boot_catalog); | ||||
|     if (!de2)  | ||||
|     { | ||||
|       fprintf (stderr, _("Boot catalog cannot be found!\n")); | ||||
|       exit (1); | ||||
|     } | ||||
|      | ||||
|     set_731(boot_desc->bootcat_ptr, | ||||
| 	    (unsigned int) get_733(de2->isorec.extent)); | ||||
|      | ||||
|     /* 
 | ||||
|      * now adjust boot catalog | ||||
|      * lets find boot image first  | ||||
|      */ | ||||
|     de=search_tree_file(root, boot_image); | ||||
|     if (!de)  | ||||
|     { | ||||
|       fprintf (stderr, _("Boot image cannot be found!\n")); | ||||
|       exit (1); | ||||
|     }  | ||||
|      | ||||
|     /* 
 | ||||
|      * we have the boot image, so write boot catalog information | ||||
|      * Next we write out the primary descriptor for the disc  | ||||
|      */ | ||||
|     memset(&valid_desc, 0, sizeof(valid_desc)); | ||||
|     valid_desc.headerid[0] = 1; | ||||
|     valid_desc.arch[0] = EL_TORITO_ARCH_x86; | ||||
|      | ||||
|     /*
 | ||||
|      * we'll shove start of publisher id into id field, may get truncated | ||||
|      * but who really reads this stuff! | ||||
|      */ | ||||
|     if (publisher) | ||||
|         memcpy_max(valid_desc.id,  publisher, MIN(23, strlen(publisher))); | ||||
|      | ||||
|     valid_desc.key1[0] = 0x55; | ||||
|     valid_desc.key2[0] = 0xAA; | ||||
|      | ||||
|     /*
 | ||||
|      * compute the checksum  | ||||
|      */ | ||||
|     checksum=0; | ||||
|     checksum_ptr = (unsigned char *) &valid_desc; | ||||
|     for (i=0; i<sizeof(valid_desc); i+=2)  | ||||
|     { | ||||
| 	/*
 | ||||
| 	 * skip adding in ckecksum word, since we dont have it yet!  | ||||
| 	 */ | ||||
| 	if (i == 28) | ||||
| 	{ | ||||
| 	    continue; | ||||
| 	} | ||||
| 	checksum += (unsigned int)checksum_ptr[i]; | ||||
| 	checksum += ((unsigned int)checksum_ptr[i+1])*256; | ||||
|     } | ||||
|      | ||||
|     /* 
 | ||||
|      * now find out the real checksum  | ||||
|      */ | ||||
|     checksum = -checksum; | ||||
|     set_721(valid_desc.cksum, (unsigned int) checksum); | ||||
|      | ||||
|     /*
 | ||||
|      * now make the initial/default entry for boot catalog  | ||||
|      */ | ||||
|     memset(&default_desc, 0, sizeof(default_desc)); | ||||
|     default_desc.boot_id[0] = EL_TORITO_BOOTABLE; | ||||
|      | ||||
|     /*
 | ||||
|      * use default BIOS loadpnt | ||||
|      */  | ||||
|     set_721(default_desc.loadseg, 0); | ||||
|     default_desc.arch[0] = EL_TORITO_ARCH_x86; | ||||
|      | ||||
|     /*
 | ||||
|      * figure out size of boot image in sectors, for now hard code to | ||||
|      * assume 512 bytes/sector on a bootable floppy | ||||
|      */ | ||||
|     nsectors = ((de->size + 511) & ~(511))/512; | ||||
|     fprintf (stderr, _("\nSize of boot image is %d sectors"), nsectors);  | ||||
|     fprintf (stderr, " -> ");  | ||||
| 
 | ||||
|     if (! use_eltorito_emul_floppy) | ||||
|       { | ||||
| 	default_desc.boot_media[0] = EL_TORITO_MEDIA_NOEMUL; | ||||
| 	fprintf (stderr, _("No emulation\n")); | ||||
|       } | ||||
|     else if (nsectors == 2880 )  | ||||
|       /*
 | ||||
|        * choose size of emulated floppy based on boot image size  | ||||
|        */ | ||||
|       { | ||||
| 	default_desc.boot_media[0] = EL_TORITO_MEDIA_144FLOP; | ||||
| 	fprintf (stderr, _("Emulating a 1.44 meg floppy\n")); | ||||
|       } | ||||
|     else if (nsectors == 5760 )  | ||||
|       { | ||||
| 	default_desc.boot_media[0] = EL_TORITO_MEDIA_288FLOP; | ||||
| 	fprintf (stderr, _("Emulating a 2.88 meg floppy\n")); | ||||
|       } | ||||
|     else if (nsectors == 2400 )  | ||||
|       { | ||||
| 	default_desc.boot_media[0] = EL_TORITO_MEDIA_12FLOP; | ||||
| 	fprintf (stderr, _("Emulating a 1.2 meg floppy\n")); | ||||
|       } | ||||
|     else  | ||||
|       { | ||||
| 	fprintf (stderr, _("\nError - boot image is not the an allowable size.\n")); | ||||
| 	exit (1); | ||||
|       } | ||||
|      | ||||
|     /* 
 | ||||
|      * FOR NOW LOAD 1 SECTOR, JUST LIKE FLOPPY BOOT!!!  | ||||
|      */ | ||||
|     nsectors = 1; | ||||
|     set_721(default_desc.nsect, (unsigned int) nsectors ); | ||||
| #ifdef DEBUG_TORITO | ||||
|     fprintf(stderr,"Extent of boot images is %d\n",get_733(de->isorec.extent)); | ||||
| #endif | ||||
|     set_731(default_desc.bootoff,  | ||||
| 	    (unsigned int) get_733(de->isorec.extent)); | ||||
|      | ||||
|     /*
 | ||||
|      * now write it to disk  | ||||
|      */ | ||||
|     bootcat = fopen (de2->whole_name, "r+b"); | ||||
|     if (bootcat == NULL)  | ||||
|       error (1, errno, _("Error opening boot catalog for update")); | ||||
| 
 | ||||
|     /* 
 | ||||
|      * write out  | ||||
|      */ | ||||
|     if (fwrite (&valid_desc, 1, 32, bootcat) != 32) | ||||
|       error (1, errno, _("Error writing to boot catalog")); | ||||
|     if (fwrite (&default_desc, 1, 32, bootcat) != 32) | ||||
|       error (1, errno, _("Error writing to boot catalog")); | ||||
|     fclose (bootcat); | ||||
| 
 | ||||
|     /* If the user has asked for it, patch the boot image */ | ||||
|     if (use_boot_info_table) | ||||
|       { | ||||
| 	FILE *bootimage; | ||||
| 	uint32_t bi_checksum; | ||||
| 	unsigned int total_len; | ||||
| 	static char csum_buffer[SECTOR_SIZE]; | ||||
| 	int len; | ||||
| 	struct eltorito_boot_info bi_table; | ||||
| 	bootimage = fopen (de->whole_name, "r+b"); | ||||
| 	if (bootimage == NULL) | ||||
| 	  error (1, errno, _("Error opening boot image file '%s' for update"), | ||||
| 		 de->whole_name); | ||||
| 	/* Compute checksum of boot image, sans 64 bytes */ | ||||
| 	total_len = 0; | ||||
| 	bi_checksum = 0; | ||||
| 	while ((len = fread (csum_buffer, 1, SECTOR_SIZE, bootimage)) > 0) | ||||
| 	  { | ||||
| 	    if (total_len & 3) | ||||
| 	      error (1, 0, _("Odd alignment at non-end-of-file in boot image '%s'"), | ||||
| 		     de->whole_name); | ||||
| 	    if (total_len < 64) | ||||
| 	      memset (csum_buffer, 0, 64 - total_len); | ||||
| 	    if (len < SECTOR_SIZE) | ||||
| 	      memset (csum_buffer + len, 0, SECTOR_SIZE - len); | ||||
| 	    for (i = 0; i < SECTOR_SIZE; i += 4) | ||||
| 	      bi_checksum += get_731 (&csum_buffer[i]); | ||||
| 	    total_len += len; | ||||
| 	  } | ||||
| 
 | ||||
| 	if (total_len != de->size) | ||||
| 	  error (1, 0, _("Boot image file '%s' changed unexpectedly"), | ||||
| 		 de->whole_name); | ||||
| 	/* End of file, set position to byte 8 */ | ||||
| 	fseeko (bootimage, (off_t) 8, SEEK_SET); | ||||
| 	memset (&bi_table, 0, sizeof (bi_table)); | ||||
| 	/* Is it always safe to assume PVD is at session_start+16? */ | ||||
| 	set_731 (bi_table.pvd_addr, session_start + 16); | ||||
| 	set_731 (bi_table.file_addr, de->starting_block); | ||||
| 	set_731 (bi_table.file_length, de->size); | ||||
| 	set_731 (bi_table.file_checksum, bi_checksum); | ||||
| 
 | ||||
| 	if (fwrite (&bi_table, 1, sizeof (bi_table), bootimage) != sizeof (bi_table)) | ||||
| 	  error (1, errno, _("Error writing to boot image (%s)"), bootimage); | ||||
| 	fclose (bootimage); | ||||
|       } | ||||
| 
 | ||||
| } /* get_torito_desc(... */ | ||||
| 
 | ||||
| /*
 | ||||
|  * Function to write the EVD for the disc. | ||||
|  */ | ||||
| static int FDECL1(tvd_write, FILE *, outfile) | ||||
| { | ||||
|   /*
 | ||||
|    * Next we write out the boot volume descriptor for the disc  | ||||
|    */ | ||||
|   get_torito_desc(&gboot_desc); | ||||
|   xfwrite(&gboot_desc, 1, 2048, outfile); | ||||
|   last_extent_written ++; | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| struct output_fragment torito_desc    = {NULL, oneblock_size, NULL,     tvd_write}; | ||||
							
								
								
									
										10
									
								
								util/mkisofs/exclude.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								util/mkisofs/exclude.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,10 @@ | |||
| /*
 | ||||
|  * 9-Dec-93 R.-D. Marzusch, marzusch@odiehh.hanse.de: | ||||
|  * added 'exclude' option (-x) to specify pathnames NOT to be included in  | ||||
|  * CD image. | ||||
|  * | ||||
|  * 	$Id: exclude.h,v 1.2 1999/03/02 03:41:25 eric Exp $ | ||||
|  */ | ||||
| 
 | ||||
| void exclude	__PR((char * fn)); | ||||
| int is_excluded	__PR((char * fn)); | ||||
							
								
								
									
										225
									
								
								util/mkisofs/hash.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										225
									
								
								util/mkisofs/hash.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,225 @@ | |||
| /*
 | ||||
|  * File hash.c - generate hash tables for iso9660 filesystem. | ||||
| 
 | ||||
|    Written by Eric Youngdale (1993). | ||||
| 
 | ||||
|    Copyright 1993 Yggdrasil Computing, Incorporated | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 2, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program 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 this program; if not, write to the Free Software | ||||
|    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */ | ||||
| 
 | ||||
| #include <stdlib.h> | ||||
| #include "config.h" | ||||
| #include "mkisofs.h" | ||||
| 
 | ||||
| #define NR_HASH 1024 | ||||
| 
 | ||||
| #define HASH_FN(DEV, INO) ((DEV + INO + (INO >> 2) + (INO << 8)) % NR_HASH) | ||||
| 
 | ||||
| static struct file_hash * hash_table[NR_HASH] = {0,}; | ||||
| 
 | ||||
| void FDECL1(add_hash, struct directory_entry *, spnt){ | ||||
|   struct file_hash * s_hash; | ||||
|   unsigned int hash_number; | ||||
| 
 | ||||
|   if(spnt->size == 0 || spnt->starting_block == 0)  | ||||
|     if(spnt->size != 0 || spnt->starting_block != 0) { | ||||
|       fprintf(stderr,"Non zero-length file assigned zero extent.\n"); | ||||
|       exit(1); | ||||
|     }; | ||||
| 
 | ||||
|   if (spnt->dev == (dev_t) UNCACHED_DEVICE || spnt->inode == UNCACHED_INODE) return; | ||||
|   hash_number = HASH_FN((unsigned int) spnt->dev, (unsigned int) spnt->inode); | ||||
| 
 | ||||
| #if 0 | ||||
|   if (verbose > 1) fprintf(stderr,"%s ",spnt->name); | ||||
| #endif | ||||
|   s_hash = (struct file_hash *) e_malloc(sizeof(struct file_hash)); | ||||
|   s_hash->next = hash_table[hash_number]; | ||||
|   s_hash->inode = spnt->inode; | ||||
|   s_hash->dev = spnt->dev; | ||||
|   s_hash->starting_block = spnt->starting_block; | ||||
|   s_hash->size = spnt->size; | ||||
|   hash_table[hash_number] = s_hash; | ||||
| } | ||||
| 
 | ||||
| struct file_hash * FDECL2(find_hash, dev_t, dev, ino_t, inode){ | ||||
|   unsigned int hash_number; | ||||
|   struct file_hash * spnt; | ||||
|   hash_number = HASH_FN((unsigned int) dev, (unsigned int) inode); | ||||
|   if (dev == (dev_t) UNCACHED_DEVICE || inode == UNCACHED_INODE) return NULL; | ||||
| 
 | ||||
|   spnt = hash_table[hash_number]; | ||||
|   while(spnt){ | ||||
|     if(spnt->inode == inode && spnt->dev == dev) return spnt; | ||||
|     spnt = spnt->next; | ||||
|   }; | ||||
|   return NULL; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| static struct file_hash * directory_hash_table[NR_HASH] = {0,}; | ||||
| 
 | ||||
| void FDECL2(add_directory_hash, dev_t, dev, ino_t, inode){ | ||||
|   struct file_hash * s_hash; | ||||
|   unsigned int hash_number; | ||||
| 
 | ||||
|   if (dev == (dev_t) UNCACHED_DEVICE || inode == UNCACHED_INODE) return; | ||||
|   hash_number = HASH_FN((unsigned int) dev, (unsigned int) inode); | ||||
| 
 | ||||
|   s_hash = (struct file_hash *) e_malloc(sizeof(struct file_hash)); | ||||
|   s_hash->next = directory_hash_table[hash_number]; | ||||
|   s_hash->inode = inode; | ||||
|   s_hash->dev = dev; | ||||
|   directory_hash_table[hash_number] = s_hash; | ||||
| } | ||||
| 
 | ||||
| struct file_hash * FDECL2(find_directory_hash, dev_t, dev, ino_t, inode){ | ||||
|   unsigned int hash_number; | ||||
|   struct file_hash * spnt; | ||||
|   hash_number = HASH_FN((unsigned int) dev, (unsigned int) inode); | ||||
|   if (dev == (dev_t) UNCACHED_DEVICE || inode == UNCACHED_INODE) return NULL; | ||||
| 
 | ||||
|   spnt = directory_hash_table[hash_number]; | ||||
|   while(spnt){ | ||||
|     if(spnt->inode == inode && spnt->dev == dev) return spnt; | ||||
|     spnt = spnt->next; | ||||
|   }; | ||||
|   return NULL; | ||||
| } | ||||
| 
 | ||||
| struct  name_hash | ||||
| { | ||||
|   struct name_hash * next; | ||||
|   struct directory_entry * de; | ||||
| }; | ||||
| 
 | ||||
| #define NR_NAME_HASH 128 | ||||
| 
 | ||||
| static struct name_hash * name_hash_table[NR_NAME_HASH] = {0,}; | ||||
| 
 | ||||
| /*
 | ||||
|  * Find the hash bucket for this name. | ||||
|  */ | ||||
| static  unsigned int FDECL1(name_hash, const char *, name) | ||||
| { | ||||
|   unsigned int hash = 0; | ||||
|   const char * p; | ||||
|    | ||||
|   p = name; | ||||
|    | ||||
|   while (*p)  | ||||
|     { | ||||
|       /*
 | ||||
|        * Don't hash the  iso9660 version number.  This way | ||||
|        * we can detect duplicates in cases where we have | ||||
|        * directories (i.e. foo) and non-directories | ||||
|        * (i.e. foo;1). | ||||
|        */ | ||||
|       if( *p == ';' ) | ||||
| 	{ | ||||
| 	  break; | ||||
| 	} | ||||
|       hash = (hash << 15) + (hash << 3) + (hash >> 3) + *p++; | ||||
|     } | ||||
|   return hash % NR_NAME_HASH; | ||||
| } | ||||
| 
 | ||||
| void FDECL1(add_file_hash, struct directory_entry *, de){ | ||||
| 	struct name_hash  * new; | ||||
| 	int hash; | ||||
| 
 | ||||
| 	new = (struct  name_hash *) e_malloc(sizeof(struct name_hash)); | ||||
| 	new->de = de; | ||||
| 	new->next = NULL; | ||||
| 	hash = name_hash(de->isorec.name); | ||||
| 
 | ||||
| 	/* Now insert into the hash table */ | ||||
| 	new->next = name_hash_table[hash]; | ||||
| 	name_hash_table[hash] = new; | ||||
| } | ||||
| 
 | ||||
| struct directory_entry * FDECL1(find_file_hash, char *, name) | ||||
| { | ||||
|   struct name_hash  * nh; | ||||
|   char		    * p1; | ||||
|   char		    * p2; | ||||
|    | ||||
|   for(nh = name_hash_table[name_hash(name)]; nh; nh = nh->next) | ||||
|     { | ||||
|       p1 = name; | ||||
|       p2 = nh->de->isorec.name; | ||||
| 
 | ||||
|       /*
 | ||||
|        * Look for end of string, or a mismatch. | ||||
|        */ | ||||
|       while(1==1) | ||||
| 	{ | ||||
| 	  if(    (*p1 == '\0' || *p1 == ';') | ||||
| 	      || (*p2 == '\0' || *p2 == ';') | ||||
| 	      || (*p1 != *p2) ) | ||||
| 	    { | ||||
| 	      break; | ||||
| 	    } | ||||
| 	  p1++; | ||||
| 	  p2++; | ||||
| 	} | ||||
| 
 | ||||
|       /*
 | ||||
|        * If we are at the end of both strings, then | ||||
|        * we have a match. | ||||
|        */ | ||||
|       if(    (*p1 == '\0' || *p1 == ';') | ||||
| 	  && (*p2 == '\0' || *p2 == ';') ) | ||||
| 	{ | ||||
| 	  return nh->de; | ||||
| 	} | ||||
|     } | ||||
|   return NULL; | ||||
| } | ||||
| 
 | ||||
| int FDECL1(delete_file_hash, struct directory_entry *, de){ | ||||
| 	struct name_hash  * nh, *prev; | ||||
| 	int hash; | ||||
| 
 | ||||
| 	prev = NULL; | ||||
| 	hash = name_hash(de->isorec.name); | ||||
| 	for(nh = name_hash_table[hash]; nh; nh = nh->next) { | ||||
| 		if(nh->de == de) break; | ||||
| 		prev = nh; | ||||
| 	} | ||||
| 	if(!nh) return 1; | ||||
| 	if(!prev) | ||||
| 		name_hash_table[hash] = nh->next; | ||||
| 	else | ||||
| 		prev->next = nh->next; | ||||
| 	free(nh); | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| void flush_file_hash(){ | ||||
| 	struct name_hash  * nh, *nh1; | ||||
| 	int i; | ||||
| 
 | ||||
| 	for(i=0; i<NR_NAME_HASH; i++) { | ||||
| 		nh = name_hash_table[i]; | ||||
| 		while(nh) { | ||||
| 			nh1 =  nh->next; | ||||
| 			free(nh); | ||||
| 			nh = nh1; | ||||
| 		} | ||||
| 		name_hash_table[i] =  NULL; | ||||
| 		 | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										57
									
								
								util/mkisofs/include/fctldefs.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								util/mkisofs/include/fctldefs.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,57 @@ | |||
| /* @(#)fctldefs.h	1.2 98/10/08 Copyright 1996 J. Schilling */ | ||||
| /*
 | ||||
|  *	Generic header for users of open(), creat() and chmod() | ||||
|  * | ||||
|  *	Copyright (c) 1996 J. Schilling | ||||
|  */ | ||||
| /*
 | ||||
|  * This program is free software; you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License as published by | ||||
|  * the Free Software Foundation; either version 2, or (at your option) | ||||
|  * any later version. | ||||
|  * | ||||
|  * This program 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 this program; see the file COPYING.  If not, write to | ||||
|  * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. | ||||
|  */ | ||||
| 
 | ||||
| #ifndef _FCTLDEFS_H | ||||
| #define	_FCTLDEFS_H | ||||
| 
 | ||||
| #ifndef	_MCONFIG_H | ||||
| #include <mconfig.h> | ||||
| #endif | ||||
| 
 | ||||
| #include <sys/types.h> | ||||
| #include <sys/stat.h> | ||||
| 
 | ||||
| #ifdef	HAVE_FCNTL_H | ||||
| 
 | ||||
| #	include <fcntl.h> | ||||
| 
 | ||||
| #else	/* HAVE_FCNTL_H */ | ||||
| 
 | ||||
| #	include <sys/file.h> | ||||
| 
 | ||||
| #endif	/* HAVE_FCNTL_H */ | ||||
| 
 | ||||
| /*
 | ||||
|  * Do not define more than O_RDONLY / O_WRONLY / O_RDWR | ||||
|  * The values may differ. | ||||
|  */ | ||||
| #ifndef	O_RDONLY | ||||
| #define	O_RDONLY	0 | ||||
| #endif | ||||
| #ifndef	O_WRONLY | ||||
| #define	O_WRONLY	1 | ||||
| #endif | ||||
| #ifndef	O_RDWR | ||||
| #define	O_RDWR		2 | ||||
| #endif | ||||
| 
 | ||||
| #endif	/* _FCTLDEFS_H */ | ||||
							
								
								
									
										253
									
								
								util/mkisofs/include/mconfig.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										253
									
								
								util/mkisofs/include/mconfig.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,253 @@ | |||
| /* @(#)mconfig.h	1.24 98/12/14 Copyright 1995 J. Schilling */ | ||||
| /*
 | ||||
|  *	definitions for machine configuration | ||||
|  * | ||||
|  *	Copyright (c) 1995 J. Schilling | ||||
|  * | ||||
|  *	This file must be included before any other file. | ||||
|  *	Use only cpp instructions. | ||||
|  * | ||||
|  *	NOTE: SING: (Schily Is Not Gnu) | ||||
|  */ | ||||
| /*
 | ||||
|  * This program is free software; you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License as published by | ||||
|  * the Free Software Foundation; either version 2, or (at your option) | ||||
|  * any later version. | ||||
|  * | ||||
|  * This program 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 this program; see the file COPYING.  If not, write to | ||||
|  * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. | ||||
|  */ | ||||
| 
 | ||||
| #ifndef _MCONFIG_H | ||||
| #define _MCONFIG_H | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| #if defined(unix) || defined(__unix) || defined(__unix__) | ||||
| #	define	IS_UNIX | ||||
| #endif | ||||
| 
 | ||||
| #ifdef	__MSDOS__ | ||||
| #	define	IS_MSDOS | ||||
| #endif | ||||
| 
 | ||||
| #if defined(tos) || defined(__tos) | ||||
| #	define	IS_TOS | ||||
| #endif | ||||
| 
 | ||||
| #ifdef	THINK_C | ||||
| #	define	IS_MAC | ||||
| #endif | ||||
| 
 | ||||
| #if defined(sun) || defined(__sun) || defined(__sun__) | ||||
| #	define	IS_SUN | ||||
| #endif | ||||
| 
 | ||||
| #if defined(__CYGWIN32__) | ||||
| #       define IS_GCC_WIN32 | ||||
| #endif | ||||
| 
 | ||||
| /*--------------------------------------------------------------------------*/ | ||||
| /*
 | ||||
|  * Some magic that cannot (yet) be figured out with autoconf. | ||||
|  */ | ||||
| 
 | ||||
| #ifdef sparc | ||||
| #	ifndef	HAVE_LDSTUB | ||||
| #	define	HAVE_LDSTUB | ||||
| #	endif | ||||
| #	ifndef	HAVE_SCANSTACK | ||||
| #	define	HAVE_SCANSTACK | ||||
| #	endif | ||||
| #endif | ||||
| #if	defined(__i386_) || defined(i386) | ||||
| #	ifndef	HAVE_XCHG | ||||
| #	define	HAVE_XCHG | ||||
| #	endif | ||||
| #	ifndef	HAVE_SCANSTACK | ||||
| #	define	HAVE_SCANSTACK | ||||
| #	endif | ||||
| #endif | ||||
| 
 | ||||
| #if	defined(SOL2) || defined(SOL2) || defined(S5R4) || defined(__S5R4) \ | ||||
| 							|| defined(SVR4) | ||||
| #	ifndef	__SVR4 | ||||
| #		define	__SVR4 | ||||
| #	endif | ||||
| #endif | ||||
| 
 | ||||
| #ifdef	__SVR4 | ||||
| #	ifndef	SVR4 | ||||
| #		define	SVR4 | ||||
| #	endif | ||||
| #endif | ||||
| 
 | ||||
| /*
 | ||||
|  * SunOS 4.x / SunOS 5.x | ||||
|  */ | ||||
| #if defined(IS_SUN) | ||||
| #	define	HAVE_GETAV0 | ||||
| #endif | ||||
| 
 | ||||
| /*
 | ||||
|  * AIX | ||||
|  */ | ||||
| #if	defined(_IBMR2) || defined(_AIX) | ||||
| #	define	IS_UNIX		/* ??? really ??? */ | ||||
| #endif | ||||
| 
 | ||||
| /*
 | ||||
|  * Silicon Graphics	(must be before SVR4) | ||||
|  */ | ||||
| #if defined(sgi) || defined(__sgi) | ||||
| #	define	__NOT_SVR4__	/* Not a real SVR4 implementation */ | ||||
| #endif | ||||
| 
 | ||||
| /*
 | ||||
|  * Data General | ||||
|  */ | ||||
| #if defined(__DGUX__) | ||||
| #ifdef	XXXXXXX | ||||
| #	undef	HAVE_MTGET_DSREG | ||||
| #	undef	HAVE_MTGET_RESID | ||||
| #	undef	HAVE_MTGET_FILENO | ||||
| #	undef	HAVE_MTGET_BLKNO | ||||
| #endif | ||||
| #	define	mt_type		mt_model | ||||
| #	define	mt_dsreg	mt_status1 | ||||
| #	define	mt_erreg	mt_status2 | ||||
| 	/*
 | ||||
| 	 * DGUX hides its flock as dg_flock. | ||||
| 	 */ | ||||
| #	define	HAVE_FLOCK | ||||
| #	define	flock	dg_flock | ||||
| 	/*
 | ||||
| 	 * Use the BSD style wait on DGUX to get the resource usages of child | ||||
| 	 * processes. | ||||
| 	 */ | ||||
| #	define	_BSD_WAIT_FLAVOR | ||||
| #endif | ||||
| 
 | ||||
| /*
 | ||||
|  * Apple Rhapsody | ||||
|  */ | ||||
| #if defined(__NeXT__) && defined(__TARGET_OSNAME) && __TARGET_OSNAME == rhapsody | ||||
| #	define HAVE_OSDEF /* prevent later definitions to overwrite current */ | ||||
| #endif | ||||
| 
 | ||||
| /*
 | ||||
|  * NextStep | ||||
|  */ | ||||
| #if defined(__NeXT__) && !defined(HAVE_OSDEF) | ||||
| #define	NO_PRINT_OVR | ||||
| #undef	HAVE_USG_STDIO		/* | ||||
| 				 *  NeXT Step 3.x uses __flsbuf(unsigned char , FILE *) | ||||
| 				 * instead of __flsbuf(int, FILE *) | ||||
| 				 */ | ||||
| #endif | ||||
| 
 | ||||
| /*
 | ||||
|  * NextStep 3.x has a broken linker that does not allow us to override | ||||
|  * these functions. | ||||
|  */ | ||||
| #ifndef	__OPRINTF__ | ||||
| 
 | ||||
| #ifdef	NO_PRINT_OVR | ||||
| #	define	printf	Xprintf | ||||
| #	define	fprintf	Xfprintf | ||||
| #	define	sprintf	Xsprintf | ||||
| #endif | ||||
| 
 | ||||
| #endif	/* __OPRINTF__ */ | ||||
| 
 | ||||
| /*--------------------------------------------------------------------------*/ | ||||
| /*
 | ||||
|  * If there is no flock defined by the system, use emulation | ||||
|  * through fcntl record locking. | ||||
|  */ | ||||
| #ifndef HAVE_FLOCK | ||||
| #define LOCK_SH         1       /* shared lock */ | ||||
| #define LOCK_EX         2       /* exclusive lock */ | ||||
| #define LOCK_NB         4       /* don't block when locking */ | ||||
| #define LOCK_UN         8       /* unlock */ | ||||
| #endif | ||||
| 
 | ||||
| #include <prototyp.h> | ||||
| 
 | ||||
| /*
 | ||||
|  * gcc 2.x generally implements the long long type. | ||||
|  */ | ||||
| #ifdef	__GNUC__ | ||||
| #	if	__GNUC__ > 1 | ||||
| #		ifndef	HAVE_LONGLONG | ||||
| #			define	HAVE_LONGLONG | ||||
| #		endif | ||||
| #	endif | ||||
| #endif | ||||
| 
 | ||||
| /*
 | ||||
|  * Convert to GNU name | ||||
|  */ | ||||
| #ifdef	HAVE_STDC_HEADERS | ||||
| #	ifndef	STDC_HEADERS | ||||
| #		define	STDC_HEADERS | ||||
| #	endif | ||||
| #endif | ||||
| /*
 | ||||
|  * Convert to SCHILY name | ||||
|  */ | ||||
| #ifdef	STDC_HEADERS | ||||
| #	ifndef	HAVE_STDC_HEADERS | ||||
| #		define	HAVE_STDC_HEADERS | ||||
| #	endif | ||||
| #endif | ||||
| 
 | ||||
| #ifdef	IS_UNIX | ||||
| #	define	PATH_DELIM	'/' | ||||
| #	define	PATH_DELIM_STR	"/" | ||||
| #	define	far | ||||
| #	define	near | ||||
| #endif | ||||
| 
 | ||||
| #ifdef	IS_GCC_WIN32 | ||||
| #	define	PATH_DELIM	'/' | ||||
| #	define	PATH_DELIM_STR	"/" | ||||
| #	define	far | ||||
| #	define	near | ||||
| #endif | ||||
| 
 | ||||
| #ifdef	IS_MSDOS | ||||
| #	define	PATH_DELIM	'\\' | ||||
| #	define	PATH_DELIM_STR	"\\" | ||||
| #endif | ||||
| 
 | ||||
| #ifdef	IS_TOS | ||||
| #	define	PATH_DELIM	'\\' | ||||
| #	define	PATH_DELIM_STR	"\\" | ||||
| #	define	far | ||||
| #	define	near | ||||
| #endif | ||||
| 
 | ||||
| #ifdef	IS_MAC | ||||
| #	define	PATH_DELIM	':' | ||||
| #	define	PATH_DELIM_STR	":" | ||||
| #	define	far | ||||
| #	define	near | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* _MCONFIG_H */ | ||||
							
								
								
									
										74
									
								
								util/mkisofs/include/prototyp.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										74
									
								
								util/mkisofs/include/prototyp.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,74 @@ | |||
| /* @(#)prototyp.h	1.7 98/10/08 Copyright 1995 J. Schilling */ | ||||
| /*
 | ||||
|  *	Definitions for dealing with ANSI / KR C-Compilers | ||||
|  * | ||||
|  *	Copyright (c) 1995 J. Schilling | ||||
|  */ | ||||
| /*
 | ||||
|  * This program is free software; you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License as published by | ||||
|  * the Free Software Foundation; either version 2, or (at your option) | ||||
|  * any later version. | ||||
|  * | ||||
|  * This program 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 this program; see the file COPYING.  If not, write to | ||||
|  * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. | ||||
|  */ | ||||
| 
 | ||||
| #ifndef	_PROTOTYP_H | ||||
| #define	_PROTOTYP_H | ||||
| 
 | ||||
| #ifndef	PROTOTYPES | ||||
| 	/*
 | ||||
| 	 * If this has already been defined, | ||||
| 	 * someone else knows better than us... | ||||
| 	 */ | ||||
| #	ifdef	__STDC__ | ||||
| #		if	__STDC__				/* ANSI C */ | ||||
| #			define	PROTOTYPES | ||||
| #		endif | ||||
| #		if	defined(sun) && __STDC__ - 0 == 0	/* Sun C */ | ||||
| #			define	PROTOTYPES | ||||
| #		endif | ||||
| #	endif | ||||
| #endif	/* PROTOTYPES */ | ||||
| 
 | ||||
| /*
 | ||||
|  * If we have prototypes, we should have stdlib.h string.h stdarg.h | ||||
|  */ | ||||
| #ifdef	PROTOTYPES | ||||
| #if	!(defined(SABER) && defined(sun)) | ||||
| #	ifndef	HAVE_STDARG_H | ||||
| #		define	HAVE_STDARG_H | ||||
| #	endif | ||||
| #endif | ||||
| #	ifndef	HAVE_STDLIB_H | ||||
| #		define	HAVE_STDLIB_H | ||||
| #	endif | ||||
| #	ifndef	HAVE_STRING_H | ||||
| #		define	HAVE_STRING_H | ||||
| #	endif | ||||
| #	ifndef	HAVE_STDC_HEADERS | ||||
| #		define	HAVE_STDC_HEADERS | ||||
| #	endif | ||||
| #	ifndef	STDC_HEADERS | ||||
| #		define	STDC_HEADERS	/* GNU name */ | ||||
| #	endif | ||||
| #endif | ||||
| 
 | ||||
| #ifdef	NO_PROTOTYPES		/* Force not to use prototypes */ | ||||
| #	undef	PROTOTYPES | ||||
| #endif | ||||
| 
 | ||||
| #ifdef	PROTOTYPES | ||||
| #	define	__PR(a)	a | ||||
| #else | ||||
| #	define	__PR(a)	() | ||||
| #endif | ||||
| 
 | ||||
| #endif	/* _PROTOTYP_H */ | ||||
							
								
								
									
										139
									
								
								util/mkisofs/include/statdefs.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										139
									
								
								util/mkisofs/include/statdefs.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,139 @@ | |||
| /* @(#)statdefs.h	1.1 98/11/22 Copyright 1998 J. Schilling */ | ||||
| /*
 | ||||
|  *	Definitions for stat() file mode | ||||
|  * | ||||
|  *	Copyright (c) 1998 J. Schilling | ||||
|  */ | ||||
| /*
 | ||||
|  * This program is free software; you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License as published by | ||||
|  * the Free Software Foundation; either version 2, or (at your option) | ||||
|  * any later version. | ||||
|  * | ||||
|  * This program 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 this program; see the file COPYING.  If not, write to | ||||
|  * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. | ||||
|  */ | ||||
| 
 | ||||
| #ifndef	_STATDEFS_H | ||||
| #define	_STATDEFS_H | ||||
| 
 | ||||
| #ifndef _MCONFIG_H | ||||
| #include <mconfig.h> | ||||
| #endif | ||||
| 
 | ||||
| #ifdef	STAT_MACROS_BROKEN | ||||
| #undef	S_ISFIFO			/* Named pipe		*/ | ||||
| #undef	S_ISCHR				/* Character special	*/ | ||||
| #undef	S_ISMPC				/* UNUSED multiplexed c	*/ | ||||
| #undef	S_ISDIR				/* Directory		*/ | ||||
| #undef	S_ISNAM				/* Named file (XENIX)	*/ | ||||
| #undef	S_ISBLK				/* Block special	*/ | ||||
| #undef	S_ISMPB				/* UNUSED multiplexed b	*/ | ||||
| #undef	S_ISREG				/* Regular file		*/ | ||||
| #undef	S_ISCNT				/* Contiguous file	*/ | ||||
| #undef	S_ISLNK				/* Symbolic link	*/ | ||||
| #undef	S_ISSHAD			/* Solaris shadow inode	*/ | ||||
| #undef	S_ISSOCK			/* UNIX domain socket	*/ | ||||
| #undef	S_ISDOOR			/* Solaris DOOR		*/ | ||||
| #endif | ||||
| 
 | ||||
| #ifndef	S_ISFIFO			/* Named pipe		*/ | ||||
| #	ifdef	S_IFIFO | ||||
| #		define	S_ISFIFO(m)	(((m) & S_IFMT) == S_IFIFO) | ||||
| #	else | ||||
| #		define	S_ISFIFO(m)	(0) | ||||
| #	endif | ||||
| #endif | ||||
| #ifndef	S_ISCHR				/* Character special	*/ | ||||
| #	ifdef	S_IFCHR | ||||
| #		define	S_ISCHR(m)	(((m) & S_IFMT) == S_IFCHR) | ||||
| #	else | ||||
| #		define	S_ISCHR(m)	(0) | ||||
| #	endif | ||||
| #endif | ||||
| #ifndef	S_ISMPC				/* UNUSED multiplexed c	*/ | ||||
| #	ifdef	S_IFMPC | ||||
| #		define	S_ISMPC(m)	(((m) & S_IFMT) == S_IFMPC) | ||||
| #	else | ||||
| #		define	S_ISMPC(m)	(0) | ||||
| #	endif | ||||
| #endif | ||||
| #ifndef	S_ISDIR				/* Directory		*/ | ||||
| #	ifdef	S_IFDIR | ||||
| #		define	S_ISDIR(m)	(((m) & S_IFMT) == S_IFDIR) | ||||
| #	else | ||||
| #		define	S_ISDIR(m)	(0) | ||||
| #	endif | ||||
| #endif | ||||
| #ifndef	S_ISNAM				/* Named file (XENIX)	*/ | ||||
| #	ifdef	S_IFNAM | ||||
| #		define	S_ISNAM(m)	(((m) & S_IFMT) == S_IFNAM) | ||||
| #	else | ||||
| #		define	S_ISNAM(m)	(0) | ||||
| #	endif | ||||
| #endif | ||||
| #ifndef	S_ISBLK				/* Block special	*/ | ||||
| #	ifdef	S_IFBLK | ||||
| #		define	S_ISBLK(m)	(((m) & S_IFMT) == S_IFBLK) | ||||
| #	else | ||||
| #		define	S_ISBLK(m)	(0) | ||||
| #	endif | ||||
| #endif | ||||
| #ifndef	S_ISMPB				/* UNUSED multiplexed b	*/ | ||||
| #	ifdef	S_IFMPB | ||||
| #		define	S_ISMPB(m)	(((m) & S_IFMT) == S_IFMPB) | ||||
| #	else | ||||
| #		define	S_ISMPB(m)	(0) | ||||
| #	endif | ||||
| #endif | ||||
| #ifndef	S_ISREG				/* Regular file		*/ | ||||
| #	ifdef	S_IFREG | ||||
| #		define	S_ISREG(m)	(((m) & S_IFMT) == S_IFREG) | ||||
| #	else | ||||
| #		define	S_ISREG(m)	(0) | ||||
| #	endif | ||||
| #endif | ||||
| #ifndef	S_ISCNT				/* Contiguous file	*/ | ||||
| #	ifdef	S_IFCNT | ||||
| #		define	S_ISCNT(m)	(((m) & S_IFMT) == S_IFCNT) | ||||
| #	else | ||||
| #		define	S_ISCNT(m)	(0) | ||||
| #	endif | ||||
| #endif | ||||
| #ifndef	S_ISLNK				/* Symbolic link	*/ | ||||
| #	ifdef	S_IFLNK | ||||
| #		define	S_ISLNK(m)	(((m) & S_IFMT) == S_IFLNK) | ||||
| #	else | ||||
| #		define	S_ISLNK(m)	(0) | ||||
| #	endif | ||||
| #endif | ||||
| #ifndef	S_ISSHAD			/* Solaris shadow inode	*/ | ||||
| #	ifdef	S_IFSHAD | ||||
| #		define	S_ISSHAD(m)	(((m) & S_IFMT) == S_IFSHAD) | ||||
| #	else | ||||
| #		define	S_ISSHAD(m)	(0) | ||||
| #	endif | ||||
| #endif | ||||
| #ifndef	S_ISSOCK			/* UNIX domain socket	*/ | ||||
| #	ifdef	S_IFSOCK | ||||
| #		define	S_ISSOCK(m)	(((m) & S_IFMT) == S_IFSOCK) | ||||
| #	else | ||||
| #		define	S_ISSOCK(m)	(0) | ||||
| #	endif | ||||
| #endif | ||||
| #ifndef	S_ISDOOR			/* Solaris DOOR		*/ | ||||
| #	ifdef	S_IFDOOR | ||||
| #		define	S_ISDOOR(m)	(((m) & S_IFMT) == S_IFDOOR) | ||||
| #	else | ||||
| #		define	S_ISDOOR(m)	(0) | ||||
| #	endif | ||||
| #endif | ||||
| 
 | ||||
| #endif	/* _STATDEFS_H */ | ||||
| 
 | ||||
							
								
								
									
										174
									
								
								util/mkisofs/iso9660.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										174
									
								
								util/mkisofs/iso9660.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,174 @@ | |||
| /*
 | ||||
|  * Header file iso9660.h - assorted structure definitions and typecasts. | ||||
|  * specific to iso9660 filesystem. | ||||
| 
 | ||||
|    Written by Eric Youngdale (1993). | ||||
| 
 | ||||
|    Copyright 1993 Yggdrasil Computing, Incorporated | ||||
| 
 | ||||
|    Copyright (C) 2009  Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program 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 this program; if not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| /*
 | ||||
|  * 	$Id: iso9660.h,v 1.2 1997/05/17 15:46:44 eric Exp $ | ||||
|  */ | ||||
| 
 | ||||
| #ifndef _ISOFS_FS_H | ||||
| #define _ISOFS_FS_H | ||||
| 
 | ||||
| /*
 | ||||
|  * The isofs filesystem constants/structures | ||||
|  */ | ||||
| 
 | ||||
| /* This part borrowed from the bsd386 isofs */ | ||||
| #define ISODCL(from, to) (to - from + 1) | ||||
| 
 | ||||
| struct iso_volume_descriptor { | ||||
| 	char type[ISODCL(1,1)]; /* 711 */ | ||||
| 	char id[ISODCL(2,6)]; | ||||
| 	char version[ISODCL(7,7)]; | ||||
| 	char data[ISODCL(8,2048)]; | ||||
| }; | ||||
| 
 | ||||
| /* volume descriptor types */ | ||||
| #define ISO_VD_PRIMARY       1 | ||||
| #define ISO_VD_SUPPLEMENTARY 2     /* Used by Joliet */ | ||||
| #define ISO_VD_END           255 | ||||
| 
 | ||||
| #define ISO_STANDARD_ID "CD001" | ||||
| 
 | ||||
| #define EL_TORITO_ID "EL TORITO SPECIFICATION" | ||||
| #define EL_TORITO_ARCH_x86 0 | ||||
| #define EL_TORITO_ARCH_PPC 1 | ||||
| #define EL_TORITO_ARCH_MAC 2 | ||||
| #define EL_TORITO_BOOTABLE 0x88 | ||||
| #define EL_TORITO_MEDIA_NOEMUL 0 | ||||
| #define EL_TORITO_MEDIA_12FLOP  1 | ||||
| #define EL_TORITO_MEDIA_144FLOP 2 | ||||
| #define EL_TORITO_MEDIA_288FLOP 3 | ||||
| #define EL_TORITO_MEDIA_HD      4 | ||||
| 
 | ||||
| struct iso_primary_descriptor { | ||||
| 	char type			[ISODCL (  1,   1)]; /* 711 */ | ||||
| 	char id				[ISODCL (  2,   6)]; | ||||
| 	char version			[ISODCL (  7,   7)]; /* 711 */ | ||||
| 	char unused1			[ISODCL (  8,   8)]; | ||||
| 	char system_id			[ISODCL (  9,  40)]; /* achars */ | ||||
| 	char volume_id			[ISODCL ( 41,  72)]; /* dchars */ | ||||
| 	char unused2			[ISODCL ( 73,  80)]; | ||||
| 	char volume_space_size		[ISODCL ( 81,  88)]; /* 733 */ | ||||
| 	char escape_sequences		[ISODCL ( 89, 120)]; | ||||
| 	char volume_set_size		[ISODCL (121, 124)]; /* 723 */ | ||||
| 	char volume_sequence_number	[ISODCL (125, 128)]; /* 723 */ | ||||
| 	char logical_block_size		[ISODCL (129, 132)]; /* 723 */ | ||||
| 	char path_table_size		[ISODCL (133, 140)]; /* 733 */ | ||||
| 	char type_l_path_table		[ISODCL (141, 144)]; /* 731 */ | ||||
| 	char opt_type_l_path_table	[ISODCL (145, 148)]; /* 731 */ | ||||
| 	char type_m_path_table		[ISODCL (149, 152)]; /* 732 */ | ||||
| 	char opt_type_m_path_table	[ISODCL (153, 156)]; /* 732 */ | ||||
| 	char root_directory_record	[ISODCL (157, 190)]; /* 9.1 */ | ||||
| 	char volume_set_id		[ISODCL (191, 318)]; /* dchars */ | ||||
| 	char publisher_id		[ISODCL (319, 446)]; /* achars */ | ||||
| 	char preparer_id		[ISODCL (447, 574)]; /* achars */ | ||||
| 	char application_id		[ISODCL (575, 702)]; /* achars */ | ||||
| 	char copyright_file_id		[ISODCL (703, 739)]; /* 7.5 dchars */ | ||||
| 	char abstract_file_id		[ISODCL (740, 776)]; /* 7.5 dchars */ | ||||
| 	char bibliographic_file_id	[ISODCL (777, 813)]; /* 7.5 dchars */ | ||||
| 	char creation_date		[ISODCL (814, 830)]; /* 8.4.26.1 */ | ||||
| 	char modification_date		[ISODCL (831, 847)]; /* 8.4.26.1 */ | ||||
| 	char expiration_date		[ISODCL (848, 864)]; /* 8.4.26.1 */ | ||||
| 	char effective_date		[ISODCL (865, 881)]; /* 8.4.26.1 */ | ||||
| 	char file_structure_version	[ISODCL (882, 882)]; /* 711 */ | ||||
| 	char unused4			[ISODCL (883, 883)]; | ||||
| 	char application_data		[ISODCL (884, 1395)]; | ||||
| 	char unused5			[ISODCL (1396, 2048)]; | ||||
| }; | ||||
| 
 | ||||
| /* El Torito Boot Record Volume Descriptor */ | ||||
| struct eltorito_boot_descriptor { | ||||
|         char id	           		[ISODCL (  1,    1)]; /* 711 */ | ||||
| 	char id2			[ISODCL (  2,    6)]; | ||||
| 	char version			[ISODCL (  7,    7)]; /* 711 */ | ||||
| 	char system_id			[ISODCL (  8,   39)]; | ||||
| 	char unused2			[ISODCL ( 40,   71)]; | ||||
|         char bootcat_ptr                [ISODCL ( 72 ,  75)]; | ||||
| 	char unused5			[ISODCL ( 76, 2048)]; | ||||
| }; | ||||
| 
 | ||||
| /* Validation entry for El Torito */ | ||||
| struct eltorito_validation_entry { | ||||
|         char headerid          		[ISODCL (  1,    1)]; /* 711 */ | ||||
| 	char arch			[ISODCL (  2,    2)]; | ||||
| 	char pad1			[ISODCL (  3,    4)]; /* 711 */ | ||||
| 	char id  			[ISODCL (  5,   28)]; | ||||
| 	char cksum			[ISODCL ( 29,   30)]; | ||||
|         char key1                       [ISODCL ( 31,   31)]; | ||||
| 	char key2			[ISODCL ( 32,   32)]; | ||||
| }; | ||||
| 
 | ||||
| /* El Torito initial/default entry in boot catalog */ | ||||
| struct eltorito_defaultboot_entry { | ||||
|         char boot_id           		[ISODCL (  1,    1)]; /* 711 */ | ||||
| 	char boot_media			[ISODCL (  2,    2)]; | ||||
| 	char loadseg			[ISODCL (  3,    4)]; /* 711 */ | ||||
| 	char arch  			[ISODCL (  5,    5)]; | ||||
| 	char pad1			[ISODCL (  6,    6)]; | ||||
|         char nsect                      [ISODCL (  7,    8)]; | ||||
| 	char bootoff			[ISODCL (  9,   12)]; | ||||
|         char pad2                       [ISODCL ( 13,   32)]; | ||||
| }; | ||||
| 
 | ||||
| /* El Torito boot information table */ | ||||
| struct eltorito_boot_info | ||||
| { | ||||
|   /* Address of Primary Volume Descriptor.  */ | ||||
|   char pvd_addr[ISODCL (1, 4)]; | ||||
|   /* Boot file address.  */ | ||||
|   char file_addr[ISODCL (5, 8)]; | ||||
|   /* Boot file length.  */   | ||||
|   char file_length[ISODCL (9, 12)]; | ||||
|   /* Boot file checksum.  */ | ||||
|   char file_checksum[ISODCL (13, 16)]; | ||||
|   char dummy[ISODCL (17, 56)]; | ||||
| }; | ||||
| 
 | ||||
| 
 | ||||
| /* We use this to help us look up the parent inode numbers. */ | ||||
| 
 | ||||
| struct iso_path_table{ | ||||
| 	unsigned char  name_len[2];	/* 721 */ | ||||
| 	char extent[4];		/* 731 */ | ||||
| 	char  parent[2];	/* 721 */ | ||||
| 	char name[1]; | ||||
| }; | ||||
| 
 | ||||
| struct iso_directory_record { | ||||
| 	unsigned char length			[ISODCL (1, 1)]; /* 711 */ | ||||
| 	char ext_attr_length		[ISODCL (2, 2)]; /* 711 */ | ||||
| 	char extent			[ISODCL (3, 10)]; /* 733 */ | ||||
| 	char size			[ISODCL (11, 18)]; /* 733 */ | ||||
| 	char date			[ISODCL (19, 25)]; /* 7 by 711 */ | ||||
| 	char flags			[ISODCL (26, 26)]; | ||||
| 	char file_unit_size		[ISODCL (27, 27)]; /* 711 */ | ||||
| 	char interleave			[ISODCL (28, 28)]; /* 711 */ | ||||
| 	char volume_sequence_number	[ISODCL (29, 32)]; /* 723 */ | ||||
| 	unsigned char name_len		[ISODCL (33, 33)]; /* 711 */ | ||||
| 	char name			[34]; /* Not really, but we need something here */ | ||||
| }; | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
							
								
								
									
										1023
									
								
								util/mkisofs/joliet.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1023
									
								
								util/mkisofs/joliet.c
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										76
									
								
								util/mkisofs/match.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										76
									
								
								util/mkisofs/match.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,76 @@ | |||
| /*
 | ||||
|  *  Copyright (C) 2009  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  This program is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  This program 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 this program.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include "config.h" | ||||
| 
 | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| #include "fnmatch.h" | ||||
| 
 | ||||
| #include "match.h" | ||||
| 
 | ||||
| struct pattern | ||||
| { | ||||
|   char *str; | ||||
|   struct pattern *next; | ||||
| }; | ||||
| 
 | ||||
| static struct pattern *patlist = NULL; | ||||
| static struct pattern *i_patlist = NULL;	/* ISO9660/RR */ | ||||
| static struct pattern *j_patlist = NULL;	/* Joliet */ | ||||
| 
 | ||||
| #define DECL_ADD_MATCH(function, list) \ | ||||
| void \ | ||||
| function (char *pattern) \ | ||||
| { \ | ||||
|   struct pattern *new; \ | ||||
|   new = malloc (sizeof (*new)); \ | ||||
|   new->str = strdup (pattern); \ | ||||
|   new->next = list; \ | ||||
|   list = new; \ | ||||
| } | ||||
| 
 | ||||
| DECL_ADD_MATCH (add_match, patlist) | ||||
| DECL_ADD_MATCH (i_add_match, i_patlist) | ||||
| DECL_ADD_MATCH (j_add_match, j_patlist) | ||||
| 
 | ||||
| #define DECL_MATCHES(function, list) \ | ||||
| int \ | ||||
| function (char *str) \ | ||||
| { \ | ||||
|   struct pattern *i; \ | ||||
|   for (i = list; i != NULL; i = i->next) \ | ||||
|     if (fnmatch (i->str, str, FNM_FILE_NAME) != FNM_NOMATCH) \ | ||||
|       return 1; \ | ||||
|   return 0; \ | ||||
| } | ||||
| 
 | ||||
| DECL_MATCHES (matches, patlist) | ||||
| DECL_MATCHES (i_matches, i_patlist) | ||||
| DECL_MATCHES (j_matches, j_patlist) | ||||
| 
 | ||||
| int | ||||
| i_ishidden() | ||||
| { | ||||
|   return (i_patlist != NULL); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| int j_ishidden() | ||||
| { | ||||
|   return (j_patlist != NULL); | ||||
| } | ||||
							
								
								
									
										29
									
								
								util/mkisofs/match.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								util/mkisofs/match.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,29 @@ | |||
| /*
 | ||||
|  *  Copyright (C) 2009  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  This program is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  This program 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 this program.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include "config.h" | ||||
| 
 | ||||
| extern void add_match (char *); | ||||
| extern void i_add_match (char *); | ||||
| extern void j_add_match (char *); | ||||
| 
 | ||||
| extern int matches (char *); | ||||
| extern int i_matches (char *); | ||||
| extern int j_matches (char *); | ||||
| 
 | ||||
| extern int i_ishidden (); | ||||
| extern int j_ishidden (); | ||||
							
								
								
									
										1407
									
								
								util/mkisofs/mkisofs.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1407
									
								
								util/mkisofs/mkisofs.c
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										513
									
								
								util/mkisofs/mkisofs.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										513
									
								
								util/mkisofs/mkisofs.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,513 @@ | |||
| /*
 | ||||
|  * Header file mkisofs.h - assorted structure definitions and typecasts. | ||||
| 
 | ||||
|    Written by Eric Youngdale (1993). | ||||
| 
 | ||||
|    Copyright 1993 Yggdrasil Computing, Incorporated | ||||
| 
 | ||||
|    Copyright (C) 2009  Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program 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 this program; if not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| /*
 | ||||
|  * 	$Id: mkisofs.h,v 1.20 1999/03/02 04:16:41 eric Exp $ | ||||
|  */ | ||||
| 
 | ||||
| #include <stdio.h> | ||||
| #include <stdint.h> | ||||
| #include <prototyp.h> | ||||
| #include <sys/stat.h> | ||||
| 
 | ||||
| #include <locale.h> | ||||
| #include <libintl.h> | ||||
| #define _(str) gettext(str) | ||||
| 
 | ||||
| /* This symbol is used to indicate that we do not have things like
 | ||||
|    symlinks, devices, and so forth available.  Just files and dirs */ | ||||
| 
 | ||||
| #ifdef VMS | ||||
| #define NON_UNIXFS | ||||
| #endif | ||||
| 
 | ||||
| #ifdef DJGPP | ||||
| #define NON_UNIXFS | ||||
| #endif | ||||
| 
 | ||||
| #ifdef VMS | ||||
| #include <sys/dir.h> | ||||
| #define dirent direct | ||||
| #endif | ||||
| 
 | ||||
| #ifdef _WIN32 | ||||
| #define NON_UNIXFS | ||||
| #endif /* _WIN32 */ | ||||
| 
 | ||||
| #ifndef S_IROTH | ||||
| #define S_IROTH 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef S_IRGRP | ||||
| #define S_IRGRP 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef HAVE_GETUID | ||||
| static inline int | ||||
| getuid () | ||||
| { | ||||
|   return 0; | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #ifndef HAVE_GETGID | ||||
| static inline int | ||||
| getgid () | ||||
| { | ||||
|   return 0; | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #ifndef HAVE_LSTAT | ||||
| static inline int | ||||
| lstat (const char *filename, struct stat *buf) | ||||
| { | ||||
|   return stat (filename, buf); | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #include <string.h> | ||||
| #include <sys/types.h> | ||||
| #include <sys/stat.h> | ||||
| 
 | ||||
| #if defined(HAVE_DIRENT_H) | ||||
| # include <dirent.h> | ||||
| # define NAMLEN(dirent) strlen((dirent)->d_name) | ||||
| #else | ||||
| # define dirent direct | ||||
| # define NAMLEN(dirent) (dirent)->d_namlen | ||||
| # if defined(HAVE_SYS_NDIR_H) | ||||
| #  include <sys/ndir.h> | ||||
| # endif | ||||
| # if defined(HAVE_SYS_DIR_H) | ||||
| #  include <sys/dir.h> | ||||
| # endif | ||||
| # if defined(HAVE_NDIR_H) | ||||
| #  include <ndir.h> | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| #if defined(HAVE_STRING_H) | ||||
| #include <string.h> | ||||
| #else | ||||
| #if defined(HAVE_STRINGS_H) | ||||
| #include <strings.h> | ||||
| #endif | ||||
| #endif | ||||
| 
 | ||||
| #ifdef ultrix | ||||
| extern char *strdup(); | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __STDC__ | ||||
| #define DECL(NAME,ARGS) NAME ARGS | ||||
| #define FDECL1(NAME,TYPE0, ARG0) \ | ||||
| 	NAME(TYPE0 ARG0) | ||||
| #define FDECL2(NAME,TYPE0, ARG0,TYPE1, ARG1) \ | ||||
| 	NAME(TYPE0 ARG0, TYPE1 ARG1) | ||||
| #define FDECL3(NAME,TYPE0, ARG0,TYPE1, ARG1, TYPE2, ARG2) \ | ||||
| 	NAME(TYPE0 ARG0, TYPE1 ARG1, TYPE2 ARG2) | ||||
| #define FDECL4(NAME,TYPE0, ARG0,TYPE1, ARG1, TYPE2, ARG2, TYPE3, ARG3) \ | ||||
| 	NAME(TYPE0 ARG0, TYPE1 ARG1, TYPE2 ARG2, TYPE3 ARG3) | ||||
| #define FDECL5(NAME,TYPE0, ARG0,TYPE1, ARG1, TYPE2, ARG2, TYPE3, ARG3, TYPE4, ARG4) \ | ||||
| 	NAME(TYPE0 ARG0, TYPE1 ARG1, TYPE2 ARG2, TYPE3 ARG3, TYPE4 ARG4) | ||||
| #define FDECL6(NAME,TYPE0, ARG0,TYPE1, ARG1, TYPE2, ARG2, TYPE3, ARG3, TYPE4, ARG4, TYPE5, ARG5) \ | ||||
| 	NAME(TYPE0 ARG0, TYPE1 ARG1, TYPE2 ARG2, TYPE3 ARG3, TYPE4 ARG4, TYPE5 ARG5) | ||||
| #else | ||||
| #define DECL(NAME,ARGS) NAME() | ||||
| #define FDECL1(NAME,TYPE0, ARG0) NAME(ARG0) TYPE0 ARG0; | ||||
| #define FDECL2(NAME,TYPE0, ARG0,TYPE1, ARG1) NAME(ARG0, ARG1) TYPE0 ARG0; TYPE1 ARG1; | ||||
| #define FDECL3(NAME,TYPE0, ARG0,TYPE1, ARG1, TYPE2, ARG2) \ | ||||
| 	NAME(ARG0, ARG1, ARG2) TYPE0 ARG0; TYPE1 ARG1; TYPE2 ARG2; | ||||
| #define FDECL4(NAME,TYPE0, ARG0,TYPE1, ARG1, TYPE2, ARG2, TYPE3, ARG3) \ | ||||
| 	NAME(ARG0, ARG1, ARG2, ARG3, ARG4) TYPE0 ARG0; TYPE1 ARG1; TYPE2 ARG2; TYPE3 ARG3; | ||||
| #define FDECL5(NAME,TYPE0, ARG0,TYPE1, ARG1, TYPE2, ARG2, TYPE3, ARG3, TYPE4, ARG4) \ | ||||
| 	NAME(ARG0, ARG1, ARG2, ARG3, ARG4) TYPE0 ARG0; TYPE1 ARG1; TYPE2 ARG2; TYPE3 ARG3; TYPE4 ARG4; | ||||
| #define FDECL6(NAME,TYPE0, ARG0,TYPE1, ARG1, TYPE2, ARG2, TYPE3, ARG3, TYPE4, ARG4, TYPE5, ARG5) \ | ||||
| 	NAME(ARG0, ARG1, ARG2, ARG3, ARG4, ARG5) TYPE0 ARG0; TYPE1 ARG1; TYPE2 ARG2; TYPE3 ARG3; TYPE4 ARG4; TYPE5 ARG5; | ||||
| #define const | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| #ifdef __SVR4 | ||||
| #include <stdlib.h> | ||||
| #else | ||||
| extern int optind; | ||||
| extern char *optarg; | ||||
| /* extern int getopt (int __argc, char **__argv, char *__optstring); */ | ||||
| #endif | ||||
| 
 | ||||
| #include "iso9660.h" | ||||
| #include "defaults.h" | ||||
| 
 | ||||
| struct directory_entry{ | ||||
|   struct directory_entry * next; | ||||
|   struct directory_entry * jnext; | ||||
|   struct iso_directory_record isorec; | ||||
|   uint64_t starting_block; | ||||
|   uint64_t size; | ||||
|   unsigned short priority; | ||||
|   unsigned char jreclen;	/* Joliet record len */ | ||||
|   char * name; | ||||
|   char * table; | ||||
|   char * whole_name; | ||||
|   struct directory * filedir; | ||||
|   struct directory_entry * parent_rec; | ||||
|   unsigned int de_flags; | ||||
|   ino_t inode;  /* Used in the hash table */ | ||||
|   dev_t dev;  /* Used in the hash table */ | ||||
|   unsigned char * rr_attributes; | ||||
|   unsigned int rr_attr_size; | ||||
|   unsigned int total_rr_attr_size; | ||||
|   unsigned int got_rr_name; | ||||
| }; | ||||
| 
 | ||||
| struct file_hash{ | ||||
|   struct file_hash * next; | ||||
|   ino_t inode;  /* Used in the hash table */ | ||||
|   dev_t dev;  /* Used in the hash table */ | ||||
|   unsigned int starting_block; | ||||
|   unsigned int size; | ||||
| }; | ||||
|    | ||||
| 
 | ||||
| /*
 | ||||
|  * This structure is used to control the output of fragments to the cdrom | ||||
|  * image.  Everything that will be written to the output image will eventually | ||||
|  * go through this structure.   There are two pieces - first is the sizing where | ||||
|  * we establish extent numbers for everything, and the second is when we actually | ||||
|  * generate the contents and write it to the output image. | ||||
|  * | ||||
|  * This makes it trivial to extend mkisofs to write special things in the image. | ||||
|  * All you need to do is hook an additional structure in the list, and the rest | ||||
|  * works like magic. | ||||
|  * | ||||
|  * The three passes each do the following: | ||||
|  * | ||||
|  * The 'size' pass determines the size of each component and assigns the extent number | ||||
|  * for that component. | ||||
|  * | ||||
|  * The 'generate' pass will adjust the contents and pointers as required now that extent | ||||
|  * numbers are assigned.   In some cases, the contents of the record are also generated. | ||||
|  * | ||||
|  * The 'write' pass actually writes the data to the disc. | ||||
|  */ | ||||
| struct	output_fragment | ||||
| { | ||||
|   struct output_fragment * of_next; | ||||
| #ifdef __STDC__ | ||||
|   int                      (*of_size)(int); | ||||
|   int	                   (*of_generate)(void); | ||||
|   int	                   (*of_write)(FILE *); | ||||
| #else | ||||
|   int                      (*of_size)(); | ||||
|   int	                   (*of_generate)(); | ||||
|   int	                   (*of_write)(); | ||||
| #endif | ||||
| }; | ||||
| 
 | ||||
| extern struct output_fragment * out_list; | ||||
| extern struct output_fragment * out_tail; | ||||
| 
 | ||||
| extern struct output_fragment padblock_desc; | ||||
| extern struct output_fragment voldesc_desc; | ||||
| extern struct output_fragment joliet_desc; | ||||
| extern struct output_fragment torito_desc; | ||||
| extern struct output_fragment end_vol; | ||||
| extern struct output_fragment pathtable_desc; | ||||
| extern struct output_fragment jpathtable_desc; | ||||
| extern struct output_fragment dirtree_desc; | ||||
| extern struct output_fragment dirtree_clean; | ||||
| extern struct output_fragment jdirtree_desc; | ||||
| extern struct output_fragment extension_desc; | ||||
| extern struct output_fragment files_desc; | ||||
| 
 | ||||
| /* 
 | ||||
|  * This structure describes one complete directory.  It has pointers | ||||
|  * to other directories in the overall tree so that it is clear where | ||||
|  * this directory lives in the tree, and it also must contain pointers | ||||
|  * to the contents of the directory.  Note that subdirectories of this | ||||
|  * directory exist twice in this stucture.  Once in the subdir chain, | ||||
|  * and again in the contents chain. | ||||
|  */ | ||||
| struct directory{ | ||||
|   struct directory * next;  /* Next directory at same level as this one */ | ||||
|   struct directory * subdir; /* First subdirectory in this directory */ | ||||
|   struct directory * parent; | ||||
|   struct directory_entry * contents; | ||||
|   struct directory_entry * jcontents; | ||||
|   struct directory_entry * self; | ||||
|   char * whole_name;  /* Entire path */ | ||||
|   char * de_name;  /* Entire path */ | ||||
|   unsigned int ce_bytes;  /* Number of bytes of CE entries reqd for this dir */ | ||||
|   unsigned int depth; | ||||
|   unsigned int size; | ||||
|   unsigned int extent; | ||||
|   unsigned int jsize; | ||||
|   unsigned int jextent; | ||||
|   unsigned short path_index; | ||||
|   unsigned short jpath_index; | ||||
|   unsigned short dir_flags; | ||||
|   unsigned short dir_nlink; | ||||
| }; | ||||
| 
 | ||||
| extern int goof; | ||||
| extern struct directory * root; | ||||
| extern struct directory * reloc_dir; | ||||
| extern uint64_t next_extent; | ||||
| extern uint64_t last_extent; | ||||
| extern uint64_t last_extent_written; | ||||
| extern uint64_t session_start; | ||||
| 
 | ||||
| extern unsigned int path_table_size; | ||||
| extern unsigned int path_table[4]; | ||||
| extern unsigned int path_blocks; | ||||
| extern char * path_table_l; | ||||
| extern char * path_table_m; | ||||
| 
 | ||||
| extern unsigned int jpath_table_size; | ||||
| extern unsigned int jpath_table[4]; | ||||
| extern unsigned int jpath_blocks; | ||||
| extern char * jpath_table_l; | ||||
| extern char * jpath_table_m; | ||||
| 
 | ||||
| extern struct iso_directory_record root_record; | ||||
| extern struct iso_directory_record jroot_record; | ||||
| 
 | ||||
| extern int use_eltorito; | ||||
| extern int use_eltorito_emul_floppy; | ||||
| extern int use_boot_info_table; | ||||
| extern int use_RockRidge; | ||||
| extern int use_Joliet; | ||||
| extern int rationalize; | ||||
| extern int follow_links; | ||||
| extern int verbose; | ||||
| extern int all_files; | ||||
| extern int generate_tables; | ||||
| extern int print_size; | ||||
| extern int split_output; | ||||
| extern int omit_period; | ||||
| extern int omit_version_number; | ||||
| extern int transparent_compression; | ||||
| extern unsigned int RR_relocation_depth; | ||||
| extern int full_iso9660_filenames; | ||||
| extern int split_SL_component; | ||||
| extern int split_SL_field; | ||||
| 
 | ||||
| /* tree.c */ | ||||
| extern int DECL(stat_filter, (char *, struct stat *)); | ||||
| extern int DECL(lstat_filter, (char *, struct stat *)); | ||||
| extern int DECL(sort_tree,(struct directory *)); | ||||
| extern struct directory * | ||||
|            DECL(find_or_create_directory,(struct directory *, const char *, | ||||
| 					  struct directory_entry * self, int)); | ||||
| extern void DECL (finish_cl_pl_entries, (void)); | ||||
| extern int DECL(scan_directory_tree,(struct directory * this_dir, | ||||
| 				     char * path,  | ||||
| 				     struct directory_entry * self)); | ||||
| extern int DECL(insert_file_entry,(struct directory *, char *,  | ||||
| 				   char *)); | ||||
| 
 | ||||
| extern void DECL(generate_iso9660_directories,(struct directory *, FILE*)); | ||||
| extern void DECL(dump_tree,(struct directory * node)); | ||||
| extern struct directory_entry * DECL(search_tree_file, (struct  | ||||
| 				directory * node,char * filename)); | ||||
| extern void DECL(update_nlink_field,(struct directory * node)); | ||||
| extern void DECL (init_fstatbuf, (void)); | ||||
| extern struct stat root_statbuf; | ||||
| 
 | ||||
| /* eltorito.c */ | ||||
| extern void DECL(init_boot_catalog, (const char * path )); | ||||
| extern void DECL(get_torito_desc, (struct eltorito_boot_descriptor * path )); | ||||
| 
 | ||||
| /* write.c */ | ||||
| extern int DECL(get_731,(char *)); | ||||
| extern int DECL(get_733,(char *)); | ||||
| extern int DECL(isonum_733,(unsigned char *)); | ||||
| extern void DECL(set_723,(char *, unsigned int)); | ||||
| extern void DECL(set_731,(char *, unsigned int)); | ||||
| extern void DECL(set_721,(char *, unsigned int)); | ||||
| extern void DECL(set_733,(char *, unsigned int)); | ||||
| extern int  DECL(sort_directory,(struct directory_entry **)); | ||||
| extern void DECL(generate_one_directory,(struct directory *, FILE*)); | ||||
| extern void DECL(memcpy_max, (char *, char *, int)); | ||||
| extern int DECL(oneblock_size, (int starting_extent)); | ||||
| extern struct iso_primary_descriptor vol_desc; | ||||
| extern void DECL(xfwrite, (void * buffer, uint64_t count, uint64_t size, FILE * file)); | ||||
| extern void DECL(set_732, (char * pnt, unsigned int i)); | ||||
| extern void DECL(set_722, (char * pnt, unsigned int i)); | ||||
| extern void DECL(outputlist_insert, (struct output_fragment * frag)); | ||||
| 
 | ||||
| /*
 | ||||
|  * Set by user command-line to override default date values | ||||
|  */ | ||||
| 
 | ||||
| extern char *creation_date; | ||||
| extern char *modification_date; | ||||
| extern char *expiration_date; | ||||
| extern char *effective_date; | ||||
| 
 | ||||
| /* multi.c */ | ||||
| 
 | ||||
| extern FILE * in_image; | ||||
| extern struct iso_directory_record * | ||||
| 	DECL(merge_isofs,(char * path));  | ||||
| 
 | ||||
| extern int DECL(free_mdinfo, (struct directory_entry **, int len)); | ||||
| 
 | ||||
| extern struct directory_entry **  | ||||
| 	DECL(read_merging_directory,(struct iso_directory_record *, int*)); | ||||
| extern void  | ||||
| 	DECL(merge_remaining_entries, (struct directory *,  | ||||
| 				       struct directory_entry **, int)); | ||||
| extern int  | ||||
| 	DECL(merge_previous_session, (struct directory *,  | ||||
| 				      struct iso_directory_record *)); | ||||
| 
 | ||||
| extern int  DECL(get_session_start, (int *)); | ||||
| 
 | ||||
| /* joliet.c */ | ||||
| int DECL(joliet_sort_tree, (struct directory * node)); | ||||
| 
 | ||||
| /* match.c */ | ||||
| extern int DECL(matches, (char *)); | ||||
| extern void DECL(add_match, (char *)); | ||||
| 
 | ||||
| /* files.c */ | ||||
| struct dirent * DECL(readdir_add_files, (char **, char *, DIR *)); | ||||
| 
 | ||||
| /* */ | ||||
| 
 | ||||
| extern int DECL(iso9660_file_length,(const char* name,  | ||||
| 			       struct directory_entry * sresult, int flag)); | ||||
| extern int DECL(iso9660_date,(char *, time_t)); | ||||
| extern void DECL(add_hash,(struct directory_entry *)); | ||||
| extern struct file_hash * DECL(find_hash,(dev_t, ino_t)); | ||||
| extern void DECL(add_directory_hash,(dev_t, ino_t)); | ||||
| extern struct file_hash * DECL(find_directory_hash,(dev_t, ino_t)); | ||||
| extern void DECL (flush_file_hash, (void)); | ||||
| extern int DECL(delete_file_hash,(struct directory_entry *)); | ||||
| extern struct directory_entry * DECL(find_file_hash,(char *)); | ||||
| extern void DECL(add_file_hash,(struct directory_entry *)); | ||||
| extern int DECL(generate_rock_ridge_attributes,(char *, char *, | ||||
| 					  struct directory_entry *,  | ||||
| 					  struct stat *, struct stat *, | ||||
| 					  int  deep_flag)); | ||||
| extern char * DECL(generate_rr_extension_record,(char * id,  char  * descriptor, | ||||
| 				    char * source, int  * size)); | ||||
| 
 | ||||
| extern int    DECL(check_prev_session, (struct directory_entry **, int len, | ||||
| 				     struct directory_entry *, | ||||
| 				     struct stat *, | ||||
| 				     struct stat *, | ||||
| 				     struct directory_entry **)); | ||||
| 
 | ||||
| #ifdef	USE_SCG | ||||
| /* scsi.c */ | ||||
| #ifdef __STDC__ | ||||
| extern	int	readsecs(int startsecno, void *buffer, int sectorcount); | ||||
| extern	int	scsidev_open(char *path); | ||||
| #else | ||||
| extern	int	readsecs(); | ||||
| extern	int	scsidev_open(); | ||||
| #endif | ||||
| #endif | ||||
| 
 | ||||
| extern char * extension_record; | ||||
| extern int extension_record_extent; | ||||
| extern int n_data_extents; | ||||
| 
 | ||||
| /* These are a few goodies that can be specified on the command line, and  are
 | ||||
|    filled into the root record */ | ||||
| 
 | ||||
| extern char * preparer; | ||||
| extern char * publisher; | ||||
| extern char * copyright; | ||||
| extern char * biblio; | ||||
| extern char * abstract; | ||||
| extern char * appid; | ||||
| extern char * volset_id; | ||||
| extern char * system_id; | ||||
| extern char * volume_id; | ||||
| extern char * boot_catalog; | ||||
| extern char * boot_image; | ||||
| extern int volume_set_size; | ||||
| extern int volume_sequence_number; | ||||
| 
 | ||||
| extern void * DECL(e_malloc,(size_t)); | ||||
| 
 | ||||
| 
 | ||||
| #define SECTOR_SIZE (2048) | ||||
| #define ROUND_UP(X)    ((X + (SECTOR_SIZE - 1)) & ~(SECTOR_SIZE - 1)) | ||||
| 
 | ||||
| #define NEED_RE 1 | ||||
| #define NEED_PL  2 | ||||
| #define NEED_CL 4 | ||||
| #define NEED_CE 8 | ||||
| #define NEED_SP 16 | ||||
| 
 | ||||
| #define PREV_SESS_DEV (sizeof(dev_t) >= 4 ? 0x7ffffffd : 0x7ffd) | ||||
| #define TABLE_INODE (sizeof(ino_t) >= 4 ? 0x7ffffffe : 0x7ffe) | ||||
| #define UNCACHED_INODE (sizeof(ino_t) >= 4 ? 0x7fffffff : 0x7fff) | ||||
| #define UNCACHED_DEVICE (sizeof(dev_t) >= 4 ? 0x7fffffff : 0x7fff) | ||||
| 
 | ||||
| #ifdef VMS | ||||
| #define STAT_INODE(X) (X.st_ino[0]) | ||||
| #define PATH_SEPARATOR ']' | ||||
| #define SPATH_SEPARATOR "" | ||||
| #else | ||||
| #define STAT_INODE(X) (X.st_ino) | ||||
| #define PATH_SEPARATOR '/' | ||||
| #define SPATH_SEPARATOR "/" | ||||
| #endif | ||||
| 
 | ||||
| /*
 | ||||
|  * When using multi-session, indicates that we can reuse the | ||||
|  * TRANS.TBL information for this directory entry.  If this flag | ||||
|  * is set for all entries in a directory, it means we can just | ||||
|  * reuse the TRANS.TBL and not generate a new one. | ||||
|  */ | ||||
| #define SAFE_TO_REUSE_TABLE_ENTRY  0x01 | ||||
| #define DIR_HAS_DOT		   0x02 | ||||
| #define DIR_HAS_DOTDOT		   0x04 | ||||
| #define INHIBIT_JOLIET_ENTRY	   0x08 | ||||
| #define INHIBIT_RR_ENTRY	   0x10 | ||||
| #define RELOCATED_DIRECTORY	   0x20 | ||||
| #define INHIBIT_ISO9660_ENTRY	   0x40 | ||||
| 
 | ||||
| /*
 | ||||
|  * Volume sequence number to use in all of the iso directory records. | ||||
|  */ | ||||
| #define DEF_VSN		1 | ||||
| 
 | ||||
| /*
 | ||||
|  * Make sure we have a definition for this.  If not, take a very conservative | ||||
|  * guess.  From what I can tell SunOS is the only one with this trouble. | ||||
|  */ | ||||
| #ifndef NAME_MAX | ||||
| #ifdef FILENAME_MAX | ||||
| #define NAME_MAX	FILENAME_MAX | ||||
| #else | ||||
| #define NAME_MAX	128 | ||||
| #endif | ||||
| #endif | ||||
							
								
								
									
										1201
									
								
								util/mkisofs/multi.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1201
									
								
								util/mkisofs/multi.c
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										394
									
								
								util/mkisofs/name.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										394
									
								
								util/mkisofs/name.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,394 @@ | |||
| /*
 | ||||
|  * File name.c - map full Unix file names to unique 8.3 names that | ||||
|  * would be valid on DOS. | ||||
|  * | ||||
| 
 | ||||
|    Written by Eric Youngdale (1993). | ||||
| 
 | ||||
|    Copyright 1993 Yggdrasil Computing, Incorporated | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 2, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program 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 this program; if not, write to the Free Software | ||||
|    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */ | ||||
| 
 | ||||
| #include "config.h" | ||||
| #include "mkisofs.h" | ||||
| 
 | ||||
| #include <ctype.h> | ||||
| 
 | ||||
| extern int allow_leading_dots; | ||||
|     | ||||
| /*
 | ||||
|  * Function:	iso9660_file_length | ||||
|  * | ||||
|  * Purpose:	Map file name to 8.3 format, return length | ||||
|  *		of result. | ||||
|  * | ||||
|  * Arguments:	name	file name we need to map. | ||||
|  *		sresult	directory entry structure to contain mapped name. | ||||
|  *		dirflag	flag indicating whether this is a directory or not. | ||||
|  * | ||||
|  * Notes:	This procedure probably needs to be rationalized somehow. | ||||
|  *		New options to affect the behavior of this function | ||||
|  *		would also be nice to have. | ||||
|  */ | ||||
| int FDECL3(iso9660_file_length, | ||||
| 	   const char*, name,  | ||||
| 	   struct directory_entry *, sresult,  | ||||
| 	   int, dirflag) | ||||
| { | ||||
|   char		* c; | ||||
|   int		  chars_after_dot  = 0; | ||||
|   int		  chars_before_dot = 0; | ||||
|   int		  current_length   = 0; | ||||
|   int		  extra		   = 0; | ||||
|   int		  ignore	   = 0; | ||||
|   char		* last_dot; | ||||
|   const char	* pnt; | ||||
|   int		  priority	   = 32767; | ||||
|   char		* result; | ||||
|   int		  seen_dot	   = 0; | ||||
|   int		  seen_semic	   = 0; | ||||
|   int		  tildes	   = 0; | ||||
| 
 | ||||
|   result = sresult->isorec.name; | ||||
| 
 | ||||
|   /*
 | ||||
|    * For the '.' entry, generate the correct record, and return | ||||
|    * 1 for the length. | ||||
|    */ | ||||
|   if(strcmp(name,".") == 0) | ||||
|     { | ||||
|       if(result)  | ||||
| 	{ | ||||
| 	  *result = 0; | ||||
| 	} | ||||
|       return 1; | ||||
|     } | ||||
| 
 | ||||
|   /*
 | ||||
|    * For the '..' entry, generate the correct record, and return | ||||
|    * 1 for the length. | ||||
|    */ | ||||
|   if(strcmp(name,"..") == 0) | ||||
|     { | ||||
|       if(result)  | ||||
| 	{ | ||||
| 	  *result++ = 1; | ||||
| 	  *result++ = 0; | ||||
| 	} | ||||
|       return 1; | ||||
|     } | ||||
| 
 | ||||
|   /*
 | ||||
|    * Now scan the directory one character at a time, and figure out | ||||
|    * what to do. | ||||
|    */ | ||||
|   pnt = name; | ||||
| 
 | ||||
|   /*
 | ||||
|    * Find the '.' that we intend to use for the extension.  Usually this | ||||
|    * is the last dot, but if we have . followed by nothing or a ~, we | ||||
|    * would consider this to be unsatisfactory, and we keep searching. | ||||
|    */ | ||||
|   last_dot = strrchr (pnt,'.'); | ||||
|   if(    (last_dot != NULL) | ||||
|       && (    (last_dot[1] == '~') | ||||
|  	   || (last_dot[1] == '\0')) ) | ||||
|     { | ||||
|       c = last_dot; | ||||
|       *c = '\0'; | ||||
|       last_dot = strrchr (pnt,'.'); | ||||
|       *c = '.'; | ||||
|     } | ||||
| 
 | ||||
|   while(*pnt) | ||||
|     { | ||||
| #ifdef VMS | ||||
|       if( strcmp(pnt,".DIR;1") == 0 )  | ||||
| 	{ | ||||
| 	  break; | ||||
| 	} | ||||
| #endif | ||||
| 
 | ||||
|       /*
 | ||||
|        * This character indicates a Unix style of backup file | ||||
|        * generated by some editors.  Lower the priority of | ||||
|        * the file. | ||||
|        */ | ||||
|       if(*pnt == '#')  | ||||
| 	{ | ||||
| 	  priority = 1;  | ||||
| 	  pnt++;  | ||||
| 	  continue;  | ||||
| 	} | ||||
| 
 | ||||
|       /*
 | ||||
|        * This character indicates a Unix style of backup file | ||||
|        * generated by some editors.  Lower the priority of | ||||
|        * the file. | ||||
|        */ | ||||
|       if(*pnt == '~')  | ||||
| 	{ | ||||
| 	  priority = 1;  | ||||
| 	  tildes++;  | ||||
| 	  pnt++;  | ||||
| 	  continue; | ||||
| 	} | ||||
| 
 | ||||
|       /*
 | ||||
|        * This might come up if we had some joker already try and put | ||||
|        * iso9660 version numbers into the file names.  This would be | ||||
|        * a silly thing to do on a Unix box, but we check for it | ||||
|        * anyways.  If we see this, then we don't have to add our | ||||
|        * own version number at the end. | ||||
|        * UNLESS the ';' is part of the filename and no version | ||||
|        * number is following. [VK] | ||||
|        */ | ||||
|        if(*pnt == ';') | ||||
| 	 { | ||||
| 	   /* [VK] */ | ||||
| 	   if (pnt[1] != '\0' && (pnt[1] < '0' || pnt[1] > '9')) | ||||
| 	     { | ||||
| 	       pnt++; | ||||
| 	       ignore++; | ||||
| 	       continue; | ||||
| 	     } | ||||
| 	 } | ||||
| 
 | ||||
|       /*
 | ||||
|        * If we have a name with multiple '.' characters, we ignore everything | ||||
|        * after we have gotten the extension. | ||||
|        */ | ||||
|       if(ignore)  | ||||
| 	{ | ||||
| 	  pnt++;  | ||||
| 	  continue; | ||||
| 	} | ||||
| 
 | ||||
|       /*
 | ||||
|        * Spin past any iso9660 version number we might have. | ||||
|        */ | ||||
|       if(seen_semic) | ||||
| 	{ | ||||
| 	  if(*pnt >= '0' && *pnt <= '9')  | ||||
| 	    { | ||||
| 	      *result++ = *pnt; | ||||
| 	    } | ||||
| 	  extra++; | ||||
| 	  pnt++; | ||||
| 	  continue; | ||||
| 	} | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * If we have full names, the names we generate will not | ||||
| 	 * work on a DOS machine, since they are not guaranteed | ||||
| 	 * to be 8.3.  Nonetheless, in many cases this is a useful | ||||
| 	 * option.  We still only allow one '.' character in the | ||||
| 	 * name, however. | ||||
| 	 */ | ||||
|       if(full_iso9660_filenames)  | ||||
| 	{ | ||||
| 	  /* Here we allow a more relaxed syntax. */ | ||||
| 	  if(*pnt == '.')  | ||||
| 	    { | ||||
| 	      if (seen_dot)  | ||||
| 		{ | ||||
| 		  ignore++;  | ||||
| 		  continue; | ||||
| 		} | ||||
| 	      seen_dot++; | ||||
| 	    } | ||||
| 	  if(current_length < 30)  | ||||
| 	    { | ||||
| 	      if( !isascii (*pnt)) | ||||
| 		{ | ||||
| 		  *result++ = '_'; | ||||
| 		} | ||||
| 	      else | ||||
| 		{ | ||||
| 		  *result++ = (islower((unsigned char)*pnt) ? toupper((unsigned char)*pnt) : *pnt); | ||||
| 		} | ||||
| 	    } | ||||
| 	} | ||||
|       else | ||||
| 	{  | ||||
| 	  /* 
 | ||||
| 	   * Dos style filenames.  We really restrict the | ||||
| 	   * names here. | ||||
| 	   */ | ||||
| 	  /* It would be nice to have .tar.gz transform to .tgz,
 | ||||
| 	   * .ps.gz to .psz, ... | ||||
| 	   */ | ||||
| 	  if(*pnt == '.')  | ||||
| 	    { | ||||
| 	      if (!chars_before_dot && !allow_leading_dots)  | ||||
| 		{ | ||||
| 		  /* DOS can't read files with dot first */ | ||||
| 		  chars_before_dot++; | ||||
| 		  if (result)  | ||||
| 		    { | ||||
| 		      *result++ = '_'; /* Substitute underscore */ | ||||
| 		    } | ||||
| 		} | ||||
| 	      else if( pnt != last_dot ) | ||||
| 		{ | ||||
| 		  /*
 | ||||
| 		   * If this isn't the dot that we use for the extension, | ||||
| 		   * then change the character into a '_' instead. | ||||
| 		   */ | ||||
| 		  if(chars_before_dot < 8)  | ||||
| 		    { | ||||
| 		      chars_before_dot++; | ||||
| 		      if(result)  | ||||
| 			{ | ||||
| 			  *result++ = '_'; | ||||
| 			} | ||||
| 		    } | ||||
| 		} | ||||
| 	      else  | ||||
| 		{ | ||||
| 		  if (seen_dot)  | ||||
| 		    { | ||||
| 		      ignore++; continue; | ||||
| 		    } | ||||
| 		  if(result)  | ||||
| 		    { | ||||
| 		      *result++ = '.'; | ||||
| 		    } | ||||
| 		  seen_dot++; | ||||
| 		} | ||||
| 	    } | ||||
| 	  else  | ||||
| 	    { | ||||
| 	      if(    (seen_dot && (chars_after_dot < 3) && ++chars_after_dot) | ||||
| 		     || (!seen_dot && (chars_before_dot < 8) && ++chars_before_dot) ) | ||||
| 		{ | ||||
| 		  if(result)  | ||||
| 		    { | ||||
| 		      switch (*pnt)  | ||||
| 			{ | ||||
| 			default: | ||||
| 			  if( !isascii (*pnt) ) | ||||
| 			    { | ||||
| 			      *result++ = '_'; | ||||
| 			    } | ||||
| 			  else | ||||
| 			    { | ||||
| 			      *result++ = islower((unsigned char)*pnt) ? toupper((unsigned char)*pnt) : *pnt; | ||||
| 			    } | ||||
| 			  break; | ||||
| 
 | ||||
| 			/* 
 | ||||
| 			 * Descriptions of DOS's 'Parse Filename' | ||||
| 			 * (function 29H) describes V1 and V2.0+ | ||||
| 			 * separator and terminator characters. | ||||
| 			 * These characters in a DOS name make | ||||
| 			 * the file visible but un-manipulable | ||||
| 			 * (all useful operations error off. | ||||
| 			 */ | ||||
| 			/* separators */ | ||||
| 			case '+': | ||||
| 			case '=': | ||||
| 			case '%': /* not legal DOS filename */ | ||||
| 			case ':': | ||||
| 			case ';': /* already handled */ | ||||
| 			case '.': /* already handled */ | ||||
| 			case ',': /* already handled */ | ||||
| 			case '\t': | ||||
| 			case ' ': | ||||
| 			  /* V1 only separators */ | ||||
| 			case '/': | ||||
| 			case '"': | ||||
| 			case '[': | ||||
| 			case ']': | ||||
| 			  /* terminators */ | ||||
| 			case '>': | ||||
| 			case '<': | ||||
| 			case '|': | ||||
| 			  /* Hmm - what to do here?  Skip?
 | ||||
| 			   * Win95 looks like it substitutes '_' | ||||
| 			   */ | ||||
| 			  *result++ = '_'; | ||||
| 			  break; | ||||
| 			} /* switch (*pnt) */ | ||||
| 		    } /* if (result) */ | ||||
| 		} /* if (chars_{after,before}_dot) ... */ | ||||
| 	    } /* else *pnt == '.' */ | ||||
| 	} /* else DOS file names */ | ||||
|       current_length++; | ||||
|       pnt++; | ||||
|     } /* while (*pnt) */ | ||||
|    | ||||
|   /*
 | ||||
|    * OK, that wraps up the scan of the name.  Now tidy up a few other | ||||
|    * things. | ||||
|    */ | ||||
| 
 | ||||
|   /*
 | ||||
|    * Look for emacs style of numbered backups, like foo.c.~3~.  If | ||||
|    * we see this, convert the version number into the priority | ||||
|    * number.  In case of name conflicts, this is what would end | ||||
|    * up being used as the 'extension'. | ||||
|    */ | ||||
|   if(tildes == 2) | ||||
|     { | ||||
|       int prio1 = 0; | ||||
|       pnt = name; | ||||
|       while (*pnt && *pnt != '~')  | ||||
| 	{ | ||||
| 	  pnt++; | ||||
| 	} | ||||
|       if (*pnt)  | ||||
| 	{ | ||||
| 	  pnt++; | ||||
| 	} | ||||
|       while(*pnt && *pnt != '~') | ||||
| 	{ | ||||
| 	  prio1 = 10*prio1 + *pnt - '0'; | ||||
| 	  pnt++; | ||||
| 	} | ||||
|       priority = prio1; | ||||
|     } | ||||
|    | ||||
|   /*
 | ||||
|    * If this is not a directory, force a '.' in case we haven't | ||||
|    * seen one, and add a version number if we haven't seen one | ||||
|    * of those either. | ||||
|    */ | ||||
|   if (!dirflag) | ||||
|     { | ||||
|       if (!seen_dot && !omit_period)  | ||||
| 	{ | ||||
| 	  if (result) *result++ = '.';  | ||||
| 	  extra++; | ||||
| 	} | ||||
|       if(!omit_version_number && !seen_semic)  | ||||
| 	{ | ||||
| 	  if(result) | ||||
| 	    { | ||||
| 	      *result++ = ';'; | ||||
| 	      *result++ = '1'; | ||||
| 	    }; | ||||
| 	  extra += 2; | ||||
| 	} | ||||
|     } | ||||
| 		     | ||||
|   if(result)  | ||||
|     { | ||||
|       *result++ = 0; | ||||
|     } | ||||
|   sresult->priority = priority; | ||||
| 
 | ||||
|   return (chars_before_dot + chars_after_dot + seen_dot + extra); | ||||
| } | ||||
							
								
								
									
										597
									
								
								util/mkisofs/rock.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										597
									
								
								util/mkisofs/rock.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,597 @@ | |||
| /*
 | ||||
|  * File rock.c - generate RRIP  records for iso9660 filesystems. | ||||
| 
 | ||||
|    Written by Eric Youngdale (1993). | ||||
| 
 | ||||
|    Copyright 1993 Yggdrasil Computing, Incorporated | ||||
| 
 | ||||
|    Copyright (C) 2009  Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program 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 this program; if not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include <stdlib.h> | ||||
| 
 | ||||
| #include "config.h" | ||||
| 
 | ||||
| #ifndef VMS | ||||
| #if defined(MAJOR_IN_SYSMACROS) | ||||
| #include <sys/sysmacros.h> | ||||
| #endif | ||||
| 
 | ||||
| #ifdef HAVE_UNISTD_H | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| 
 | ||||
| #endif | ||||
| #if defined(MAJOR_IN_MKDEV) | ||||
| #include <sys/types.h> | ||||
| #include <sys/mkdev.h> | ||||
| #endif | ||||
| 
 | ||||
| #include "mkisofs.h" | ||||
| #include "iso9660.h" | ||||
| #include <string.h> | ||||
| #include <errno.h> | ||||
| 
 | ||||
| #ifdef	DOESNT_WORK | ||||
| 
 | ||||
| #ifdef NON_UNIXFS | ||||
| #define S_ISLNK(m)	(0) | ||||
| #else | ||||
| #ifndef S_ISLNK | ||||
| #define S_ISLNK(m)	(((m) & S_IFMT) == S_IFLNK) | ||||
| #endif | ||||
| #endif | ||||
| 
 | ||||
| #else | ||||
| #include <statdefs.h> | ||||
| #endif | ||||
| 
 | ||||
| #define SU_VERSION 1 | ||||
| 
 | ||||
| #define SL_ROOT    8 | ||||
| #define SL_PARENT  4 | ||||
| #define SL_CURRENT 2 | ||||
| #define SL_CONTINUE 1 | ||||
| 
 | ||||
| #define CE_SIZE 28 | ||||
| #define CL_SIZE 12 | ||||
| #define ER_SIZE 8 | ||||
| #define NM_SIZE 5 | ||||
| #define PL_SIZE 12 | ||||
| #define PN_SIZE 20 | ||||
| #define PX_SIZE 36 | ||||
| #define RE_SIZE 4 | ||||
| #define SL_SIZE 20 | ||||
| #define ZZ_SIZE 15 | ||||
| #ifdef __QNX__ | ||||
| #define TF_SIZE (5 + 4 * 7) | ||||
| #else | ||||
| #define TF_SIZE (5 + 3 * 7) | ||||
| #endif | ||||
| 
 | ||||
| /* If we need to store this number of bytes, make sure we
 | ||||
|    do not box ourselves in so that we do not have room for | ||||
|    a CE entry for the continuation record */ | ||||
| 
 | ||||
| #define MAYBE_ADD_CE_ENTRY(BYTES) \ | ||||
|     ((unsigned) ((BYTES) + CE_SIZE + currlen + ipnt) > (unsigned) (recstart + reclimit) ? 1 : 0)  | ||||
| 
 | ||||
| /*
 | ||||
|  * Buffer to build RR attributes | ||||
|  */ | ||||
| 
 | ||||
| static unsigned char Rock[16384]; | ||||
| static unsigned char symlink_buff[256]; | ||||
| static int ipnt = 0; | ||||
| static int recstart = 0; | ||||
| static int currlen = 0; | ||||
| static int mainrec = 0; | ||||
| static int reclimit; | ||||
| 
 | ||||
| static void add_CE_entry	__PR((void)); | ||||
| 
 | ||||
| static void add_CE_entry(){ | ||||
|           if(recstart) | ||||
| 	    set_733((char*)Rock + recstart - 8, ipnt + 28 - recstart); | ||||
| 	  Rock[ipnt++] ='C'; | ||||
| 	  Rock[ipnt++] ='E'; | ||||
| 	  Rock[ipnt++] = CE_SIZE; | ||||
| 	  Rock[ipnt++] = SU_VERSION; | ||||
| 	  set_733((char*)Rock + ipnt, 0); | ||||
| 	  ipnt += 8; | ||||
| 	  set_733((char*)Rock + ipnt, 0); | ||||
| 	  ipnt += 8; | ||||
| 	  set_733((char*)Rock + ipnt, 0); | ||||
| 	  ipnt += 8; | ||||
| 	  recstart = ipnt; | ||||
| 	  currlen = 0; | ||||
| 	  if(!mainrec) mainrec = ipnt; | ||||
| 	  reclimit = SECTOR_SIZE - 8; /* Limit to one sector */ | ||||
| } | ||||
| 
 | ||||
| #ifdef __STDC__ | ||||
| int generate_rock_ridge_attributes (char * whole_name, char * name, | ||||
| 				    struct directory_entry * s_entry, | ||||
| 				    struct stat * statbuf, | ||||
| 				    struct stat * lstatbuf, | ||||
| 				    int deep_opt) | ||||
| #else | ||||
| int generate_rock_ridge_attributes (whole_name, name, | ||||
| 				    s_entry, | ||||
| 				    statbuf, | ||||
| 				    lstatbuf, | ||||
| 				    deep_opt) | ||||
| char * whole_name; char * name; struct directory_entry * s_entry; | ||||
| struct stat * statbuf, *lstatbuf; | ||||
| int deep_opt; | ||||
| #endif | ||||
| { | ||||
|   int flagpos, flagval; | ||||
|   int need_ce; | ||||
| 
 | ||||
|   statbuf = statbuf;        /* this shuts up unreferenced compiler warnings */ | ||||
|   mainrec = recstart = ipnt = 0; | ||||
|   reclimit = 0xf8; | ||||
| 
 | ||||
|   /* no need to fill in the RR stuff if we won't see the file */ | ||||
|   if (s_entry->de_flags & INHIBIT_ISO9660_ENTRY) | ||||
|     return 0; | ||||
| 
 | ||||
|   /* Obtain the amount of space that is currently used for the directory
 | ||||
|      record.  Assume max for name, since name conflicts may cause us | ||||
|      to rename the file later on */ | ||||
|   currlen = sizeof(s_entry->isorec); | ||||
| 
 | ||||
|   /* Identify that we are using the SUSP protocol */ | ||||
|   if(deep_opt & NEED_SP){ | ||||
| 	  Rock[ipnt++] ='S'; | ||||
| 	  Rock[ipnt++] ='P'; | ||||
| 	  Rock[ipnt++] = 7; | ||||
| 	  Rock[ipnt++] = SU_VERSION; | ||||
| 	  Rock[ipnt++] = 0xbe; | ||||
| 	  Rock[ipnt++] = 0xef; | ||||
| 	  Rock[ipnt++] = 0; | ||||
|   }; | ||||
| 
 | ||||
|   /* First build the posix name field */ | ||||
|   Rock[ipnt++] ='R'; | ||||
|   Rock[ipnt++] ='R'; | ||||
|   Rock[ipnt++] = 5; | ||||
|   Rock[ipnt++] = SU_VERSION; | ||||
|   flagpos = ipnt; | ||||
|   flagval = 0; | ||||
|   Rock[ipnt++] = 0;   /* We go back and fix this later */ | ||||
| 
 | ||||
|   if(strcmp(name,".")  && strcmp(name,"..")){ | ||||
|     char * npnt; | ||||
|     int remain, use; | ||||
| 
 | ||||
|     remain = strlen(name); | ||||
|     npnt = name; | ||||
| 
 | ||||
|     while(remain){ | ||||
|           use = remain; | ||||
| 	  need_ce = 0; | ||||
| 	  /* Can we fit this SUSP and a CE entry? */ | ||||
| 	  if(use + currlen + CE_SIZE + (ipnt - recstart) > reclimit) { | ||||
| 	    use = reclimit - currlen - CE_SIZE - (ipnt - recstart); | ||||
| 	    need_ce++; | ||||
| 	  } | ||||
| 
 | ||||
| 	  /* Only room for 256 per SUSP field */ | ||||
| 	  if(use > 0xf8) use = 0xf8; | ||||
| 
 | ||||
| 	  /* First build the posix name field */ | ||||
| 	  Rock[ipnt++] ='N'; | ||||
| 	  Rock[ipnt++] ='M'; | ||||
| 	  Rock[ipnt++] = NM_SIZE + use; | ||||
| 	  Rock[ipnt++] = SU_VERSION; | ||||
| 	  Rock[ipnt++] = (remain != use ? 1 : 0); | ||||
| 	  flagval |= (1<<3); | ||||
| 	  strncpy((char *)&Rock[ipnt], npnt, use); | ||||
| 	  npnt += use; | ||||
| 	  ipnt += use; | ||||
| 	  remain -= use; | ||||
| 	  if(remain && need_ce) add_CE_entry(); | ||||
| 	}; | ||||
|   }; | ||||
| 
 | ||||
|   /*
 | ||||
|    * Add the posix modes  | ||||
|    */ | ||||
|   if(MAYBE_ADD_CE_ENTRY(PX_SIZE)) add_CE_entry(); | ||||
|   Rock[ipnt++] ='P'; | ||||
|   Rock[ipnt++] ='X'; | ||||
|   Rock[ipnt++] = PX_SIZE; | ||||
|   Rock[ipnt++] = SU_VERSION;   | ||||
|   flagval |= (1<<0); | ||||
|   set_733((char*)Rock + ipnt, lstatbuf->st_mode); | ||||
|   ipnt += 8; | ||||
|   set_733((char*)Rock + ipnt, lstatbuf->st_nlink); | ||||
|   ipnt += 8; | ||||
|   set_733((char*)Rock + ipnt, lstatbuf->st_uid); | ||||
|   ipnt += 8; | ||||
|   set_733((char*)Rock + ipnt, lstatbuf->st_gid); | ||||
|   ipnt += 8; | ||||
| 
 | ||||
|   /*
 | ||||
|    * Check for special devices | ||||
|    */ | ||||
| #ifndef NON_UNIXFS | ||||
|   if (S_ISCHR(lstatbuf->st_mode) || S_ISBLK(lstatbuf->st_mode)) { | ||||
|     if(MAYBE_ADD_CE_ENTRY(PN_SIZE)) add_CE_entry(); | ||||
|     Rock[ipnt++] ='P'; | ||||
|     Rock[ipnt++] ='N'; | ||||
|     Rock[ipnt++] = PN_SIZE; | ||||
|     Rock[ipnt++] = SU_VERSION;   | ||||
|     flagval |= (1<<1); | ||||
| #if defined(MAJOR_IN_SYSMACROS) || defined(MAJOR_IN_MKDEV) | ||||
|     set_733((char*)Rock + ipnt, major(lstatbuf->st_rdev )); | ||||
|     ipnt += 8; | ||||
|     set_733((char*)Rock + ipnt, minor(lstatbuf->st_rdev)); | ||||
|     ipnt += 8; | ||||
| #else | ||||
|     /*
 | ||||
|      * If we don't have sysmacros.h, then we have to guess as to how | ||||
|      * best to pick apart the device number for major/minor. | ||||
|      * Note: this may very well be wrong for many systems, so | ||||
|      * it is always best to use the major/minor macros if the | ||||
|      * system supports it. | ||||
|      */ | ||||
|     if(sizeof(dev_t) <= 2) { | ||||
|         set_733((char*)Rock + ipnt, (lstatbuf->st_rdev >> 8)); | ||||
|         ipnt += 8; | ||||
|         set_733((char*)Rock + ipnt, lstatbuf->st_rdev & 0xff); | ||||
|         ipnt += 8; | ||||
|     } | ||||
|     else if(sizeof(dev_t) <= 4) { | ||||
|         set_733((char*)Rock + ipnt, (lstatbuf->st_rdev >> 8) >> 8); | ||||
|         ipnt += 8; | ||||
|         set_733((char*)Rock + ipnt, lstatbuf->st_rdev & 0xffff); | ||||
|         ipnt += 8; | ||||
|     } | ||||
|     else { | ||||
|         set_733((char*)Rock + ipnt, (lstatbuf->st_rdev >> 16) >> 16); | ||||
|         ipnt += 8; | ||||
|         set_733((char*)Rock + ipnt, lstatbuf->st_rdev); | ||||
|         ipnt += 8; | ||||
|     } | ||||
| #endif | ||||
|   }; | ||||
| #endif | ||||
|   /*
 | ||||
|    * Check for and symbolic links.  VMS does not have these. | ||||
|    */ | ||||
|   if (S_ISLNK(lstatbuf->st_mode)){ | ||||
|     int lenpos, lenval, j0, j1; | ||||
|     int nchar; | ||||
|     unsigned char * cpnt, *cpnt1; | ||||
|     nchar = readlink(whole_name, (char *)symlink_buff, sizeof(symlink_buff)); | ||||
|     symlink_buff[nchar < 0 ? 0 : nchar] = 0; | ||||
|     nchar = strlen((char *) symlink_buff); | ||||
|     set_733(s_entry->isorec.size, 0); | ||||
|     cpnt = &symlink_buff[0]; | ||||
|     flagval |= (1<<2); | ||||
| 
 | ||||
|     if (! split_SL_field)  | ||||
|       { | ||||
| 	int sl_bytes = 0; | ||||
| 	for (cpnt1 = cpnt; *cpnt1 != '\0'; cpnt1++)  | ||||
| 	  { | ||||
| 	    if (*cpnt1 == '/')  | ||||
| 	      { | ||||
| 		sl_bytes += 4; | ||||
| 	      }  | ||||
| 	    else  | ||||
| 	      { | ||||
| 		sl_bytes += 1; | ||||
| 	      } | ||||
| 	  } | ||||
| 	if (sl_bytes > 250)  | ||||
| 	  { | ||||
| 	    /* 
 | ||||
| 	     * the symbolic link won't fit into one SL System Use Field | ||||
| 	     * print an error message and continue with splited one  | ||||
| 	     */ | ||||
| 	    fprintf(stderr, _("symbolic link ``%s'' to long for one SL System Use Field, splitting"), cpnt); | ||||
| 	  } | ||||
|        if(MAYBE_ADD_CE_ENTRY(SL_SIZE + sl_bytes)) add_CE_entry(); | ||||
|      } | ||||
| 
 | ||||
|     while(nchar){ | ||||
|       if(MAYBE_ADD_CE_ENTRY(SL_SIZE)) add_CE_entry(); | ||||
|       Rock[ipnt++] ='S'; | ||||
|       Rock[ipnt++] ='L'; | ||||
|       lenpos = ipnt; | ||||
|       Rock[ipnt++] = SL_SIZE; | ||||
|       Rock[ipnt++] = SU_VERSION;   | ||||
|       Rock[ipnt++] = 0; /* Flags */ | ||||
|       lenval = 5; | ||||
|       while(*cpnt){ | ||||
| 	cpnt1 = (unsigned char *) strchr((char *) cpnt, '/'); | ||||
| 	if(cpnt1) { | ||||
| 	  nchar--; | ||||
| 	  *cpnt1 = 0; | ||||
| 	}; | ||||
| 	 | ||||
| 	/* We treat certain components in a special way.  */ | ||||
| 	if(cpnt[0] == '.' && cpnt[1] == '.' && cpnt[2] == 0){ | ||||
| 	  if(MAYBE_ADD_CE_ENTRY(2)) add_CE_entry(); | ||||
| 	  Rock[ipnt++] = SL_PARENT; | ||||
| 	  Rock[ipnt++] = 0;  /* length is zero */ | ||||
| 	  lenval += 2; | ||||
| 	  nchar -= 2; | ||||
| 	} else if(cpnt[0] == '.' && cpnt[1] == 0){ | ||||
| 	  if(MAYBE_ADD_CE_ENTRY(2)) add_CE_entry(); | ||||
| 	  Rock[ipnt++] = SL_CURRENT; | ||||
| 	  Rock[ipnt++] = 0;  /* length is zero */ | ||||
| 	  lenval += 2; | ||||
| 	  nchar -= 1; | ||||
| 	} else if(cpnt[0] == 0){ | ||||
| 	  if(MAYBE_ADD_CE_ENTRY(2)) add_CE_entry(); | ||||
| 	  Rock[ipnt++] = SL_ROOT; | ||||
| 	  Rock[ipnt++] = 0;  /* length is zero */ | ||||
| 	  lenval += 2; | ||||
| 	} else { | ||||
| 	  /* If we do not have enough room for a component, start
 | ||||
| 	     a new continuations segment now */ | ||||
|          if(split_SL_component ? MAYBE_ADD_CE_ENTRY(6) : | ||||
|                                  MAYBE_ADD_CE_ENTRY(6 + strlen ((char *) cpnt)))  | ||||
| 	   { | ||||
| 	     add_CE_entry(); | ||||
| 	     if(cpnt1) | ||||
| 	       { | ||||
| 		 *cpnt1 = '/'; | ||||
| 		 nchar++; | ||||
| 		 cpnt1 = NULL; /* A kluge so that we can restart properly */ | ||||
| 	       } | ||||
| 	     break; | ||||
| 	   } | ||||
| 	  j0 = strlen((char *) cpnt); | ||||
| 	  while(j0) { | ||||
| 	    j1 = j0; | ||||
| 	    if(j1 > 0xf8) j1 = 0xf8; | ||||
| 	    need_ce = 0; | ||||
| 	    if(j1 + currlen + CE_SIZE + (ipnt - recstart) > reclimit) { | ||||
| 	      j1 = reclimit - currlen - CE_SIZE - (ipnt - recstart); | ||||
| 	      need_ce++; | ||||
| 	    } | ||||
| 	    Rock[ipnt++] = (j1 != j0 ? SL_CONTINUE : 0); | ||||
| 	    Rock[ipnt++] = j1; | ||||
| 	    strncpy((char *) Rock + ipnt, (char *) cpnt, j1); | ||||
| 	    ipnt += j1; | ||||
| 	    lenval += j1 + 2; | ||||
| 	    cpnt += j1; | ||||
| 	    nchar -= j1;  /* Number we processed this time */ | ||||
| 	    j0 -= j1; | ||||
| 	    if(need_ce) { | ||||
| 	      add_CE_entry(); | ||||
| 	      if(cpnt1) { | ||||
| 		*cpnt1 = '/'; | ||||
|                 nchar++; | ||||
| 		cpnt1 = NULL; /* A kluge so that we can restart properly */ | ||||
| 	      } | ||||
| 	      break; | ||||
| 	    } | ||||
| 	  } | ||||
| 	}; | ||||
| 	if(cpnt1) { | ||||
| 	  cpnt = cpnt1 + 1; | ||||
| 	} else | ||||
| 	  break; | ||||
|       } | ||||
|       Rock[lenpos] = lenval; | ||||
|       if(nchar) Rock[lenpos + 2] = SL_CONTINUE; /* We need another SL entry */ | ||||
|     } /* while nchar */ | ||||
|   } /* Is a symbolic link */ | ||||
|   /* 
 | ||||
|    * Add in the Rock Ridge TF time field | ||||
|    */ | ||||
|   if(MAYBE_ADD_CE_ENTRY(TF_SIZE)) add_CE_entry(); | ||||
|   Rock[ipnt++] ='T'; | ||||
|   Rock[ipnt++] ='F'; | ||||
|   Rock[ipnt++] = TF_SIZE; | ||||
|   Rock[ipnt++] = SU_VERSION; | ||||
| #ifdef __QNX__ | ||||
|   Rock[ipnt++] = 0x0f; | ||||
| #else | ||||
|   Rock[ipnt++] = 0x0e; | ||||
| #endif | ||||
|   flagval |= (1<<7); | ||||
| #ifdef __QNX__ | ||||
|   iso9660_date((char *) &Rock[ipnt], lstatbuf->st_ftime); | ||||
|   ipnt += 7; | ||||
| #endif | ||||
|   iso9660_date((char *) &Rock[ipnt], lstatbuf->st_mtime); | ||||
|   ipnt += 7; | ||||
|   iso9660_date((char *) &Rock[ipnt], lstatbuf->st_atime); | ||||
|   ipnt += 7; | ||||
|   iso9660_date((char *) &Rock[ipnt], lstatbuf->st_ctime); | ||||
|   ipnt += 7; | ||||
| 
 | ||||
|   /* 
 | ||||
|    * Add in the Rock Ridge RE time field | ||||
|    */ | ||||
|   if(deep_opt & NEED_RE){ | ||||
|           if(MAYBE_ADD_CE_ENTRY(RE_SIZE)) add_CE_entry(); | ||||
| 	  Rock[ipnt++] ='R'; | ||||
| 	  Rock[ipnt++] ='E'; | ||||
| 	  Rock[ipnt++] = RE_SIZE; | ||||
| 	  Rock[ipnt++] = SU_VERSION; | ||||
| 	  flagval |= (1<<6); | ||||
|   }; | ||||
|   /* 
 | ||||
|    * Add in the Rock Ridge PL record, if required. | ||||
|    */ | ||||
|   if(deep_opt & NEED_PL){ | ||||
|           if(MAYBE_ADD_CE_ENTRY(PL_SIZE)) add_CE_entry(); | ||||
| 	  Rock[ipnt++] ='P'; | ||||
| 	  Rock[ipnt++] ='L'; | ||||
| 	  Rock[ipnt++] = PL_SIZE; | ||||
| 	  Rock[ipnt++] = SU_VERSION; | ||||
| 	  set_733((char*)Rock + ipnt, 0); | ||||
| 	  ipnt += 8; | ||||
| 	  flagval |= (1<<5); | ||||
|   }; | ||||
| 
 | ||||
|   /* 
 | ||||
|    * Add in the Rock Ridge CL field, if required. | ||||
|    */ | ||||
|   if(deep_opt & NEED_CL){ | ||||
|           if(MAYBE_ADD_CE_ENTRY(CL_SIZE)) add_CE_entry(); | ||||
| 	  Rock[ipnt++] ='C'; | ||||
| 	  Rock[ipnt++] ='L'; | ||||
| 	  Rock[ipnt++] = CL_SIZE; | ||||
| 	  Rock[ipnt++] = SU_VERSION; | ||||
| 	  set_733((char*)Rock + ipnt, 0); | ||||
| 	  ipnt += 8; | ||||
| 	  flagval |= (1<<4); | ||||
|   }; | ||||
| 
 | ||||
| #ifndef VMS | ||||
|   /* If transparent compression was requested, fill in the correct
 | ||||
|      field for this file */ | ||||
|   if(transparent_compression &&  | ||||
|      S_ISREG(lstatbuf->st_mode) && | ||||
|      strlen(name) > 3 && | ||||
|      strcmp(name + strlen(name) - 3,".gZ") == 0){ | ||||
|     FILE * zipfile; | ||||
|     char * checkname; | ||||
|     unsigned int file_size; | ||||
|     unsigned char header[8]; | ||||
|     int OK_flag; | ||||
| 
 | ||||
|     /* First open file and verify that the correct algorithm was used */ | ||||
|     file_size = 0; | ||||
|     OK_flag = 1; | ||||
| 
 | ||||
|     zipfile = fopen(whole_name, "rb"); | ||||
|     if (fread (header, 1, sizeof (header), zipfile) != sizeof(header)) | ||||
|       error (1, errno, "fread"); | ||||
| 
 | ||||
|     /* Check some magic numbers from gzip. */ | ||||
|     if(header[0] != 0x1f || header[1] != 0x8b || header[2] != 8) OK_flag = 0; | ||||
|     /* Make sure file was blocksized. */ | ||||
|     if(((header[3] & 0x40) == 0)) OK_flag = 0; | ||||
|     /* OK, now go to the end of the file and get some more info */ | ||||
|     if(OK_flag){ | ||||
|       int status; | ||||
|       status = (long)lseek(fileno(zipfile), (off_t)(-8), SEEK_END); | ||||
|       if(status == -1) OK_flag = 0; | ||||
|     } | ||||
|     if(OK_flag){ | ||||
|       if(read(fileno(zipfile), (char*)header, sizeof(header)) != sizeof(header)) | ||||
| 	OK_flag = 0; | ||||
|       else { | ||||
| 	int blocksize; | ||||
| 	blocksize = (header[3] << 8) | header[2]; | ||||
| 	file_size = ((unsigned int)header[7] << 24) |  | ||||
| 		    ((unsigned int)header[6] << 16) |  | ||||
| 		    ((unsigned int)header[5] << 8)  | header[4]; | ||||
| #if 0 | ||||
| 	fprintf(stderr,"Blocksize = %d %d\n", blocksize, file_size); | ||||
| #endif | ||||
| 	if(blocksize != SECTOR_SIZE) OK_flag = 0; | ||||
|       } | ||||
|     } | ||||
|     fclose(zipfile); | ||||
| 
 | ||||
|     checkname = strdup(whole_name); | ||||
|     checkname[strlen(whole_name)-3] = 0; | ||||
|     zipfile = fopen(checkname, "rb"); | ||||
|     if(zipfile) { | ||||
|       OK_flag = 0; | ||||
|       fprintf (stderr, _("Unable to insert transparent compressed file - name conflict\n")); | ||||
|       fclose(zipfile); | ||||
|     } | ||||
| 
 | ||||
|     free(checkname); | ||||
| 
 | ||||
|     if(OK_flag){ | ||||
|       if(MAYBE_ADD_CE_ENTRY(ZZ_SIZE)) add_CE_entry(); | ||||
|       Rock[ipnt++] ='Z'; | ||||
|       Rock[ipnt++] ='Z'; | ||||
|       Rock[ipnt++] = ZZ_SIZE; | ||||
|       Rock[ipnt++] = SU_VERSION; | ||||
|       Rock[ipnt++] = 'g'; /* Identify compression technique used */ | ||||
|       Rock[ipnt++] = 'z'; | ||||
|       Rock[ipnt++] = 3; | ||||
|       set_733((char*)Rock + ipnt, file_size); /* Real file size */ | ||||
|       ipnt += 8; | ||||
|     }; | ||||
|   } | ||||
| #endif | ||||
|   /* 
 | ||||
|    * Add in the Rock Ridge CE field, if required.  We use  this for the | ||||
|    * extension record that is stored in the root directory. | ||||
|    */ | ||||
|   if(deep_opt & NEED_CE) add_CE_entry(); | ||||
|   /*
 | ||||
|    * Done filling in all of the fields.  Now copy it back to a buffer for the | ||||
|    * file in question. | ||||
|    */ | ||||
| 
 | ||||
|   /* Now copy this back to the buffer for the file */ | ||||
|   Rock[flagpos] = flagval; | ||||
| 
 | ||||
|   /* If there was a CE, fill in the size field */ | ||||
|   if(recstart) | ||||
|     set_733((char*)Rock + recstart - 8, ipnt - recstart); | ||||
| 
 | ||||
|   s_entry->rr_attributes = (unsigned char *) e_malloc(ipnt); | ||||
|   s_entry->total_rr_attr_size = ipnt; | ||||
|   s_entry->rr_attr_size = (mainrec ? mainrec : ipnt); | ||||
|   memcpy(s_entry->rr_attributes, Rock, ipnt); | ||||
|   return ipnt; | ||||
| } | ||||
| 
 | ||||
| /* Guaranteed to  return a single sector with the relevant info */ | ||||
| 
 | ||||
| char * FDECL4(generate_rr_extension_record, char *, id,  char  *, descriptor, | ||||
| 				    char *, source, int  *, size){ | ||||
|   int lipnt = 0; | ||||
|   char * pnt; | ||||
|   int len_id, len_des, len_src; | ||||
| 
 | ||||
|   len_id = strlen(id); | ||||
|   len_des =  strlen(descriptor); | ||||
|   len_src = strlen(source); | ||||
|   Rock[lipnt++] ='E'; | ||||
|   Rock[lipnt++] ='R'; | ||||
|   Rock[lipnt++] = ER_SIZE + len_id + len_des + len_src; | ||||
|   Rock[lipnt++] = 1; | ||||
|   Rock[lipnt++] = len_id; | ||||
|   Rock[lipnt++] = len_des; | ||||
|   Rock[lipnt++] = len_src; | ||||
|   Rock[lipnt++] = 1; | ||||
| 
 | ||||
|   memcpy(Rock  + lipnt, id, len_id); | ||||
|   lipnt += len_id; | ||||
| 
 | ||||
|   memcpy(Rock  + lipnt, descriptor, len_des); | ||||
|   lipnt += len_des; | ||||
| 
 | ||||
|   memcpy(Rock  + lipnt, source, len_src); | ||||
|   lipnt += len_src; | ||||
| 
 | ||||
|   if(lipnt  > SECTOR_SIZE) | ||||
|     error (1, 0, _("Extension record too long\n")); | ||||
|   pnt = (char *) e_malloc(SECTOR_SIZE); | ||||
|   memset(pnt, 0,  SECTOR_SIZE); | ||||
|   memcpy(pnt, Rock, lipnt); | ||||
|   *size = lipnt; | ||||
|   return pnt; | ||||
| } | ||||
							
								
								
									
										1865
									
								
								util/mkisofs/tree.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1865
									
								
								util/mkisofs/tree.c
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										1444
									
								
								util/mkisofs/write.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1444
									
								
								util/mkisofs/write.c
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -1,111 +0,0 @@ | |||
| #!lua | ||||
| -- | ||||
| -- Copyright (C) 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/>. | ||||
| -- | ||||
| 
 | ||||
| function enum_device (device, fs, uuid) | ||||
|   local root | ||||
|   local title | ||||
|   local source | ||||
|   local kernels = {} | ||||
|   local kernel_num = 0 | ||||
| 
 | ||||
|   local function enum_file (name) | ||||
|     local version | ||||
| 
 | ||||
|     version = string.match (name, "vmlinuz%-(.*)") | ||||
|     if (version ~= nil) then | ||||
|       table.insert (kernels, version) | ||||
|       kernel_num = kernel_num + 1 | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   local function sort_kernel (first, second) | ||||
|     local a1, a2, a3, a4, b1, b2, b3, b4 | ||||
| 
 | ||||
|     a1, a2, a3, a4 = string.match (first, "(%d+)%.?(%d*).?(%d*)%-?(%d*)") | ||||
|     b1, b2, b3, b4 = string.match (second, "(%d+)%.?(%d*).?(%d*)%-?(%d*)") | ||||
|     return (a1 > b1) or (a2 > b2) or (a3 > b3) or (a4 < b4); | ||||
|   end | ||||
| 
 | ||||
|   root = "(" .. device .. ")/" | ||||
|   source = "root (" .. device .. ")\nchainloader +1" | ||||
|   title = nil | ||||
|   if (grub.file_exist (root .. "bootmgr") and | ||||
|       grub.file_exist (root .. "boot/bcd")) then | ||||
|     title = "Windows Vista bootmgr" | ||||
|   elseif (grub.file_exist (root .. "ntldr") and | ||||
| 	  grub.file_exist (root .. "ntdetect.com") and | ||||
| 	  grub.file_exist (root .. "boot.ini")) then | ||||
|     title = "Windows NT/2000/XP loader" | ||||
|   elseif (grub.file_exist (root .. "windows/win.com")) then | ||||
|     title = "Windows 98/ME" | ||||
|   elseif (grub.file_exist (root .. "io.sys") and | ||||
| 	  grub.file_exist (root .. "command.com")) then | ||||
|     title = "MS-DOS" | ||||
|   elseif (grub.file_exist (root .. "kernel.sys")) then | ||||
|     title = "FreeDOS" | ||||
|   elseif (grub.file_exist (root .. "boot/loader") and | ||||
| 	  grub.file_exist (root .. "boot/device.hints")) then | ||||
|     source = "root (" .. device .. ")\nfreebsd /boot/loader" .. | ||||
|       "\nfreebsd_loadenv /boot/device.hints" | ||||
|     title = "FreeBSD" | ||||
|   else | ||||
|     grub.enum_file (enum_file, root .. "boot") | ||||
|     if kernel_num ~= 0 then | ||||
|       table.sort (kernels, sort_kernel) | ||||
|       for i = 1, kernel_num do | ||||
| 	local initrd | ||||
| 
 | ||||
| 	title = "Linux " .. kernels[i] | ||||
| 	source = "root (" .. device .. | ||||
| 	  ")\nlinux /boot/vmlinuz-" .. kernels[i] .. | ||||
| 	  " root=UUID=" .. uuid .. " ro" | ||||
| 
 | ||||
| 	if grub.file_exist (root .. "boot/initrd-" .. | ||||
| 			    kernels[i] .. ".img") then | ||||
| 	  initrd = "\ninitrd /boot/initrd-" .. kernels[i] .. ".img" | ||||
| 	elseif grub.file_exist (root .. "boot/initrd.img-" .. kernels[i]) then | ||||
| 	  initrd = "\ninitrd /boot/initrd.img-" .. kernels[i] | ||||
| 	elseif grub.file_exist (root .. "boot/initrd-" .. kernels[i]) then | ||||
| 	  initrd = "\ninitrd /boot/initrd-" .. kernels[i] | ||||
| 	else | ||||
| 	  initrd = "" | ||||
| 	end | ||||
| 
 | ||||
| 	grub.add_menu (source .. initrd, title) | ||||
| 	grub.add_menu (source .. " single" .. initrd, | ||||
| 		       title .. " (single-user mode)") | ||||
|       end | ||||
|       return 0 | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   if title == nil then | ||||
|     local partition = string.match (device, ".*,(%d+)") | ||||
| 
 | ||||
|     if (partition ~= nil) and (tonumber (partition) > 4) then | ||||
|       return 0 | ||||
|     end | ||||
| 
 | ||||
|     title = "Other OS" | ||||
|   end | ||||
| 
 | ||||
|   grub.add_menu (source, title) | ||||
|   return 0 | ||||
| end | ||||
| 
 | ||||
| grub.enum_device (enum_device) | ||||
|  | @ -61,7 +61,7 @@ for option in "$@"; do | |||
| 	usage | ||||
| 	exit 0 ;; | ||||
|     -v | --version) | ||||
| 	echo "grub-install (GNU GRUB ${PACKAGE_VERSION})" | ||||
| 	echo "grub-mkrescue (GNU GRUB ${PACKAGE_VERSION})" | ||||
| 	exit 0 ;; | ||||
|     --modules=*) | ||||
| 	modules=`echo "$option" | sed 's/--modules=//'` ;; | ||||
|  |  | |||
|  | @ -31,6 +31,9 @@ target_cpu=@target_cpu@ | |||
| platform=@platform@ | ||||
| pkglibdir=${libdir}/`echo ${PACKAGE_TARNAME}/${target_cpu}-${platform} | sed ${transform}` | ||||
| 
 | ||||
| # for make_system_path_relative_to_its_root() | ||||
| . ${libdir}/grub/grub-mkconfig_lib | ||||
| 
 | ||||
| grub_setup=${sbindir}/`echo grub-setup | sed ${transform}` | ||||
| grub_mkimage=${bindir}/`echo grub-mkimage | sed ${transform}` | ||||
| grub_mkdevicemap=${sbindir}/`echo grub-mkdevicemap | sed ${transform}` | ||||
|  | @ -117,9 +120,6 @@ for option in "$@"; do | |||
|     esac | ||||
| done | ||||
| 
 | ||||
| # for make_system_path_relative_to_its_root() | ||||
| . ${libdir}/grub/grub-mkconfig_lib | ||||
| 
 | ||||
| if test "x$install_device" = x; then | ||||
|     echo "install_device not specified." 1>&2 | ||||
|     usage | ||||
|  |  | |||
|  | @ -98,8 +98,8 @@ generate_image (const char *dir, const char *prefix, FILE *out, char *mods[], ch | |||
|       mod_size = grub_util_get_image_size (p->name); | ||||
| 
 | ||||
|       header = (struct grub_module_header *) (kernel_img + offset); | ||||
|       header->type = grub_cpu_to_be32 (OBJ_TYPE_ELF); | ||||
|       header->size = grub_cpu_to_be32 (mod_size + sizeof (*header)); | ||||
|       header->type = OBJ_TYPE_ELF; | ||||
|       header->size = grub_host_to_target32 (mod_size + sizeof (*header)); | ||||
|       offset += sizeof (*header); | ||||
| 
 | ||||
|       grub_util_load_image (p->name, kernel_img + offset); | ||||
|  | @ -111,8 +111,8 @@ generate_image (const char *dir, const char *prefix, FILE *out, char *mods[], ch | |||
|       struct grub_module_header *header; | ||||
| 
 | ||||
|       header = (struct grub_module_header *) (kernel_img + offset); | ||||
|       header->type = grub_cpu_to_be32 (OBJ_TYPE_MEMDISK); | ||||
|       header->size = grub_cpu_to_be32 (memdisk_size + sizeof (*header)); | ||||
|       header->type = 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); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue