merge mainline into newreloc
This commit is contained in:
		
						commit
						13f58ea31f
					
				
					 59 changed files with 1342 additions and 11023 deletions
				
			
		
							
								
								
									
										384
									
								
								util/console.c
									
										
									
									
									
								
							
							
						
						
									
										384
									
								
								util/console.c
									
										
									
									
									
								
							|  | @ -1,384 +0,0 @@ | |||
| /*  console.c -- Ncurses console for GRUB.  */ | ||||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2003,2005,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/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| /* For compatibility.  */ | ||||
| #ifndef A_NORMAL | ||||
| # define A_NORMAL	0 | ||||
| #endif /* ! A_NORMAL */ | ||||
| #ifndef A_STANDOUT | ||||
| # define A_STANDOUT	0 | ||||
| #endif /* ! A_STANDOUT */ | ||||
| 
 | ||||
| #include <grub/util/console.h> | ||||
| #include <grub/term.h> | ||||
| #include <grub/types.h> | ||||
| 
 | ||||
| #if defined(HAVE_NCURSES_CURSES_H) | ||||
| # include <ncurses/curses.h> | ||||
| #elif defined(HAVE_NCURSES_H) | ||||
| # include <ncurses.h> | ||||
| #elif defined(HAVE_CURSES_H) | ||||
| # include <curses.h> | ||||
| #endif | ||||
| 
 | ||||
| static int grub_console_attr = A_NORMAL; | ||||
| 
 | ||||
| grub_uint8_t grub_console_cur_color = 7; | ||||
| 
 | ||||
| static grub_uint8_t grub_console_standard_color = 0x7; | ||||
| static grub_uint8_t grub_console_normal_color = 0x7; | ||||
| static grub_uint8_t grub_console_highlight_color = 0x70; | ||||
| 
 | ||||
| #define NUM_COLORS	8 | ||||
| 
 | ||||
| static grub_uint8_t color_map[NUM_COLORS] = | ||||
| { | ||||
|   COLOR_BLACK, | ||||
|   COLOR_BLUE, | ||||
|   COLOR_GREEN, | ||||
|   COLOR_CYAN, | ||||
|   COLOR_RED, | ||||
|   COLOR_MAGENTA, | ||||
|   COLOR_YELLOW, | ||||
|   COLOR_WHITE | ||||
| }; | ||||
| 
 | ||||
| static int use_color; | ||||
| 
 | ||||
| static void | ||||
| grub_ncurses_putchar (grub_uint32_t c) | ||||
| { | ||||
|   /* Better than nothing.  */ | ||||
|   switch (c) | ||||
|     { | ||||
|     case GRUB_TERM_DISP_LEFT: | ||||
|       c = '<'; | ||||
|       break; | ||||
| 
 | ||||
|     case GRUB_TERM_DISP_UP: | ||||
|       c = '^'; | ||||
|       break; | ||||
| 
 | ||||
|     case GRUB_TERM_DISP_RIGHT: | ||||
|       c = '>'; | ||||
|       break; | ||||
| 
 | ||||
|     case GRUB_TERM_DISP_DOWN: | ||||
|       c = 'v'; | ||||
|       break; | ||||
| 
 | ||||
|     case GRUB_TERM_DISP_HLINE: | ||||
|       c = '-'; | ||||
|       break; | ||||
| 
 | ||||
|     case GRUB_TERM_DISP_VLINE: | ||||
|       c = '|'; | ||||
|       break; | ||||
| 
 | ||||
|     case GRUB_TERM_DISP_UL: | ||||
|     case GRUB_TERM_DISP_UR: | ||||
|     case GRUB_TERM_DISP_LL: | ||||
|     case GRUB_TERM_DISP_LR: | ||||
|       c = '+'; | ||||
|       break; | ||||
| 
 | ||||
|     default: | ||||
|       /* ncurses does not support Unicode.  */ | ||||
|       if (c > 0x7f) | ||||
| 	c = '?'; | ||||
|       break; | ||||
|     } | ||||
| 
 | ||||
|   addch (c | grub_console_attr); | ||||
| } | ||||
| 
 | ||||
| static grub_ssize_t | ||||
| grub_ncurses_getcharwidth (grub_uint32_t code __attribute__ ((unused))) | ||||
| { | ||||
|   return 1; | ||||
| } | ||||
| 
 | ||||
