From 8ef77f9da8c62412431e23f78756c5d7d93b5eed Mon Sep 17 00:00:00 2001 From: landley Date: Fri, 16 Dec 2005 21:33:10 +0000 Subject: Bug 601: When we fork an archiver and feed stuff to it through a pipe, if we don't close the pipe the child process won't exit, and we'll hang in waitpid(). git-svn-id: svn://busybox.net/trunk/busybox@12941 69ca8d6d-28ef-0310-b511-8ec308f3f277 --- archival/tar.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/archival/tar.c b/archival/tar.c index b2967463e..cd89a7566 100644 --- a/archival/tar.c +++ b/archival/tar.c @@ -513,11 +513,12 @@ static inline int writeTarFile(const int tar_fd, const int verboseFlag, * but that isn't necessary for GNU tar interoperability, and * so is considered a waste of space */ + /* Close so the child process (if any) will exit */ + close(tbInfo.tarFd); + /* Hang up the tools, close up shop, head home */ - if (ENABLE_FEATURE_CLEAN_UP) { - close(tbInfo.tarFd); + if (ENABLE_FEATURE_CLEAN_UP) freeHardLinkInfo(&tbInfo.hlInfoHead); - } if (errorFlag) bb_error_msg("Error exit delayed from previous errors"); -- cgit v1.2.3-55-g6feb