]> git.ipfire.org Git - people/teissler/ipfire-2.x.git/blob - src/patches/grub-0.97-disk_geometry-1.patch
kernel: updated rpi patches to 091073b.
[people/teissler/ipfire-2.x.git] / src / patches / grub-0.97-disk_geometry-1.patch
1 Submitted By: Jim Gifford <jim@linuxfromscratch.org>
2 Date: 05-28-2006
3 Initial Package Version: 0.97
4 Upstream Status: Unknown
5 Origin: Fedora and Mandriva
6 Description: This patch fixes issues with disk geometry not being
7 detected properly. Part of this patch also fixes
8 gcc 4 compile errors, which are a part of the issue.
9
10 diff -Naur grub-0.97.orig/configure grub-0.97/configure
11 --- grub-0.97.orig/configure 2005-05-07 19:48:12.000000000 -0700
12 +++ grub-0.97/configure 2006-05-28 20:29:36.025466751 -0700
13 @@ -3485,9 +3485,9 @@
14 echo "$as_me:$LINENO: result: $size_flag" >&5
15 echo "${ECHO_T}$size_flag" >&6
16 if test "x$size_flag" = xyes; then
17 - STAGE2_CFLAGS="-Os"
18 + STAGE2_CFLAGS="-Os -fno-strict-aliasing"
19 else
20 - STAGE2_CFLAGS="-O2 -fno-strength-reduce -fno-unroll-loops"
21 + STAGE2_CFLAGS="-O2 -fno-strict-aliasing -fno-strength-reduce -fno-unroll-loops"
22 fi
23 # OpenBSD has a GCC extension for protecting applications from
24 # stack smashing attacks, but GRUB doesn't want this feature.
25 diff -Naur grub-0.97.orig/configure.ac grub-0.97/configure.ac
26 --- grub-0.97.orig/configure.ac 2005-05-07 19:36:03.000000000 -0700
27 +++ grub-0.97/configure.ac 2006-05-28 20:28:41.538819726 -0700
28 @@ -93,9 +93,9 @@
29 CFLAGS=$saved_CFLAGS
30 ])
31 if test "x$size_flag" = xyes; then
32 - STAGE2_CFLAGS="-Os"
33 + STAGE2_CFLAGS="-Os -fno-strict-aliasing"
34 else
35 - STAGE2_CFLAGS="-O2 -fno-strength-reduce -fno-unroll-loops"
36 + STAGE2_CFLAGS="-O2 -fno-strict-aliasing -fno-strength-reduce -fno-unroll-loops"
37 fi
38 # OpenBSD has a GCC extension for protecting applications from
39 # stack smashing attacks, but GRUB doesn't want this feature.
40 diff -Naur grub-0.97.orig/lib/device.c grub-0.97/lib/device.c
41 --- grub-0.97.orig/lib/device.c 2005-03-27 15:14:25.000000000 -0800
42 +++ grub-0.97/lib/device.c 2006-05-28 20:34:03.546804777 -0700
43 @@ -131,6 +131,152 @@
44 #include <shared.h>
45 #include <device.h>
46
47 +#if defined(__linux__)
48 +/* The 2.6 kernel has removed all of the geometry handling for IDE drives
49 + * that did fixups for LBA, etc. This means that the geometry we get
50 + * with the ioctl has a good chance of being wrong. So, we get to
51 + * also know about partition tables and try to read what the geometry
52 + * is there. *grumble* Very closely based on code from cfdisk
53 + */
54 +static void get_kernel_geometry(int fd, long long *cyl, int *heads, int *sectors) {
55 + struct hd_geometry hdg;
56 +
57 + if (ioctl (fd, HDIO_GETGEO, &hdg))
58 + return;
59 +
60 + *cyl = hdg.cylinders;
61 + *heads = hdg.heads;
62 + *sectors = hdg.sectors;
63 +}
64 +
65 +struct partition {
66 + unsigned char boot_ind; /* 0x80 - active */
67 + unsigned char head; /* starting head */
68 + unsigned char sector; /* starting sector */
69 + unsigned char cyl; /* starting cylinder */
70 + unsigned char sys_ind; /* What partition type */
71 + unsigned char end_head; /* end head */
72 + unsigned char end_sector; /* end sector */
73 + unsigned char end_cyl; /* end cylinder */
74 + unsigned char start4[4]; /* starting sector counting from 0 */
75 + unsigned char size4[4]; /* nr of sectors in partition */
76 +};
77 +
78 +#define ALIGNMENT 2
79 +typedef union {
80 + struct {
81 + unsigned char align[ALIGNMENT];
82 + unsigned char b[SECTOR_SIZE];
83 + } c;
84 + struct {
85 + unsigned char align[ALIGNMENT];
86 + unsigned char buffer[0x1BE];
87 + struct partition part[4];
88 + unsigned char magicflag[2];
89 + } p;
90 +} partition_table;
91 +
92 +#define PART_TABLE_FLAG0 0x55
93 +#define PART_TABLE_FLAG1 0xAA
94 +
95 +static void
96 +get_partition_table_geometry(partition_table *bufp, long long *cyl, int *heads,
97 + int *sectors) {
98 + struct partition *p;
99 + int i,h,s,hh,ss;
100 + int first = 1;
101 + int bad = 0;
102 +
103 + if (bufp->p.magicflag[0] != PART_TABLE_FLAG0 ||
104 + bufp->p.magicflag[1] != PART_TABLE_FLAG1) {
105 + /* Matthew Wilcox: slightly friendlier version of
106 + fatal(_("Bad signature on partition table"), 3);
107 + */
108 + fprintf(stderr, "Unknown partition table signature\n");
109 + return;
110 + }
111 +
112 + hh = ss = 0;
113 + for (i=0; i<4; i++) {
114 + p = &(bufp->p.part[i]);
115 + if (p->sys_ind != 0) {
116 + h = p->end_head + 1;
117 + s = (p->end_sector & 077);
118 + if (first) {
119 + hh = h;
120 + ss = s;
121 + first = 0;
122 + } else if (hh != h || ss != s)
123 + bad = 1;
124 + }
125 + }
126 +
127 + if (!first && !bad) {
128 + *heads = hh;
129 + *sectors = ss;
130 + }
131 +}
132 +
133 +static long long my_lseek (unsigned int fd, long long offset,
134 + unsigned int origin)
135 +{
136 +#if defined(__linux__) && (!defined(__GLIBC__) || \
137 + ((__GLIBC__ < 2) || ((__GLIBC__ == 2) && (__GLIBC_MINOR__ < 1))))
138 + /* Maybe libc doesn't have large file support. */
139 + loff_t offset, result;
140 + static int _llseek (uint filedes, ulong hi, ulong lo,
141 + loff_t *res, uint wh);
142 + _syscall5 (int, _llseek, uint, filedes, ulong, hi, ulong, lo,
143 + loff_t *, res, uint, wh);
144 +
145 + if (_llseek (fd, offset >> 32, offset & 0xffffffff, &result, SEEK_SET) < 0)
146 + return (long long) -1;
147 + return result;
148 +#else
149 + return lseek(fd, offset, SEEK_SET);
150 +#endif
151 +}
152 +
153 +static void get_linux_geometry (int fd, struct geometry *geom) {
154 + long long kern_cyl = 0; int kern_head = 0, kern_sectors = 0;
155 + long long pt_cyl = 0; int pt_head = 0, pt_sectors = 0;
156 + partition_table bufp;
157 + char *buff, *buf_unaligned;
158 +
159 + buf_unaligned = malloc(sizeof(partition_table) + 4095);
160 + buff = (char *) (((unsigned long)buf_unaligned + 4096 - 1) &
161 + (~(4096-1)));
162 +
163 + get_kernel_geometry(fd, &kern_cyl, &kern_head, &kern_sectors);
164 +
165 + if (my_lseek (fd, 0*SECTOR_SIZE, SEEK_SET) < 0) {
166 + fprintf(stderr, "Unable to seek");
167 + }
168 +
169 + if (read(fd, buff, SECTOR_SIZE) == SECTOR_SIZE) {
170 + memcpy(bufp.c.b, buff, SECTOR_SIZE);
171 + get_partition_table_geometry(&bufp, &pt_cyl, &pt_head, &pt_sectors);
172 + } else {
173 + fprintf(stderr, "Unable to read partition table: %s\n", strerror(errno));
174 + }
175 +
176 + if (pt_head && pt_sectors) {
177 + int cyl_size;
178 +
179 + geom->heads = pt_head;
180 + geom->sectors = pt_sectors;
181 + cyl_size = pt_head * pt_sectors;
182 + geom->cylinders = geom->total_sectors/cyl_size;
183 + } else {
184 + geom->heads = kern_head;
185 + geom->sectors = kern_sectors;
186 + geom->cylinders = kern_cyl;
187 + }
188 +
189 + return;
190 +}
191 +#endif
192 +
193 /* Get the geometry of a drive DRIVE. */
194 void
195 get_drive_geometry (struct geometry *geom, char **map, int drive)
196 @@ -151,21 +297,16 @@
197 #if defined(__linux__)
198 /* Linux */
199 {
200 - struct hd_geometry hdg;
201 unsigned long nr;
202 -
203 - if (ioctl (fd, HDIO_GETGEO, &hdg))
204 - goto fail;
205
206 if (ioctl (fd, BLKGETSIZE, &nr))
207 goto fail;
208
209 /* Got the geometry, so save it. */
210 - geom->cylinders = hdg.cylinders;
211 - geom->heads = hdg.heads;
212 - geom->sectors = hdg.sectors;
213 geom->total_sectors = nr;
214 -
215 + get_linux_geometry(fd, geom);
216 + if (!geom->heads && !geom->cylinders && !geom->sectors)
217 + goto fail;
218 goto success;
219 }
220
221 @@ -844,6 +985,7 @@
222 {
223 char dev[PATH_MAX]; /* XXX */
224 int fd;
225 + off_t offset = (off_t) sector * (off_t) SECTOR_SIZE;
226
227 if ((partition & 0x00FF00) != 0x00FF00)
228 {
229 @@ -870,35 +1012,13 @@
230 errnum = ERR_NO_PART;
231 return 0;
232 }
233 -
234 -#if defined(__linux__) && (!defined(__GLIBC__) || \
235 - ((__GLIBC__ < 2) || ((__GLIBC__ == 2) && (__GLIBC_MINOR__ < 1))))
236 - /* Maybe libc doesn't have large file support. */
237 - {
238 - loff_t offset, result;
239 - static int _llseek (uint filedes, ulong hi, ulong lo,
240 - loff_t *res, uint wh);
241 - _syscall5 (int, _llseek, uint, filedes, ulong, hi, ulong, lo,
242 - loff_t *, res, uint, wh);
243
244 - offset = (loff_t) sector * (loff_t) SECTOR_SIZE;
245 - if (_llseek (fd, offset >> 32, offset & 0xffffffff, &result, SEEK_SET))
246 - {
247 - errnum = ERR_DEV_VALUES;
248 - return 0;
249 - }
250 - }
251 -#else
252 - {
253 - off_t offset = (off_t) sector * (off_t) SECTOR_SIZE;
254
255 - if (lseek (fd, offset, SEEK_SET) != offset)
256 - {
257 - errnum = ERR_DEV_VALUES;
258 - return 0;
259 - }
260 - }
261 -#endif
262 + if (my_lseek(fd, offset, SEEK_SET) != offset)
263 + {
264 + errnum = ERR_DEV_VALUES;
265 + return 0;
266 + }
267
268 if (write (fd, buf, size * SECTOR_SIZE) != (size * SECTOR_SIZE))
269 {
270 diff -Naur grub-0.97.orig/stage2/Makefile.am grub-0.97/stage2/Makefile.am
271 --- grub-0.97.orig/stage2/Makefile.am 2005-02-02 12:37:35.000000000 -0800
272 +++ grub-0.97/stage2/Makefile.am 2006-05-28 20:28:41.590818435 -0700
273 @@ -24,7 +24,8 @@
274 -DGRUB_UTIL=1 -DFSYS_EXT2FS=1 -DFSYS_FAT=1 -DFSYS_FFS=1 \
275 -DFSYS_ISO9660=1 -DFSYS_JFS=1 -DFSYS_MINIX=1 -DFSYS_REISERFS=1 \
276 -DFSYS_UFS2=1 -DFSYS_VSTAFS=1 -DFSYS_XFS=1 \
277 - -DUSE_MD5_PASSWORDS=1 -DSUPPORT_SERIAL=1 -DSUPPORT_HERCULES=1
278 + -DUSE_MD5_PASSWORDS=1 -DSUPPORT_SERIAL=1 -DSUPPORT_HERCULES=1 \
279 + -fno-strict-aliasing
280
281 # Stage 2 and Stage 1.5's.
282 pkglibdir = $(libdir)/$(PACKAGE)/$(host_cpu)-$(host_vendor)
283 diff -Naur grub-0.97.orig/stage2/boot.c grub-0.97/stage2/boot.c
284 --- grub-0.97.orig/stage2/boot.c 2004-03-30 03:44:08.000000000 -0800
285 +++ grub-0.97/stage2/boot.c 2006-05-28 20:33:30.123638792 -0700
286 @@ -55,7 +55,7 @@
287 pu;
288 /* presuming that MULTIBOOT_SEARCH is large enough to encompass an
289 executable header */
290 - unsigned char buffer[MULTIBOOT_SEARCH];
291 + char buffer[MULTIBOOT_SEARCH];
292
293 /* sets the header pointer to point to the beginning of the
294 buffer by default */
295 @@ -98,7 +98,7 @@
296 /* ELF loading supported if multiboot, FreeBSD and NetBSD. */
297 if ((type == KERNEL_TYPE_MULTIBOOT
298 || pu.elf->e_ident[EI_OSABI] == ELFOSABI_FREEBSD
299 - || grub_strcmp (pu.elf->e_ident + EI_BRAND, "FreeBSD") == 0
300 + || grub_strcmp ((char *) pu.elf->e_ident + EI_BRAND, "FreeBSD") == 0
301 || suggested_type == KERNEL_TYPE_NETBSD)
302 && len > sizeof (Elf32_Ehdr)
303 && BOOTABLE_I386_ELF ((*((Elf32_Ehdr *) buffer))))
304 @@ -824,8 +824,12 @@
305 moveto = (mbi.mem_upper + 0x400) << 10;
306
307 moveto = (moveto - len) & 0xfffff000;
308 +#if 0
309 max_addr = (lh->header == LINUX_MAGIC_SIGNATURE && lh->version >= 0x0203
310 ? lh->initrd_addr_max : LINUX_INITRD_MAX_ADDRESS);
311 +#else
312 + max_addr = LINUX_INITRD_MAX_ADDRESS;
313 +#endif
314 if (moveto + len >= max_addr)
315 moveto = (max_addr - len) & 0xfffff000;
316
317 diff -Naur grub-0.97.orig/stage2/disk_io.c grub-0.97/stage2/disk_io.c
318 --- grub-0.97.orig/stage2/disk_io.c 2004-05-23 09:35:24.000000000 -0700
319 +++ grub-0.97/stage2/disk_io.c 2006-05-28 20:28:41.582818634 -0700
320 @@ -127,12 +127,19 @@
321 int filepos;
322 int filemax;
323
324 -static inline unsigned long
325 -log2 (unsigned long word)
326 +#define log2(n) ffz(~(n))
327 +
328 +/* include/asm-i386/bitops.h */
329 +/*
330 + * ffz = Find First Zero in word. Undefined if no zero exists,
331 + * so code should check against ~0UL first..
332 + */
333 +static __inline__ unsigned long
334 +ffz (unsigned long word)
335 {
336 - asm volatile ("bsfl %1,%0"
337 - : "=r" (word)
338 - : "r" (word));
339 + __asm__ ("bsfl %1,%0"
340 +: "=r" (word)
341 +: "r" (~word));
342 return word;
343 }
344
345 diff -Naur grub-0.97.orig/stage2/freebsd.h grub-0.97/stage2/freebsd.h
346 --- grub-0.97.orig/stage2/freebsd.h 2003-07-09 04:45:52.000000000 -0700
347 +++ grub-0.97/stage2/freebsd.h 2006-05-28 20:28:41.582818634 -0700
348 @@ -78,7 +78,7 @@
349 struct bootinfo
350 {
351 unsigned int bi_version;
352 - unsigned char *bi_kernelname;
353 + char *bi_kernelname;
354 struct nfs_diskless *bi_nfs_diskless;
355 /* End of fields that are always present. */
356 #define bi_endcommon bi_n_bios_used
357 diff -Naur grub-0.97.orig/stage2/fsys_fat.c grub-0.97/stage2/fsys_fat.c
358 --- grub-0.97.orig/stage2/fsys_fat.c 2005-03-15 08:52:00.000000000 -0800
359 +++ grub-0.97/stage2/fsys_fat.c 2006-05-28 20:28:41.582818634 -0700
360 @@ -54,12 +54,19 @@
361
362 #define FAT_CACHE_SIZE 2048
363
364 +#define log2(n) ffz(~(n))
365 +
366 +/* include/asm-i386/bitops.h */
367 +/*
368 + * ffz = Find First Zero in word. Undefined if no zero exists,
369 + * so code should check against ~0UL first..
370 + */
371 static __inline__ unsigned long
372 -log2 (unsigned long word)
373 +ffz (unsigned long word)
374 {
375 __asm__ ("bsfl %1,%0"
376 - : "=r" (word)
377 - : "r" (word));
378 +: "=r" (word)
379 +: "r" (~word));
380 return word;
381 }
382
383 diff -Naur grub-0.97.orig/stage2/fsys_iso9660.c grub-0.97/stage2/fsys_iso9660.c
384 --- grub-0.97.orig/stage2/fsys_iso9660.c 2004-05-11 05:11:19.000000000 -0700
385 +++ grub-0.97/stage2/fsys_iso9660.c 2006-05-28 20:28:41.582818634 -0700
386 @@ -55,13 +55,19 @@
387 #define RRCONT_BUF ((unsigned char *)(FSYS_BUF + 6144))
388 #define NAME_BUF ((unsigned char *)(FSYS_BUF + 8192))
389
390 +#define log2(n) ffz(~(n))
391
392 -static inline unsigned long
393 -log2 (unsigned long word)
394 +/* include/asm-i386/bitops.h */
395 +/*
396 + * ffz = Find First Zero in word. Undefined if no zero exists,
397 + * so code should check against ~0UL first..
398 + */
399 +static __inline__ unsigned long
400 +ffz (unsigned long word)
401 {
402 - asm volatile ("bsfl %1,%0"
403 - : "=r" (word)
404 - : "r" (word));
405 + __asm__ ("bsfl %1,%0"
406 +: "=r" (word)
407 +: "r" (~word));
408 return word;
409 }
410
411 @@ -120,7 +126,7 @@
412 break;
413 /* check ISO_VD_PRIMARY and ISO_STANDARD_ID */
414 if (PRIMDESC->type.l == ISO_VD_PRIMARY
415 - && !memcmp(PRIMDESC->id, ISO_STANDARD_ID, sizeof(PRIMDESC->id)))
416 + && !memcmp((char *) PRIMDESC->id, ISO_STANDARD_ID, sizeof(PRIMDESC->id)))
417 {
418 ISO_SUPER->vol_sector = sector;
419 INODE->file_start = 0;
420 @@ -175,7 +181,7 @@
421 for (; idr->length.l > 0;
422 idr = (struct iso_directory_record *)((char *)idr + idr->length.l) )
423 {
424 - const char *name = idr->name;
425 + const u_int8_t *name = idr->name;
426 unsigned int name_len = idr->name_len.l;
427
428 file_type = (idr->flags.l & 2) ? ISO_DIRECTORY : ISO_REGULAR;
429 @@ -198,7 +204,7 @@
430 rr_len = (idr->length.l - idr->name_len.l
431 - sizeof(struct iso_directory_record)
432 + sizeof(idr->name));
433 - rr_ptr.ptr = ((unsigned char *)idr + idr->name_len.l
434 + rr_ptr.ptr = ((char *)idr + idr->name_len.l
435 + sizeof(struct iso_directory_record)
436 - sizeof(idr->name));
437 if (rr_ptr.i & 1)
438 @@ -331,9 +337,9 @@
439 memcpy(NAME_BUF, name, name_len);
440 name = NAME_BUF;
441 }
442 - rr_ptr.ptr = RRCONT_BUF + ce_ptr->u.ce.offset.l;
443 + rr_ptr.ptr = (char *) RRCONT_BUF + ce_ptr->u.ce.offset.l;
444 rr_len = ce_ptr->u.ce.size.l;
445 - if (!iso9660_devread(ce_ptr->u.ce.extent.l, 0, ISO_SECTOR_SIZE, RRCONT_BUF))
446 + if (!iso9660_devread(ce_ptr->u.ce.extent.l, 0, ISO_SECTOR_SIZE, (char *) RRCONT_BUF))
447 {
448 errnum = 0; /* this is not fatal. */
449 break;
450 @@ -344,7 +350,7 @@
451
452 filemax = MAXINT;
453 if (name_len >= pathlen
454 - && !memcmp(name, dirname, pathlen))
455 + && !memcmp((char *) name, dirname, pathlen))
456 {
457 if (dirname[pathlen] == '/' || !print_possibilities)
458 {
459 @@ -381,7 +387,7 @@
460 print_possibilities = -print_possibilities;
461 memcpy(NAME_BUF, name, name_len);
462 NAME_BUF[name_len] = '\0';
463 - print_a_completion (NAME_BUF);
464 + print_a_completion ((char *) NAME_BUF);
465 #endif
466 }
467 }
468 diff -Naur grub-0.97.orig/stage2/fsys_reiserfs.c grub-0.97/stage2/fsys_reiserfs.c
469 --- grub-0.97.orig/stage2/fsys_reiserfs.c 2004-02-18 14:09:10.000000000 -0800
470 +++ grub-0.97/stage2/fsys_reiserfs.c 2006-05-28 20:28:41.586818535 -0700
471 @@ -365,13 +365,19 @@
472 #define JOURNAL_START ((__u32 *) (INFO + 1))
473 #define JOURNAL_END ((__u32 *) (FSYS_BUF + FSYS_BUFLEN))
474
475 +#define log2(n) ffz(~(n))
476
477 +/* include/asm-i386/bitops.h */
478 +/*
479 + * ffz = Find First Zero in word. Undefined if no zero exists,
480 + * so code should check against ~0UL first..
481 + */
482 static __inline__ unsigned long
483 -log2 (unsigned long word)
484 +ffz (unsigned long word)
485 {
486 __asm__ ("bsfl %1,%0"
487 - : "=r" (word)
488 - : "r" (word));
489 +: "=r" (word)
490 +: "r" (~word));
491 return word;
492 }
493
494 diff -Naur grub-0.97.orig/stage2/fsys_vstafs.c grub-0.97/stage2/fsys_vstafs.c
495 --- grub-0.97.orig/stage2/fsys_vstafs.c 2003-07-09 04:45:53.000000000 -0700
496 +++ grub-0.97/stage2/fsys_vstafs.c 2006-05-28 20:28:41.586818535 -0700
497 @@ -186,35 +186,35 @@
498 int
499 vstafs_read (char *addr, int len)
500 {
501 - struct alloc *a;
502 + struct alloc *b;
503 int size, ret = 0, offset, curr_len = 0;
504 - int curr_ext;
505 + int curr_exten;
506 char extent;
507 int ext_size;
508 char *curr_pos;
509
510 get_file_info (f_sector);
511 size = FILE_INFO->len-VSTAFS_START_DATA;
512 - a = FILE_INFO->blocks;
513 + b = FILE_INFO->blocks;
514
515 if (filepos > 0)
516 {
517 - if (filepos < a[0].a_len * 512 - VSTAFS_START_DATA)
518 + if (filepos < b[0].a_len * 512 - VSTAFS_START_DATA)
519 {
520 offset = filepos + VSTAFS_START_DATA;
521 extent = 0;
522 - curr_len = a[0].a_len * 512 - offset - filepos;
523 + curr_len = b[0].a_len * 512 - offset - filepos;
524 }
525 else
526 {
527 - ext_size = a[0].a_len * 512 - VSTAFS_START_DATA;
528 + ext_size = b[0].a_len * 512 - VSTAFS_START_DATA;
529 offset = filepos - ext_size;
530 extent = 1;
531 do
532 {
533 curr_len -= ext_size;
534 offset -= ext_size;
535 - ext_size = a[extent+1].a_len * 512;
536 + ext_size = b[extent+1].a_len * 512;
537 }
538 while (extent < FILE_INFO->extents && offset>ext_size);
539 }
540 @@ -223,16 +223,16 @@
541 {
542 offset = VSTAFS_START_DATA;
543 extent = 0;
544 - curr_len = a[0].a_len * 512 - offset;
545 + curr_len = b[0].a_len * 512 - offset;
546 }
547
548 curr_pos = addr;
549 if (curr_len > len)
550 curr_len = len;
551
552 - for (curr_ext=extent;
553 - curr_ext < FILE_INFO->extents;
554 - curr_len = a[curr_ext].a_len * 512, curr_pos += curr_len, curr_ext++)
555 + for (curr_exten = extent;
556 + curr_exten < FILE_INFO->extents;
557 + curr_len = b[curr_exten].a_len * 512, curr_pos += curr_len, curr_exten++)
558 {
559 ret += curr_len;
560 size -= curr_len;
561 @@ -242,7 +242,7 @@
562 curr_len += size;
563 }
564
565 - devread (a[curr_ext].a_start,offset, curr_len, curr_pos);
566 + devread (b[curr_exten].a_start, offset, curr_len, curr_pos);
567 offset = 0;
568 }
569
570 diff -Naur grub-0.97.orig/stage2/fsys_xfs.c grub-0.97/stage2/fsys_xfs.c
571 --- grub-0.97.orig/stage2/fsys_xfs.c 2005-05-07 19:15:55.000000000 -0700
572 +++ grub-0.97/stage2/fsys_xfs.c 2006-05-28 20:28:41.586818535 -0700
573 @@ -97,7 +97,7 @@
574 return ino & XFS_INO_MASK(XFS_INO_OFFSET_BITS);
575 }
576
577 -static inline __const__ xfs_uint16_t
578 +static inline __attribute__((const)) xfs_uint16_t
579 le16 (xfs_uint16_t x)
580 {
581 __asm__("xchgb %b0,%h0" \
582 @@ -106,7 +106,7 @@
583 return x;
584 }
585
586 -static inline __const__ xfs_uint32_t
587 +static inline __attribute__((const)) xfs_uint32_t
588 le32 (xfs_uint32_t x)
589 {
590 #if 0
591 @@ -122,7 +122,7 @@
592 return x;
593 }
594
595 -static inline __const__ xfs_uint64_t
596 +static inline __attribute__((const)) xfs_uint64_t
597 le64 (xfs_uint64_t x)
598 {
599 xfs_uint32_t h = x >> 32;
600 @@ -368,7 +368,7 @@
601 default:
602 namelen = sfe->namelen;
603 *ino = sf_ino ((char *)sfe, namelen);
604 - name = sfe->name;
605 + name = (char *) sfe->name;
606 sfe = (xfs_dir2_sf_entry_t *)
607 ((char *)sfe + namelen + 11 - xfs.i8param);
608 }
609 diff -Naur grub-0.97.orig/stage2/gunzip.c grub-0.97/stage2/gunzip.c
610 --- grub-0.97.orig/stage2/gunzip.c 2003-07-09 04:45:53.000000000 -0700
611 +++ grub-0.97/stage2/gunzip.c 2006-05-28 20:28:41.586818535 -0700
612 @@ -277,7 +277,7 @@
613 * is a compressed file, and simply mark it as such.
614 */
615 if (no_decompression
616 - || grub_read (buf, 10) != 10
617 + || grub_read ((char *) buf, 10) != 10
618 || ((*((unsigned short *) buf) != GZIP_HDR_LE)
619 && (*((unsigned short *) buf) != OLD_GZIP_HDR_LE)))
620 {
621 @@ -293,7 +293,7 @@
622 if (buf[2] != DEFLATED
623 || (buf[3] & UNSUPP_FLAGS)
624 || ((buf[3] & EXTRA_FIELD)
625 - && (grub_read (buf, 2) != 2
626 + && (grub_read ((char *) buf, 2) != 2
627 || bad_field (*((unsigned short *) buf))))
628 || ((buf[3] & ORIG_NAME) && bad_field (-1))
629 || ((buf[3] & COMMENT) && bad_field (-1)))
630 @@ -308,7 +308,7 @@
631
632 filepos = filemax - 8;
633
634 - if (grub_read (buf, 8) != 8)
635 + if (grub_read ((char *) buf, 8) != 8)
636 {
637 if (! errnum)
638 errnum = ERR_BAD_GZIP_HEADER;
639 @@ -485,8 +485,8 @@
640
641 #define INBUFSIZ 0x2000
642
643 -static uch inbuf[INBUFSIZ];
644 -static int bufloc;
645 +static unsigned char inbuf[INBUFSIZ];
646 +static int bufloc;
647
648 static int
649 get_byte (void)
650 @@ -494,7 +494,7 @@
651 if (filepos == gzip_data_offset || bufloc == INBUFSIZ)
652 {
653 bufloc = 0;
654 - grub_read (inbuf, INBUFSIZ);
655 + grub_read ((char *) inbuf, INBUFSIZ);
656 }
657
658 return inbuf[bufloc++];
659 @@ -925,7 +925,7 @@
660 unsigned m; /* mask for bit lengths table */
661 unsigned n; /* number of lengths to get */
662 unsigned nb; /* number of bit length codes */
663 - unsigned nl; /* number of literal/length codes */
664 + unsigned nc; /* number of literal/length codes */
665 unsigned nd; /* number of distance codes */
666 unsigned ll[286 + 30]; /* literal/length and distance code lengths */
667 register ulg b; /* bit buffer */
668 @@ -937,7 +937,7 @@
669
670 /* read in table lengths */
671 NEEDBITS (5);
672 - nl = 257 + ((unsigned) b & 0x1f); /* number of literal/length codes */
673 + nc = 257 + ((unsigned) b & 0x1f); /* number of literal/length codes */
674 DUMPBITS (5);
675 NEEDBITS (5);
676 nd = 1 + ((unsigned) b & 0x1f); /* number of distance codes */
677 @@ -945,7 +945,7 @@
678 NEEDBITS (4);
679 nb = 4 + ((unsigned) b & 0xf); /* number of bit length codes */
680 DUMPBITS (4);
681 - if (nl > 286 || nd > 30)
682 + if (nc > 286 || nd > 30)
683 {
684 errnum = ERR_BAD_GZIP_DATA;
685 return;
686 @@ -970,7 +970,7 @@
687 }
688
689 /* read in literal and distance code lengths */
690 - n = nl + nd;
691 + n = nc + nd;
692 m = mask_bits[bl];
693 i = l = 0;
694 while ((unsigned) i < n)
695 @@ -1034,7 +1034,7 @@
696
697 /* build the decoding tables for literal/length and distance codes */
698 bl = lbits;
699 - if ((i = huft_build (ll, nl, 257, cplens, cplext, &tl, &bl)) != 0)
700 + if ((i = huft_build (ll, nc, 257, cplens, cplext, &tl, &bl)) != 0)
701 {
702 #if 0
703 if (i == 1)
704 @@ -1045,7 +1045,7 @@
705 return;
706 }
707 bd = dbits;
708 - if ((i = huft_build (ll + nl, nd, 0, cpdist, cpdext, &td, &bd)) != 0)
709 + if ((i = huft_build (ll + nc, nd, 0, cpdist, cpdext, &td, &bd)) != 0)
710 {
711 #if 0
712 if (i == 1)
713 diff -Naur grub-0.97.orig/stage2/md5.c grub-0.97/stage2/md5.c
714 --- grub-0.97.orig/stage2/md5.c 2003-07-09 04:45:53.000000000 -0700
715 +++ grub-0.97/stage2/md5.c 2006-05-28 20:28:41.590818435 -0700
716 @@ -166,7 +166,7 @@
717 inputlen -= 64 - buflen;
718 while (inputlen >= 64)
719 {
720 - md5_transform (input);
721 + md5_transform ((unsigned char *) input);
722 input += 64;
723 inputlen -= 64;
724 }
725 @@ -211,7 +211,7 @@
726 char *p;
727 int saltlen;
728 int i, n;
729 - unsigned char alt_result[16];
730 + char alt_result[16];
731 unsigned char *digest;
732
733 if (check)
734 diff -Naur grub-0.97.orig/stage2/start_eltorito.S grub-0.97/stage2/start_eltorito.S
735 --- grub-0.97.orig/stage2/start_eltorito.S 2004-03-27 08:14:20.000000000 -0800
736 +++ grub-0.97/stage2/start_eltorito.S 2006-05-28 20:31:17.770936712 -0700
737 @@ -40,9 +40,9 @@
738 #define ABS(x) (x-_start+BOOTSEC_LOCATION)
739
740 #ifdef STAGE1_5
741 -# define STAGE_ADDR 0x2000
742 +# define STAGE_ADDR 0x2200
743 #else
744 -# define STAGE_ADDR 0x8000
745 +# define STAGE_ADDR 0x8200
746 #endif /* STAGE1_5 */
747
748 /* Print message string */
749 @@ -71,12 +71,14 @@
750 . = _start + 8 /* Pad to file offset 8 */
751
752 /* This table gets filled in by mkisofs using the
753 - -boot-info-table option */
754 -bi_pvd: .long 0xDEADBEEF /* LBA of primary volume descript */
755 -bi_file: .long 0xDEADBEEF /* LBA of boot file */
756 -bi_length: .long 0xDEADBEEF /* Length of boot file */
757 -bi_csum: .long 0xDEADBEEF /* Checksum of boot file */
758 -bi_reserved: .space (10*4) /* Reserved */
759 + -boot-info-table option If not, the values in this
760 + table are default values that we can use to get us
761 + what we need, at least under a certain set of assumptions. */
762 +bi_pvd: .long 16 /* LBA of primary volume descript */
763 +bi_file: .long 0 /* LBA of boot file */
764 +bi_length: .long 0xDEADBEEF /* Length of boot file */
765 +bi_csum: .long 0xDEADBEEF /* Checksum of boot file */
766 +bi_reserved: .space (10*4) /* Reserved */
767
768 real_start:
769 xor %ax, %ax
770 @@ -92,10 +94,28 @@
771 /* save drive reference first thing! */
772 mov %dl, ABS(BootDrive)
773
774 - /* print a notification message on the screen */
775 - MSG(notification_string)
776 + /* check if machine support IBM/MS int 13h extensions */
777 + mov $0x41, %ah
778 + mov $0x55AA, %bx
779 + int $0x13
780 + jnc load_image
781 +
782 + /* bios doesn't support int 13h extensions, print error messages */
783 + MSG(int13_error_string1)
784 + MSG(notification_done)
785 + MSG(int13_error_string2)
786 + MSG(notification_done)
787 + MSG(int13_error_string3)
788 + MSG(notification_done)
789 + /* even when bios says that it doesn't support int 13h
790 + extensions, do not stop here and try to load image anyway,
791 + because some bioses says that there isn't support for
792 + extended functions but have the needed extended read function
793 + (int 13h, function AH=42h) */
794
795 load_image:
796 + /* print a notification message on the screen */
797 + MSG(notification_string)
798 /* Set up boot file sector, size, load address */
799 mov ABS(bi_length), %eax
800 add $(ISO_SECTOR_SIZE-1), %eax
801 @@ -105,6 +125,8 @@
802 mov %bx, %es
803 xor %bx, %bx
804 mov ABS(bi_file), %eax
805 + inc %eax /* do not reload the first sector (this code) */
806 + dec %bp /* this way we have more room for code in stage1 */
807 call getlinsec
808 mov %ds, %ax
809 mov %ax, %es
810 @@ -115,7 +137,7 @@
811 mov $ABS(firstlist - BOOTSEC_LISTSIZE), %si
812 mov (%si), %ebp
813 mov ABS(BootDrive), %dl /* this makes sure %dl is our "boot" drive */
814 - ljmp $0, $(STAGE_ADDR+SECTOR_SIZE) /* jump to main() in asm.S */
815 + ljmp $0, $(STAGE_ADDR) /* jump to main() in asm.S */
816
817 /* go here when you need to stop the machine hard after an error condition */
818 stop: jmp stop
819 @@ -171,11 +193,11 @@
820 */
821 xint13:
822 movb $6, ABS(RetryCount)
823 - pushal
824 .try:
825 + pushal
826 int $0x13
827 jc 1f
828 - add $(8*4), %sp /* Clean up stack */
829 + popal /* Clean up stack */
830 ret
831 1:
832 mov %ah, %dl /* Save error code */
833 @@ -276,6 +298,10 @@
834
835 read_error_string: .string "Read error 0x"
836
837 +int13_error_string1: .string "Support for IBM/MS INT 13h extensions not found"
838 +int13_error_string2: .string "GRUB cannot be loaded if int 13h/function AH=42h isn't present"
839 +int13_error_string3: .string "Trying to load stage 2 anyway..."
840 +
841 /*
842 * EBIOS disk address packet
843 */
844 @@ -306,7 +332,8 @@
845 .word 0
846 .word 0
847
848 - . = _start + SECTOR_SIZE - BOOTSEC_LISTSIZE
849 + /* size of the code we can place between main body and fixed top location */
850 + . = _start + 1536 - BOOTSEC_LISTSIZE
851
852 /* fill the first data listing with the default */
853 blocklist_default_start:/* this is the sector start parameter, in logical
854 @@ -321,6 +348,12 @@
855 #endif
856 blocklist_default_seg: /* this is the segment of the starting address
857 to load the data into */
858 - .word (STAGE_ADDR + SECTOR_SIZE) >> 4
859 + .word (STAGE_ADDR) >> 4
860
861 firstlist: /* this label has to be after the list data!!! */
862 +
863 + /* this is a workaround to allow more code to be added in stage1,
864 + it allows more code to be added for this stage, but for this
865 + we can't reload the first sector. So we have to align the code
866 + to ISO_SECTOR_SIZE. */
867 + . = _start + ISO_SECTOR_SIZE
868 diff -Naur grub-0.97.orig/util/grub-install.in grub-0.97/util/grub-install.in
869 --- grub-0.97.orig/util/grub-install.in 2004-07-24 11:57:31.000000000 -0700
870 +++ grub-0.97/util/grub-install.in 2006-05-28 20:30:31.484088268 -0700
871 @@ -336,6 +336,10 @@
872 # Create a safe temporary file.
873 test -n "$mklog" && log_file=`$mklog`
874
875 + # Before all invocations of the grub shell, call sync to make sure
876 + # the raw device is in sync with any bufferring in filesystems.
877 + sync
878 +
879 $grub_shell --batch $no_floppy --device-map=$device_map <<EOF >$log_file
880 quit
881 EOF
882 @@ -450,6 +454,10 @@
883 # Create a safe temporary file.
884 test -n "$mklog" && log_file=`$mklog`
885
886 +# Before all invocations of the grub shell, call sync to make sure
887 +# the raw device is in sync with any bufferring in filesystems.
888 +sync
889 +
890 # Now perform the installation.
891 $grub_shell --batch $no_floppy --device-map=$device_map <<EOF >$log_file
892 root $root_drive