| static void | ||||
| grub_ncurses_setcolorstate (grub_term_color_state state) | ||||
| { | ||||
|   switch (state) | ||||
|     { | ||||
|     case GRUB_TERM_COLOR_STANDARD: | ||||
|       grub_console_cur_color = grub_console_standard_color; | ||||
|       grub_console_attr = A_NORMAL; | ||||
|       break; | ||||
|     case GRUB_TERM_COLOR_NORMAL: | ||||
|       grub_console_cur_color = grub_console_normal_color; | ||||
|       grub_console_attr = A_NORMAL; | ||||
|       break; | ||||
|     case GRUB_TERM_COLOR_HIGHLIGHT: | ||||
|       grub_console_cur_color = grub_console_highlight_color; | ||||
|       grub_console_attr = A_STANDOUT; | ||||
|       break; | ||||
|     default: | ||||
|       break; | ||||
|     } | ||||
| 
 | ||||
|   if (use_color) | ||||
|     { | ||||
|       grub_uint8_t fg, bg; | ||||
| 
 | ||||
|       fg = (grub_console_cur_color & 7); | ||||
|       bg = (grub_console_cur_color >> 4) & 7; | ||||
| 
 | ||||
|       grub_console_attr = (grub_console_cur_color & 8) ? A_BOLD : A_NORMAL; | ||||
|       color_set ((bg << 3) + fg, 0); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| /* XXX: This function is never called.  */ | ||||
| static void | ||||
| grub_ncurses_setcolor (grub_uint8_t normal_color, grub_uint8_t highlight_color) | ||||
| { | ||||
|   grub_console_normal_color = normal_color; | ||||
|   grub_console_highlight_color = highlight_color; | ||||
| } | ||||
| 
 | ||||
| static void | ||||
| grub_ncurses_getcolor (grub_uint8_t *normal_color, grub_uint8_t *highlight_color) | ||||
| { | ||||
|   *normal_color = grub_console_normal_color; | ||||
|   *highlight_color = grub_console_highlight_color; | ||||
| } | ||||
| 
 | ||||
| static int saved_char = ERR; | ||||
| 
 | ||||
| static int | ||||
| grub_ncurses_checkkey (void) | ||||
| { | ||||
|   int c; | ||||
| 
 | ||||
|   /* Check for SAVED_CHAR. This should not be true, because this
 | ||||
|      means checkkey is called twice continuously.  */ | ||||
|   if (saved_char != ERR) | ||||
|     return saved_char; | ||||
| 
 | ||||
|   wtimeout (stdscr, 100); | ||||
|   c = getch (); | ||||
|   /* If C is not ERR, then put it back in the input queue.  */ | ||||
|   if (c != ERR) | ||||
|     { | ||||
|       saved_char = c; | ||||
|       return c; | ||||
|     } | ||||
| 
 | ||||
|   return -1; | ||||
| } | ||||
| 
 | ||||
| static int | ||||
| grub_ncurses_getkey (void) | ||||
| { | ||||
|   int c; | ||||
| 
 | ||||
|   /* If checkkey has already got a character, then return it.  */ | ||||
|   if (saved_char != ERR) | ||||
|     { | ||||
|       c = saved_char; | ||||
|       saved_char = ERR; | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       wtimeout (stdscr, -1); | ||||
|       c = getch (); | ||||
|     } | ||||
| 
 | ||||
|   switch (c) | ||||
|     { | ||||
|     case KEY_LEFT: | ||||
|       c = 2; | ||||
|       break; | ||||
| 
 | ||||
|     case KEY_RIGHT: | ||||
|       c = 6; | ||||
|       break; | ||||
| 
 | ||||
|     case KEY_UP: | ||||
|       c = 16; | ||||
|       break; | ||||
| 
 | ||||
|     case KEY_DOWN: | ||||
|       c = 14; | ||||
|       break; | ||||
| 
 | ||||
|     case KEY_IC: | ||||
|       c = 24; | ||||
|       break; | ||||
| 
 | ||||
|     case KEY_DC: | ||||
|       c = 4; | ||||
|       break; | ||||
| 
 | ||||
|     case KEY_BACKSPACE: | ||||
|       /* XXX: For some reason ncurses on xterm does not return
 | ||||
| 	 KEY_BACKSPACE.  */ | ||||
|     case 127: | ||||
|       c = 8; | ||||
|       break; | ||||
| 
 | ||||
|     case KEY_HOME: | ||||
|       c = 1; | ||||
|       break; | ||||
| 
 | ||||
|     case KEY_END: | ||||
|       c = 5; | ||||
|       break; | ||||
| 
 | ||||
|     case KEY_NPAGE: | ||||
|       c = 3; | ||||
|       break; | ||||
| 
 | ||||
|     case KEY_PPAGE: | ||||
|       c = 7; | ||||
|       break; | ||||
|     } | ||||
| 
 | ||||
|   return c; | ||||
| } | ||||
| 
 | ||||
| static grub_uint16_t | ||||
| grub_ncurses_getxy (void) | ||||
| { | ||||
|   int x; | ||||
|   int y; | ||||
| 
 | ||||
|   getyx (stdscr, y, x); | ||||
| 
 | ||||
|   return (x << 8) | y; | ||||
| } | ||||
| 
 | ||||
| static grub_uint16_t | ||||
| grub_ncurses_getwh (void) | ||||
| { | ||||
|   int x; | ||||
|   int y; | ||||
| 
 | ||||
|   getmaxyx (stdscr, y, x); | ||||
| 
 | ||||
|   return (x << 8) | y; | ||||
| } | ||||
| 
 | ||||
| static void | ||||
| grub_ncurses_gotoxy (grub_uint8_t x, grub_uint8_t y) | ||||
| { | ||||
|   move (y, x); | ||||
| } | ||||
| 
 | ||||
| static void | ||||
| grub_ncurses_cls (void) | ||||
| { | ||||
|   clear (); | ||||
|   refresh (); | ||||
| } | ||||
| 
 | ||||
| static void | ||||
| grub_ncurses_setcursor (int on) | ||||
| { | ||||
|   curs_set (on ? 1 : 0); | ||||
| } | ||||
| 
 | ||||
| static void | ||||
| grub_ncurses_refresh (void) | ||||
| { | ||||
|   refresh (); | ||||
| } | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_ncurses_init (void) | ||||
| { | ||||
|   initscr (); | ||||
|   raw (); | ||||
|   noecho (); | ||||
|   scrollok (stdscr, TRUE); | ||||
| 
 | ||||
|   nonl (); | ||||
|   intrflush (stdscr, FALSE); | ||||
|   keypad (stdscr, TRUE); | ||||
| 
 | ||||
|   if (has_colors ()) | ||||
|     { | ||||
|       start_color (); | ||||
| 
 | ||||
|       if ((COLORS >= NUM_COLORS) && (COLOR_PAIRS >= NUM_COLORS * NUM_COLORS)) | ||||
|         { | ||||
|           int i, j, n; | ||||
| 
 | ||||
|           n = 0; | ||||
|           for (i = 0; i < NUM_COLORS; i++) | ||||
|             for (j = 0; j < NUM_COLORS; j++) | ||||
|               init_pair(n++, color_map[j], color_map[i]); | ||||
| 
 | ||||
|           use_color = 1; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_ncurses_fini (void) | ||||
| { | ||||
|   endwin (); | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
|  | ||||
| static struct grub_term_input grub_ncurses_term_input = | ||||
|   { | ||||
|     .name = "console", | ||||
|     .checkkey = grub_ncurses_checkkey, | ||||
|     .getkey = grub_ncurses_getkey, | ||||
|   }; | ||||
| 
 | ||||
| static struct grub_term_output grub_ncurses_term_output = | ||||
|   { | ||||
|     .name = "console", | ||||
|     .init = grub_ncurses_init, | ||||
|     .fini = grub_ncurses_fini, | ||||
|     .putchar = grub_ncurses_putchar, | ||||
|     .getcharwidth = grub_ncurses_getcharwidth, | ||||
|     .getxy = grub_ncurses_getxy, | ||||
|     .getwh = grub_ncurses_getwh, | ||||
|     .gotoxy = grub_ncurses_gotoxy, | ||||
|     .cls = grub_ncurses_cls, | ||||
|     .setcolorstate = grub_ncurses_setcolorstate, | ||||
|     .setcolor = grub_ncurses_setcolor, | ||||
|     .getcolor = grub_ncurses_getcolor, | ||||
|     .setcursor = grub_ncurses_setcursor, | ||||
|     .refresh = grub_ncurses_refresh | ||||
|   }; | ||||
| 
 | ||||
| void | ||||
| grub_console_init (void) | ||||
| { | ||||
|   grub_term_register_output ("console", &grub_ncurses_term_output); | ||||
|   grub_term_register_input ("console", &grub_ncurses_term_input); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_console_fini (void) | ||||
| { | ||||
|   grub_ncurses_fini (); | ||||
| } | ||||
							
								
								
									
										543
									
								
								util/getroot.c
									
										
									
									
									
								
							
							
						
						
									
										543
									
								
								util/getroot.c
									
										
									
									
									
								
							|  | @ -1,543 +0,0 @@ | |||
| /* getroot.c - Get root device */ | ||||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 1999,2000,2001,2002,2003,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/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include <config.h> | ||||
| #include <sys/stat.h> | ||||
| #include <unistd.h> | ||||
| #include <string.h> | ||||
| #include <dirent.h> | ||||
| 
 | ||||
| #ifdef __CYGWIN__ | ||||
| # include <sys/fcntl.h> | ||||
| # include <sys/cygwin.h> | ||||
| # include <limits.h> | ||||
| # 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> | ||||
| 
 | ||||
| static void | ||||
| strip_extra_slashes (char *dir) | ||||
| { | ||||
|   char *p = dir; | ||||
| 
 | ||||
|   while ((p = strchr (p, '/')) != 0) | ||||
|     { | ||||
|       if (p[1] == '/') | ||||
| 	{ | ||||
| 	  memmove (p, p + 1, strlen (p)); | ||||
| 	  continue; | ||||
| 	} | ||||
|       else if (p[1] == '\0') | ||||
| 	{ | ||||
| 	  if (p > dir) | ||||
| 	    p[0] = '\0'; | ||||
| 	  break; | ||||
| 	} | ||||
| 
 | ||||
|       p++; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| static char * | ||||
| xgetcwd (void) | ||||
| { | ||||
|   size_t size = 10; | ||||
|   char *path; | ||||
| 
 | ||||
|   path = xmalloc (size); | ||||
|   while (! getcwd (path, size)) | ||||
|     { | ||||
|       size <<= 1; | ||||
|       path = xrealloc (path, size); | ||||
|     } | ||||
| 
 | ||||
|   return path; | ||||
| } | ||||
| 
 | ||||
| #ifdef __MINGW32__ | ||||
| 
 | ||||
| static char * | ||||
| find_root_device (const char *dir __attribute__ ((unused)), | ||||
|                   dev_t dev __attribute__ ((unused))) | ||||
| { | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| #elif ! defined(__CYGWIN__) | ||||
| 
 | ||||
| static char * | ||||
| find_root_device (const char *dir, dev_t dev) | ||||
| { | ||||
|   DIR *dp; | ||||
|   char *saved_cwd; | ||||
|   struct dirent *ent; | ||||
| 
 | ||||
|   dp = opendir (dir); | ||||
|   if (! dp) | ||||
|     return 0; | ||||
| 
 | ||||
|   saved_cwd = xgetcwd (); | ||||
| 
 | ||||
|   grub_util_info ("changing current directory to %s", dir); | ||||
|   if (chdir (dir) < 0) | ||||
|     { | ||||
|       free (saved_cwd); | ||||
|       closedir (dp); | ||||
|       return 0; | ||||
|     } | ||||
| 
 | ||||
|   while ((ent = readdir (dp)) != 0) | ||||
|     { | ||||
|       struct stat st; | ||||
| 
 | ||||
|       /* Avoid:
 | ||||
| 	 - dotfiles (like "/dev/.tmp.md0") since they could be duplicates. | ||||
| 	 - dotdirs (like "/dev/.static") since they could contain duplicates.  */ | ||||
|       if (ent->d_name[0] == '.') | ||||
| 	continue; | ||||
| 
 | ||||
|       if (lstat (ent->d_name, &st) < 0) | ||||
| 	/* Ignore any error.  */ | ||||
| 	continue; | ||||
| 
 | ||||
|       if (S_ISLNK (st.st_mode)) | ||||
| 	/* Don't follow symbolic links.  */ | ||||
| 	continue; | ||||
| 
 | ||||
|       if (S_ISDIR (st.st_mode)) | ||||
| 	{ | ||||
| 	  /* Find it recursively.  */ | ||||
| 	  char *res; | ||||
| 
 | ||||
| 	  res = find_root_device (ent->d_name, dev); | ||||
| 
 | ||||
| 	  if (res) | ||||
| 	    { | ||||
| 	      if (chdir (saved_cwd) < 0) | ||||
| 		grub_util_error ("cannot restore the original directory"); | ||||
| 
 | ||||
| 	      free (saved_cwd); | ||||
| 	      closedir (dp); | ||||
| 	      return res; | ||||
| 	    } | ||||
| 	} | ||||
| 
 | ||||
| #if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__APPLE__) | ||||
|       if (S_ISCHR (st.st_mode) && st.st_rdev == dev) | ||||
| #else | ||||
|       if (S_ISBLK (st.st_mode) && st.st_rdev == dev) | ||||
| #endif | ||||
| 	{ | ||||
| #ifdef __linux__ | ||||
| 	  /* Skip device names like /dev/dm-0, which are short-hand aliases
 | ||||
| 	     to more descriptive device names, e.g. those under /dev/mapper */ | ||||
| 	  if (ent->d_name[0] == 'd' && | ||||
| 	      ent->d_name[1] == 'm' && | ||||
| 	      ent->d_name[2] == '-' && | ||||
| 	      ent->d_name[3] >= '0' && | ||||
| 	      ent->d_name[3] <= '9') | ||||
| 	    continue; | ||||
| #endif | ||||
| 
 | ||||
| 	  /* Found!  */ | ||||
| 	  char *res; | ||||
| 	  char *cwd; | ||||
| #if defined(__NetBSD__) | ||||
| 	  /* Convert this block device to its character (raw) device.  */ | ||||
| 	  const char *template = "%s/r%s"; | ||||
| #else | ||||
| 	  /* Keep the device name as it is.  */ | ||||
| 	  const char *template = "%s/%s"; | ||||
| #endif | ||||
| 
 | ||||
| 	  cwd = xgetcwd (); | ||||
| 	  res = xmalloc (strlen (cwd) + strlen (ent->d_name) + 3); | ||||
| 	  sprintf (res, template, cwd, ent->d_name); | ||||
| 	  strip_extra_slashes (res); | ||||
| 	  free (cwd); | ||||
| 
 | ||||
| 	  /* /dev/root is not a real block device keep looking, takes care
 | ||||
| 	     of situation where root filesystem is on the same partition as | ||||
| 	     grub files */ | ||||
| 
 | ||||
| 	  if (strcmp(res, "/dev/root") == 0) | ||||
| 		continue; | ||||
| 
 | ||||
| 	  if (chdir (saved_cwd) < 0) | ||||
| 	    grub_util_error ("cannot restore the original directory"); | ||||
| 
 | ||||
| 	  free (saved_cwd); | ||||
| 	  closedir (dp); | ||||
| 	  return res; | ||||
| 	} | ||||
|     } | ||||
| 
 | ||||
|   if (chdir (saved_cwd) < 0) | ||||
|     grub_util_error ("cannot restore the original directory"); | ||||
| 
 | ||||
|   free (saved_cwd); | ||||
|   closedir (dp); | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| #else /* __CYGWIN__ */ | ||||
| 
 | ||||
| /* Read drive/partition serial number from mbr/boot sector,
 | ||||
|    return 0 on read error, ~0 on unknown serial.  */ | ||||
| static unsigned | ||||
| get_bootsec_serial (const char *os_dev, int mbr) | ||||
| { | ||||
|   /* Read boot sector.  */ | ||||
|   int fd = open (os_dev, O_RDONLY); | ||||
|   if (fd < 0) | ||||
|     return 0; | ||||
|   unsigned char buf[0x200]; | ||||
|   int n = read (fd, buf, sizeof (buf)); | ||||
|   close (fd); | ||||
|   if (n != sizeof(buf)) | ||||
|     return 0; | ||||
| 
 | ||||
|   /* Check signature.  */ | ||||
|   if (!(buf[0x1fe] == 0x55 && buf[0x1ff] == 0xaa)) | ||||
|     return ~0; | ||||
| 
 | ||||
|   /* Serial number offset depends on boot sector type.  */ | ||||
|   if (mbr) | ||||
|     n = 0x1b8; | ||||
|   else if (memcmp (buf + 0x03, "NTFS", 4) == 0) | ||||
|     n = 0x048; | ||||
|   else if (memcmp (buf + 0x52, "FAT32", 5) == 0) | ||||
|     n = 0x043; | ||||
|   else if (memcmp (buf + 0x36, "FAT", 3) == 0) | ||||
|     n = 0x027; | ||||
|   else | ||||
|     return ~0; | ||||
| 
 | ||||
|   unsigned serial = *(unsigned *)(buf + n); | ||||
|   if (serial == 0) | ||||
|     return ~0; | ||||
|   return serial; | ||||
| } | ||||
| 
 | ||||
| static char * | ||||
| find_cygwin_root_device (const char *path, dev_t dev) | ||||
| { | ||||
|   /* No root device for /cygdrive.  */ | ||||
|   if (dev == (DEV_CYGDRIVE_MAJOR << 16)) | ||||
|     return 0; | ||||
| 
 | ||||
|   /* Convert to full POSIX and Win32 path.  */ | ||||
|   char fullpath[PATH_MAX], winpath[PATH_MAX]; | ||||
|   cygwin_conv_to_full_posix_path (path, fullpath); | ||||
|   cygwin_conv_to_full_win32_path (fullpath, winpath); | ||||
| 
 | ||||
|   /* If identical, this is no real filesystem path.  */ | ||||
|   if (strcmp (fullpath, winpath) == 0) | ||||
|     return 0; | ||||
| 
 | ||||
|   /* Check for floppy drive letter.  */ | ||||
|   if (winpath[0] && winpath[1] == ':' && strchr ("AaBb", winpath[0])) | ||||
|     return xstrdup (strchr ("Aa", winpath[0]) ? "/dev/fd0" : "/dev/fd1"); | ||||
| 
 | ||||
|   /* Cygwin returns the partition serial number in stat.st_dev.
 | ||||
|      This is never identical to the device number of the emulated | ||||
|      /dev/sdXN device, so above find_root_device () does not work. | ||||
|      Search the partition with the same serial in boot sector instead.  */ | ||||
|   char devpath[sizeof ("/dev/sda15") + 13]; /* Size + Paranoia.  */ | ||||
|   int d; | ||||
|   for (d = 'a'; d <= 'z'; d++) | ||||
|     { | ||||
|       sprintf (devpath, "/dev/sd%c", d); | ||||
|       if (get_bootsec_serial (devpath, 1) == 0) | ||||
| 	continue; | ||||
|       int p; | ||||
|       for (p = 1; p <= 15; p++) | ||||
| 	{ | ||||
| 	  sprintf (devpath, "/dev/sd%c%d", d, p); | ||||
| 	  unsigned ser = get_bootsec_serial (devpath, 0); | ||||
| 	  if (ser == 0) | ||||
| 	    break; | ||||
| 	  if (ser != (unsigned)~0 && dev == (dev_t)ser) | ||||
| 	    return xstrdup (devpath); | ||||
| 	} | ||||
|     } | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| #endif /* __CYGWIN__ */ | ||||
| 
 | ||||
| char * | ||||
| grub_guess_root_device (const char *dir) | ||||
| { | ||||
|   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); | ||||
| 
 | ||||
| #ifdef __CYGWIN__ | ||||
|   /* Cygwin specific function.  */ | ||||
|   os_dev = find_cygwin_root_device (dir, st.st_dev); | ||||
| 
 | ||||
| #else | ||||
| 
 | ||||
|   /* 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; | ||||
| } | ||||
| 
 | ||||
| static int | ||||
| grub_util_is_dmraid (const char *os_dev) | ||||
| { | ||||
|   if (! strncmp (os_dev, "/dev/mapper/nvidia_", 19)) | ||||
|     return 1; | ||||
|   else if (! strncmp (os_dev, "/dev/mapper/isw_", 16)) | ||||
|     return 1; | ||||
|   else if (! strncmp (os_dev, "/dev/mapper/hpt37x_", 19)) | ||||
|     return 1; | ||||
|   else if (! strncmp (os_dev, "/dev/mapper/hpt45x_", 19)) | ||||
|     return 1; | ||||
|   else if (! strncmp (os_dev, "/dev/mapper/via_", 16)) | ||||
|     return 1; | ||||
|   else if (! strncmp (os_dev, "/dev/mapper/lsi_", 16)) | ||||
|     return 1; | ||||
|   else if (! strncmp (os_dev, "/dev/mapper/pdc_", 16)) | ||||
|     return 1; | ||||
|   else if (! strncmp (os_dev, "/dev/mapper/jmicron_", 20)) | ||||
|     return 1; | ||||
|   else if (! strncmp (os_dev, "/dev/mapper/asr_", 16)) | ||||
|     return 1; | ||||
|   else if (! strncmp (os_dev, "/dev/mapper/sil_", 16)) | ||||
|     return 1; | ||||
| 
 | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| int | ||||
| grub_util_get_dev_abstraction (const char *os_dev __attribute__((unused))) | ||||
| { | ||||
| #ifdef __linux__ | ||||
|   /* Check for LVM.  */ | ||||
|   if (!strncmp (os_dev, "/dev/mapper/", 12) | ||||
|       && ! grub_util_is_dmraid (os_dev) | ||||
|       && strncmp (os_dev, "/dev/mapper/mpath", 17) != 0) | ||||
|     return GRUB_DEV_ABSTRACTION_LVM; | ||||
| 
 | ||||
|   /* Check for RAID.  */ | ||||
|   if (!strncmp (os_dev, "/dev/md", 7)) | ||||
|     return GRUB_DEV_ABSTRACTION_RAID; | ||||
| #endif | ||||
| 
 | ||||
|   /* No abstraction found.  */ | ||||
|   return GRUB_DEV_ABSTRACTION_NONE; | ||||
| } | ||||
| 
 | ||||
| char * | ||||
| grub_util_get_grub_dev (const char *os_dev) | ||||
| { | ||||
|   char *grub_dev; | ||||
| 
 | ||||
|   switch (grub_util_get_dev_abstraction (os_dev)) | ||||
|     { | ||||
|     case GRUB_DEV_ABSTRACTION_LVM: | ||||
| 
 | ||||
|       { | ||||
| 	unsigned short i, len; | ||||
| 	grub_size_t offset = sizeof ("/dev/mapper/") - 1; | ||||
| 
 | ||||
| 	len = strlen (os_dev) - offset + 1; | ||||
| 	grub_dev = xmalloc (len); | ||||
| 
 | ||||
| 	for (i = 0; i < len; i++, offset++) | ||||
| 	  { | ||||
| 	    grub_dev[i] = os_dev[offset]; | ||||
| 	    if (os_dev[offset] == '-' && os_dev[offset + 1] == '-') | ||||
| 	      offset++; | ||||
| 	  } | ||||
|       } | ||||
| 
 | ||||
|       break; | ||||
| 
 | ||||
|     case GRUB_DEV_ABSTRACTION_RAID: | ||||
| 
 | ||||
|       if (os_dev[7] == '_' && os_dev[8] == 'd') | ||||
| 	{ | ||||
| 	  /* This a partitionable RAID device of the form /dev/md_dNNpMM. */ | ||||
| 
 | ||||
| 	  char *p, *q; | ||||
| 
 | ||||
| 	  p = strdup (os_dev + sizeof ("/dev/md_d") - 1); | ||||
| 
 | ||||
| 	  q = strchr (p, 'p'); | ||||
| 	  if (q) | ||||
| 	    *q = ','; | ||||
| 
 | ||||
| 	  grub_dev = xasprintf ("md%s", p); | ||||
| 	  free (p); | ||||
| 	} | ||||
|       else if (os_dev[7] == '/' && os_dev[8] == 'd') | ||||
| 	{ | ||||
| 	  /* This a partitionable RAID device of the form /dev/md/dNNpMM. */ | ||||
| 
 | ||||
| 	  char *p, *q; | ||||
| 
 | ||||
| 	  p = strdup (os_dev + sizeof ("/dev/md/d") - 1); | ||||
| 
 | ||||
| 	  q = strchr (p, 'p'); | ||||
| 	  if (q) | ||||
| 	    *q = ','; | ||||
| 
 | ||||
| 	  grub_dev = xasprintf ("md%s", p); | ||||
| 	  free (p); | ||||
| 	} | ||||
|       else if (os_dev[7] >= '0' && os_dev[7] <= '9') | ||||
| 	{ | ||||
| 	  char *p , *q; | ||||
| 
 | ||||
| 	  p = strdup (os_dev + sizeof ("/dev/md") - 1); | ||||
| 
 | ||||
| 	  q = strchr (p, 'p'); | ||||
| 	  if (q) | ||||
| 	    *q = ','; | ||||
| 
 | ||||
| 	  grub_dev = xasprintf ("md%s", p); | ||||
| 	  free (p); | ||||
| 	} | ||||
|       else if (os_dev[7] == '/' && os_dev[8] >= '0' && os_dev[8] <= '9') | ||||
| 	{ | ||||
| 	  char *p , *q; | ||||
| 
 | ||||
| 	  p = strdup (os_dev + sizeof ("/dev/md/") - 1); | ||||
| 
 | ||||
| 	  q = strchr (p, 'p'); | ||||
| 	  if (q) | ||||
| 	    *q = ','; | ||||
| 
 | ||||
| 	  grub_dev = xasprintf ("md%s", p); | ||||
| 	  free (p); | ||||
| 	} | ||||
|       else | ||||
| 	grub_util_error ("unknown kind of RAID device `%s'", os_dev); | ||||
| 
 | ||||
|       break; | ||||
| 
 | ||||
|     default:  /* GRUB_DEV_ABSTRACTION_NONE */ | ||||
|       grub_dev = grub_util_biosdisk_get_grub_dev (os_dev); | ||||
|     } | ||||
| 
 | ||||
|   return grub_dev; | ||||
| } | ||||
| 
 | ||||
| const char * | ||||
| grub_util_check_block_device (const char *blk_dev) | ||||
| { | ||||
|   struct stat st; | ||||
| 
 | ||||
|   if (stat (blk_dev, &st) < 0) | ||||
|     grub_util_error ("cannot stat `%s'", blk_dev); | ||||
| 
 | ||||
|   if (S_ISBLK (st.st_mode)) | ||||
|     return (blk_dev); | ||||
|   else | ||||
|     return 0; | ||||
| } | ||||
| 
 | ||||
| const char * | ||||
| grub_util_check_char_device (const char *blk_dev) | ||||
| { | ||||
|   struct stat st; | ||||
| 
 | ||||
|   if (stat (blk_dev, &st) < 0) | ||||
|     grub_util_error ("cannot stat `%s'", blk_dev); | ||||
| 
 | ||||
|   if (S_ISCHR (st.st_mode)) | ||||
|     return (blk_dev); | ||||
|   else | ||||
|     return 0; | ||||
| } | ||||
| 
 | ||||
							
								
								
									
										263
									
								
								util/grub-emu.c
									
										
									
									
									
								
							
							
						
						
									
										263
									
								
								util/grub-emu.c
									
										
									
									
									
								
							|  | @ -1,263 +0,0 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2003,2004,2005,2006,2007,2008,2009,2010  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include <stdlib.h> | ||||
| #include <sys/stat.h> | ||||
| #include <getopt.h> | ||||
| #include <string.h> | ||||
| #include <signal.h> | ||||
| #include <sys/types.h> | ||||
| #include <unistd.h> | ||||
| 
 | ||||
| #include <grub/mm.h> | ||||
| #include <grub/setjmp.h> | ||||
| #include <grub/fs.h> | ||||
| #include <grub/util/hostdisk.h> | ||||
| #include <grub/dl.h> | ||||
| #include <grub/util/console.h> | ||||
| #include <grub/util/misc.h> | ||||
| #include <grub/kernel.h> | ||||
| #include <grub/normal.h> | ||||
| #include <grub/util/getroot.h> | ||||
| #include <grub/env.h> | ||||
| #include <grub/partition.h> | ||||
| #include <grub/i18n.h> | ||||
| 
 | ||||
| #define ENABLE_RELOCATABLE 0 | ||||
| #include "progname.h" | ||||
| 
 | ||||
| /* Used for going back to the main function.  */ | ||||
| static jmp_buf main_env; | ||||
| 
 | ||||
| /* Store the prefix specified by an argument.  */ | ||||
| static char *prefix = NULL; | ||||
| 
 | ||||
| grub_addr_t | ||||
| grub_arch_modules_addr (void) | ||||
| { | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| #if GRUB_NO_MODULES | ||||
| grub_err_t | ||||
| grub_arch_dl_check_header (void *ehdr) | ||||
| { | ||||
|   (void) ehdr; | ||||
| 
 | ||||
|   return GRUB_ERR_BAD_MODULE; | ||||
| } | ||||
| 
 | ||||
| grub_err_t | ||||
| grub_arch_dl_relocate_symbols (grub_dl_t mod, void *ehdr) | ||||
| { | ||||
|   (void) mod; | ||||
|   (void) ehdr; | ||||
| 
 | ||||
|   return GRUB_ERR_BAD_MODULE; | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| void | ||||
| grub_reboot (void) | ||||
| { | ||||
|   longjmp (main_env, 1); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_halt ( | ||||
| #ifdef GRUB_MACHINE_PCBIOS | ||||
| 	   int no_apm __attribute__ ((unused)) | ||||
| #endif | ||||
| 	   ) | ||||
| { | ||||
|   grub_reboot (); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_machine_init (void) | ||||
| { | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_machine_set_prefix (void) | ||||
| { | ||||
|   grub_env_set ("prefix", prefix); | ||||
|   free (prefix); | ||||
|   prefix = 0; | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_machine_fini (void) | ||||
| { | ||||
|   grub_console_fini (); | ||||
| } | ||||
| 
 | ||||
|  | ||||
| 
 | ||||
| static struct option options[] = | ||||
|   { | ||||
|     {"root-device", required_argument, 0, 'r'}, | ||||
|     {"device-map", required_argument, 0, 'm'}, | ||||
|     {"directory", required_argument, 0, 'd'}, | ||||
|     {"hold", optional_argument, 0, 'H'}, | ||||
|     {"help", no_argument, 0, 'h'}, | ||||
|     {"version", no_argument, 0, 'V'}, | ||||
|     {"verbose", no_argument, 0, 'v'}, | ||||
|     { 0, 0, 0, 0 } | ||||
|   }; | ||||
| 
 | ||||
| static int | ||||
| usage (int status) | ||||
| { | ||||
|   if (status) | ||||
|     fprintf (stderr, | ||||
| 	     "Try `%s --help' for more information.\n", program_name); | ||||
|   else | ||||
|     printf ( | ||||
|       "Usage: %s [OPTION]...\n" | ||||
|       "\n" | ||||
|       "GRUB emulator.\n" | ||||
|       "\n" | ||||
|       "  -r, --root-device=DEV     use DEV as the root device [default=guessed]\n" | ||||
|       "  -m, --device-map=FILE     use FILE as the device map [default=%s]\n" | ||||
|       "  -d, --directory=DIR       use GRUB files in the directory DIR [default=%s]\n" | ||||
|       "  -v, --verbose             print verbose messages\n" | ||||
|       "  -H, --hold[=SECONDS]      wait until a debugger will attach\n" | ||||
|       "  -h, --help                display this message and exit\n" | ||||
|       "  -V, --version             print version information and exit\n" | ||||
|       "\n" | ||||
|       "Report bugs to <%s>.\n", program_name, DEFAULT_DEVICE_MAP, DEFAULT_DIRECTORY, PACKAGE_BUGREPORT); | ||||
|   return status; | ||||
| } | ||||
|  | ||||
| 
 | ||||
| void grub_hostfs_init (void); | ||||
| void grub_hostfs_fini (void); | ||||
| void grub_host_init (void); | ||||
| void grub_host_fini (void); | ||||
| #if GRUB_NO_MODULES | ||||
| void grub_init_all (void); | ||||
| void grub_fini_all (void); | ||||
| #endif | ||||
| 
 | ||||
| int | ||||
| main (int argc, char *argv[]) | ||||
| { | ||||
|   char *root_dev = 0; | ||||
|   char *dir = DEFAULT_DIRECTORY; | ||||
|   char *dev_map = DEFAULT_DEVICE_MAP; | ||||
|   volatile int hold = 0; | ||||
|   int opt; | ||||
| 
 | ||||
|   set_program_name (argv[0]); | ||||
| 
 | ||||
|   while ((opt = getopt_long (argc, argv, "r:d:m:vH:hV", options, 0)) != -1) | ||||
|     switch (opt) | ||||
|       { | ||||
|       case 'r': | ||||
|         root_dev = optarg; | ||||
|         break; | ||||
|       case 'd': | ||||
|         dir = optarg; | ||||
|         break; | ||||
|       case 'm': | ||||
|         dev_map = optarg; | ||||
|         break; | ||||
|       case 'v': | ||||
|         verbosity++; | ||||
|         break; | ||||
|       case 'H': | ||||
|         hold = (optarg ? atoi (optarg) : -1); | ||||
|         break; | ||||
|       case 'h': | ||||
|         return usage (0); | ||||
|       case 'V': | ||||
|         printf ("%s (%s) %s\n", program_name, PACKAGE_NAME, PACKAGE_VERSION); | ||||
|         return 0; | ||||
|       default: | ||||
|         return usage (1); | ||||
|       } | ||||
| 
 | ||||
|   if (optind < argc) | ||||
|     { | ||||
|       fprintf (stderr, "Unknown extra argument `%s'.\n", argv[optind]); | ||||
|       return usage (1); | ||||
|     } | ||||
| 
 | ||||
|   /* Wait until the ARGS.HOLD variable is cleared by an attached debugger. */ | ||||
|   if (hold && verbosity > 0) | ||||
|     printf ("Run \"gdb %s %d\", and set ARGS.HOLD to zero.\n", | ||||
|             program_name, (int) getpid ()); | ||||
|   while (hold) | ||||
|     { | ||||
|       if (hold > 0) | ||||
|         hold--; | ||||
| 
 | ||||
|       sleep (1); | ||||
|     } | ||||
| 
 | ||||
|   signal (SIGINT, SIG_IGN); | ||||
|   grub_console_init (); | ||||
|   grub_host_init (); | ||||
|   grub_hostfs_init (); | ||||
| 
 | ||||
|   /* XXX: This is a bit unportable.  */ | ||||
|   grub_util_biosdisk_init (dev_map); | ||||
| 
 | ||||
| #if GRUB_NO_MODULES | ||||
|   grub_init_all (); | ||||
| #endif | ||||
| 
 | ||||
|   /* Make sure that there is a root device.  */ | ||||
|   if (! root_dev) | ||||
|     { | ||||
|       char *device_name = grub_guess_root_device (dir); | ||||
|       if (! device_name) | ||||
|         grub_util_error ("cannot find a device for %s", dir); | ||||
| 
 | ||||
|       root_dev = grub_util_get_grub_dev (device_name); | ||||
|       if (! root_dev) | ||||
| 	{ | ||||
| 	  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'"); | ||||
| 	} | ||||
|     } | ||||
| 
 | ||||
|   if (strcmp (root_dev, "host") == 0) | ||||
|     dir = xstrdup (dir); | ||||
|   else | ||||
|     dir = make_system_path_relative_to_its_root (dir); | ||||
|   prefix = xmalloc (strlen (root_dev) + 2 + strlen (dir) + 1); | ||||
|   sprintf (prefix, "(%s)%s", root_dev, dir); | ||||
|   free (dir); | ||||
| 
 | ||||
|   /* Start GRUB!  */ | ||||
|   if (setjmp (main_env) == 0) | ||||
|     grub_main (); | ||||
| 
 | ||||
| #if GRUB_NO_MODULES | ||||
|   grub_fini_all (); | ||||
| #endif | ||||
|   grub_hostfs_fini (); | ||||
|   grub_host_fini (); | ||||
| 
 | ||||
|   grub_machine_fini (); | ||||
| 
 | ||||
|   return 0; | ||||
| } | ||||
|  | @ -17,7 +17,9 @@ | |||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include <stdio.h> | ||||
| #include <grub/util/misc.h> | ||||
| #include <grub/emu/misc.h> | ||||
| #include <grub/i18n.h> | ||||
| #include <getopt.h> | ||||
| 
 | ||||
|  | @ -97,7 +99,7 @@ main (int argc, char *argv[]) | |||
| 
 | ||||
|   argument = argv[optind]; | ||||
| 
 | ||||
|   relpath = make_system_path_relative_to_its_root (argument); | ||||
|   relpath = grub_make_system_path_relative_to_its_root (argument); | ||||
|   printf ("%s\n", relpath); | ||||
|   free (relpath); | ||||
| 
 | ||||
|  |  | |||
|  | @ -47,8 +47,8 @@ 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] | ||||
|   --modules=MODULES       pre-load specified modules MODULES | ||||
|   --rom-directory=DIR     save rom images in DIR [optional] | ||||
| 
 | ||||
| $0 generates a bootable rescue image with specified source files or directories. | ||||
|  | @ -158,7 +158,7 @@ EOF | |||
|     tar -C ${memdisk_dir} -cf ${memdisk_img} boot | ||||
|     rm -rf ${memdisk_dir} | ||||
|     grub-mkimage -O ${platform} -d "${source_directory}" -m "${memdisk_img}" -o "$3" --prefix='(memdisk)/boot/grub' \ | ||||
|         search iso9660 configfile sh memdisk tar $4 | ||||
|         search iso9660 configfile normal sh memdisk tar $4 | ||||
|     rm -rf ${memdisk_img} | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -20,14 +20,15 @@ | |||
| #include <config.h> | ||||
| #include <grub/types.h> | ||||
| #include <grub/util/misc.h> | ||||
| #include <grub/util/misc.h> | ||||
| #include <grub/device.h> | ||||
| #include <grub/disk.h> | ||||
| #include <grub/file.h> | ||||
| #include <grub/fs.h> | ||||
| #include <grub/partition.h> | ||||
| #include <grub/msdos_partition.h> | ||||
| #include <grub/util/hostdisk.h> | ||||
| #include <grub/util/getroot.h> | ||||
| #include <grub/emu/hostdisk.h> | ||||
| #include <grub/emu/getroot.h> | ||||
| #include <grub/term.h> | ||||
| #include <grub/env.h> | ||||
| #include <grub/raid.h> | ||||
|  | @ -261,7 +262,7 @@ probe (const char *path, char *device_name) | |||
| 	      grub_util_info ("reading %s via OS facilities", path); | ||||
| 	      filebuf_via_sys = grub_util_read_image (path); | ||||
| 
 | ||||
| 	      rel_path = make_system_path_relative_to_its_root (path); | ||||
| 	      rel_path = grub_make_system_path_relative_to_its_root (path); | ||||
| 	      grub_path = xasprintf ("(%s)%s", drive_name, rel_path); | ||||
| 	      free (rel_path); | ||||
| 	      grub_util_info ("reading %s via GRUB facilities", grub_path); | ||||
|  |  | |||
							
								
								
									
										1360
									
								
								util/hostdisk.c
									
										
									
									
									
								
							
							
						
						
									
										1360
									
								
								util/hostdisk.c
									
										
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										175
									
								
								util/hostfs.c
									
										
									
									
									
								
							
							
						
						
									
										175
									
								
								util/hostfs.c
									
										
									
									
									
								
							|  | @ -1,175 +0,0 @@ | |||
| /* hostfs.c - Dummy filesystem to provide access to the hosts filesystem  */ | ||||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2007,2008,2009,2010  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| #define _BSD_SOURCE | ||||
| #include <grub/fs.h> | ||||
| #include <grub/file.h> | ||||
| #include <grub/disk.h> | ||||
| #include <grub/misc.h> | ||||
| #include <grub/dl.h> | ||||
| #include <grub/util/misc.h> | ||||
| 
 | ||||
| #include <dirent.h> | ||||
| #include <stdio.h> | ||||
| #include <errno.h> | ||||
| 
 | ||||
| 
 | ||||
| /* dirent.d_type is a BSD extension, not part of POSIX */ | ||||
| #include <sys/stat.h> | ||||
| #include <string.h> | ||||
| 
 | ||||
| static int | ||||
| is_dir (const char *path, const char *name) | ||||
| { | ||||
|   int len1 = strlen(path); | ||||
|   int len2 = strlen(name); | ||||
| 
 | ||||
|   char pathname[len1 + 1 + len2 + 1 + 13]; | ||||
|   strcpy (pathname, path); | ||||
| 
 | ||||
|   /* Avoid UNC-path "//name" on Cygwin.  */ | ||||
|   if (len1 > 0 && pathname[len1 - 1] != '/') | ||||
|     strcat (pathname, "/"); | ||||
| 
 | ||||
|   strcat (pathname, name); | ||||
| 
 | ||||
|   struct stat st; | ||||
|   if (stat (pathname, &st)) | ||||
|     return 0; | ||||
|   return S_ISDIR (st.st_mode); | ||||
| } | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_hostfs_dir (grub_device_t device, const char *path, | ||||
| 		 int (*hook) (const char *filename, | ||||
| 			      const struct grub_dirhook_info *info)) | ||||
| { | ||||
|   DIR *dir; | ||||
| 
 | ||||
|   /* Check if the disk is our dummy disk.  */ | ||||
|   if (grub_strcmp (device->disk->name, "host")) | ||||
|     return grub_error (GRUB_ERR_BAD_FS, "not a hostfs"); | ||||
| 
 | ||||
|   dir = opendir (path); | ||||
|   if (! dir) | ||||
|     return grub_error (GRUB_ERR_BAD_FILENAME, | ||||
| 		       "can't open the hostfs directory `%s'", path); | ||||
| 
 | ||||
|   while (1) | ||||
|     { | ||||
|       struct dirent *de; | ||||
|       struct grub_dirhook_info info; | ||||
|       grub_memset (&info, 0, sizeof (info)); | ||||
| 
 | ||||
|       de = readdir (dir); | ||||
|       if (! de) | ||||
| 	break; | ||||
| 
 | ||||
|       info.dir = !! is_dir (path, de->d_name); | ||||
|       hook (de->d_name, &info); | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
|   closedir (dir); | ||||
| 
 | ||||
|   return GRUB_ERR_NONE; | ||||
| } | ||||
| 
 | ||||
| /* Open a file named NAME and initialize FILE.  */ | ||||
| static grub_err_t | ||||
| grub_hostfs_open (struct grub_file *file, const char *name) | ||||
| { | ||||
|   FILE *f; | ||||
| 
 | ||||
|   f = fopen (name, "rb"); | ||||
|   if (! f) | ||||
|     return grub_error (GRUB_ERR_BAD_FILENAME, | ||||
| 		       "can't open `%s'", name); | ||||
|   file->data = f; | ||||
| 
 | ||||
| #ifdef __MINGW32__ | ||||
|   file->size = grub_util_get_disk_size (name); | ||||
| #else | ||||
|   fseeko (f, 0, SEEK_END); | ||||
|   file->size = ftello (f); | ||||
|   fseeko (f, 0, SEEK_SET); | ||||
| #endif | ||||
| 
 | ||||
|   return GRUB_ERR_NONE; | ||||
| } | ||||
| 
 | ||||
| static grub_ssize_t | ||||
| grub_hostfs_read (grub_file_t file, char *buf, grub_size_t len) | ||||
| { | ||||
|   FILE *f; | ||||
| 
 | ||||
|   f = (FILE *) file->data; | ||||
|   if (fseeko (f, file->offset, SEEK_SET) != 0) | ||||
|     { | ||||
|       grub_error (GRUB_ERR_OUT_OF_RANGE, "fseeko: %s", strerror (errno)); | ||||
|       return -1; | ||||
|     } | ||||
| 
 | ||||
|   unsigned int s = fread (buf, 1, len, f); | ||||
|   if (s != len) | ||||
|     grub_error (GRUB_ERR_FILE_READ_ERROR, "fread: %s", strerror (errno)); | ||||
| 
 | ||||
|   return (signed) s; | ||||
| } | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_hostfs_close (grub_file_t file) | ||||
| { | ||||
|   FILE *f; | ||||
| 
 | ||||
|   f = (FILE *) file->data; | ||||
|   fclose (f); | ||||
| 
 | ||||
|   return GRUB_ERR_NONE; | ||||
| } | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_hostfs_label (grub_device_t device __attribute ((unused)), | ||||
| 		   char **label __attribute ((unused))) | ||||
| { | ||||
|   *label = 0; | ||||
|   return GRUB_ERR_NONE; | ||||
| } | ||||
| 
 | ||||
| static struct grub_fs grub_hostfs_fs = | ||||
|   { | ||||
|     .name = "hostfs", | ||||
|     .dir = grub_hostfs_dir, | ||||
|     .open = grub_hostfs_open, | ||||
|     .read = grub_hostfs_read, | ||||
|     .close = grub_hostfs_close, | ||||
|     .label = grub_hostfs_label, | ||||
|     .next = 0 | ||||
|   }; | ||||
| 
 | ||||
|  | ||||
| 
 | ||||
| GRUB_MOD_INIT(hostfs) | ||||
| { | ||||
|   grub_fs_register (&grub_hostfs_fs); | ||||
| } | ||||
| 
 | ||||
| GRUB_MOD_FINI(hostfs) | ||||
| { | ||||
|   grub_fs_unregister (&grub_hostfs_fs); | ||||
| } | ||||
|  | @ -28,14 +28,14 @@ | |||
| #include <grub/msdos_partition.h> | ||||
| #include <grub/gpt_partition.h> | ||||
| #include <grub/env.h> | ||||
| #include <grub/util/hostdisk.h> | ||||
| #include <grub/emu/hostdisk.h> | ||||
| #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> | ||||
| #include <grub/emu/getroot.h> | ||||
| 
 | ||||
| static const grub_gpt_part_type_t grub_gpt_partition_type_bios_boot = GRUB_GPT_PARTITION_TYPE_BIOS_BOOT; | ||||
| 
 | ||||
|  | @ -430,7 +430,7 @@ unable_to_embed: | |||
|   /* Make sure that GRUB reads the identical image as the OS.  */ | ||||
|   tmp_img = xmalloc (core_size); | ||||
|   core_path_dev_full = grub_util_get_path (dir, core_file); | ||||
|   core_path_dev = make_system_path_relative_to_its_root (core_path_dev_full); | ||||
|   core_path_dev = grub_make_system_path_relative_to_its_root (core_path_dev_full); | ||||
|   free (core_path_dev_full); | ||||
| 
 | ||||
|   /* It is a Good Thing to sync two times.  */ | ||||
|  |  | |||
							
								
								
									
										295
									
								
								util/misc.c
									
										
									
									
									
								
							
							
						
						
									
										295
									
								
								util/misc.c
									
										
									
									
									
								
							|  | @ -53,63 +53,11 @@ | |||
| # include <malloc.h> | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __CYGWIN__ | ||||
| # include <sys/cygwin.h> | ||||
| # define DEV_CYGDRIVE_MAJOR 98 | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __MINGW32__ | ||||
| #include <windows.h> | ||||
| #include <winioctl.h> | ||||
| #endif | ||||
| 
 | ||||
| int verbosity = 0; | ||||
| 
 | ||||
| void | ||||
| grub_util_warn (const char *fmt, ...) | ||||
| { | ||||
|   va_list ap; | ||||
| 
 | ||||
|   fprintf (stderr, _("%s: warn:"), program_name); | ||||
|   fprintf (stderr, " "); | ||||
|   va_start (ap, fmt); | ||||
|   vfprintf (stderr, fmt, ap); | ||||
|   va_end (ap); | ||||
|   fprintf (stderr, ".\n"); | ||||
|   fflush (stderr); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_util_info (const char *fmt, ...) | ||||
| { | ||||
|   if (verbosity > 0) | ||||
|     { | ||||
|       va_list ap; | ||||
| 
 | ||||
|       fprintf (stderr, _("%s: info:"), program_name); | ||||
|       fprintf (stderr, " "); | ||||
|       va_start (ap, fmt); | ||||
|       vfprintf (stderr, fmt, ap); | ||||
|       va_end (ap); | ||||
|       fprintf (stderr, ".\n"); | ||||
|       fflush (stderr); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_util_error (const char *fmt, ...) | ||||
| { | ||||
|   va_list ap; | ||||
| 
 | ||||
|   fprintf (stderr, _("%s: error:"), program_name); | ||||
|   fprintf (stderr, " "); | ||||
|   va_start (ap, fmt); | ||||
|   vfprintf (stderr, fmt, ap); | ||||
|   va_end (ap); | ||||
|   fprintf (stderr, ".\n"); | ||||
|   exit (1); | ||||
| } | ||||
| 
 | ||||
| #ifdef GRUB_UTIL | ||||
| int | ||||
| grub_err_printf (const char *fmt, ...) | ||||
|  | @ -125,41 +73,6 @@ grub_err_printf (const char *fmt, ...) | |||
| } | ||||
| #endif | ||||
| 
 | ||||
| void * | ||||
| xmalloc (size_t size) | ||||
| { | ||||
|   void *p; | ||||
| 
 | ||||
|   p = malloc (size); | ||||
|   if (! p) | ||||
|     grub_util_error ("out of memory"); | ||||
| 
 | ||||
|   return p; | ||||
| } | ||||
| 
 | ||||
| void * | ||||
| xrealloc (void *ptr, size_t size) | ||||
| { | ||||
|   ptr = realloc (ptr, size); | ||||
|   if (! ptr) | ||||
|     grub_util_error ("out of memory"); | ||||
| 
 | ||||
|   return ptr; | ||||
| } | ||||
| 
 | ||||
| char * | ||||
| xstrdup (const char *str) | ||||
| { | ||||
|   size_t len; | ||||
|   char *newstr; | ||||
| 
 | ||||
|   len = strlen (str); | ||||
|   newstr = (char *) xmalloc (len + 1); | ||||
|   memcpy (newstr, str, len + 1); | ||||
| 
 | ||||
|   return newstr; | ||||
| } | ||||
| 
 | ||||
| char * | ||||
| grub_util_get_path (const char *dir, const char *file) | ||||
| { | ||||
|  | @ -282,34 +195,6 @@ grub_register_exported_symbols (void) | |||
| } | ||||
| #endif | ||||
| 
 | ||||
| void | ||||
| grub_exit (void) | ||||
| { | ||||
|   exit (1); | ||||
| } | ||||
| 
 | ||||
| grub_uint32_t | ||||
| grub_get_rtc (void) | ||||
| { | ||||
|   struct timeval tv; | ||||
| 
 | ||||
|   gettimeofday (&tv, 0); | ||||
| 
 | ||||
|   return (tv.tv_sec * GRUB_TICKS_PER_SECOND | ||||
| 	  + (((tv.tv_sec % GRUB_TICKS_PER_SECOND) * 1000000 + tv.tv_usec) | ||||
| 	     * GRUB_TICKS_PER_SECOND / 1000000)); | ||||
| } | ||||
| 
 | ||||
| grub_uint64_t | ||||
| grub_get_time_ms (void) | ||||
| { | ||||
|   struct timeval tv; | ||||
| 
 | ||||
|   gettimeofday (&tv, 0); | ||||
| 
 | ||||
|   return (tv.tv_sec * 1000 + tv.tv_usec / 1000); | ||||
| } | ||||
| 
 | ||||
| #ifdef __MINGW32__ | ||||
| 
 | ||||
| void | ||||
|  | @ -340,53 +225,6 @@ grub_arch_sync_caches (void *address __attribute__ ((unused)), | |||
| } | ||||
| #endif | ||||
| 
 | ||||
| #ifndef HAVE_VASPRINTF | ||||
| 
 | ||||
| int | ||||
| vasprintf (char **buf, const char *fmt, va_list ap) | ||||
| { | ||||
|   /* Should be large enough.  */ | ||||
|   *buf = xmalloc (512); | ||||
| 
 | ||||
|   return vsprintf (*buf, fmt, ap); | ||||
| } | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef  HAVE_ASPRINTF | ||||
| 
 | ||||
| int | ||||
| asprintf (char **buf, const char *fmt, ...) | ||||
| { | ||||
|   int status; | ||||
|   va_list ap; | ||||
| 
 | ||||
|   va_start (ap, fmt); | ||||
|   status = vasprintf (*buf, fmt, ap); | ||||
|   va_end (ap); | ||||
| 
 | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| char * | ||||
| xasprintf (const char *fmt, ...) | ||||
| { | ||||
|   va_list ap; | ||||
|   char *result; | ||||
| 
 | ||||
|   va_start (ap, fmt); | ||||
|   if (vasprintf (&result, fmt, ap) < 0) | ||||
|     { | ||||
|       if (errno == ENOMEM) | ||||
| 	grub_util_error ("out of memory"); | ||||
|       return NULL; | ||||
|     } | ||||
| 
 | ||||
|   return result; | ||||
| } | ||||
| 
 | ||||
| #ifdef __MINGW32__ | ||||
| 
 | ||||
| void sync (void) | ||||
|  | @ -461,125 +299,6 @@ canonicalize_file_name (const char *path) | |||
|   return ret; | ||||
| } | ||||
| 
 | ||||
| #ifdef __CYGWIN__ | ||||
| /* Convert POSIX path to Win32 path,
 | ||||
|    remove drive letter, replace backslashes.  */ | ||||
| static char * | ||||
| get_win32_path (const char *path) | ||||
| { | ||||
|   char winpath[PATH_MAX]; | ||||
|   if (cygwin_conv_path (CCP_POSIX_TO_WIN_A, path, winpath, sizeof(winpath))) | ||||
|     grub_util_error ("cygwin_conv_path() failed"); | ||||
| 
 | ||||
|   int len = strlen (winpath); | ||||
|   int offs = (len > 2 && winpath[1] == ':' ? 2 : 0); | ||||
| 
 | ||||
|   int i; | ||||
|   for (i = offs; i < len; i++) | ||||
|     if (winpath[i] == '\\') | ||||
|       winpath[i] = '/'; | ||||
|   return xstrdup (winpath + offs); | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| /* This function never prints trailing slashes (so that its output
 | ||||
|    can be appended a slash unconditionally).  */ | ||||
| char * | ||||
| make_system_path_relative_to_its_root (const char *path) | ||||
| { | ||||
|   struct stat st; | ||||
|   char *p, *buf, *buf2, *buf3; | ||||
|   uintptr_t offset = 0; | ||||
|   dev_t num; | ||||
|   size_t len; | ||||
| 
 | ||||
|   /* canonicalize.  */ | ||||
|   p = canonicalize_file_name (path); | ||||
| 
 | ||||
|   if (p == NULL) | ||||
|     grub_util_error ("failed to get canonical path of %s", path); | ||||
| 
 | ||||
|   len = strlen (p) + 1; | ||||
|   buf = xstrdup (p); | ||||
|   free (p); | ||||
| 
 | ||||
|   if (stat (buf, &st) < 0) | ||||
|     grub_util_error ("cannot stat %s: %s", buf, strerror (errno)); | ||||
| 
 | ||||
|   buf2 = xstrdup (buf); | ||||
|   num = st.st_dev; | ||||
| 
 | ||||
|   /* This loop sets offset to the number of chars of the root
 | ||||
|      directory we're inspecting.  */ | ||||
|   while (1) | ||||
|     { | ||||
|       p = strrchr (buf, '/'); | ||||
|       if (p == NULL) | ||||
| 	/* This should never happen.  */ | ||||
| 	grub_util_error ("FIXME: no / in buf. (make_system_path_relative_to_its_root)"); | ||||
|       if (p != buf) | ||||
| 	*p = 0; | ||||
|       else | ||||
| 	*++p = 0; | ||||
| 
 | ||||
|       if (stat (buf, &st) < 0) | ||||
| 	grub_util_error ("cannot stat %s: %s", buf, strerror (errno)); | ||||
| 
 | ||||
|       /* buf is another filesystem; we found it.  */ | ||||
|       if (st.st_dev != num) | ||||
| 	{ | ||||
| 	  /* offset == 0 means path given is the mount point.
 | ||||
| 	     This works around special-casing of "/" in Un*x.  This function never | ||||
| 	     prints trailing slashes (so that its output can be appended a slash | ||||
| 	     unconditionally).  Each slash in is considered a preceding slash, and | ||||
| 	     therefore the root directory is an empty string.  */ | ||||
| 	  if (offset == 0) | ||||
| 	    { | ||||
| 	      free (buf); | ||||
| 	      free (buf2); | ||||
| 	      return xstrdup (""); | ||||
| 	    } | ||||
| 	  else | ||||
| 	    break; | ||||
| 	} | ||||
| 
 | ||||
|       offset = p - buf; | ||||
|       /* offset == 1 means root directory.  */ | ||||
|       if (offset == 1) | ||||
| 	{ | ||||
| 	  /* Include leading slash.  */ | ||||
| 	  offset = 0; | ||||
| 	  break; | ||||
| 	} | ||||
|     } | ||||
|   free (buf); | ||||
|   buf3 = xstrdup (buf2 + offset); | ||||
|   free (buf2); | ||||
| 
 | ||||
| #ifdef __CYGWIN__ | ||||
|   if (st.st_dev != (DEV_CYGDRIVE_MAJOR << 16)) | ||||
|     { | ||||
|       /* Reached some mount point not below /cygdrive.
 | ||||
| 	 GRUB does not know Cygwin's emulated mounts, | ||||
| 	 convert to Win32 path.  */ | ||||
|       grub_util_info ("Cygwin path = %s\n", buf3); | ||||
|       char * temp = get_win32_path (buf3); | ||||
|       free (buf3); | ||||
|       buf3 = temp; | ||||
|     } | ||||
| #endif | ||||
| 
 | ||||
|   /* Remove trailing slashes, return empty string if root directory.  */ | ||||
|   len = strlen (buf3); | ||||
|   while (len > 0 && buf3[len - 1] == '/') | ||||
|     { | ||||
|       buf3[len - 1] = '\0'; | ||||
|       len--; | ||||
|     } | ||||
| 
 | ||||
|   return buf3; | ||||
| } | ||||
| 
 | ||||
| #ifdef GRUB_UTIL | ||||
| void | ||||
| grub_util_init_nls (void) | ||||
|  | @ -591,3 +310,17 @@ grub_util_init_nls (void) | |||
| #endif /* (defined(ENABLE_NLS) && ENABLE_NLS) */ | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| int | ||||
| grub_dl_ref (grub_dl_t mod) | ||||
| { | ||||
|   (void) mod; | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| int | ||||
| grub_dl_unref (grub_dl_t mod) | ||||
| { | ||||
|   (void) mod; | ||||
|   return 0; | ||||
| } | ||||
|  |  | |||
|  | @ -1,20 +0,0 @@ | |||
| /*
 | ||||
|  * 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 		PACKAGE_NAME " 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 | ||||
| #define  SYSTEM_ID_DEFAULT 	"GNU" | ||||
|  | @ -1,343 +0,0 @@ | |||
| /*
 | ||||
|  * 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}; | ||||
|  | @ -1,10 +0,0 @@ | |||
| /*
 | ||||
|  * 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)); | ||||
|  | @ -1,225 +0,0 @@ | |||
| /*
 | ||||
|  * 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; | ||||
| 	 | ||||
| 	} | ||||
| } | ||||
|  | @ -1,57 +0,0 @@ | |||
| /* @(#)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 */ | ||||
|  | @ -1,253 +0,0 @@ | |||
| /* @(#)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 */ | ||||
|  | @ -1,74 +0,0 @@ | |||
| /* @(#)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 */ | ||||
|  | @ -1,139 +0,0 @@ | |||
| /* @(#)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 */ | ||||
| 
 | ||||
|  | @ -1,174 +0,0 @@ | |||
| /*
 | ||||
|  * 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 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -1,76 +0,0 @@ | |||
| /*
 | ||||
|  *  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); | ||||
| } | ||||
|  | @ -1,29 +0,0 @@ | |||
| /*
 | ||||
|  *  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 (); | ||||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -1,530 +0,0 @@ | |||
| /*
 | ||||
|  * Header file mkisofs.h - assorted structure definitions and typecasts. | ||||
| 
 | ||||
|    Written by Eric Youngdale (1993). | ||||
| 
 | ||||
|    Copyright 1993 Yggdrasil Computing, Incorporated | ||||
| 
 | ||||
|    Copyright (C) 2009,2010  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> | ||||
| 
 | ||||
| #if (defined(ENABLE_NLS) && ENABLE_NLS) | ||||
| 
 | ||||
| #  include <locale.h> | ||||
| #  include <libintl.h> | ||||
| 
 | ||||
| #else /* ! (defined(ENABLE_NLS) && ENABLE_NLS) */ | ||||
| 
 | ||||
| /* Disabled NLS.
 | ||||
|    The casts to 'const char *' serve the purpose of producing warnings | ||||
|    for invalid uses of the value returned from these functions. | ||||
|    On pre-ANSI systems without 'const', the config.h file is supposed to | ||||
|    contain "#define const".  */ | ||||
| #  define gettext(Msgid) ((const char *) (Msgid)) | ||||
| #endif /* (defined(ENABLE_NLS) && ENABLE_NLS) */ | ||||
| 
 | ||||
| #define _(str) gettext(str) | ||||
| #define N_(str) 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_embedded_boot; | ||||
| extern int use_protective_msdos_label; | ||||
| 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 char *boot_image_embed; | ||||
| 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 | ||||
|  | @ -1,75 +0,0 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 1999,2000,2001,2002,2004,2007  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #ifndef MSDOS_PARTITION_H | ||||
| #define MSDOS_PARTITION_H	1 | ||||
| 
 | ||||
| #include <stdint.h> | ||||
| 
 | ||||
| /* The signature.  */ | ||||
| #define MSDOS_PARTITION_SIGNATURE		((0xaa << 8) | 0x55) | ||||
| 
 | ||||
| /* This is not a flag actually, but used as if it were a flag.  */ | ||||
| #define MSDOS_PARTITION_TYPE_HIDDEN_FLAG	0x10 | ||||
| 
 | ||||
| /* The partition entry.  */ | ||||
| struct msdos_partition_entry | ||||
| { | ||||
|   /* If active, 0x80, otherwise, 0x00.  */ | ||||
|   uint8_t flag; | ||||
| 
 | ||||
|   /* The head of the start.  */ | ||||
|   uint8_t start_head; | ||||
| 
 | ||||
|   /* (S | ((C >> 2) & 0xC0)) where S is the sector of the start and C
 | ||||
|      is the cylinder of the start. Note that S is counted from one.  */ | ||||
|   uint8_t start_sector; | ||||
| 
 | ||||
|   /* (C & 0xFF) where C is the cylinder of the start.  */ | ||||
|   uint8_t start_cylinder; | ||||
| 
 | ||||
|   /* The partition type.  */ | ||||
|   uint8_t type; | ||||
| 
 | ||||
|   /* The end versions of start_head, start_sector and start_cylinder,
 | ||||
|      respectively.  */ | ||||
|   uint8_t end_head; | ||||
|   uint8_t end_sector; | ||||
|   uint8_t end_cylinder; | ||||
| 
 | ||||
|   /* The start sector. Note that this is counted from zero.  */ | ||||
|   uint32_t start; | ||||
| 
 | ||||
|   /* The length in sector units.  */ | ||||
|   uint32_t length; | ||||
| } __attribute__ ((packed)); | ||||
| 
 | ||||
| /* The structure of MBR.  */ | ||||
| struct msdos_partition_mbr | ||||
| { | ||||
|   /* The code area (actually, including BPB).  */ | ||||
|   uint8_t code[446]; | ||||
| 
 | ||||
|   /* Four partition entries.  */ | ||||
|   struct msdos_partition_entry entries[4]; | ||||
| 
 | ||||
|   /* The signature 0xaa55.  */ | ||||
|   uint16_t signature; | ||||
| } __attribute__ ((packed)); | ||||
| 
 | ||||
| #endif | ||||
							
								
								
									
										1201
									
								
								util/mkisofs/multi.c
									
										
									
									
									
								
							
							
						
						
									
										1201
									
								
								util/mkisofs/multi.c
									
										
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -1,394 +0,0 @@ | |||
| /*
 | ||||
|  * 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); | ||||
| } | ||||
|  | @ -1,597 +0,0 @@ | |||
| /*
 | ||||
|  * File rock.c - generate RRIP  records for iso9660 filesystems. | ||||
| 
 | ||||
|    Written by Eric Youngdale (1993). | ||||
| 
 | ||||
|    Copyright 1993 Yggdrasil Computing, Incorporated | ||||
| 
 | ||||
|    Copyright (C) 2009,2010  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' too 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
									
										
									
									
									
								
							
							
						
						
									
										1865
									
								
								util/mkisofs/tree.c
									
										
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										1483
									
								
								util/mkisofs/write.c
									
										
									
									
									
								
							
							
						
						
									
										1483
									
								
								util/mkisofs/write.c
									
										
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										85
									
								
								util/mm.c
									
										
									
									
									
								
							
							
						
						
									
										85
									
								
								util/mm.c
									
										
									
									
									
								
							|  | @ -1,85 +0,0 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2002,2003,2005,2006,2007,2008,2009,2010  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include <grub/types.h> | ||||
| #include <grub/err.h> | ||||
| #include <grub/mm.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| 
 | ||||
| void * | ||||
| grub_malloc (grub_size_t size) | ||||
| { | ||||
|   void *ret; | ||||
|   ret = malloc (size); | ||||
|   if (!ret) | ||||
|     grub_error (GRUB_ERR_OUT_OF_MEMORY, "out of memory"); | ||||
|   return ret; | ||||
| } | ||||
| 
 | ||||
| void * | ||||
| grub_zalloc (grub_size_t size) | ||||
| { | ||||
|   void *ret; | ||||
| 
 | ||||
|   ret = grub_malloc (size); | ||||
|   if (!ret) | ||||
|     return NULL; | ||||
|   memset (ret, 0, size); | ||||
|   return ret; | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_free (void *ptr) | ||||
| { | ||||
|   free (ptr); | ||||
| } | ||||
| 
 | ||||
| void * | ||||
| grub_realloc (void *ptr, grub_size_t size) | ||||
| { | ||||
|   void *ret; | ||||
|   ret = realloc (ptr, size); | ||||
|   if (!ret) | ||||
|     grub_error (GRUB_ERR_OUT_OF_MEMORY, "out of memory"); | ||||
|   return ret; | ||||
| } | ||||
| 
 | ||||
| void * | ||||
| grub_memalign (grub_size_t align, grub_size_t size) | ||||
| { | ||||
|   void *p; | ||||
| 
 | ||||
| #if defined(HAVE_POSIX_MEMALIGN) | ||||
|   if (align < sizeof (void *)) | ||||
|     align = sizeof (void *); | ||||
|   if (posix_memalign (&p, align, size) != 0) | ||||
|     p = 0; | ||||
| #elif defined(HAVE_MEMALIGN) | ||||
|   p = memalign (align, size); | ||||
| #else | ||||
|   (void) align; | ||||
|   (void) size; | ||||
|   grub_util_error ("grub_memalign is not supported"); | ||||
| #endif | ||||
| 
 | ||||
|   if (!p) | ||||
|     grub_error (GRUB_ERR_OUT_OF_MEMORY, "out of memory"); | ||||
| 
 | ||||
|   return p; | ||||
| } | ||||
							
								
								
									
										76
									
								
								util/pci.c
									
										
									
									
									
								
							
							
						
						
									
										76
									
								
								util/pci.c
									
										
									
									
									
								
							|  | @ -1,76 +0,0 @@ | |||
| /* pci.c - Generic PCI interfaces.  */ | ||||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2007,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/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include <grub/pci.h> | ||||
| #include <grub/dl.h> | ||||
| #include <grub/util/misc.h> | ||||
| 
 | ||||
| grub_pci_address_t | ||||
| grub_pci_make_address (grub_pci_device_t dev, int reg) | ||||
| { | ||||
|   grub_pci_address_t ret; | ||||
|   ret.dev = dev; | ||||
|   ret.pos = reg; | ||||
|   return ret; | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_pci_iterate (grub_pci_iteratefunc_t hook) | ||||
| { | ||||
|   struct pci_device_iterator *iter; | ||||
|   struct pci_slot_match slot; | ||||
|   struct pci_device *dev; | ||||
|   slot.domain = PCI_MATCH_ANY; | ||||
|   slot.bus = PCI_MATCH_ANY; | ||||
|   slot.dev = PCI_MATCH_ANY; | ||||
|   slot.func = PCI_MATCH_ANY; | ||||
|   iter = pci_slot_match_iterator_create (&slot); | ||||
|   while ((dev = pci_device_next (iter))) | ||||
|     hook (dev, dev->vendor_id | (dev->device_id << 16)); | ||||
|   pci_iterator_destroy (iter); | ||||
| } | ||||
| 
 | ||||
| void * | ||||
| grub_pci_device_map_range (grub_pci_device_t dev, grub_addr_t base, | ||||
| 			   grub_size_t size) | ||||
| { | ||||
|   void *addr; | ||||
|   int err; | ||||
|   err = pci_device_map_range (dev, base, size, PCI_DEV_MAP_FLAG_WRITABLE, &addr); | ||||
|   if (err) | ||||
|     grub_util_error ("mapping 0x%x failed (error %d)\n", base, err); | ||||
|   return addr; | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_pci_device_unmap_range (grub_pci_device_t dev, void *mem, | ||||
| 			     grub_size_t size) | ||||
| { | ||||
|   pci_device_unmap_range (dev, mem, size); | ||||
| } | ||||
| 
 | ||||
| GRUB_MOD_INIT (pci) | ||||
| { | ||||
|   pci_system_init (); | ||||
| } | ||||
| 
 | ||||
| GRUB_MOD_FINI (pci) | ||||
| { | ||||
|   pci_system_cleanup (); | ||||
| } | ||||
							
								
								
									
										237
									
								
								util/sdl.c
									
										
									
									
									
								
							
							
						
						
									
										237
									
								
								util/sdl.c
									
										
									
									
									
								
							|  | @ -1,237 +0,0 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2005,2006,2007,2008,2009  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #define grub_video_render_target grub_video_fbrender_target | ||||
| 
 | ||||
| #include <grub/err.h> | ||||
| #include <grub/types.h> | ||||
| #include <grub/dl.h> | ||||
| #include <grub/misc.h> | ||||
| #include <grub/mm.h> | ||||
| #include <grub/video.h> | ||||
| #include <grub/video_fb.h> | ||||
| #include <SDL/SDL.h> | ||||
| 
 | ||||
| static SDL_Surface *window = 0; | ||||
| static struct grub_video_render_target *sdl_render_target; | ||||
| static struct grub_video_mode_info mode_info; | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_video_sdl_set_palette (unsigned int start, unsigned int count, | ||||
|                             struct grub_video_palette_data *palette_data); | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_video_sdl_init (void) | ||||
| { | ||||
|   window = 0; | ||||
| 
 | ||||
|   if (SDL_Init (SDL_INIT_VIDEO) < 0) | ||||
|     return grub_error (GRUB_ERR_BAD_DEVICE, "Couldn't init SDL: %s", | ||||
| 		       SDL_GetError ()); | ||||
| 
 | ||||
|   grub_memset (&mode_info, 0, sizeof (mode_info)); | ||||
| 
 | ||||
|   return grub_video_fb_init (); | ||||
| } | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_video_sdl_fini (void) | ||||
| { | ||||
|   SDL_Quit (); | ||||
|   window = 0; | ||||
| 
 | ||||
|   grub_memset (&mode_info, 0, sizeof (mode_info)); | ||||
| 
 | ||||
|   return grub_video_fb_fini (); | ||||
| } | ||||
| 
 | ||||
| static inline unsigned int | ||||
| get_mask_size (grub_uint32_t mask) | ||||
| { | ||||
|   unsigned i; | ||||
|   for (i = 0; mask > 1U << i; i++); | ||||
|   return i; | ||||
| } | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_video_sdl_setup (unsigned int width, unsigned int height, | ||||
|                       unsigned int mode_type, unsigned int mode_mask) | ||||
| { | ||||
|   int depth; | ||||
|   int flags = 0; | ||||
|   grub_err_t err; | ||||
| 
 | ||||
|   /* Decode depth from mode_type.  If it is zero, then autodetect.  */ | ||||
|   depth = (mode_type & GRUB_VIDEO_MODE_TYPE_DEPTH_MASK) | ||||
|           >> GRUB_VIDEO_MODE_TYPE_DEPTH_POS; | ||||
| 
 | ||||
|   if (depth == 0) | ||||
|     depth = 32; | ||||
| 
 | ||||
|   if (width == 0 && height == 0) | ||||
|     { | ||||
|       width = 800; | ||||
|       height = 600; | ||||
|     } | ||||
| 
 | ||||
|   if ((mode_type & GRUB_VIDEO_MODE_TYPE_DOUBLE_BUFFERED) | ||||
|       || !(mode_mask & GRUB_VIDEO_MODE_TYPE_DOUBLE_BUFFERED)) | ||||
|     flags |= SDL_DOUBLEBUF; | ||||
| 
 | ||||
|   window = SDL_SetVideoMode (width, height, depth, flags | SDL_HWSURFACE); | ||||
|   if (! window) | ||||
|     window = SDL_SetVideoMode (width, height, depth, flags | SDL_SWSURFACE); | ||||
|   if (! window) | ||||
|     return grub_error (GRUB_ERR_BAD_DEVICE, "Couldn't open window: %s", | ||||
| 		       SDL_GetError ()); | ||||
| 
 | ||||
|   grub_memset (&sdl_render_target, 0, sizeof (sdl_render_target)); | ||||
| 
 | ||||
|   mode_info.width = window->w; | ||||
|   mode_info.height = window->h; | ||||
|   mode_info.mode_type = 0; | ||||
|   if (window->flags & SDL_DOUBLEBUF) | ||||
|     mode_info.mode_type | ||||
|       |= GRUB_VIDEO_MODE_TYPE_DOUBLE_BUFFERED; | ||||
|   if (window->format->palette) | ||||
|     mode_info.mode_type |= GRUB_VIDEO_MODE_TYPE_INDEX_COLOR; | ||||
|   else | ||||
|     mode_info.mode_type |= GRUB_VIDEO_MODE_TYPE_RGB; | ||||
| 
 | ||||
|   mode_info.bpp = window->format->BitsPerPixel; | ||||
|   mode_info.bytes_per_pixel = window->format->BytesPerPixel; | ||||
|   mode_info.pitch = window->pitch; | ||||
| 
 | ||||
|   /* In index color mode, number of colors.  In RGB mode this is 256.  */ | ||||
|   if (window->format->palette) | ||||
|     mode_info.number_of_colors | ||||
|       = 1 << window->format->BitsPerPixel; | ||||
|   else | ||||
|     mode_info.number_of_colors = 256; | ||||
| 
 | ||||
|   if (! window->format->palette) | ||||
|     { | ||||
|       mode_info.red_mask_size | ||||
| 	= get_mask_size (window->format->Rmask >> window->format->Rshift); | ||||
|       mode_info.red_field_pos = window->format->Rshift; | ||||
|       mode_info.green_mask_size | ||||
| 	= get_mask_size (window->format->Gmask >> window->format->Gshift); | ||||
|       mode_info.green_field_pos = window->format->Gshift; | ||||
|       mode_info.blue_mask_size | ||||
| 	= get_mask_size (window->format->Bmask >> window->format->Bshift); | ||||
|       mode_info.blue_field_pos = window->format->Bshift; | ||||
|       mode_info.reserved_mask_size | ||||
| 	= get_mask_size (window->format->Amask >> window->format->Ashift); | ||||
|       mode_info.reserved_field_pos = window->format->Ashift; | ||||
|       mode_info.blit_format | ||||
| 	= grub_video_get_blit_format (&mode_info); | ||||
|     } | ||||
| 
 | ||||
|   err = grub_video_fb_create_render_target_from_pointer (&sdl_render_target, | ||||
| 							 &mode_info, | ||||
| 							 window->pixels); | ||||
|   if (err) | ||||
|     return err; | ||||
| 
 | ||||
|   /* Copy default palette to initialize emulated palette.  */ | ||||
|   grub_video_sdl_set_palette (0, (sizeof (grub_video_fbstd_colors) | ||||
| 				  / sizeof (grub_video_fbstd_colors[0])), | ||||
| 			      grub_video_fbstd_colors); | ||||
| 
 | ||||
|   /* Reset render target to SDL one.  */ | ||||
|   return grub_video_fb_set_active_render_target (sdl_render_target); | ||||
| } | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_video_sdl_set_palette (unsigned int start, unsigned int count, | ||||
|                             struct grub_video_palette_data *palette_data) | ||||
| { | ||||
|   unsigned i; | ||||
|   if (window->format->palette) | ||||
|     { | ||||
|       SDL_Color *tmp = grub_malloc (count * sizeof (tmp[0])); | ||||
|       for (i = 0; i < count; i++) | ||||
| 	{ | ||||
| 	  tmp[i].r = palette_data[i].r; | ||||
| 	  tmp[i].g = palette_data[i].g; | ||||
| 	  tmp[i].b = palette_data[i].b; | ||||
| 	  tmp[i].unused = palette_data[i].a; | ||||
| 	} | ||||
|       SDL_SetColors (window, tmp, start, count); | ||||
|       grub_free (tmp); | ||||
|     } | ||||
| 
 | ||||
|   return grub_video_fb_set_palette (start, count, palette_data); | ||||
| } | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_video_sdl_swap_buffers (void) | ||||
| { | ||||
|   if (SDL_Flip (window) < 0) | ||||
|     return grub_error (GRUB_ERR_BAD_DEVICE, "couldn't swap buffers: %s", | ||||
| 		       SDL_GetError ()); | ||||
|   return GRUB_ERR_NONE; | ||||
| } | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_video_sdl_set_active_render_target (struct grub_video_render_target *target) | ||||
| { | ||||
|   if (target == GRUB_VIDEO_RENDER_TARGET_DISPLAY) | ||||
|     return grub_video_fb_set_active_render_target (sdl_render_target); | ||||
| 
 | ||||
|   return grub_video_fb_set_active_render_target (target); | ||||
| } | ||||
| 
 | ||||
| static struct grub_video_adapter grub_video_sdl_adapter = | ||||
|   { | ||||
|     .name = "SDL Video Driver", | ||||
| 
 | ||||
|     .init = grub_video_sdl_init, | ||||
|     .fini = grub_video_sdl_fini, | ||||
|     .setup = grub_video_sdl_setup, | ||||
|     .get_info = grub_video_fb_get_info, | ||||
|     .set_palette = grub_video_sdl_set_palette, | ||||
|     .get_palette = grub_video_fb_get_palette, | ||||
|     .set_viewport = grub_video_fb_set_viewport, | ||||
|     .get_viewport = grub_video_fb_get_viewport, | ||||
|     .map_color = grub_video_fb_map_color, | ||||
|     .map_rgb = grub_video_fb_map_rgb, | ||||
|     .map_rgba = grub_video_fb_map_rgba, | ||||
|     .unmap_color = grub_video_fb_unmap_color, | ||||
|     .fill_rect = grub_video_fb_fill_rect, | ||||
|     .blit_bitmap = grub_video_fb_blit_bitmap, | ||||
|     .blit_render_target = grub_video_fb_blit_render_target, | ||||
|     .scroll = grub_video_fb_scroll, | ||||
|     .swap_buffers = grub_video_sdl_swap_buffers, | ||||
|     .create_render_target = grub_video_fb_create_render_target, | ||||
|     .delete_render_target = grub_video_fb_delete_render_target, | ||||
|     .set_active_render_target = grub_video_sdl_set_active_render_target, | ||||
|     .get_active_render_target = grub_video_fb_get_active_render_target, | ||||
| 
 | ||||
|     .next = 0 | ||||
|   }; | ||||
| 
 | ||||
| GRUB_MOD_INIT(sdl) | ||||
| { | ||||
|   grub_video_register (&grub_video_sdl_adapter); | ||||
| } | ||||
| 
 | ||||
| GRUB_MOD_FINI(sdl) | ||||
| { | ||||
|   grub_video_unregister (&grub_video_sdl_adapter); | ||||
| } | ||||
|  | @ -29,7 +29,7 @@ | |||
| #include <grub/msdos_partition.h> | ||||
| #include <grub/gpt_partition.h> | ||||
| #include <grub/env.h> | ||||
| #include <grub/util/hostdisk.h> | ||||
| #include <grub/emu/hostdisk.h> | ||||
| #include <grub/machine/boot.h> | ||||
| #include <grub/machine/kernel.h> | ||||
| #include <grub/term.h> | ||||
|  | @ -46,7 +46,7 @@ | |||
| #include <sys/types.h> | ||||
| #include <sys/stat.h> | ||||
| #include <dirent.h> | ||||
| #include <grub/util/getroot.h> | ||||
| #include <grub/emu/getroot.h> | ||||
| 
 | ||||
| #define _GNU_SOURCE	1 | ||||
| #include <getopt.h> | ||||
|  | @ -634,8 +634,8 @@ main (int argc, char *argv[]) | |||
| 
 | ||||
|   find_dest_dev (&ginfo, argv); | ||||
| 
 | ||||
|   ginfo.prefix = make_system_path_relative_to_its_root (ginfo.dir ? | ||||
| 							: DEFAULT_DIRECTORY); | ||||
|   ginfo.prefix = grub_make_system_path_relative_to_its_root (ginfo.dir ? | ||||
| 							     : DEFAULT_DIRECTORY); | ||||
| 
 | ||||
|   check_root_dev (&ginfo); | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										46
									
								
								util/time.c
									
										
									
									
									
								
							
							
						
						
									
										46
									
								
								util/time.c
									
										
									
									
									
								
							|  | @ -1,46 +0,0 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2010  Free Software Foundation, Inc. | ||||
|  * | ||||
|  *  GRUB is free software: you can redistribute it and/or modify | ||||
|  *  it under the terms of the GNU General Public License as published by | ||||
|  *  the Free Software Foundation, either version 3 of the License, or | ||||
|  *  (at your option) any later version. | ||||
|  * | ||||
|  *  GRUB is distributed in the hope that it will be useful, | ||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *  GNU General Public License for more details. | ||||
|  * | ||||
|  *  You should have received a copy of the GNU General Public License | ||||
|  *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include <grub/datetime.h> | ||||
| #include <time.h> | ||||
| 
 | ||||
| grub_err_t | ||||
| grub_get_datetime (struct grub_datetime *datetime) | ||||
| { | ||||
|   struct tm *mytm; | ||||
|   time_t mytime; | ||||
| 
 | ||||
|   mytime = time (&mytime); | ||||
|   mytm = gmtime (&mytime); | ||||
| 
 | ||||
|   datetime->year = mytm->tm_year + 1900; | ||||
|   datetime->month = mytm->tm_mon + 1; | ||||
|   datetime->day = mytm->tm_mday; | ||||
|   datetime->hour = mytm->tm_hour; | ||||
|   datetime->minute = mytm->tm_min; | ||||
|   datetime->second = mytm->tm_sec; | ||||
| 
 | ||||
|   return GRUB_ERR_NONE; | ||||
| } | ||||
| 
 | ||||
| grub_err_t | ||||
| grub_set_datetime (struct grub_datetime *datetime __attribute__ ((unused))) | ||||
| { | ||||
|   return grub_error (GRUB_ERR_NOT_IMPLEMENTED_YET, | ||||
| 		     "no clock setting routine available"); | ||||
| } | ||||
							
								
								
									
										195
									
								
								util/usb.c
									
										
									
									
									
								
							
							
						
						
									
										195
									
								
								util/usb.c
									
										
									
									
									
								
							|  | @ -1,195 +0,0 @@ | |||
| /*  usb.c -- libusb USB support for GRUB.  */ | ||||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 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/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include <config.h> | ||||
| #include <grub/misc.h> | ||||
| #include <grub/mm.h> | ||||
| #include <usb.h> | ||||
| #include <grub/usb.h> | ||||
| #include <grub/dl.h> | ||||
| 
 | ||||
|  | ||||
| static struct grub_usb_controller_dev usb_controller = | ||||
| { | ||||
|   .name = "libusb" | ||||
| }; | ||||
| 
 | ||||
| static struct grub_usb_device *grub_usb_devs[128]; | ||||
| 
 | ||||
| struct usb_bus *busses; | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_libusb_devices (void) | ||||
| 
 | ||||
| { | ||||
|   struct usb_bus *bus; | ||||
|   int last = 0; | ||||
| 
 | ||||
|   busses = usb_get_busses(); | ||||
| 
 | ||||
|   for (bus = busses; bus; bus = bus->next) | ||||
|     { | ||||
|       struct usb_device *usbdev; | ||||
|       struct grub_usb_device *dev; | ||||
| 
 | ||||
|       for (usbdev = bus->devices; usbdev; usbdev = usbdev->next) | ||||
| 	{ | ||||
| 	  struct usb_device_descriptor *desc = &usbdev->descriptor; | ||||
| 	  grub_err_t err; | ||||
| 
 | ||||
| 	  if (! desc->bcdUSB) | ||||
| 	    continue; | ||||
| 
 | ||||
| 	  dev = grub_malloc (sizeof (*dev)); | ||||
| 	  if (! dev) | ||||
| 	    return grub_errno; | ||||
| 
 | ||||
| 	  dev->data = usbdev; | ||||
| 
 | ||||
| 	  /* Fill in all descriptors.  */ | ||||
| 	  err = grub_usb_device_initialize (dev); | ||||
| 	  if (err) | ||||
| 	    { | ||||
| 	      grub_errno = GRUB_ERR_NONE; | ||||
| 	      continue; | ||||
| 	    } | ||||
| 
 | ||||
| 	  /* Register the device.  */ | ||||
| 	  grub_usb_devs[last++] = dev; | ||||
| 	} | ||||
|     } | ||||
| 
 | ||||
|   return GRUB_USB_ERR_NONE; | ||||
| } | ||||
| 
 | ||||
|  | ||||
| int | ||||
| grub_usb_iterate (int (*hook) (grub_usb_device_t dev)) | ||||
| { | ||||
|   int i; | ||||
| 
 | ||||
|   for (i = 0; i < 128; i++) | ||||
|     { | ||||
|       if (grub_usb_devs[i]) | ||||
| 	{ | ||||
| 	  if (hook (grub_usb_devs[i])) | ||||
| 	      return 1; | ||||
| 	} | ||||
|     } | ||||
| 
 | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| grub_usb_err_t | ||||
| grub_usb_root_hub (grub_usb_controller_t controller __attribute__((unused))) | ||||
| { | ||||
|   return GRUB_USB_ERR_NONE; | ||||
| } | ||||
| 
 | ||||
| grub_usb_err_t | ||||
| grub_usb_control_msg (grub_usb_device_t dev, grub_uint8_t reqtype, | ||||
| 		      grub_uint8_t request, grub_uint16_t value, | ||||
| 		      grub_uint16_t index, grub_size_t size, char *data) | ||||
| { | ||||
|   usb_dev_handle *devh; | ||||
|   struct usb_device *d = dev->data; | ||||
| 
 | ||||
|   devh = usb_open (d); | ||||
|   if (usb_control_msg (devh, reqtype, request, | ||||
| 		       value, index, data, size, 20) < 0) | ||||
|     { | ||||
|       usb_close (devh); | ||||
|       return GRUB_USB_ERR_STALL; | ||||
|     } | ||||
| 
 | ||||
|   usb_close (devh); | ||||
| 
 | ||||
|   return GRUB_USB_ERR_NONE; | ||||
| } | ||||
| 
 | ||||
| grub_usb_err_t | ||||
| grub_usb_bulk_read (grub_usb_device_t dev, | ||||
| 		    int endpoint, grub_size_t size, char *data) | ||||
| { | ||||
|   usb_dev_handle *devh; | ||||
|   struct usb_device *d = dev->data; | ||||
| 
 | ||||
|   devh = usb_open (d); | ||||
|   if (usb_claim_interface (devh, 0) < 1) | ||||
|     { | ||||
|       usb_close (devh); | ||||
|       return GRUB_USB_ERR_STALL; | ||||
|     } | ||||
| 
 | ||||
|   if (usb_bulk_read (devh, endpoint, data, size, 20) < 1) | ||||
|     { | ||||
|       usb_close (devh); | ||||
|       return GRUB_USB_ERR_STALL; | ||||
|     } | ||||
| 
 | ||||
|   usb_release_interface (devh, 0); | ||||
|   usb_close (devh); | ||||
| 
 | ||||
|   return GRUB_USB_ERR_NONE; | ||||
| } | ||||
| 
 | ||||
| grub_usb_err_t | ||||
| grub_usb_bulk_write (grub_usb_device_t dev, | ||||
| 		     int endpoint, grub_size_t size, char *data) | ||||
| { | ||||
|   usb_dev_handle *devh; | ||||
|   struct usb_device *d = dev->data; | ||||
| 
 | ||||
|   devh = usb_open (d); | ||||
|   if (usb_claim_interface (devh, 0) < 0) | ||||
|     goto fail; | ||||
| 
 | ||||
|   if (usb_bulk_write (devh, endpoint, data, size, 20) < 0) | ||||
|     goto fail; | ||||
| 
 | ||||
|   if (usb_release_interface (devh, 0) < 0) | ||||
|     goto fail; | ||||
| 
 | ||||
|   usb_close (devh); | ||||
| 
 | ||||
|   return GRUB_USB_ERR_NONE; | ||||
| 
 | ||||
|  fail: | ||||
|   usb_close (devh); | ||||
|   return GRUB_USB_ERR_STALL; | ||||
| } | ||||
| 
 | ||||
| GRUB_MOD_INIT (libusb) | ||||
| { | ||||
|   usb_init(); | ||||
|   usb_find_busses(); | ||||
|   usb_find_devices(); | ||||
| 
 | ||||
|   if (grub_libusb_devices ()) | ||||
|     return; | ||||
| 
 | ||||
|   grub_usb_controller_dev_register (&usb_controller); | ||||
| 
 | ||||
|   return; | ||||
| } | ||||
| 
 | ||||
| GRUB_MOD_FINI (libusb) | ||||
| { | ||||
|   return; | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue