diff options
Diffstat (limited to 'main/busybox/0001-tar-Implement-no-recursion.patch')
-rw-r--r-- | main/busybox/0001-tar-Implement-no-recursion.patch | 112 |
1 files changed, 0 insertions, 112 deletions
diff --git a/main/busybox/0001-tar-Implement-no-recursion.patch b/main/busybox/0001-tar-Implement-no-recursion.patch deleted file mode 100644 index b457c50c93..0000000000 --- a/main/busybox/0001-tar-Implement-no-recursion.patch +++ /dev/null @@ -1,112 +0,0 @@ -From abc357b4612ac02e9246eccdde8dcfcda81a5433 Mon Sep 17 00:00:00 2001 -From: Natanael Copa <ncopa@alpinelinux.org> -Date: Tue, 24 Apr 2012 17:02:15 +0200 -Subject: [PATCH] tar: Implement --no-recursion - -bloatcheck on x86_64: - -function old new delta -tar_longopts 259 274 +15 -.rodata 5757 5772 +15 -tar_main 1038 1052 +14 -writeTarFile 362 353 -9 ------------------------------------------------------------------------------- -(add/remove: 0/0 grow/shrink: 3/1 up/down: 44/-9) Total: 35 bytes - text data bss dec hex filename - 81457 1706 8344 91507 16573 busybox_old - 81477 1706 8344 91527 16587 busybox_unstripped - -Signed-off-by: Natanael Copa <ncopa@alpinelinux.org> ---- - archival/tar.c | 19 ++++++++++++------- - 1 file changed, 12 insertions(+), 7 deletions(-) - -diff --git a/archival/tar.c b/archival/tar.c -index cf972c2..a64d651 100644 ---- a/archival/tar.c -+++ b/archival/tar.c -@@ -60,8 +60,8 @@ - - #if !ENABLE_FEATURE_SEAMLESS_GZ && !ENABLE_FEATURE_SEAMLESS_BZ2 - /* Do not pass gzip flag to writeTarFile() */ --#define writeTarFile(tar_fd, verboseFlag, dereferenceFlag, include, exclude, gzip) \ -- writeTarFile(tar_fd, verboseFlag, dereferenceFlag, include, exclude) -+#define writeTarFile(tar_fd, verboseFlag, recurseFlags, include, exclude, gzip) \ -+ writeTarFile(tar_fd, verboseFlag, recurseFlags, include, exclude) - #endif - - -@@ -598,7 +598,7 @@ static void NOINLINE vfork_compressor(int tar_fd, int gzip) - - /* gcc 4.2.1 inlines it, making code bigger */ - static NOINLINE int writeTarFile(int tar_fd, int verboseFlag, -- int dereferenceFlag, const llist_t *include, -+ int recurseFlags, const llist_t *include, - const llist_t *exclude, int gzip) - { - int errorFlag = FALSE; -@@ -621,8 +621,7 @@ static NOINLINE int writeTarFile(int tar_fd, int verboseFlag, - - /* Read the directory/files and iterate over them one at a time */ - while (include) { -- if (!recursive_action(include->data, ACTION_RECURSE | -- (dereferenceFlag ? ACTION_FOLLOWLINKS : 0), -+ if (!recursive_action(include->data, recurseFlags, - writeFileToTarball, writeFileToTarball, &tbInfo, 0) - ) { - errorFlag = TRUE; -@@ -662,7 +661,7 @@ static NOINLINE int writeTarFile(int tar_fd, int verboseFlag, - } - #else - int writeTarFile(int tar_fd, int verboseFlag, -- int dereferenceFlag, const llist_t *include, -+ int recurseFlags, const llist_t *include, - const llist_t *exclude, int gzip); - #endif /* FEATURE_TAR_CREATE */ - -@@ -749,6 +748,7 @@ static llist_t *append_file_list_to_list(llist_t *list) - // o no-same-owner - // p same-permissions - // k keep-old -+// no-recursion - // numeric-owner - // no-same-permissions - // overwrite -@@ -768,6 +768,7 @@ enum { - IF_FEATURE_SEAMLESS_Z( OPTBIT_COMPRESS ,) // 16th bit - IF_FEATURE_TAR_NOPRESERVE_TIME(OPTBIT_NOPRESERVE_TIME,) - #if ENABLE_FEATURE_TAR_LONG_OPTIONS -+ OPTBIT_NORECURSION, - IF_FEATURE_TAR_TO_COMMAND(OPTBIT_2COMMAND ,) - OPTBIT_NUMERIC_OWNER, - OPTBIT_NOPRESERVE_PERM, -@@ -791,6 +792,7 @@ enum { - OPT_GZIP = IF_FEATURE_SEAMLESS_GZ( (1 << OPTBIT_GZIP )) + 0, // z - OPT_COMPRESS = IF_FEATURE_SEAMLESS_Z( (1 << OPTBIT_COMPRESS )) + 0, // Z - OPT_NOPRESERVE_TIME = IF_FEATURE_TAR_NOPRESERVE_TIME((1 << OPTBIT_NOPRESERVE_TIME)) + 0, // m -+ OPT_NORECURSION = IF_FEATURE_TAR_LONG_OPTIONS((1 << OPTBIT_NORECURSION )) + 0, // no-recursion - OPT_2COMMAND = IF_FEATURE_TAR_TO_COMMAND( (1 << OPTBIT_2COMMAND )) + 0, // to-command - OPT_NUMERIC_OWNER = IF_FEATURE_TAR_LONG_OPTIONS((1 << OPTBIT_NUMERIC_OWNER )) + 0, // numeric-owner - OPT_NOPRESERVE_PERM = IF_FEATURE_TAR_LONG_OPTIONS((1 << OPTBIT_NOPRESERVE_PERM)) + 0, // no-same-permissions -@@ -835,6 +837,7 @@ static const char tar_longopts[] ALIGN1 = - # if ENABLE_FEATURE_TAR_NOPRESERVE_TIME - "touch\0" No_argument "m" - # endif -+ "no-recursion\0" No_argument "\xfa" - # if ENABLE_FEATURE_TAR_TO_COMMAND - "to-command\0" Required_argument "\xfb" - # endif -@@ -1050,7 +1053,9 @@ int tar_main(int argc UNUSED_PARAM, char **argv) - zipMode = 2; - #endif - /* NB: writeTarFile() closes tar_handle->src_fd */ -- return writeTarFile(tar_handle->src_fd, verboseFlag, opt & OPT_DEREFERENCE, -+ return writeTarFile(tar_handle->src_fd, verboseFlag, -+ (opt & OPT_DEREFERENCE ? ACTION_FOLLOWLINKS : 0) -+ | (opt & OPT_NORECURSION ? 0 : ACTION_RECURSE), - tar_handle->accept, - tar_handle->reject, zipMode); - } --- -1.7.10 - |