diff options
author | Alexander Couzens <lynxis@fe80.eu> | 2017-06-18 21:28:59 +0200 |
---|---|---|
committer | Alexander Couzens <lynxis@fe80.eu> | 2017-06-19 14:35:07 +0200 |
commit | b5aaafe9a36031149fa52bd07aa4a339e226c23c (patch) | |
tree | abe6d6d817a8b9d03f4c0e42906784197b2457c2 /tools | |
parent | c47a1a3527d988b637c1daee573cbe0170ef73c6 (diff) | |
download | mtk-20170518-b5aaafe9a36031149fa52bd07aa4a339e226c23c.zip mtk-20170518-b5aaafe9a36031149fa52bd07aa4a339e226c23c.tar.gz mtk-20170518-b5aaafe9a36031149fa52bd07aa4a339e226c23c.tar.bz2 |
mtd-utils/mkfs.jffs2: honor env SOURCE_DATE_EPOCH
Use the timestamp from the enviroment SOURCE_DATE_EPOCH
if set instead of the build time.
Signed-off-by: Alexander Couzens <lynxis@fe80.eu>
Diffstat (limited to 'tools')
-rw-r--r-- | tools/mtd-utils/patches/320-mkfs.jffs2-SOURCE_DATE_EPOCH.patch | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/tools/mtd-utils/patches/320-mkfs.jffs2-SOURCE_DATE_EPOCH.patch b/tools/mtd-utils/patches/320-mkfs.jffs2-SOURCE_DATE_EPOCH.patch new file mode 100644 index 0000000..46014e7 --- /dev/null +++ b/tools/mtd-utils/patches/320-mkfs.jffs2-SOURCE_DATE_EPOCH.patch @@ -0,0 +1,62 @@ +Index: mtd-utils-1.5.2/mkfs.jffs2.c +=================================================================== +--- mtd-utils-1.5.2.orig/mkfs.jffs2.c ++++ mtd-utils-1.5.2/mkfs.jffs2.c +@@ -108,7 +108,7 @@ static char *rootdir = default_rootdir; + static int verbose = 0; + static int squash_uids = 0; + static int squash_perms = 0; +-static int fake_times = 0; ++static time_t fixed_timestamp = -1; + int target_endian = __BYTE_ORDER; + + uint32_t find_hardlink(struct filesystem_entry *e) +@@ -249,8 +249,8 @@ static struct filesystem_entry *add_host + mode &= ~(S_ISUID | S_ISGID); + } + } +- if (fake_times) { +- timestamp = 0; ++ if (fixed_timestamp != -1) { ++ timestamp = fixed_timestamp; + } + + entry = xcalloc(1, sizeof(struct filesystem_entry)); +@@ -1554,6 +1554,20 @@ void parse_image(){ + close(in_fd); + } + ++static void set_source_date_epoch() { ++ char *env = getenv("SOURCE_DATE_EPOCH"); ++ char *endptr = env; ++ errno = 0; ++ if (env && *env) { ++ fixed_timestamp = strtoull(env, &endptr, 10); ++ if (errno || (endptr && *endptr != '\0')) { ++ fprintf(stderr, "Invalid SOURCE_DATE_EPOCH"); ++ exit(1); ++ } ++ } ++} ++ ++ + int main(int argc, char **argv) + { + int c, opt; +@@ -1572,6 +1586,7 @@ int main(int argc, char **argv) + warn_page_size = 1; /* warn user if page size not 4096 */ + + jffs2_compressors_init(); ++ set_source_date_epoch(); + + while ((opt = getopt_long(argc, argv, + "D:d:r:s:o:qUPfh?vVe:lbp::nc:m:x:X:Lty:i:", long_options, &c)) >= 0) +@@ -1622,7 +1637,7 @@ int main(int argc, char **argv) + break; + + case 'f': +- fake_times = 1; ++ fixed_timestamp = 0; + break; + + case 'h': |