This updates: * m4 * bison * e2fsprogs * make_ext4fs * mtd-utils * findutils * squashfs * squashfs4 * grub2 to their version used in LEDE v17.01.6. This fixes various compile errors appearing on Debian Sid. A list of the patches picked from upstream: m4: $ git log --oneline f7e56763e1..HEAD tools/m4 6e78c5502c tools: m4: fix compilation with glibc 2.28 a91d8dd162 tools/m4: update 1.4.18 f19d47f848 tools: patch various gnu tools for macOS 10.13 720b99215d treewide: clean up download hashes bison: $ git log --oneline 877f2972d4..HEAD tools/bison 1e09cbf118 tools/bison: Update to 3.0.5 f19d47f848 tools: patch various gnu tools for macOS 10.13 720b99215d treewide: clean up download hashes 5062cff673 tools/bison: update to 3.0.4 e2fsprogs: $ git log --oneline f7e56763e1..HEAD tools/e2fsprogs/ 8f5c55f63e tools/e2fsprogs: update to 1.44.1 d35a7bf4b4 e2fsprogs: bump to 1.44.0 79ac69d9c9 tools/e2fsprogs: Update to 1.43.7 5d9114c9cb tools/e2fsprogs: Update to 1.43.6 7955fab22a tools/e2fsprogs: Update to 1.43.5 866e5b4956 tools/e2fsprogs: Update to 1.43.4 a964738a5c Revert "tools/e2fsprogs: fix building on a glibc 2.27 host" 58a95f0f8f tools/e2fsprogs: fix building on a glibc 2.27 host 720b99215d treewide: clean up download hashes b8b807b1a9 tools/e2fsprogs: Update to 1.43.3 d635ef50c5 e2fsprogs: fix build problem with very old libmagic 819cf75c40 tools: e2fsprogs: bump to 1.43.1 2baf90a84e tools/e2fsprogs: remove outdated configure args b7e946f33e tools/e2fsprogs: update to 1.42.13 52ea491bdf tools/e2fsprogs: add a darwin-compat patch make-ext4fs: $ git log --oneline 1170a3de76..HEAD tools/make-ext4fs/ c7c1cf5618 treewide: clean up and unify PKG_VERSION for git based downloads 720b99215d treewide: clean up download hashes 9edfe7dd13 source: Switch to xz for packages and tools where possible 95bad62f2a tools: make_ext4fs: switch to LEDE git mirror 98b960c218 tools: make_ext4fs: support creating empty filesystem images 9ec4ca525c tools: make-ext4fs: fix build regression on mac os x 49ad0c565a tools: fix make_ext4fs build with recent glibc 8af9119ff4 tools: make-ext4fs: explicitely request C collation for sorting 01fb448d56 tools/make-ext4fs: prefer static linking $ git log --oneline 17ae95bb20..HEAD tools/mtd-utils 96dbf59e5a tools/mtd-utils: include sysmacros.h explicitly 018d80007e kernel: remove ubifs xz decompression support c7c1cf5618 treewide: clean up and unify PKG_VERSION for git based downloads 720b99215d treewide: clean up download hashes 9edfe7dd13 source: Switch to xz for packages and tools where possible e27c8bb156 update mtd-utils to 1.5.2 $ git log --oneline dd86bc73fb..HEAD tools/findutils 6449ed1553 tools: findutils: fix compilation with glibc 2.28 d2fd6412a6 tools/findutils: include sysmacros.h explicitly 720b99215d treewide: clean up download hashes 70a5c062f1 tools/findutils: Update to 4.6.0 $ git log --oneline f7e56763e1..HEAD tools/squashfs tools/squashfs4 1aedf2f149 tools/squashfs: use host cflags 8a48a53dcb tools/squashfs4: include sysmacros.h explicitly 8406e50df5 tools/squashfs: include sysmacros.h explicitly 720b99215d treewide: clean up download hashes f97ad870e1 squashfs4: use upstream xz compression header format d437c72c21 tools/squashfs4: refresh patches 34124de139 tools/squashfs: refresh patches fd1c1b4918 tools/squashfs: add argument -fixed-time to set all timestamps $ git log --oneline fcc6f801ca..HEAD package/boot/grub2/ 2252731af4 grub2: rebase patches 6aae528cc3 grub2: Fix CVE-2015-8370 6e1e2e7b96 package/grub2: update to 2.02 10182cb2c6 grub2: update to 2.02~rc2 f0e8470aa9 grub2: update to 2.02~rc1 806d3cc2c3 packages: mark packages depending on a target as nonshared 65c8f2890c grub2: upgrade to 2.02-beta3 (3 years newer than previous) 77812cdfec grub2: disable 'check-macro-version' build rule in 'po' build 2b54fa4dff grub2: do not generate mkfonts at build time b33845b2da grub2: add PKG_FIXUP:=autoreconf 720b99215d treewide: clean up download hashes 3c52cbfa53 Revert "grub2: add PKG_FIXUP:=autoreconf" a0ea22ac43 grub2: add PKG_FIXUP:=autoreconf f2752f4735 grub2: add missing SECTION variable and remove non breaking space d140648622 grub2: move to Boot Loaders category 59e3a4714a grub2: switch back to installing to STAGING_DIR_HOST 9b01282515 grub2: disable stack-protector 25eddec9cb grub2: fix build against musl $ git log --oneline 81a2f9d6f86 81a2f9d6f8 target/linux/x86/image: add explicit prefix to grub-mkimage command Signed-off-by: Linus Lüssing <linus.luessing@c0d3.blue>
187 lines
6.4 KiB
Diff
187 lines
6.4 KiB
Diff
From: John Crispin <john@openwrt.org>
|
|
Date: Fri, 11 Dec 2015 15:07:15 +0000
|
|
Subject: tools/squashfs: add argument -fixed-time to set all timestamps
|
|
|
|
-fixed-time <timestamp> set mkfs-timestamp and file-mtime to this timestamp.
|
|
Reproducible builds requires the removal of all timestamp or setting all to a specific one.
|
|
|
|
Signed-off-by: Alexander Couzens <lynxis@fe80.eu>
|
|
|
|
SVN-Revision: 47858
|
|
|
|
diff --git a/tools/squashfs/patches/120-add-fixed-timestamp-support.patch b/tools/squashfs/patches/120-add-fixed-timestamp-support.patch
|
|
new file mode 100644
|
|
index 0000000000000000000000000000000000000000..e2f4bb2e049cebca5f2be22b67161d56b9218876
|
|
--- /dev/null
|
|
+++ b/tools/squashfs/patches/120-add-fixed-timestamp-support.patch
|
|
@@ -0,0 +1,79 @@
|
|
+--- a/squashfs-tools/mksquashfs.c
|
|
++++ b/squashfs-tools/mksquashfs.c
|
|
+@@ -117,6 +117,9 @@ unsigned int inode_bytes = 0, inode_size
|
|
+ char *data_cache = NULL;
|
|
+ unsigned int cache_bytes = 0, cache_size = 0, inode_count = 0;
|
|
+
|
|
++/* override all timestamps */
|
|
++time_t fixed_time = -1;
|
|
++
|
|
+ /* in memory directory data */
|
|
+ #define I_COUNT_SIZE 128
|
|
+ #define DIR_ENTRIES 32
|
|
+@@ -1554,6 +1557,11 @@ void dir_scan(squashfs_inode *inode, cha
|
|
+ perror(buffer);
|
|
+ return;
|
|
+ }
|
|
++
|
|
++ /* override timestamp of lstat if fixed_time is given */
|
|
++ if(fixed_time != -1)
|
|
++ inode_info->buf.st_mtime = fixed_time;
|
|
++
|
|
+ if(sorted)
|
|
+ sort_files_and_write(dir_info);
|
|
+ dir_scan2(inode, dir_info);
|
|
+@@ -1582,6 +1590,10 @@ struct dir_info *dir_scan1(char *pathnam
|
|
+ perror(buffer);
|
|
+ continue;
|
|
+ }
|
|
++
|
|
++ if(fixed_time != -1)
|
|
++ buf.st_mtime = fixed_time;
|
|
++
|
|
+ if(excluded(filename, &buf))
|
|
+ continue;
|
|
+
|
|
+@@ -1621,6 +1633,9 @@ int dir_scan2(squashfs_inode *inode, str
|
|
+ char *dir_name = dir_ent->name;
|
|
+ unsigned int inode_number = ((buf->st_mode & S_IFMT) == S_IFDIR) ? dir_ent->inode->inode_number : dir_ent->inode->inode_number + dir_inode_no;
|
|
+
|
|
++ if(fixed_time != -1)
|
|
++ buf->st_mtime = fixed_time;
|
|
++
|
|
+ if(dir_ent->inode->inode == SQUASHFS_INVALID_BLK) {
|
|
+ switch(buf->st_mode & S_IFMT) {
|
|
+ case S_IFREG:
|
|
+@@ -1898,6 +1913,16 @@ int main(int argc, char *argv[])
|
|
+ exit(1);
|
|
+ }
|
|
+ }
|
|
++ } else if(strcmp(argv[i], "-fixed-time") == 0) {
|
|
++ if(++i == argc) {
|
|
++ ERROR("%s: -fixed-time missing a timestamp\n", argv[0]);
|
|
++ exit(1);
|
|
++ }
|
|
++ fixed_time = strtoll(argv[i], &b, 10);
|
|
++ if(*b != '\0') {
|
|
++ ERROR("%s: -fixed-time has an invalid number\n", argv[0]);
|
|
++ exit(1);
|
|
++ }
|
|
+ } else if(strcmp(argv[i], "-noI") == 0 ||
|
|
+ strcmp(argv[i], "-noInodeCompression") == 0)
|
|
+ noI = TRUE;
|
|
+@@ -1967,6 +1992,7 @@ printOptions:
|
|
+ ERROR("-all-root\t\tmake all files owned by root\n");
|
|
+ ERROR("-force-uid uid\t\tset all file uids to uid\n");
|
|
+ ERROR("-force-gid gid\t\tset all file gids to gid\n");
|
|
++ ERROR("-fixed-time timestamp\tset all timestamps to timestamp\n");
|
|
+ ERROR("-le\t\t\tcreate a little endian filesystem\n");
|
|
+ ERROR("-be\t\t\tcreate a big endian filesystem\n");
|
|
+ ERROR("-nopad\t\t\tdo not pad filesystem to a multiple of 4K\n");
|
|
+@@ -2190,7 +2216,7 @@ printOptions:
|
|
+ sBlk.block_size = block_size;
|
|
+ sBlk.block_log = block_log;
|
|
+ sBlk.flags = SQUASHFS_MKFLAGS(noI, noD, check_data, noF, no_fragments, always_use_fragments, duplicate_checking);
|
|
+- sBlk.mkfs_time = time(NULL);
|
|
++ sBlk.mkfs_time = fixed_time != -1 ? fixed_time : time(NULL);
|
|
+
|
|
+ restore_filesystem:
|
|
+ write_fragment();
|
|
diff --git a/tools/squashfs4/patches/200-add-fixed-timestamp-option.patch b/tools/squashfs4/patches/200-add-fixed-timestamp-option.patch
|
|
new file mode 100644
|
|
index 0000000000000000000000000000000000000000..7ac1765eed22a371f8584e4a3968941eb923fa89
|
|
--- /dev/null
|
|
+++ b/tools/squashfs4/patches/200-add-fixed-timestamp-option.patch
|
|
@@ -0,0 +1,84 @@
|
|
+Index: squashfs4.2/squashfs-tools/mksquashfs.c
|
|
+===================================================================
|
|
+--- squashfs4.2.orig/squashfs-tools/mksquashfs.c
|
|
++++ squashfs4.2/squashfs-tools/mksquashfs.c
|
|
+@@ -175,6 +175,9 @@ unsigned int cache_bytes = 0, cache_size
|
|
+ /* inode lookup table */
|
|
+ squashfs_inode *inode_lookup_table = NULL;
|
|
+
|
|
++/* override all timestamps */
|
|
++time_t fixed_time = -1;
|
|
++
|
|
+ /* in memory directory data */
|
|
+ #define I_COUNT_SIZE 128
|
|
+ #define DIR_ENTRIES 32
|
|
+@@ -2452,6 +2455,8 @@ again:
|
|
+ restat:
|
|
+ fstat(file, &buf2);
|
|
+ close(file);
|
|
++ if (fixed_time != -1)
|
|
++ buf2.st_mtime = fixed_time;
|
|
+ if(read_size != buf2.st_size) {
|
|
+ memcpy(buf, &buf2, sizeof(struct stat));
|
|
+ file_buffer->error = 2;
|
|
+@@ -3612,7 +3617,7 @@ void dir_scan(squashfs_inode *inode, cha
|
|
+ buf.st_mode = S_IRWXU | S_IRWXG | S_IRWXO | S_IFDIR;
|
|
+ buf.st_uid = getuid();
|
|
+ buf.st_gid = getgid();
|
|
+- buf.st_mtime = time(NULL);
|
|
++ buf.st_mtime = fixed_time != -1 ? fixed_time : time(NULL);
|
|
+ buf.st_dev = 0;
|
|
+ buf.st_ino = 0;
|
|
+ dir_ent->inode = lookup_inode(&buf);
|
|
+@@ -3623,6 +3628,8 @@ void dir_scan(squashfs_inode *inode, cha
|
|
+ pathname, strerror(errno));
|
|
+ return;
|
|
+ }
|
|
++ if(fixed_time != -1)
|
|
++ buf.st_mtime = fixed_time;
|
|
+ dir_ent->inode = lookup_inode(&buf);
|
|
+ }
|
|
+
|
|
+@@ -3677,6 +3684,8 @@ struct dir_info *dir_scan1(char *pathnam
|
|
+ filename, strerror(errno));
|
|
+ continue;
|
|
+ }
|
|
++ if(fixed_time != -1)
|
|
++ buf.st_mtime = fixed_time;
|
|
+
|
|
+ if((buf.st_mode & S_IFMT) != S_IFREG &&
|
|
+ (buf.st_mode & S_IFMT) != S_IFDIR &&
|
|
+@@ -3795,7 +3804,7 @@ struct dir_info *dir_scan2(struct dir_in
|
|
+ buf.st_gid = pseudo_ent->dev->gid;
|
|
+ buf.st_rdev = makedev(pseudo_ent->dev->major,
|
|
+ pseudo_ent->dev->minor);
|
|
+- buf.st_mtime = time(NULL);
|
|
++ buf.st_mtime = fixed_time != -1 ? fixed_time : time(NULL);
|
|
+ buf.st_ino = pseudo_ino ++;
|
|
+
|
|
+ if(pseudo_ent->dev->type == 'f') {
|
|
+@@ -4674,6 +4683,15 @@ int main(int argc, char *argv[])
|
|
+ progress = FALSE;
|
|
+ else if(strcmp(argv[i], "-no-exports") == 0)
|
|
+ exportable = FALSE;
|
|
++ else if(strcmp(argv[i], "-fixed-time") == 0) {
|
|
++ if((++i == argc) || (fixed_time =
|
|
++ strtoll(argv[i], &b, 10), *b != '\0')) {
|
|
++ ERROR("%s: -fixed-time missing or invalid "
|
|
++ "timestamp\n", argv[0]);
|
|
++
|
|
++ exit(1);
|
|
++ }
|
|
++ }
|
|
+ else if(strcmp(argv[i], "-processors") == 0) {
|
|
+ if((++i == argc) || (processors =
|
|
+ strtol(argv[i], &b, 10), *b != '\0')) {
|
|
+@@ -5314,7 +5332,7 @@ printOptions:
|
|
+ sBlk.flags = SQUASHFS_MKFLAGS(noI, noD, noF, noX, no_fragments,
|
|
+ always_use_fragments, duplicate_checking, exportable,
|
|
+ no_xattrs, comp_opts);
|
|
+- sBlk.mkfs_time = time(NULL);
|
|
++ sBlk.mkfs_time = fixed_time != -1 ? fixed_time : time(NULL);
|
|
+
|
|
+ restore_filesystem:
|
|
+ if(progress && estimated_uncompressed) {
|