diff options
author | Luigi Rizzo <luigi@FreeBSD.org> | 2009-12-08 10:09:02 +0000 |
---|---|---|
committer | Luigi Rizzo <luigi@FreeBSD.org> | 2009-12-08 10:09:02 +0000 |
commit | 5a3e648d5e5c62786eaf465c2a3160e68f9ea2f1 (patch) | |
tree | 65439d6a8dfa4bc244f52b346a2db38812a89f65 /sysutils/syslinux | |
parent | c62af3a812cf69a132918ea25a0f1ce6ff5a4c17 (diff) |
Update to 3.83
This is basically PR ports/141166 by Boris Samorodov, which
updates the code to version 3.83 and splits the patches
into smaller chunks to ease future updates.
I have only touched the indentation in one function in patch-mtools_syslinux.c
Submitted-by: Boris Samorodov
PR: 141166
Notes
Notes:
svn path=/head/; revision=245401
Diffstat (limited to 'sysutils/syslinux')
-rw-r--r-- | sysutils/syslinux/Makefile | 4 | ||||
-rw-r--r-- | sysutils/syslinux/distinfo | 6 | ||||
-rw-r--r-- | sysutils/syslinux/files/patch-1 | 76 | ||||
-rw-r--r-- | sysutils/syslinux/files/patch-2 | 22 | ||||
-rw-r--r-- | sysutils/syslinux/files/patch-boot_option | 65 | ||||
-rw-r--r-- | sysutils/syslinux/files/patch-com32_lib_MCONFIG | 11 | ||||
-rw-r--r-- | sysutils/syslinux/files/patch-libinstaller_syslinux.h | 21 | ||||
-rw-r--r-- | sysutils/syslinux/files/patch-mtools_syslinux.c | 119 | ||||
-rw-r--r-- | sysutils/syslinux/pkg-plist | 7 |
9 files changed, 162 insertions, 169 deletions
diff --git a/sysutils/syslinux/Makefile b/sysutils/syslinux/Makefile index 1e37aff9a04c..f9f51d254a52 100644 --- a/sysutils/syslinux/Makefile +++ b/sysutils/syslinux/Makefile @@ -7,10 +7,10 @@ # PORTNAME= syslinux -PORTVERSION= 3.72 +PORTVERSION= 3.83 CATEGORIES= sysutils MASTER_SITES= ${MASTER_SITE_KERNEL_ORG} -MASTER_SITE_SUBDIR= linux/boot/syslinux/Old +MASTER_SITE_SUBDIR= linux/boot/syslinux MAINTAINER= luigi@FreeBSD.org COMMENT= Syslinux for FreeBSD diff --git a/sysutils/syslinux/distinfo b/sysutils/syslinux/distinfo index fca55c32f6ac..047429c7a803 100644 --- a/sysutils/syslinux/distinfo +++ b/sysutils/syslinux/distinfo @@ -1,3 +1,3 @@ -MD5 (syslinux-3.72.tar.bz2) = 9858c801ecd36265f4374996324f01a0 -SHA256 (syslinux-3.72.tar.bz2) = dc19ea3e1297468d9b4c579aba1dd491c963a02887f7fb362c95c6f1c0567e90 -SIZE (syslinux-3.72.tar.bz2) = 3262688 +MD5 (syslinux-3.83.tar.bz2) = 069160bc3776eca71a57cabace22bb24 +SHA256 (syslinux-3.83.tar.bz2) = 9ec84d6dcc188f082a875b69796b196f98ea8c0102b55b03123616a285c2d9f9 +SIZE (syslinux-3.83.tar.bz2) = 3184349 diff --git a/sysutils/syslinux/files/patch-1 b/sysutils/syslinux/files/patch-1 index 75f5755c0c29..e2a6061ef28a 100644 --- a/sysutils/syslinux/files/patch-1 +++ b/sysutils/syslinux/files/patch-1 @@ -24,18 +24,6 @@ diff -ubwr ./Makefile ../../work/syslinux-3.72/Makefile # Things to install in /usr/lib/syslinux INSTALL_AUX = core/pxelinux.0 gpxe/gpxelinux.0 core/isolinux.bin \ core/isolinux-debug.bin \ -diff -ubwr ./com32/lib/MCONFIG ../../work/syslinux-3.72/com32/lib/MCONFIG ---- ./com32/lib/MCONFIG 2008-09-26 01:46:02.000000000 +0200 -+++ ../../work/syslinux-3.72/com32/lib/MCONFIG 2008-11-25 11:32:22.000000000 +0100 -@@ -47,7 +47,7 @@ - $(CC) $(CFLAGS) -S -o $@ $< - - .S.o: -- $(CC) $(CFLAGS) -D__ASSEMBLY__ -c -o $@ $< -+ $(CC) $(filter-out -std=gnu99, $(CFLAGS)) -D__ASSEMBLY__ -c -o $@ $< - - .S.s: - $(CC) $(CFLAGS) -D__ASSEMBLY__ -E -o $@ $< diff -ubwr ./com32/libutil/md5.c ../../work/syslinux-3.72/com32/libutil/md5.c --- ./com32/libutil/md5.c 2008-09-26 01:46:02.000000000 +0200 +++ ../../work/syslinux-3.72/com32/libutil/md5.c 2008-11-25 11:32:22.000000000 +0100 @@ -76,67 +64,3 @@ diff -ubwr ./com32/libutil/sha512crypt.c ../../work/syslinux-3.72/com32/libutil/ #include <errno.h> #include <limits.h> #include <stdbool.h> -diff -ubwr ./mtools/syslinux.c ../../work/syslinux-3.72/mtools/syslinux.c ---- ./mtools/syslinux.c 2008-09-26 01:46:02.000000000 +0200 -+++ ../../work/syslinux-3.72/mtools/syslinux.c 2008-11-25 11:32:22.000000000 +0100 -@@ -38,6 +38,8 @@ - #include "syslinux.h" - #include "libfat.h" - -+int verbose=0; -+ - char *program; /* Name of program */ - char *device; /* Device to install to */ - pid_t mypid; -@@ -159,6 +161,8 @@ - while ( *opt ) { - if ( *opt == 's' ) { - stupid = 1; -+ } else if ( *opt == 'v' ) { -+ verbose++; - } else if ( *opt == 'r' ) { - raid_mode = 1; - } else if ( *opt == 'f' ) { -@@ -217,11 +221,9 @@ - fprintf(mtc, - /* "MTOOLS_NO_VFAT=1\n" */ - "MTOOLS_SKIP_CHECK=1\n" /* Needed for some flash memories */ -- "drive s:\n" -- " file=\"/proc/%lu/fd/%d\"\n" -+ "drive s: file=\"%s\"\n" - " offset=%llu\n", -- (unsigned long)mypid, -- dev_fd, -+ device, - (unsigned long long)filesystem_offset); - fclose(mtc); - -@@ -234,8 +236,10 @@ - } - - /* This command may fail legitimately */ -+if (verbose) fprintf(stderr, "doing mattrib\n"); - system("mattrib -h -r -s s:/ldlinux.sys 2>/dev/null"); - -+if (verbose) fprintf(stderr, "doing mcopy\n"); - mtp = popen("mcopy -D o -D O -o - s:/ldlinux.sys", "w"); - if ( !mtp || - (fwrite(syslinux_ldlinux, 1, syslinux_ldlinux_len, mtp) -@@ -248,7 +252,9 @@ - * Now, use libfat to create a block map - */ - fs = libfat_open(libfat_xpread, dev_fd); -+if (verbose) fprintf(stderr, "libfat_open returns %p\n", fs); - ldlinux_cluster = libfat_searchdir(fs, 0, "LDLINUX SYS", NULL); -+if (verbose) fprintf(stderr, "libfat_searchdir returns %d\n", ldlinux_cluster); - secp = sectors; - nsectors = 0; - s = libfat_clustertosector(fs, ldlinux_cluster); -@@ -256,6 +262,7 @@ - *secp++ = s; - nsectors++; - s = libfat_nextsector(fs, s); -+if (verbose) fprintf(stderr, "libfat_nextsector returns %d\n", s); - } - libfat_close(fs); - diff --git a/sysutils/syslinux/files/patch-2 b/sysutils/syslinux/files/patch-2 index 4242be4ea0ad..0f1939ca2ac5 100644 --- a/sysutils/syslinux/files/patch-2 +++ b/sysutils/syslinux/files/patch-2 @@ -17,25 +17,3 @@ diff -ubwr ../../work/syslinux-3.72/libinstaller/bin2c.pl ./libinstaller/bin2c.p +printf "\nunsigned char *%s = _%s;\n", $table_name, $table_name; exit 0; -diff -ubwr ../../work/syslinux-3.72/libinstaller/syslinux.h ./libinstaller/syslinux.h ---- ../../work/syslinux-3.72/libinstaller/syslinux.h 2008-09-26 01:46:02.000000000 +0200 -+++ ./libinstaller/syslinux.h 2008-11-26 13:32:23.000000000 +0100 -@@ -17,15 +17,15 @@ - #include "advconst.h" - - /* The standard boot sector and ldlinux image */ --extern unsigned char syslinux_bootsect[]; -+extern unsigned char *syslinux_bootsect; - extern unsigned int syslinux_bootsect_len; - extern int syslinux_bootsect_mtime; - --extern unsigned char syslinux_ldlinux[]; -+extern unsigned char *syslinux_ldlinux; - extern unsigned int syslinux_ldlinux_len; - extern int syslinux_ldlinux_mtime; - --extern unsigned char syslinux_mbr[]; -+extern unsigned char *syslinux_mbr; - extern unsigned int syslinux_mbr_len; - extern int syslinux_mbr_mtime; - diff --git a/sysutils/syslinux/files/patch-boot_option b/sysutils/syslinux/files/patch-boot_option deleted file mode 100644 index 93e8f9a3bdba..000000000000 --- a/sysutils/syslinux/files/patch-boot_option +++ /dev/null @@ -1,65 +0,0 @@ -diff -ubwr ../../work.2/syslinux-3.72/mtools/syslinux.c ./mtools/syslinux.c ---- ../../work.2/syslinux-3.72/mtools/syslinux.c 2008-11-26 13:32:57.000000000 +0100 -+++ ./mtools/syslinux.c 2008-11-26 14:07:05.000000000 +0100 -@@ -123,6 +123,52 @@ - return xpread(pp, buf, secsize, offset); - } - -+/* -+ * load a file to be used as boot image -+ */ -+static int load_boot_image(const char *name) -+{ -+ int l, fd; -+ struct stat sb; -+ unsigned char *buf; -+ -+ memset(&sb, 0, sizeof(sb)); -+ fd = open(name, O_RDONLY); -+ if (fd < 0) { -+ fprintf(stderr, "cannot open boot image %s\n", name); -+ return 1; -+ } -+ if (fstat(fd, &sb)) { -+ fprintf(stderr, "cannot stat boot image %s\n", name); -+ return 1; -+ } -+ if ( (sb.st_mode & S_IFREG) == 0) { -+ fprintf(stderr, "boot image %s is not a file 0x%x\n", name, sb.st_mode); -+ return 1; -+ } -+ if (sb.st_size < 1024 || sb.st_size > 0x8000) { -+ fprintf(stderr, "boot image %s bad size %lld\n", name, sb.st_size); -+ return 1; -+ } -+ buf = calloc(1, sb.st_size); -+ if (buf == NULL) { -+ fprintf(stderr, "malloc failed for boot image %s\n", name); -+ return 1; -+ } -+ l = read(fd, buf, sb.st_size); -+ if (l != sb.st_size) { -+ fprintf(stderr, "read failed for boot image %s got %d\n", name, l); -+ return 1; -+ } -+ if (buf[0] != 0xeb || buf[0x200] != 0x0d) { -+ fprintf(stderr, "bad content for boot image %s\n", name); -+ return 1; -+ } -+ syslinux_bootsect = buf; -+ syslinux_ldlinux = buf + 512; -+ syslinux_ldlinux_len = sb.st_size - 512; -+ return 0; -+} - - int main(int argc, char *argv[]) - { -@@ -163,6 +209,8 @@ - stupid = 1; - } else if ( *opt == 'v' ) { - verbose++; -+ } else if ( *opt == 'b' && argp[1] ) { -+ load_boot_image(*++argp); - } else if ( *opt == 'r' ) { - raid_mode = 1; - } else if ( *opt == 'f' ) { diff --git a/sysutils/syslinux/files/patch-com32_lib_MCONFIG b/sysutils/syslinux/files/patch-com32_lib_MCONFIG new file mode 100644 index 000000000000..85bf06474295 --- /dev/null +++ b/sysutils/syslinux/files/patch-com32_lib_MCONFIG @@ -0,0 +1,11 @@ +--- com32/lib/MCONFIG.orig 2009-10-06 02:06:06.000000000 +0400 ++++ com32/lib/MCONFIG 2009-12-04 09:46:19.000000000 +0300 +@@ -45,7 +45,7 @@ + $(CC) $(MAKEDEPS) $(CFLAGS) -S -o $@ $< + + .S.o: +- $(CC) $(MAKEDEPS) $(CFLAGS) -D__ASSEMBLY__ -c -o $@ $< ++ $(CC) $(MAKEDEPS) $(filter-out -std=gnu99, $(CFLAGS)) -D__ASSEMBLY__ -c -o $@ $< + + .S.s: + $(CC) $(MAKEDEPS) $(CFLAGS) -D__ASSEMBLY__ -E -o $@ $< diff --git a/sysutils/syslinux/files/patch-libinstaller_syslinux.h b/sysutils/syslinux/files/patch-libinstaller_syslinux.h new file mode 100644 index 000000000000..484e97f70b92 --- /dev/null +++ b/sysutils/syslinux/files/patch-libinstaller_syslinux.h @@ -0,0 +1,21 @@ +--- libinstaller/syslinux.h.orig 2009-10-06 02:06:06.000000000 +0400 ++++ libinstaller/syslinux.h 2009-12-04 10:09:04.000000000 +0300 +@@ -17,15 +17,15 @@ + #include "advconst.h" + + /* The standard boot sector and ldlinux image */ +-extern unsigned char syslinux_bootsect[]; ++extern unsigned char *syslinux_bootsect; + extern unsigned int syslinux_bootsect_len; + extern int syslinux_bootsect_mtime; + +-extern unsigned char syslinux_ldlinux[]; ++extern unsigned char *syslinux_ldlinux; + extern unsigned int syslinux_ldlinux_len; + extern int syslinux_ldlinux_mtime; + +-extern unsigned char syslinux_mbr[]; ++extern unsigned char *syslinux_mbr; + extern unsigned int syslinux_mbr_len; + extern int syslinux_mbr_mtime; + diff --git a/sysutils/syslinux/files/patch-mtools_syslinux.c b/sysutils/syslinux/files/patch-mtools_syslinux.c new file mode 100644 index 000000000000..6c5c99648f0e --- /dev/null +++ b/sysutils/syslinux/files/patch-mtools_syslinux.c @@ -0,0 +1,119 @@ +--- mtools/syslinux.c.orig 2009-10-06 02:06:06.000000000 +0400 ++++ mtools/syslinux.c 2009-12-04 11:18:37.000000000 +0300 +@@ -38,6 +38,8 @@ + #include "syslinux.h" + #include "libfat.h" + ++int verbose=0; ++ + char *program; /* Name of program */ + char *device; /* Device to install to */ + pid_t mypid; +@@ -123,6 +125,53 @@ + return xpread(pp, buf, secsize, offset); + } + ++/* ++ * load a file to be used as boot image ++ */ ++static int load_boot_image(const char *name) ++{ ++ int l, fd; ++ struct stat sb; ++ unsigned char *buf; ++ ++ memset(&sb, 0, sizeof(sb)); ++ fd = open(name, O_RDONLY); ++ if (fd < 0) { ++ fprintf(stderr, "cannot open boot image %s\n", name); ++ return 1; ++ } ++ if (fstat(fd, &sb)) { ++ fprintf(stderr, "cannot stat boot image %s\n", name); ++ return 1; ++ } ++ if ( (sb.st_mode & S_IFREG) == 0) { ++ fprintf(stderr, "boot image %s is not a file 0x%x\n", name, sb.st_mode); ++ return 1; ++ } ++ if (sb.st_size < 1024 || sb.st_size > 0x8000) { ++ fprintf(stderr, "boot image %s bad size %lld\n", name, sb.st_size); ++ return 1; ++ } ++ buf = calloc(1, sb.st_size); ++ if (buf == NULL) { ++ fprintf(stderr, "malloc failed for boot image %s\n", name); ++ return 1; ++ } ++ l = read(fd, buf, sb.st_size); ++ if (l != sb.st_size) { ++ fprintf(stderr, "read failed for boot image %s got %d\n", name, l); ++ return 1; ++ } ++ if (buf[0] != 0xeb || buf[0x200] != 0x0d) { ++ fprintf(stderr, "bad content for boot image %s\n", name); ++ return 1; ++ } ++ syslinux_bootsect = buf; ++ syslinux_ldlinux = buf + 512; ++ syslinux_ldlinux_len = sb.st_size - 512; ++ return 0; ++} ++ + int main(int argc, char *argv[]) + { + static unsigned char sectbuf[512]; +@@ -160,6 +209,10 @@ + while (*opt) { + if (*opt == 's') { + stupid = 1; ++ } else if ( *opt == 'v' ) { ++ verbose++; ++ } else if ( *opt == 'b' && argp[1] ) { ++ load_boot_image(*++argp); + } else if (*opt == 'r') { + raid_mode = 1; + } else if (*opt == 'f') { +@@ -220,11 +273,10 @@ + fprintf(mtc, + /* "MTOOLS_NO_VFAT=1\n" */ + "MTOOLS_SKIP_CHECK=1\n" /* Needed for some flash memories */ +- "drive s:\n" +- " file=\"/proc/%lu/fd/%d\"\n" ++ "drive s: file=\"%s\"\n" + " offset=%llu\n", + (unsigned long)mypid, +- dev_fd, (unsigned long long)filesystem_offset); ++ device, (unsigned long long)filesystem_offset); + fclose(mtc); + + /* +@@ -236,8 +288,10 @@ + } + + /* This command may fail legitimately */ ++ if (verbose) fprintf(stderr, "doing mattrib\n"); + system("mattrib -h -r -s s:/ldlinux.sys 2>/dev/null"); + ++ if (verbose) fprintf(stderr, "doing mcopy\n"); + mtp = popen("mcopy -D o -D O -o - s:/ldlinux.sys", "w"); + if (!mtp || (fwrite(syslinux_ldlinux, 1, syslinux_ldlinux_len, mtp) + != syslinux_ldlinux_len) || +@@ -249,7 +303,9 @@ + * Now, use libfat to create a block map + */ + fs = libfat_open(libfat_xpread, dev_fd); ++ if (verbose) fprintf(stderr, "libfat_open returns %p\n", fs); + ldlinux_cluster = libfat_searchdir(fs, 0, "LDLINUX SYS", NULL); ++ if (verbose) fprintf(stderr, "libfat_searchdir returns %d\n", ldlinux_cluster); + secp = sectors; + nsectors = 0; + s = libfat_clustertosector(fs, ldlinux_cluster); +@@ -257,6 +313,7 @@ + *secp++ = s; + nsectors++; + s = libfat_nextsector(fs, s); ++ if (verbose) fprintf(stderr, "libfat_nextsector returns %d\n", s); + } + libfat_close(fs); + diff --git a/sysutils/syslinux/pkg-plist b/sysutils/syslinux/pkg-plist index 8d8663014e54..1f361768cb22 100644 --- a/sysutils/syslinux/pkg-plist +++ b/sysutils/syslinux/pkg-plist @@ -8,17 +8,22 @@ share/syslinux/memdisk share/syslinux/menu.c32 share/syslinux/vesamenu.c32 share/syslinux/chain.c32 +share/syslinux/cmd.c32 share/syslinux/cpuidtest.c32 +share/syslinux/disk.c32 share/syslinux/dmitest.c32 share/syslinux/elf.c32 share/syslinux/ethersel.c32 share/syslinux/ifcpu64.c32 +share/syslinux/kbdmap.c32 share/syslinux/linux.c32 -share/syslinux/mboot.c32 +#share/syslinux/mboot.c32 share/syslinux/meminfo.c32 share/syslinux/pcitest.c32 share/syslinux/pmload.c32 share/syslinux/reboot.c32 share/syslinux/sanboot.c32 share/syslinux/sdi.c32 +share/syslinux/vesainfo.c32 +share/syslinux/vpdtest.c32 @dirrm share/syslinux |