From 08d32590411568e7bf11612ac695a6e9c6df6286 Mon Sep 17 00:00:00 2001 From: Richard Purdie Date: Mon, 13 Jul 2015 12:04:52 +0100 Subject: dpkg: Fix for Fedora22 and new versions of tar They managed to 'break' tar. Again. Sorry, they fixed a regression which broke dpkg-deb. The addition of: http://git.savannah.gnu.org/cgit/tar.git/commit/?id=163e96a0e619a900eab6de827c7c5749ecc9d3f2 ("Bugfix: entries read from the -T file did not get proper matching_flag.") means that the no-recursion option gets lost. This leads to many files getting included multiple times, along with files which shouldn't be there. The commit message is horrendous. The patch actually makes the option positional (as documnted since 2003) and therefore doesn't affect the input from the -T option. Moving the --no-reursion option to earlier in the command avoids the bug. The bug was not present in tar 1.28 however it has been backported in at least Fedora 22 and heading into Fedora 21. Redhat reports of issue: https://bugzilla.redhat.com/show_bug.cgi?id=1230762 [tar] https://bugzilla.redhat.com/show_bug.cgi?id=1241508 [dpkg] Discussion of bug in upstream tar: http://www.mail-archive.com/bug-tar@gnu.org/msg04799.html [YOCTO #7988] (From OE-Core rev: 6be698b7270f73f40d38713ecf13f12aec0ced61) (From OE-Core rev: 1c916ddebc3009d3817359144b02745c3ecbd5c4) Signed-off-by: Richard Purdie --- meta/recipes-devtools/dpkg/dpkg/tarfix.patch | 45 ++++++++++++++++++++++++++++ meta/recipes-devtools/dpkg/dpkg_1.17.21.bb | 1 + 2 files changed, 46 insertions(+) create mode 100644 meta/recipes-devtools/dpkg/dpkg/tarfix.patch diff --git a/meta/recipes-devtools/dpkg/dpkg/tarfix.patch b/meta/recipes-devtools/dpkg/dpkg/tarfix.patch new file mode 100644 index 0000000..50e0bb4 --- /dev/null +++ b/meta/recipes-devtools/dpkg/dpkg/tarfix.patch @@ -0,0 +1,45 @@ +They managed to 'break' tar. Again. Sorry, they fixed a regression +which broke dpkg-deb. + +The addition of: +http://git.savannah.gnu.org/cgit/tar.git/commit/?id=163e96a0e619a900eab6de827c7c5749ecc9d3f2 +("Bugfix: entries read from the -T file did not get proper matching_flag.") +means that the no-recursion option gets lost. This leads to many files getting included +multiple times, along with files which shouldn't be there. + +The commit message is horrendous. The patch actually makes the option positional +(as documnted since 2003) and therefore doesn't affect the input from the -T option. + +Moving the --no-reursion option to earlier in the command avoids the bug. + +The bug was not present in tar 1.28 however it has been backported in at least +Fedora 22 and heading into Fedora 21. + +Redhat reports of issue: +https://bugzilla.redhat.com/show_bug.cgi?id=1230762 [tar] +https://bugzilla.redhat.com/show_bug.cgi?id=1241508 [dpkg] + +Discussion of bug in upstream tar: +http://www.mail-archive.com/bug-tar@gnu.org/msg04799.html + +Yocto bug: +https://bugzilla.yoctoproject.org/show_bug.cgi?id=7988 + +Upstream-Status: Submitted [have mailed dpkg maintainer about this] + +RP +2015/7/13 + +Index: dpkg-1.17.25/dpkg-deb/build.c +=================================================================== +--- dpkg-1.17.25.orig/dpkg-deb/build.c ++++ dpkg-1.17.25/dpkg-deb/build.c +@@ -560,7 +560,7 @@ do_build(const char *const *argv) + if (chdir(dir)) + ohshite(_("failed to chdir to `%.255s'"), dir); + execlp(TAR, "tar", "-cf", "-", "--format=gnu", "--null", "--no-unquote", +- "-T", "-", "--no-recursion", NULL); ++ "--no-recursion", "-T", "-", NULL); + ohshite(_("unable to execute %s (%s)"), "tar -cf", TAR); + } + close(p1[0]); diff --git a/meta/recipes-devtools/dpkg/dpkg_1.17.21.bb b/meta/recipes-devtools/dpkg/dpkg_1.17.21.bb index ebb8671..7adb2b2 100644 --- a/meta/recipes-devtools/dpkg/dpkg_1.17.21.bb +++ b/meta/recipes-devtools/dpkg/dpkg_1.17.21.bb @@ -13,6 +13,7 @@ SRC_URI += "file://noman.patch \ file://glibc2.5-sync_file_range.patch \ file://no-vla-warning.patch \ file://add_armeb_triplet_entry.patch \ + file://tarfix.patch \ " SRC_URI[md5sum] = "765a96fd0180196613bbfa3c4aef0775" -- cgit v1.1