Initialize for cpio
This commit is contained in:
commit
3aa57bc9dd
22 changed files with 1731 additions and 0 deletions
1
.cpio.metadata
Normal file
1
.cpio.metadata
Normal file
|
@ -0,0 +1 @@
|
||||||
|
5d5d55d2165a02c3d79b949daef64d6593d944451c5e7d2da64192df4c01943c cpio-2.13.tar.bz2
|
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
|
@ -0,0 +1 @@
|
||||||
|
cpio-2.13.tar.bz2
|
7
cpio-2.13.tar.bz2.sig
Normal file
7
cpio-2.13.tar.bz2.sig
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
-----BEGIN PGP SIGNATURE-----
|
||||||
|
Version: GnuPG v1.4.15 (GNU/Linux)
|
||||||
|
|
||||||
|
iEYEABECAAYFAl3CgW4ACgkQNgKwf1XQxzInuACdFx2CwRnphQ5Zka2zFicnNNCX
|
||||||
|
3z4AoIQeYZNDDyJoOzIYvKuNrFePJ4hG
|
||||||
|
=InYG
|
||||||
|
-----END PGP SIGNATURE-----
|
24
cpio-close_files_after_copy.patch
Normal file
24
cpio-close_files_after_copy.patch
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
Index: src/copyin.c
|
||||||
|
===================================================================
|
||||||
|
--- src/copyin.c.orig
|
||||||
|
+++ src/copyin.c
|
||||||
|
@@ -1420,6 +1420,19 @@ process_copy_in ()
|
||||||
|
|
||||||
|
cpio_file_stat_free (&file_hdr);
|
||||||
|
|
||||||
|
+ if (tty_in)
|
||||||
|
+ {
|
||||||
|
+ fclose(tty_in);
|
||||||
|
+ }
|
||||||
|
+ if (tty_out)
|
||||||
|
+ {
|
||||||
|
+ fclose(tty_out);
|
||||||
|
+ }
|
||||||
|
+ if (rename_in)
|
||||||
|
+ {
|
||||||
|
+ fclose(rename_in);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
if (append_flag)
|
||||||
|
return;
|
||||||
|
|
28
cpio-default_tape_dev.patch
Normal file
28
cpio-default_tape_dev.patch
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
Index: src/mt.c
|
||||||
|
===================================================================
|
||||||
|
--- src/mt.c.orig
|
||||||
|
+++ src/mt.c
|
||||||
|
@@ -225,11 +225,18 @@ parse_opt (int key, char *arg, struct ar
|
||||||
|
{
|
||||||
|
tapedev = getenv ("TAPE");
|
||||||
|
if (tapedev == NULL)
|
||||||
|
-#ifdef DEFTAPE /* From sys/mtio.h. */
|
||||||
|
- tapedev = DEFTAPE;
|
||||||
|
-#else
|
||||||
|
- error (MT_EXIT_INVOP, 0, _("no tape device specified"));
|
||||||
|
-#endif
|
||||||
|
+
|
||||||
|
+/* Suse doesn't have /dev/tape as link to /dev/nst0 any more.
|
||||||
|
+Instead it uses udev and creates different names in /dev/tape/by-id/ directory.
|
||||||
|
+If it is SCSI tape storage then it creates /dev/tape/by-id/scsi--nst
|
||||||
|
+If it is USB device then it creates something not predictibable:
|
||||||
|
+/dev/tape/by-id/scsi-*HP_blabla*{VENDOR_SPECIFIC}*-nst
|
||||||
|
+So let's use old behave which was /dev/nst0.
|
||||||
|
+bnc#355241
|
||||||
|
+*/
|
||||||
|
+/* #ifdef DEFTAPE * From sys/mtio.h. * */
|
||||||
|
+# define DEFSUSETAPE "/dev/nst0"
|
||||||
|
+ tapedev = DEFSUSETAPE;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
24
cpio-dev_number.patch
Normal file
24
cpio-dev_number.patch
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
Index: src/copyin.c
|
||||||
|
===================================================================
|
||||||
|
--- src/copyin.c.orig
|
||||||
|
+++ src/copyin.c
|
||||||
|
@@ -1123,15 +1123,15 @@ read_in_binary (struct cpio_file_stat *f
|
||||||
|
swab_array ((char *) short_hdr, 13);
|
||||||
|
}
|
||||||
|
|
||||||
|
- file_hdr->c_dev_maj = major (short_hdr->c_dev);
|
||||||
|
- file_hdr->c_dev_min = minor (short_hdr->c_dev);
|
||||||
|
+ file_hdr->c_dev_maj = major ((unsigned short)short_hdr->c_dev);
|
||||||
|
+ file_hdr->c_dev_min = minor ((unsigned short)short_hdr->c_dev);
|
||||||
|
file_hdr->c_ino = short_hdr->c_ino;
|
||||||
|
file_hdr->c_mode = short_hdr->c_mode;
|
||||||
|
file_hdr->c_uid = short_hdr->c_uid;
|
||||||
|
file_hdr->c_gid = short_hdr->c_gid;
|
||||||
|
file_hdr->c_nlink = short_hdr->c_nlink;
|
||||||
|
- file_hdr->c_rdev_maj = major (short_hdr->c_rdev);
|
||||||
|
- file_hdr->c_rdev_min = minor (short_hdr->c_rdev);
|
||||||
|
+ file_hdr->c_rdev_maj = major ((unsigned short)short_hdr->c_rdev);
|
||||||
|
+ file_hdr->c_rdev_min = minor ((unsigned short)short_hdr->c_rdev);
|
||||||
|
file_hdr->c_mtime = (unsigned long) short_hdr->c_mtimes[0] << 16
|
||||||
|
| short_hdr->c_mtimes[1];
|
||||||
|
file_hdr->c_filesize = (unsigned long) short_hdr->c_filesizes[0] << 16
|
79
cpio-eof_tape_handling.patch
Normal file
79
cpio-eof_tape_handling.patch
Normal file
|
@ -0,0 +1,79 @@
|
||||||
|
Index: src/util.c
|
||||||
|
===================================================================
|
||||||
|
--- src/util.c.orig
|
||||||
|
+++ src/util.c
|
||||||
|
@@ -203,8 +203,15 @@ tape_fill_input_buffer (int in_des, int
|
||||||
|
input_size = rmtread (in_des, input_buffer, num_bytes);
|
||||||
|
if (input_size == 0 && input_is_special)
|
||||||
|
{
|
||||||
|
- get_next_reel (in_des);
|
||||||
|
+ if (!tape_eof (in_des))
|
||||||
|
+ get_next_reel (in_des);
|
||||||
|
input_size = rmtread (in_des, input_buffer, num_bytes);
|
||||||
|
+ if (input_size == 0)
|
||||||
|
+ {
|
||||||
|
+ if (tape_eod (in_des))
|
||||||
|
+ get_next_reel (in_des);
|
||||||
|
+ input_size = rmtread (in_des, input_buffer, num_bytes);
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
if (input_size == SAFE_READ_ERROR)
|
||||||
|
error (PAXEXIT_FAILURE, errno, _("read error"));
|
||||||
|
@@ -366,8 +373,15 @@ tape_buffered_peek (char *peek_buf, int
|
||||||
|
{
|
||||||
|
if (input_is_special)
|
||||||
|
{
|
||||||
|
- get_next_reel (in_des);
|
||||||
|
+ if (!tape_eof (in_des))
|
||||||
|
+ get_next_reel (in_des);
|
||||||
|
tmp_input_size = rmtread (in_des, append_buf, io_block_size);
|
||||||
|
+ if (tmp_input_size == 0)
|
||||||
|
+ {
|
||||||
|
+ if (tape_eod (in_des))
|
||||||
|
+ get_next_reel (in_des);
|
||||||
|
+ tmp_input_size = rmtread (in_des, append_buf, io_block_size);
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
else
|
||||||
|
break;
|
||||||
|
@@ -829,6 +843,40 @@ tape_offline (int tape_des)
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
+int
|
||||||
|
+tape_eof( int tape_des)
|
||||||
|
+{
|
||||||
|
+ struct mtget status;
|
||||||
|
+
|
||||||
|
+ if (rmtioctl (tape_des, MTIOCGET, (char*)&status) == -1) {
|
||||||
|
+ error (1, errno, "Cannot get tape status");
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (GMT_EOF(status.mt_gstat)) {
|
||||||
|
+ return 1;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int
|
||||||
|
+tape_eod( int tape_des)
|
||||||
|
+{
|
||||||
|
+ struct mtget status;
|
||||||
|
+
|
||||||
|
+ if (rmtioctl (tape_des, MTIOCGET, (char*)&status) == -1) {
|
||||||
|
+ error (1, errno, "Cannot get tape status");
|
||||||
|
+ return 1;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (GMT_EOD(status.mt_gstat)) {
|
||||||
|
+ return 1;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
/* The file on file descriptor TAPE_DES is assumed to be magnetic tape
|
||||||
|
(or floppy disk or other device) and the end of the medium
|
||||||
|
has been reached. Ask the user for to mount a new "tape" to continue
|
13
cpio-fix_truncation_check.patch
Normal file
13
cpio-fix_truncation_check.patch
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
Index: cpio-2.13/src/mt.c
|
||||||
|
===================================================================
|
||||||
|
--- cpio-2.13.orig/src/mt.c
|
||||||
|
+++ cpio-2.13/src/mt.c
|
||||||
|
@@ -208,7 +208,7 @@ parse_opt (int key, char *arg, struct ar
|
||||||
|
{
|
||||||
|
char *p;
|
||||||
|
long val = strtol (arg, &p, 0);
|
||||||
|
- if (*p || (count = val) != count)
|
||||||
|
+ if (*p || (count = val) != val)
|
||||||
|
error (MT_EXIT_INVOP, 0, _("invalid count value"));
|
||||||
|
}
|
||||||
|
break;
|
68
cpio-open_nonblock.patch
Normal file
68
cpio-open_nonblock.patch
Normal file
|
@ -0,0 +1,68 @@
|
||||||
|
From: Alexey Svistunov <svalx@svalx.net>
|
||||||
|
Date: 2017-02-17 16:07:00 +0300
|
||||||
|
Subject: open device with O_NONBLOCK option
|
||||||
|
References: https://savannah.gnu.org/patch/?9263, bnc#94449
|
||||||
|
Upstream: submitted
|
||||||
|
|
||||||
|
When running the 2.6 kernel, "mt -f /dev/nst0 status" blocks if there is
|
||||||
|
no media in the drive. The same occurs for other commands.
|
||||||
|
|
||||||
|
When running the 2.4.24 kernel, "mt -f /dev/nst0 status" does not block
|
||||||
|
when there is no tape in the drive.
|
||||||
|
|
||||||
|
This behavior change is documented for the 2.6 kernel (see
|
||||||
|
kernel-source-2.6.3/Documentation/scsi/st.txt for the full doc):
|
||||||
|
|
||||||
|
If the open option O_NONBLOCK is used, open succeeds even if the
|
||||||
|
drive is not ready. If O_NONBLOCK is not used, the driver waits for
|
||||||
|
the drive to become ready. If this does not happen in ST_BLOCK_SECONDS
|
||||||
|
seconds, open fails with the errno value EIO. With O_NONBLOCK the
|
||||||
|
device can be opened for writing even if there is a write protected
|
||||||
|
tape in the drive (commands trying to write something return error if
|
||||||
|
attempted).
|
||||||
|
|
||||||
|
It appears that the use of O_NONBLOCK is safe with pre-2.6 kernels.
|
||||||
|
Suggest adding the use of O_NONBLOCK when opening the device. As it is,
|
||||||
|
for long-running commands such as "fsf", one cannot tell if the command is
|
||||||
|
progressing or if it's blocking waiting for media.
|
||||||
|
|
||||||
|
Index: src/mt.c
|
||||||
|
===================================================================
|
||||||
|
--- src/mt.c.orig
|
||||||
|
+++ src/mt.c
|
||||||
|
@@ -333,11 +333,11 @@ main (int argc, char **argv)
|
||||||
|
#ifdef MTERASE
|
||||||
|
case MTERASE:
|
||||||
|
#endif
|
||||||
|
- tapedesc = rmtopen (tapedev, O_WRONLY, 0, rsh_command_option);
|
||||||
|
+ tapedesc = rmtopen (tapedev, O_WRONLY | O_NONBLOCK, 0, rsh_command_option);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
- tapedesc = rmtopen (tapedev, O_RDONLY, 0, rsh_command_option);
|
||||||
|
+ tapedesc = rmtopen (tapedev, O_RDONLY | O_NONBLOCK, 0, rsh_command_option);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (tapedesc == -1)
|
||||||
|
Index: src/util.c
|
||||||
|
===================================================================
|
||||||
|
--- src/util.c.orig
|
||||||
|
+++ src/util.c
|
||||||
|
@@ -801,14 +801,14 @@ open_archive (char *file)
|
||||||
|
copy_in = process_copy_in;
|
||||||
|
|
||||||
|
if (copy_function == copy_in)
|
||||||
|
- fd = rmtopen (file, O_RDONLY | O_BINARY, MODE_RW, rsh_command_option);
|
||||||
|
+ fd = rmtopen (file, O_RDONLY | O_BINARY | O_NONBLOCK, MODE_RW, rsh_command_option);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (!append_flag)
|
||||||
|
- fd = rmtopen (file, O_WRONLY | O_CREAT | O_TRUNC | O_BINARY, MODE_RW,
|
||||||
|
+ fd = rmtopen (file, O_WRONLY | O_CREAT | O_TRUNC | O_BINARY | O_NONBLOCK, MODE_RW,
|
||||||
|
rsh_command_option);
|
||||||
|
else
|
||||||
|
- fd = rmtopen (file, O_RDWR | O_BINARY, MODE_RW, rsh_command_option);
|
||||||
|
+ fd = rmtopen (file, O_RDWR | O_BINARY | O_NONBLOCK, MODE_RW, rsh_command_option);
|
||||||
|
}
|
||||||
|
|
||||||
|
return fd;
|
21
cpio-pattern-file-sigsegv.patch
Normal file
21
cpio-pattern-file-sigsegv.patch
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
Index: cpio-2.13/src/copyin.c
|
||||||
|
===================================================================
|
||||||
|
--- cpio-2.13.orig/src/copyin.c
|
||||||
|
+++ cpio-2.13/src/copyin.c
|
||||||
|
@@ -798,6 +798,8 @@ read_pattern_file ()
|
||||||
|
pattern_fp = fopen (pattern_file_name, "r");
|
||||||
|
if (pattern_fp == NULL)
|
||||||
|
open_fatal (pattern_file_name);
|
||||||
|
+ else
|
||||||
|
+ {
|
||||||
|
while (ds_fgetstr (pattern_fp, &pattern_name, '\n') != NULL)
|
||||||
|
{
|
||||||
|
if (new_num_patterns >= max_new_patterns)
|
||||||
|
@@ -812,6 +814,7 @@ read_pattern_file ()
|
||||||
|
}
|
||||||
|
if (ferror (pattern_fp) || fclose (pattern_fp) == EOF)
|
||||||
|
close_error (pattern_file_name);
|
||||||
|
+ }
|
||||||
|
|
||||||
|
for (i = 0; i < num_patterns; ++i)
|
||||||
|
new_save_patterns[i] = save_patterns[i];
|
91
cpio-revert-CVE-2015-1197-fix.patch
Normal file
91
cpio-revert-CVE-2015-1197-fix.patch
Normal file
|
@ -0,0 +1,91 @@
|
||||||
|
revert fix for CVE-2015-1197 as it causes shutdown issues
|
||||||
|
|
||||||
|
revert suggested as a workaround by upstream:
|
||||||
|
https://lists.gnu.org/archive/html/bug-cpio/2019-11/msg00016.html
|
||||||
|
|
||||||
|
--- b/src/copyin.c
|
||||||
|
+++ a/src/copyin.c
|
||||||
|
@@ -645,14 +645,13 @@
|
||||||
|
link_name = xstrdup (file_hdr->c_tar_linkname);
|
||||||
|
}
|
||||||
|
|
||||||
|
- cpio_safer_name_suffix (link_name, true, !no_abs_paths_flag, false);
|
||||||
|
-
|
||||||
|
res = UMASKED_SYMLINK (link_name, file_hdr->c_name,
|
||||||
|
file_hdr->c_mode);
|
||||||
|
if (res < 0 && create_dir_flag)
|
||||||
|
{
|
||||||
|
create_all_directories (file_hdr->c_name);
|
||||||
|
+ res = UMASKED_SYMLINK (link_name, file_hdr->c_name,
|
||||||
|
+ file_hdr->c_mode);
|
||||||
|
- res = UMASKED_SYMLINK (link_name, file_hdr->c_name, file_hdr->c_mode);
|
||||||
|
}
|
||||||
|
if (res < 0)
|
||||||
|
{
|
||||||
|
--- b/tests/CVE-2015-1197.at
|
||||||
|
+++ /dev/null
|
||||||
|
@@ -1,43 +0,0 @@
|
||||||
|
-# Process this file with autom4te to create testsuite. -*- Autotest -*-
|
||||||
|
-# Copyright (C) 2009-2019 Free Software Foundation, Inc.
|
||||||
|
-#
|
||||||
|
-# This program is free software; you can redistribute it and/or modify
|
||||||
|
-# it under the terms of the GNU General Public License as published by
|
||||||
|
-# the Free Software Foundation; either version 3, or (at your option)
|
||||||
|
-# any later version.
|
||||||
|
-#
|
||||||
|
-# This program is distributed in the hope that it will be useful,
|
||||||
|
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
-# GNU General Public License for more details.
|
||||||
|
-#
|
||||||
|
-# You should have received a copy of the GNU General Public License
|
||||||
|
-# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
-
|
||||||
|
-AT_SETUP([CVE-2015-1197 (--no-absolute-filenames for symlinks)])
|
||||||
|
-AT_CHECK([
|
||||||
|
-tempdir=$(pwd)/tmp
|
||||||
|
-mkdir $tempdir
|
||||||
|
-touch $tempdir/file
|
||||||
|
-ln -s $tempdir dir
|
||||||
|
-AT_DATA([filelist],
|
||||||
|
-[dir
|
||||||
|
-dir/file
|
||||||
|
-])
|
||||||
|
-ln -s /tmp dir
|
||||||
|
-touch /tmp/file
|
||||||
|
-cpio -o < filelist > test.cpio
|
||||||
|
-rm dir /tmp/file
|
||||||
|
-cpio --no-absolute-filenames -iv < test.cpio
|
||||||
|
-],
|
||||||
|
-[2],
|
||||||
|
-[],
|
||||||
|
-[1 block
|
||||||
|
-cpio: Removing leading `/' from hard link targets
|
||||||
|
-dir
|
||||||
|
-cpio: dir/file: Cannot open: No such file or directory
|
||||||
|
-dir/file
|
||||||
|
-1 block
|
||||||
|
-])
|
||||||
|
-AT_CLEANUP
|
||||||
|
-
|
||||||
|
--- b/tests/Makefile.am
|
||||||
|
+++ a/tests/Makefile.am
|
||||||
|
@@ -56,9 +56,8 @@
|
||||||
|
symlink-long.at\
|
||||||
|
symlink-to-stdout.at\
|
||||||
|
version.at\
|
||||||
|
big-block-size.at\
|
||||||
|
- CVE-2015-1197.at\
|
||||||
|
CVE-2019-14866.at
|
||||||
|
|
||||||
|
TESTSUITE = $(srcdir)/testsuite
|
||||||
|
|
||||||
|
--- b/tests/testsuite.at
|
||||||
|
+++ a/tests/testsuite.at
|
||||||
|
@@ -43,6 +43,5 @@
|
||||||
|
m4_include([setstat04.at])
|
||||||
|
m4_include([setstat05.at])
|
||||||
|
m4_include([big-block-size.at])
|
||||||
|
|
||||||
|
-m4_include([CVE-2015-1197.at])
|
||||||
|
m4_include([CVE-2019-14866.at])
|
56
cpio-use_new_ascii_format.patch
Normal file
56
cpio-use_new_ascii_format.patch
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
Index: doc/cpio.info
|
||||||
|
===================================================================
|
||||||
|
--- doc/cpio.info.orig
|
||||||
|
+++ doc/cpio.info
|
||||||
|
@@ -226,7 +226,8 @@ option, e.g.:
|
||||||
|
'-B'
|
||||||
|
Set the I/O block size to 5120 bytes.
|
||||||
|
'-c'
|
||||||
|
- Use the old portable (ASCII) archive format.
|
||||||
|
+ Identical to "-H newc", use the new (SVR4) portable format.
|
||||||
|
+ If you wish the old portable (ASCII) archive format, use "-H odc" instead.
|
||||||
|
'-C NUMBER'
|
||||||
|
'--io-size=NUMBER'
|
||||||
|
Set the I/O block size to the given NUMBER of bytes.
|
||||||
|
@@ -307,7 +308,8 @@ option.
|
||||||
|
'-B'
|
||||||
|
Set the I/O block size to 5120 bytes.
|
||||||
|
'-c'
|
||||||
|
- Use the old portable (ASCII) archive format.
|
||||||
|
+ Identical to "-H newc", use the new (SVR4) portable format.
|
||||||
|
+ If you wish the old portable (ASCII) archive format, use "-H odc" instead.
|
||||||
|
'-C NUMBER'
|
||||||
|
'--io-size=NUMBER'
|
||||||
|
Set the I/O block size to the given NUMBER of bytes.
|
||||||
|
@@ -417,7 +419,8 @@ option.
|
||||||
|
'-B'
|
||||||
|
Set the I/O block size to 5120 bytes.
|
||||||
|
'-c'
|
||||||
|
- Use the old portable (ASCII) archive format.
|
||||||
|
+ Identical to "-H newc", use the new (SVR4) portable format.
|
||||||
|
+ If you wish the old portable (ASCII) archive format, use "-H odc" instead.
|
||||||
|
'-C NUMBER'
|
||||||
|
'--io-size=NUMBER'
|
||||||
|
Set the I/O block size to the given NUMBER of bytes.
|
||||||
|
@@ -565,7 +568,8 @@ option is valid.
|
||||||
|
|
||||||
|
'-c'
|
||||||
|
[*note copy-in::,*note copy-out::,*note copy-pass::]
|
||||||
|
- Use the old portable (ASCII) archive format.
|
||||||
|
+ Identical to "-H newc", use the new (SVR4) portable format.
|
||||||
|
+ If you wish the old portable (ASCII) archive format, use "-H odc" instead.
|
||||||
|
|
||||||
|
'-C IO-SIZE'
|
||||||
|
'--io-size=IO-SIZE'
|
||||||
|
Index: src/main.c
|
||||||
|
===================================================================
|
||||||
|
--- src/main.c.orig
|
||||||
|
+++ src/main.c
|
||||||
|
@@ -328,6 +328,7 @@ parse_opt (int key, char *arg, struct ar
|
||||||
|
case 'c': /* Use the old portable ASCII format. */
|
||||||
|
if (archive_format != arf_unknown)
|
||||||
|
USAGE_ERROR ((0, 0, _("Archive format multiply defined")));
|
||||||
|
+#define SVR4_COMPAT
|
||||||
|
#ifdef SVR4_COMPAT
|
||||||
|
archive_format = arf_newascii; /* -H newc. */
|
||||||
|
#else
|
22
cpio-use_sbin_rmt.patch
Normal file
22
cpio-use_sbin_rmt.patch
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
Index: lib/rtapelib.c
|
||||||
|
===================================================================
|
||||||
|
--- lib/rtapelib.c.orig
|
||||||
|
+++ lib/rtapelib.c
|
||||||
|
@@ -17,7 +17,7 @@
|
||||||
|
along with this program; if not, write to the Free Software Foundation,
|
||||||
|
Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */
|
||||||
|
|
||||||
|
-/* The man page rmt(8) for /etc/rmt documents the remote mag tape protocol
|
||||||
|
+/* The man page rmt(8) for /sbin/rmt documents the remote mag tape protocol
|
||||||
|
which rdump and rrestore use. Unfortunately, the man page is *WRONG*.
|
||||||
|
The author of the routines I'm including originally wrote his code just
|
||||||
|
based on the man page, and it didn't work, so he went to the rdump source
|
||||||
|
@@ -267,7 +267,7 @@ get_status_off (int handle)
|
||||||
|
|
||||||
|
#if WITH_REXEC
|
||||||
|
|
||||||
|
-/* Execute /etc/rmt as user USER on remote system HOST using rexec.
|
||||||
|
+/* Execute /sbin/rmt as user USER on remote system HOST using rexec.
|
||||||
|
Return a file descriptor of a bidirectional socket for stdin and
|
||||||
|
stdout. If USER is zero, use the current username.
|
||||||
|
|
343
cpio.changes
Normal file
343
cpio.changes
Normal file
|
@ -0,0 +1,343 @@
|
||||||
|
* Mon Jan 29 2024 danilo.spinella@suse.com
|
||||||
|
- Fix cpio not working after the fix in bsc#1218571, fixes bsc#1219238
|
||||||
|
* fix-bsc1219238.patch
|
||||||
|
* Fri Jan 12 2024 danilo.spinella@suse.com
|
||||||
|
- Fix CVE-2023-7207, path traversal vulnerability (bsc#1218571)
|
||||||
|
* fix-CVE-2023-7207.patch
|
||||||
|
* Thu Oct 28 2021 danilo.spinella@suse.com
|
||||||
|
- Update keyring
|
||||||
|
* Wed Aug 18 2021 danilo.spinella@suse.com
|
||||||
|
- Fix regression in last update (bsc#1189465)
|
||||||
|
* fix-CVE-2021-38185_2.patch
|
||||||
|
* fix-CVE-2021-38185_3.patch
|
||||||
|
* Mon Aug 9 2021 danilo.spinella@suse.com
|
||||||
|
- Fix CVE-2021-38185 Remote code execution caused by an integer overflow in ds_fgetstr
|
||||||
|
(CVE-2021-38185, bsc#1189206)
|
||||||
|
* fix-CVE-2021-38185.patch
|
||||||
|
* Fri Oct 16 2020 lnussel@suse.de
|
||||||
|
- prepare usrmerge (boo#1029961)
|
||||||
|
* Fri Sep 11 2020 dmueller@suse.com
|
||||||
|
- add cpio-revert-CVE-2015-1197-fix.patch as recommended by upstream
|
||||||
|
to fix https://lists.gnu.org/archive/html/bug-cpio/2019-11/msg00016.html
|
||||||
|
* Sat Aug 15 2020 dmueller@suse.com
|
||||||
|
- update to 2.13:
|
||||||
|
* CVE-2015-1197, CVE-2016-2037, CVE-2019-14866
|
||||||
|
- remove patches (upstream):
|
||||||
|
cpio-2.12-out_of_bounds_write.patch, cpio-2.12-CVE-2019-14866.patch,
|
||||||
|
cpio-2.12-util.c_no_return_in_nonvoid_fnc.patch,
|
||||||
|
cpio-check_for_symlinks.patch
|
||||||
|
* Sun Mar 29 2020 kstreitova@suse.com
|
||||||
|
- starting with GCC 10, the default of '-fcommon' option will
|
||||||
|
change to '-fno-common'. Because cpio build fails with
|
||||||
|
'fno-common', add '-fcommon' option to optflags as a temporary
|
||||||
|
workaround for this problem till it's properly fixed [bsc#1160870]
|
||||||
|
* Mon Nov 4 2019 kstreitova@suse.com
|
||||||
|
- add cpio-2.12-CVE-2019-14866.patch to fix a security issue where
|
||||||
|
cpio does not properly validate the values written in the header
|
||||||
|
of a TAR file through the to_oct() function [bsc#1155199]
|
||||||
|
[CVE-2019-14866]
|
||||||
|
* Thu Sep 19 2019 lnussel@suse.de
|
||||||
|
- Do not recommend lang package. The lang package already has a
|
||||||
|
supplements.
|
||||||
|
* Wed Sep 26 2018 bwiedemann@suse.com
|
||||||
|
- Use gettextize --no-changelog to drop build date
|
||||||
|
to make package build reproducible (boo#1047218)
|
||||||
|
* Fri Sep 14 2018 mpluskal@suse.com
|
||||||
|
- Use URL to fetch keyring
|
||||||
|
- Do not force building with PIE, it is default now anyways
|
||||||
|
- Use https for URLs
|
||||||
|
- Install license
|
||||||
|
* Tue Apr 11 2017 kstreitova@suse.com
|
||||||
|
- modify cpio-2.12-out_of_bounds_write.patch to fix a regression
|
||||||
|
causing cpio to crash for tar and ustar archive types
|
||||||
|
[bsc#1028410]
|
||||||
|
* Mon Mar 27 2017 mpluskal@suse.com
|
||||||
|
- Use macro for configure and make install
|
||||||
|
- Use update-alternatives according to current documentation
|
||||||
|
- Enable testsuite
|
||||||
|
* Fri Mar 24 2017 svalx@svalx.net
|
||||||
|
- Enable mt building
|
||||||
|
- Separated cpio-mt subpackge
|
||||||
|
- Change recommend to own mt subpackge
|
||||||
|
- Remove cpio-mt.patch - those features available in original mt-st package
|
||||||
|
- Switch to use alternatives system for mt
|
||||||
|
- Disable rmt building: this binary fully identical to rmt from tar
|
||||||
|
- Change default rmt dir to /usr/bin
|
||||||
|
* Thu Mar 23 2017 kstreitova@suse.com
|
||||||
|
- cleanup with spec-cleaner
|
||||||
|
* Sat Mar 5 2016 mpluskal@suse.com
|
||||||
|
- Recommend mt_st as it is not hard dependency
|
||||||
|
* Thu Mar 3 2016 kstreitova@suse.com
|
||||||
|
- fix typos in the description
|
||||||
|
- add 'Require: mt_st' in order not to surprise users by the missing
|
||||||
|
'mt' binary
|
||||||
|
* Thu Mar 3 2016 svalx@svalx.net
|
||||||
|
- Disable mt building: this binary from mt_st package offers
|
||||||
|
advanced capabilities with the same functionality.
|
||||||
|
- Enable rmt building: 'dump' package no longer include it, besides
|
||||||
|
cpio code base for rmt is more fresh.
|
||||||
|
- Reflect those changes in the package description.
|
||||||
|
* Fri Feb 19 2016 kstreitova@suse.com
|
||||||
|
- add cpio-2.12-out_of_bounds_write.patch to fix an out of bounds
|
||||||
|
write in a way cpio parses certain cpio files [bsc#963448],
|
||||||
|
[CVE-2016-2037]
|
||||||
|
* Thu Oct 8 2015 kstreitova@suse.com
|
||||||
|
- update to 2.12
|
||||||
|
* Improved documentation
|
||||||
|
* Manpages are installed by make install
|
||||||
|
* New options for copy-out mode: --ignore-devno,
|
||||||
|
- -renumber-inodes, --device-independent, --reproducible
|
||||||
|
* update
|
||||||
|
* cpio-use_new_ascii_format.patch
|
||||||
|
* cpio-mt.patch
|
||||||
|
* cpio-eof_tape_handling.patch
|
||||||
|
* cpio-pattern-file-sigsegv.patch
|
||||||
|
* cpio-check_for_symlinks.patch
|
||||||
|
* remove (no longer needed)
|
||||||
|
* cpio-stdio.in.patch
|
||||||
|
* 0001-Fix-memory-overrun-on-reading-improperly-created-lin.patch
|
||||||
|
* add
|
||||||
|
* cpio-2.12-util.c_no_return_in_nonvoid_fnc.patch to add missing
|
||||||
|
return to the nonvoid get_inode_and_dev() function
|
||||||
|
- use spec-cleaner
|
||||||
|
* Mon Mar 16 2015 mpluskal@suse.com
|
||||||
|
- Add gpg signature
|
||||||
|
- Correct info scriplet dependencies
|
||||||
|
- Cleanup spec file with spec-cleaner
|
||||||
|
* Thu Jan 1 2015 meissner@suse.com
|
||||||
|
- build with PIE
|
||||||
|
* Mon Dec 1 2014 vcizek@suse.com
|
||||||
|
- fix an OOB write with cpio -i (bnc#907456) (CVE-2014-9112)
|
||||||
|
* added 0001-Fix-memory-overrun-on-reading-improperly-created-lin.patch
|
||||||
|
* Fri Aug 29 2014 jengelh@inai.de
|
||||||
|
- Improve on RPM group classification (cpio does not compress
|
||||||
|
on its own per se)
|
||||||
|
- Remove redundant %%clean section
|
||||||
|
* Thu Aug 21 2014 vcizek@suse.com
|
||||||
|
- drop cpio-dir_perm.patch
|
||||||
|
* no longer needed since 2.11
|
||||||
|
* it was dropped from Fedora too and only caused problems (bnc#889138)
|
||||||
|
* Tue Jul 29 2014 vcizek@suse.com
|
||||||
|
- fix a truncation check in mt
|
||||||
|
* added cpio-fix_truncation_check.patch
|
||||||
|
* Thu Jul 17 2014 vcizek@suse.com
|
||||||
|
- prevent cpio from extracting over a symlink (bnc#658010)
|
||||||
|
* added cpio-check_for_symlinks.patch
|
||||||
|
* Tue Jul 23 2013 vcizek@suse.com
|
||||||
|
- add a missing fix from SLE for bnc#830779 (original bug bnc#658031)
|
||||||
|
added paxutils-rtapelib_mtget.patch
|
||||||
|
* Thu Mar 21 2013 mmeister@suse.com
|
||||||
|
- Added url as source.
|
||||||
|
Please see http://en.opensuse.org/SourceUrls
|
||||||
|
* Wed Jul 18 2012 aj@suse.de
|
||||||
|
- Fix build with missing gets declaration (glibc 2.16)
|
||||||
|
* Thu Feb 2 2012 rschweikert@suse.com
|
||||||
|
- leave binary in /usr (UsrMerge project), link to binary from /bin
|
||||||
|
* Mon Jan 2 2012 vcizek@suse.cz
|
||||||
|
- added autoconf to BuildRequires
|
||||||
|
* Thu Dec 1 2011 coolo@suse.com
|
||||||
|
- add automake as buildrequire to avoid implicit dependency
|
||||||
|
* Sun Sep 18 2011 andrea.turrini@gmail.com
|
||||||
|
- fix typos in spec file
|
||||||
|
* Tue Nov 9 2010 puzel@novell.com
|
||||||
|
- disable-silent-rules
|
||||||
|
* Tue Aug 31 2010 aj@suse.de
|
||||||
|
- Recommend instead of require lang package since it's not mandatory.
|
||||||
|
* Tue Aug 10 2010 puzel@novell.com
|
||||||
|
- add cpio-pattern-file-sigsegv.patch (bnc#629860)
|
||||||
|
* Mon Jun 28 2010 jengelh@medozas.de
|
||||||
|
- use %%_smp_mflags
|
||||||
|
* Fri Mar 12 2010 mseben@novell.com
|
||||||
|
- updated to 2.11
|
||||||
|
* Fix mt build.
|
||||||
|
* In copy-in mode, if directory attributes do not permit writing to it,
|
||||||
|
setting them is delayed until the end of run. This allows to
|
||||||
|
correctly extract files in such directories.
|
||||||
|
* In copy-in mode, permissions of a directory are restored if it
|
||||||
|
appears in the file list after files in it (e.g. in listings
|
||||||
|
produced by find . -depth). This fixes debian bug #458079.
|
||||||
|
* Fix possible memory overflow in the rmt client code (CVE-2010-0624).
|
||||||
|
- deprecated heap_overflow_in_rtapelib.patch,chmodRaceC.patch and
|
||||||
|
include_fatal_c.patch
|
||||||
|
* Wed Mar 3 2010 mseben@novell.com
|
||||||
|
- added heap_overflow_in_rtapelib.patch fix possible heap overflow in
|
||||||
|
rtapelib.c (bnc#579475)
|
||||||
|
* Sat Dec 26 2009 jengelh@medozas.de
|
||||||
|
- enable parallel build
|
||||||
|
* Tue Nov 3 2009 coolo@novell.com
|
||||||
|
- updated patches to apply with fuzz=0
|
||||||
|
* Fri Oct 16 2009 rschweikert@novell.com
|
||||||
|
- close files after copy (bnc#543132)
|
||||||
|
(cpio-2.10-close_files_after_copy.patch)
|
||||||
|
* Mon Aug 10 2009 mseben@novell.com
|
||||||
|
- merged DAT160.patch with mt.patch
|
||||||
|
- added other tape density definitions from mt_st package (bnc#523357)
|
||||||
|
* Fri Jul 17 2009 rguenther@suse.de
|
||||||
|
- Drop rmt BuildRequires again
|
||||||
|
* Fri Jul 17 2009 mseben@suse.cz
|
||||||
|
- fix identification of the density code for DAT160 bnc#415166
|
||||||
|
* Mon Jun 22 2009 mseben@suse.cz
|
||||||
|
- updated to version 2.10
|
||||||
|
* Ensure record headers are properly packed (fix builds on ARM).
|
||||||
|
* Fix exit codes to reliably indicate success or failure of the operation.
|
||||||
|
* Fix large file support.
|
||||||
|
* Support MinGW builds.
|
||||||
|
* Minor bugfixes.
|
||||||
|
- deprecated : lfs_correction.patch,paxlib-owl-alloca.patch,
|
||||||
|
gcc4_3.patch,segfault_in_copyin.patch,doc_typo.patch,
|
||||||
|
m4_macro.patch,gnulib.patch, no_rmt.patch
|
||||||
|
- added include_fatal_c.patch : fix undefined ref in mt build
|
||||||
|
- configure stage : removed useless DEFAULT_RMT_DIR=/sbin, added
|
||||||
|
- -with-rmt="%%{_sysconfdir}/rmt" and --enable-mt
|
||||||
|
* Mon Aug 4 2008 lmichnovic@suse.cz
|
||||||
|
- changed default tape device for 'mt' command to /dev/nst0
|
||||||
|
/dev/tape is not symlink any more but directory handled by udev
|
||||||
|
(*default_tape_dev.patch) [bnc#355241]
|
||||||
|
* Fri Aug 1 2008 cthiel@suse.de
|
||||||
|
- specfile cleanup
|
||||||
|
* Fri Jul 18 2008 lmichnovic@suse.cz
|
||||||
|
- make possible device nodes with major number > 127 [rhb#450109]
|
||||||
|
(*dev_number.patch)
|
||||||
|
* Fri Jun 27 2008 schwab@suse.de
|
||||||
|
- Fix gnulib macro.
|
||||||
|
* Fri Apr 11 2008 lmichnovic@suse.cz
|
||||||
|
- adjusted eof-handling.patch to check for 'end-of-file' and
|
||||||
|
'end-of-data' marker when detecting reel change. [bnc#371077]
|
||||||
|
* Fri Apr 4 2008 lmichnovic@suse.cz
|
||||||
|
- adjusted cpio-2.9-dir_perm.patch acording Red Hat patch to fix
|
||||||
|
correct dir permissions after extraction in pass-through mode.
|
||||||
|
- fix for two tapes handling (eof_tape_handling.patch) [bnc#371077]
|
||||||
|
* Thu Mar 13 2008 lmichnovic@suse.cz
|
||||||
|
- lang subpackage split off
|
||||||
|
* Thu Mar 13 2008 lmichnovic@suse.cz
|
||||||
|
- applying upstream patch cpio-2.9-dir_perm.patch which fixes
|
||||||
|
incorrect directory permissions after archive extraction
|
||||||
|
* Thu Nov 29 2007 lmichnovic@suse.cz
|
||||||
|
- removed unused m4 macro gl_LONG_LONG (*m4_macro.patch)
|
||||||
|
* Wed Nov 7 2007 lmichnovic@suse.cz
|
||||||
|
- upstream fix of typo in documantation (*doc_typo.patch)
|
||||||
|
* Tue Oct 23 2007 lmichnovic@suse.cz
|
||||||
|
- rewrote code which uses overflow to copy string in structure and
|
||||||
|
gcc was complaining about it (*avoid_overflow_warning.patch)
|
||||||
|
* Mon Oct 1 2007 lmichnovic@suse.cz
|
||||||
|
- Fixed typo in copin.c causing segfault [#329744]
|
||||||
|
(*segfault_in_copyin.patch)
|
||||||
|
* Tue Sep 25 2007 lmichnovic@suse.cz
|
||||||
|
- fix for compiling with new gcc 4.3 (*gcc4_3.patch)
|
||||||
|
* Mon Aug 20 2007 lmichnovic@suse.cz
|
||||||
|
- fixed typo in paxlib-owl-alloca.patch [#301416]
|
||||||
|
* Fri Aug 17 2007 lmichnovic@suse.cz
|
||||||
|
- upstream fix: use of alloca can cause stack overflow
|
||||||
|
(paxlib-owl-alloca.patch)
|
||||||
|
* Tue Aug 14 2007 lmichnovic@suse.cz
|
||||||
|
- CAN-2005-1111 is not fixed completely in 2.9 (chmodRaceC.patch)
|
||||||
|
based on fedora patch
|
||||||
|
* Wed Jul 25 2007 lmichnovic@suse.cz
|
||||||
|
- fixed types of variables for LFS support (*lfs_correction.patch)
|
||||||
|
* Tue Jul 24 2007 lmichnovic@suse.cz
|
||||||
|
- adjusted *mt.patch to fix compression handling [#223494]
|
||||||
|
* Fri Jul 20 2007 lmichnovic@suse.cz
|
||||||
|
- update to version 2.9
|
||||||
|
- obsoletes *lstat.patch
|
||||||
|
* Licensed under the GPLv3.
|
||||||
|
* Bugfixes: Honor umask when creating intermediate directories,
|
||||||
|
not specified in the archive (debian bug #430053). (This bug
|
||||||
|
is only in version 2.8)
|
||||||
|
* 2.8:
|
||||||
|
* Option --owner can be used in copy-out mode, allowing
|
||||||
|
to uniformly override the ownership of the files being added
|
||||||
|
to the archive.
|
||||||
|
* Bugfixes:
|
||||||
|
- Symlinks were handled incorrectly in copy-out mode. (This
|
||||||
|
bug was only in version 2.7)
|
||||||
|
- Fix handling of large files. {obsoletes lfs.patch}
|
||||||
|
o Fix setting the file permissions in copy-out mode.
|
||||||
|
o Fix CAN-2005-1111 {obsoletes chmodRaceC.patch}
|
||||||
|
* 2.7:
|
||||||
|
* Improved error checking and diagnostics
|
||||||
|
* Fixed CAN-1999-1572 {obsoletes writeOutHeaderBufferOverflow.patch}
|
||||||
|
* Allow to use --sparse in both copy-in and copy-pass.
|
||||||
|
* Fix bug that eventually caused copying out the same
|
||||||
|
hard-linked file several times to archive.
|
||||||
|
* Fix several LFS-related issues. {obsoletes lfs.patch}
|
||||||
|
* Fix Debian bug #335580.
|
||||||
|
- obsoletes *dirTraversal.patch implemented with option
|
||||||
|
- -no-absolute-pathnames; option --absolute-pathnames is still possible
|
||||||
|
- obsoletes *checksum.patch, fix_umask.patch, sparse.patch
|
||||||
|
- using lang macro
|
||||||
|
* Thu Sep 21 2006 lmichnovic@suse.cz
|
||||||
|
- fixed typo in cpio-2.6.dif; renamed to *-mt.patch
|
||||||
|
- united suffix of patches
|
||||||
|
* Tue Sep 19 2006 schwab@suse.de
|
||||||
|
- Fix missing newline after mt status.
|
||||||
|
* Mon Jul 24 2006 rguenther@suse.de
|
||||||
|
- remove useless build-dependency on rsh.
|
||||||
|
* Wed Jan 25 2006 mls@suse.de
|
||||||
|
- converted neededforbuild to BuildRequires
|
||||||
|
* Tue Dec 6 2005 fehr@suse.de
|
||||||
|
- add cpio-2.6-chmodRaceC.patch and cpio-2.6-dirTraversal.patch to
|
||||||
|
fix bug #80226
|
||||||
|
- add cpio-2.6-writeOutHeaderBufferOverflow.patch to fix #133454
|
||||||
|
- add cpio-2.6-checksum.patch fix wrong checksum on 64bit archs
|
||||||
|
- add cpio-2.6-lfs.patch to support large files on 32bit archs
|
||||||
|
* Wed Aug 10 2005 fehr@suse.de
|
||||||
|
- fix call to setlocale to make multibyte characters work (#98902)
|
||||||
|
* Thu Jun 30 2005 fehr@suse.de
|
||||||
|
- open with O_NONBLOCK option (#94449)
|
||||||
|
* Wed May 4 2005 ro@suse.de
|
||||||
|
- properly detect lstat in configure
|
||||||
|
* Wed Apr 27 2005 snwint@suse.de
|
||||||
|
- fix '--sparse' option check
|
||||||
|
* Mon Apr 25 2005 fehr@suse.de
|
||||||
|
- update to cpio 2.6
|
||||||
|
* Mon Jan 24 2005 fehr@suse.de
|
||||||
|
- fix problem with cpio not respecting umask (#50054)
|
||||||
|
* Mon Jan 19 2004 ro@suse.de
|
||||||
|
- fix build as user
|
||||||
|
* Sun Jan 11 2004 adrian@suse.de
|
||||||
|
- add %%defattr
|
||||||
|
* Thu Apr 24 2003 ro@suse.de
|
||||||
|
- fix install_info --delete call and move from preun to postun
|
||||||
|
* Tue Apr 15 2003 coolo@suse.de
|
||||||
|
- use BuildRoot
|
||||||
|
* Fri Feb 7 2003 fehr@suse.de
|
||||||
|
- Use %%install_info macro
|
||||||
|
* Tue Sep 17 2002 ro@suse.de
|
||||||
|
- removed bogus self-provides
|
||||||
|
* Tue Aug 13 2002 mfabian@suse.de
|
||||||
|
- add cpio-2.5-i18n-0.1.patch received from
|
||||||
|
"Mitsuru Chinen" <CHINEN@jp.ibm.com>
|
||||||
|
The patch just adds a setlocale (LC_ALL, "").
|
||||||
|
* Sun Jul 28 2002 kukuk@suse.de
|
||||||
|
- remove unused tetex from neededforbuild
|
||||||
|
* Fri Jul 5 2002 fehr@suse.de
|
||||||
|
- update to new version 2.5
|
||||||
|
* Mon Dec 3 2001 fehr@suse.de
|
||||||
|
- make the -c switch comatible to SVR4 (and compatible to RedHat)
|
||||||
|
- fix the man page accordingly
|
||||||
|
- add rsh to #needfobuild to allow remote file access again (#12543)
|
||||||
|
* Sun Dec 3 2000 schwab@suse.de
|
||||||
|
- Fix a few bugs and typos.
|
||||||
|
* Tue Nov 28 2000 fehr@suse.de
|
||||||
|
- add compile options for LFS
|
||||||
|
* Mon Apr 17 2000 fehr@suse.de
|
||||||
|
- move cpio binary to /bin for compatibility with RedHat
|
||||||
|
* Fri Feb 25 2000 kukuk@suse.de
|
||||||
|
- remove Makefile.Linux
|
||||||
|
- use _infodir/_mandir
|
||||||
|
* Mon Sep 13 1999 bs@suse.de
|
||||||
|
- ran old prepare_spec on spec file to switch to new prepare_spec.
|
||||||
|
* Thu Sep 2 1999 fehr@suse.de
|
||||||
|
- Fix patch for broken header (cast to short instead of int)
|
||||||
|
* Wed Aug 4 1999 kukuk@suse.de
|
||||||
|
- Add patch for broken header in oldascii format
|
||||||
|
* Tue Sep 22 1998 ro@suse.de
|
||||||
|
- define _GNU_SOURCE for glibc where including getopt
|
||||||
|
* Tue Sep 1 1998 ro@suse.de
|
||||||
|
- fixed strdup-macro problem
|
||||||
|
* Thu Jun 5 1997 florian@suse.de
|
||||||
|
- go through the list of regex in a more suitable way (from ma@suse.de)
|
||||||
|
* Sun Apr 13 1997 florian@suse.de
|
||||||
|
- update to new version 2.4.2
|
||||||
|
- add Linux patches from RedHat
|
||||||
|
- add patches from gnu.utils.bugs
|
37
cpio.keyring
Normal file
37
cpio.keyring
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
Member GPG keyring of cpio group.
|
||||||
|
|
||||||
|
Note that this keyring is not intended for checking releases of that group.
|
||||||
|
Use Group Release Keyring instead.
|
||||||
|
|
||||||
|
GPG keys of Sergey Poznyakoff <gray>
|
||||||
|
-----BEGIN PGP PUBLIC KEY BLOCK-----
|
||||||
|
Version: GnuPG v1.4.7 (GNU/Linux)
|
||||||
|
|
||||||
|
mQGiBDxhQHkRBACyhJxCLQvLs70IUZSlYVKAm+u1Oa4RyUo5/ctCcMm2KOcjui3z
|
||||||
|
xs+yUwlglo1n/de9NNJY98PJNLHniMVi5sPba8OKwYx9bilwuAWLgTsgfpX8UuuY
|
||||||
|
TANQmTybmrxjzxrGqN7eyjBT3utgbK3ACKDo/JUCgZMkdFu2c2i7186sDwCgo9pQ
|
||||||
|
ygxOOWEWBm70Rymdfvkon6EEAKY5h9nL1qYw46vM1+QY+vhyX2lHTD/E9QyFQv4L
|
||||||
|
driY3CerLAZ07yk5p8I6T31d7HEUt9DZcl0ZD99Y9IH84wWvms1xtnCuoLlP4ntw
|
||||||
|
FQ5ZUZtMY0AIVRtFbgkTDDLZsdanscqMu/LqnO2/QWjCQhaO/tcaIdPVgBIbCr28
|
||||||
|
fuBJA/9KA5vbQBd4WnNFLVJsr47irnJBYdR+OqPQAUFUcQPO1metR76UZ7+7LwtO
|
||||||
|
ldAjPN3RDJtRB8/JooHDNq+VCEzjs02JaBpQ+BCOzzqELnkoBPl26yHR56r4WbC5
|
||||||
|
+FH/QxEaicjVGxIF/Z9crzG/XUMXwieTNcM6HoGCnMboGqCM4bQjU2VyZ2V5IFBv
|
||||||
|
em55YWtvZmYgPGdyYXlAZ251Lm9yZy51YT6IXgQTEQIAHgUCQ/CVdwIbAwYLCQgH
|
||||||
|
AwIDFQIDAxYCAQIeAQIXgAAKCRA2ArB/VdDHMubqAJ9tq+C7VtEMexpRAq9jzcKo
|
||||||
|
5fZFywCeKtqljjB7nsCIKvZNOV1D4fn7HDm0MlNlcmdleSBQb3pueWFrb2ZmIChH
|
||||||
|
cmF5KSA8Z3JheUBtaXJkZGluLmZhcmxlcC5uZXQ+iFcEExECABcFAjxhQHkFCwcK
|
||||||
|
AwQDFQMCAxYCAQIXgAAKCRA2ArB/VdDHMg3iAKCVtLVewNzCDfjui1wTWmz73IcU
|
||||||
|
aQCcDjK4771A6G/z6qX5bDuK1yL/YeSIRgQSEQIABgUCP1tgaAAKCRCjCdZ5GaIl
|
||||||
|
R3GsAJ9IHf/Rl/2+eR03mdAe+AeSTaBfagCfUsLc7/wp+fb7Xo6lKQezvJzGBqu0
|
||||||
|
IFNlcmdleSBQb3pueWFrb2ZmIDxncmF5QGdudS5vcmc+iF4EExECAB4FAkPwlbUC
|
||||||
|
GwMGCwkIBwMCAxUCAwMWAgECHgECF4AACgkQNgKwf1XQxzJFSgCeNYJSs7nalOVI
|
||||||
|
MTJB3Ui6NvKL/nAAni1KxoLZr/+jG5iAnhuuL+ijq54GuQENBDxhQHwQBAD3qEph
|
||||||
|
UOWRg9C8hSJpZ9Zo8F+hXnF6mvMWuy76R+yHqg4H5CPWSH116lOKl5xpGeXdOOzM
|
||||||
|
5OxGgdEChb+jLoszM9rc3HQfcKAQmFMd03Iay4/5jMAS+vNgCfDV98nj6gU0Y3ku
|
||||||
|
UdTkyMPDObQWv1ginAnkoOVXb7nAVW/X5n8izwADBQP8CPuRROj2FC+w2tTXDgaJ
|
||||||
|
am9PEm1coHRJAoHef1nBZfOAOZLjRD10wBg2m8q2EUJ4/mr/1D0whTINThJkvmZk
|
||||||
|
RGVkuNILeC3X5dMQ1AX4fIOOnVObWVrlg5etH8ichIOYOUOqCx/cuV9F6Apg9PE6
|
||||||
|
vcFqmh4BoOlb0qOaIdzN1sWIRgQYEQIABgUCPGFAfAAKCRA2ArB/VdDHMlPgAKCM
|
||||||
|
9FxutfWWvZqNKW5up6GnB4y6WwCeN5k4mxck975PULOk8jq/ZqLGvnQ=
|
||||||
|
=5lxD
|
||||||
|
-----END PGP PUBLIC KEY BLOCK-----
|
155
cpio.spec
Normal file
155
cpio.spec
Normal file
|
@ -0,0 +1,155 @@
|
||||||
|
#
|
||||||
|
# spec file for package cpio
|
||||||
|
#
|
||||||
|
# Copyright (c) 2022-2023 ZhuningOS
|
||||||
|
#
|
||||||
|
|
||||||
|
|
||||||
|
Name: cpio
|
||||||
|
Version: 2.13
|
||||||
|
Release: 150400.3.6.1
|
||||||
|
Summary: A Backup and Archiving Utility
|
||||||
|
License: GPL-3.0-only
|
||||||
|
Group: Productivity/Archiving/Backup
|
||||||
|
URL: https://www.gnu.org/software/cpio/cpio.html
|
||||||
|
Source0: https://ftp.gnu.org/gnu/%{name}/%{name}-%{version}.tar.bz2
|
||||||
|
Source1: https://ftp.gnu.org/gnu/%{name}/%{name}-%{version}.tar.bz2.sig
|
||||||
|
Source2: https://savannah.gnu.org/project/memberlist-gpgkeys.php?group=%{name}&download=1#/%{name}.keyring
|
||||||
|
Patch2: cpio-use_new_ascii_format.patch
|
||||||
|
Patch4: cpio-use_sbin_rmt.patch
|
||||||
|
#PATCH-FIX-UPSTREAM cpio-2.12 cpio-open_nonblock.patch bnc#94449,
|
||||||
|
#https://savannah.gnu.org/patch/?9263 -- open device with O_NONBLOCK option
|
||||||
|
Patch5: cpio-open_nonblock.patch
|
||||||
|
Patch15: cpio-eof_tape_handling.patch
|
||||||
|
# make posibble to have device nodes with major number > 127
|
||||||
|
# Red Hat Bugzilla #450109
|
||||||
|
Patch17: cpio-dev_number.patch
|
||||||
|
Patch18: cpio-default_tape_dev.patch
|
||||||
|
#PATCH-FIX-UPSTREAM cpio-2.10-close_files_after_copy.patch
|
||||||
|
Patch20: cpio-close_files_after_copy.patch
|
||||||
|
Patch21: cpio-pattern-file-sigsegv.patch
|
||||||
|
Patch23: paxutils-rtapelib_mtget.patch
|
||||||
|
# see https://lists.gnu.org/archive/html/bug-cpio/2019-11/msg00016.html
|
||||||
|
Patch24: cpio-revert-CVE-2015-1197-fix.patch
|
||||||
|
Patch25: cpio-fix_truncation_check.patch
|
||||||
|
# PATCH-FIX-UPSTREAM danilo.spinella@suse.com bsc#1189206
|
||||||
|
# Remote code execution caused by an integer overflow in ds_fgetstr
|
||||||
|
Patch26: fix-CVE-2021-38185.patch
|
||||||
|
Patch27: fix-CVE-2021-38185_2.patch
|
||||||
|
Patch28: fix-CVE-2021-38185_3.patch
|
||||||
|
# PATCH-FIX-UPSTREAM danilo.spinella@suse.com bsc#1218571
|
||||||
|
# Path traversal vulnerability
|
||||||
|
Patch29: fix-CVE-2023-7207.patch
|
||||||
|
# PATCH-FIX-UPSTREAM danilo.spinella@suse.com bsc#1219238
|
||||||
|
# Fix cpio not working anymore
|
||||||
|
Patch30: fix-bsc1219238.patch
|
||||||
|
BuildRequires: autoconf
|
||||||
|
BuildRequires: automake
|
||||||
|
#Requires(post): %{xinstall_info_prereq}
|
||||||
|
#Requires(preun): %{xinstall_info_prereq}
|
||||||
|
Recommends: %{name}-mt = %{version}
|
||||||
|
Recommends: rmt
|
||||||
|
|
||||||
|
%description
|
||||||
|
GNU cpio is a program to manage archives of files. Cpio copies files
|
||||||
|
into or out of a cpio or tar archive. An archive is a file that contains
|
||||||
|
other files plus information about them, such as their pathname, owner,
|
||||||
|
time stamps, and access permissions. The archive can be another file on
|
||||||
|
the disk, a magnetic tape, or a pipe.
|
||||||
|
|
||||||
|
%package mt
|
||||||
|
Summary: Tape drive control utility
|
||||||
|
Group: Productivity/Archiving/Backup
|
||||||
|
Requires: %{name} = %{version}
|
||||||
|
Requires(post): update-alternatives
|
||||||
|
Requires(postun):update-alternatives
|
||||||
|
Provides: mt
|
||||||
|
|
||||||
|
%description mt
|
||||||
|
This package includes the 'mt', a local tape drive control program.
|
||||||
|
|
||||||
|
%lang_package
|
||||||
|
|
||||||
|
%prep
|
||||||
|
%setup -q
|
||||||
|
%patch2
|
||||||
|
%patch4
|
||||||
|
%patch5
|
||||||
|
%patch15
|
||||||
|
%patch17
|
||||||
|
%patch18
|
||||||
|
%patch20
|
||||||
|
###
|
||||||
|
%patch21 -p1
|
||||||
|
%patch23 -p1
|
||||||
|
%patch24 -p1
|
||||||
|
%patch25 -p1
|
||||||
|
%patch26 -p1
|
||||||
|
%patch27 -p1
|
||||||
|
%patch28 -p1
|
||||||
|
%patch29 -p1
|
||||||
|
%patch30 -p1
|
||||||
|
|
||||||
|
%build
|
||||||
|
gettextize -f --no-changelog
|
||||||
|
autoreconf -fiv
|
||||||
|
export CFLAGS="%{optflags} -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -fcommon"
|
||||||
|
%configure \
|
||||||
|
--with-rmt="%{_bindir}/rmt" \
|
||||||
|
--enable-mt \
|
||||||
|
--disable-silent-rules \
|
||||||
|
--program-transform-name='s/^mt$/gnumt/'
|
||||||
|
make %{?_smp_mflags}
|
||||||
|
|
||||||
|
%install
|
||||||
|
mkdir -p %{buildroot}/{usr/bin,bin}
|
||||||
|
%make_install
|
||||||
|
mkdir -p %{buildroot}%{_sysconfdir}/alternatives
|
||||||
|
ln -sf %{_sysconfdir}/alternatives/mt %{buildroot}%{_bindir}/mt
|
||||||
|
ln -sf %{_sysconfdir}/alternatives/mt.1%{ext_man} %{buildroot}%{_mandir}/man1/mt.1%{ext_man}
|
||||||
|
%if !0%{?usrmerged}
|
||||||
|
ln -sf %{_bindir}/cpio %{buildroot}/bin
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%find_lang %{name}
|
||||||
|
|
||||||
|
%check
|
||||||
|
make %{?_smp_mflags} check
|
||||||
|
|
||||||
|
%post mt
|
||||||
|
%{_sbindir}/update-alternatives --force \
|
||||||
|
--install %{_bindir}/mt mt %{_bindir}/gnumt 10 \
|
||||||
|
--slave %{_mandir}/man1/mt.1%{ext_man} mt.1%{ext_man} %{_mandir}/man1/gnumt.1%{ext_man}
|
||||||
|
|
||||||
|
%post
|
||||||
|
%install_info --info-dir=%{_infodir} %{_infodir}/%{name}.info%{ext_info}
|
||||||
|
|
||||||
|
%preun
|
||||||
|
%install_info_delete --info-dir=%{_infodir} %{_infodir}/%{name}.info%{ext_info}
|
||||||
|
|
||||||
|
%postun mt
|
||||||
|
if [ ! -f %{_bindir}/gnumt ] ; then
|
||||||
|
"%{_sbindir}/update-alternatives" --remove mt %{_bindir}/gnumt
|
||||||
|
fi
|
||||||
|
|
||||||
|
%files
|
||||||
|
%license COPYING
|
||||||
|
%doc NEWS ChangeLog
|
||||||
|
%if !0%{?usrmerged}
|
||||||
|
/bin/cpio
|
||||||
|
%endif
|
||||||
|
%{_bindir}/cpio
|
||||||
|
%{_infodir}/cpio.info%{?ext_info}
|
||||||
|
%{_mandir}/man1/cpio.1%{?ext_man}
|
||||||
|
|
||||||
|
%files mt
|
||||||
|
%ghost %{_bindir}/mt
|
||||||
|
%{_bindir}/gnumt
|
||||||
|
%ghost %{_mandir}/man1/mt.1%{ext_man}
|
||||||
|
%{_mandir}/man1/gnumt.1%{?ext_man}
|
||||||
|
%ghost %{_sysconfdir}/alternatives/mt
|
||||||
|
%ghost %{_sysconfdir}/alternatives/mt.1%{ext_man}
|
||||||
|
|
||||||
|
%files lang -f %{name}.lang
|
||||||
|
|
||||||
|
%changelog
|
446
fix-CVE-2021-38185.patch
Normal file
446
fix-CVE-2021-38185.patch
Normal file
|
@ -0,0 +1,446 @@
|
||||||
|
From dd96882877721703e19272fe25034560b794061b Mon Sep 17 00:00:00 2001
|
||||||
|
From: Sergey Poznyakoff <gray@gnu.org>
|
||||||
|
Date: Sat, 7 Aug 2021 12:52:21 +0300
|
||||||
|
Subject: Rewrite dynamic string support.
|
||||||
|
|
||||||
|
* src/dstring.c (ds_init): Take a single argument.
|
||||||
|
(ds_free): New function.
|
||||||
|
(ds_resize): Take a single argument. Use x2nrealloc to expand
|
||||||
|
the storage.
|
||||||
|
(ds_reset,ds_append,ds_concat,ds_endswith): New function.
|
||||||
|
(ds_fgetstr): Rewrite. In particular, this fixes integer overflow.
|
||||||
|
* src/dstring.h (dynamic_string): Keep both the allocated length
|
||||||
|
(ds_size) and index of the next free byte in the string (ds_idx).
|
||||||
|
(ds_init,ds_resize): Change signature.
|
||||||
|
(ds_len): New macro.
|
||||||
|
(ds_free,ds_reset,ds_append,ds_concat,ds_endswith): New protos.
|
||||||
|
* src/copyin.c: Use new ds_ functions.
|
||||||
|
* src/copyout.c: Likewise.
|
||||||
|
* src/copypass.c: Likewise.
|
||||||
|
* src/util.c: Likewise.
|
||||||
|
---
|
||||||
|
src/copyin.c | 40 +++++++++++++-------------
|
||||||
|
src/copyout.c | 16 ++++-------
|
||||||
|
src/copypass.c | 34 +++++++++++------------
|
||||||
|
src/dstring.c | 88 ++++++++++++++++++++++++++++++++++++++++++----------------
|
||||||
|
src/dstring.h | 31 ++++++++++-----------
|
||||||
|
src/util.c | 6 ++--
|
||||||
|
6 files changed, 123 insertions(+), 92 deletions(-)
|
||||||
|
|
||||||
|
Index: cpio-2.13/src/copyin.c
|
||||||
|
===================================================================
|
||||||
|
--- cpio-2.13.orig/src/copyin.c
|
||||||
|
+++ cpio-2.13/src/copyin.c
|
||||||
|
@@ -55,11 +55,12 @@ query_rename(struct cpio_file_stat* file
|
||||||
|
char *str_res; /* Result for string function. */
|
||||||
|
static dynamic_string new_name; /* New file name for rename option. */
|
||||||
|
static int initialized_new_name = false;
|
||||||
|
+
|
||||||
|
if (!initialized_new_name)
|
||||||
|
- {
|
||||||
|
- ds_init (&new_name, 128);
|
||||||
|
- initialized_new_name = true;
|
||||||
|
- }
|
||||||
|
+ {
|
||||||
|
+ ds_init (&new_name);
|
||||||
|
+ initialized_new_name = true;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
if (rename_flag)
|
||||||
|
{
|
||||||
|
@@ -778,21 +779,20 @@ long_format (struct cpio_file_stat *file
|
||||||
|
already in `save_patterns' (from the command line) are preserved. */
|
||||||
|
|
||||||
|
static void
|
||||||
|
-read_pattern_file ()
|
||||||
|
+read_pattern_file (void)
|
||||||
|
{
|
||||||
|
- int max_new_patterns;
|
||||||
|
- char **new_save_patterns;
|
||||||
|
- int new_num_patterns;
|
||||||
|
+ char **new_save_patterns = NULL;
|
||||||
|
+ size_t max_new_patterns;
|
||||||
|
+ size_t new_num_patterns;
|
||||||
|
int i;
|
||||||
|
- dynamic_string pattern_name;
|
||||||
|
+ dynamic_string pattern_name = DYNAMIC_STRING_INITIALIZER;
|
||||||
|
FILE *pattern_fp;
|
||||||
|
|
||||||
|
if (num_patterns < 0)
|
||||||
|
num_patterns = 0;
|
||||||
|
- max_new_patterns = 1 + num_patterns;
|
||||||
|
- new_save_patterns = (char **) xmalloc (max_new_patterns * sizeof (char *));
|
||||||
|
new_num_patterns = num_patterns;
|
||||||
|
- ds_init (&pattern_name, 128);
|
||||||
|
+ max_new_patterns = num_patterns;
|
||||||
|
+ new_save_patterns = xcalloc (max_new_patterns, sizeof (new_save_patterns[0]));
|
||||||
|
|
||||||
|
pattern_fp = fopen (pattern_file_name, "r");
|
||||||
|
if (pattern_fp == NULL)
|
||||||
|
@@ -801,16 +801,16 @@ read_pattern_file ()
|
||||||
|
{
|
||||||
|
while (ds_fgetstr (pattern_fp, &pattern_name, '\n') != NULL)
|
||||||
|
{
|
||||||
|
- if (new_num_patterns >= max_new_patterns)
|
||||||
|
- {
|
||||||
|
- max_new_patterns += 1;
|
||||||
|
- new_save_patterns = (char **)
|
||||||
|
- xrealloc ((char *) new_save_patterns,
|
||||||
|
- max_new_patterns * sizeof (char *));
|
||||||
|
- }
|
||||||
|
+ if (new_num_patterns == max_new_patterns)
|
||||||
|
+ new_save_patterns = x2nrealloc (new_save_patterns,
|
||||||
|
+ &max_new_patterns,
|
||||||
|
+ sizeof (new_save_patterns[0]));
|
||||||
|
new_save_patterns[new_num_patterns] = xstrdup (pattern_name.ds_string);
|
||||||
|
++new_num_patterns;
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ ds_free (&pattern_name);
|
||||||
|
+
|
||||||
|
if (ferror (pattern_fp) || fclose (pattern_fp) == EOF)
|
||||||
|
close_error (pattern_file_name);
|
||||||
|
}
|
||||||
|
Index: cpio-2.13/src/copyout.c
|
||||||
|
===================================================================
|
||||||
|
--- cpio-2.13.orig/src/copyout.c
|
||||||
|
+++ cpio-2.13/src/copyout.c
|
||||||
|
@@ -594,9 +594,10 @@ assign_string (char **pvar, char *value)
|
||||||
|
The format of the header depends on the compatibility (-c) flag. */
|
||||||
|
|
||||||
|
void
|
||||||
|
-process_copy_out ()
|
||||||
|
+process_copy_out (void)
|
||||||
|
{
|
||||||
|
- dynamic_string input_name; /* Name of file read from stdin. */
|
||||||
|
+ dynamic_string input_name = DYNAMIC_STRING_INITIALIZER;
|
||||||
|
+ /* Name of file read from stdin. */
|
||||||
|
struct stat file_stat; /* Stat record for file. */
|
||||||
|
struct cpio_file_stat file_hdr = CPIO_FILE_STAT_INITIALIZER;
|
||||||
|
/* Output header information. */
|
||||||
|
@@ -605,7 +606,6 @@ process_copy_out ()
|
||||||
|
char *orig_file_name = NULL;
|
||||||
|
|
||||||
|
/* Initialize the copy out. */
|
||||||
|
- ds_init (&input_name, 128);
|
||||||
|
file_hdr.c_magic = 070707;
|
||||||
|
|
||||||
|
/* Check whether the output file might be a tape. */
|
||||||
|
@@ -657,14 +657,9 @@ process_copy_out ()
|
||||||
|
{
|
||||||
|
if (file_hdr.c_mode & CP_IFDIR)
|
||||||
|
{
|
||||||
|
- int len = strlen (input_name.ds_string);
|
||||||
|
/* Make sure the name ends with a slash */
|
||||||
|
- if (input_name.ds_string[len-1] != '/')
|
||||||
|
- {
|
||||||
|
- ds_resize (&input_name, len + 2);
|
||||||
|
- input_name.ds_string[len] = '/';
|
||||||
|
- input_name.ds_string[len+1] = 0;
|
||||||
|
- }
|
||||||
|
+ if (!ds_endswith (&input_name, '/'))
|
||||||
|
+ ds_append (&input_name, '/');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -875,6 +870,7 @@ process_copy_out ()
|
||||||
|
(unsigned long) blocks), (unsigned long) blocks);
|
||||||
|
}
|
||||||
|
cpio_file_stat_free (&file_hdr);
|
||||||
|
+ ds_free (&input_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Index: cpio-2.13/src/copypass.c
|
||||||
|
===================================================================
|
||||||
|
--- cpio-2.13.orig/src/copypass.c
|
||||||
|
+++ cpio-2.13/src/copypass.c
|
||||||
|
@@ -48,10 +48,12 @@ set_copypass_perms (int fd, const char *
|
||||||
|
If `link_flag', link instead of copying. */
|
||||||
|
|
||||||
|
void
|
||||||
|
-process_copy_pass ()
|
||||||
|
+process_copy_pass (void)
|
||||||
|
{
|
||||||
|
- dynamic_string input_name; /* Name of file from stdin. */
|
||||||
|
- dynamic_string output_name; /* Name of new file. */
|
||||||
|
+ dynamic_string input_name = DYNAMIC_STRING_INITIALIZER;
|
||||||
|
+ /* Name of file from stdin. */
|
||||||
|
+ dynamic_string output_name = DYNAMIC_STRING_INITIALIZER;
|
||||||
|
+ /* Name of new file. */
|
||||||
|
size_t dirname_len; /* Length of `directory_name'. */
|
||||||
|
int res; /* Result of functions. */
|
||||||
|
char *slash; /* For moving past slashes in input name. */
|
||||||
|
@@ -65,25 +67,18 @@ process_copy_pass ()
|
||||||
|
created files */
|
||||||
|
|
||||||
|
/* Initialize the copy pass. */
|
||||||
|
- ds_init (&input_name, 128);
|
||||||
|
|
||||||
|
dirname_len = strlen (directory_name);
|
||||||
|
if (change_directory_option && !ISSLASH (directory_name[0]))
|
||||||
|
{
|
||||||
|
char *pwd = xgetcwd ();
|
||||||
|
-
|
||||||
|
- dirname_len += strlen (pwd) + 1;
|
||||||
|
- ds_init (&output_name, dirname_len + 2);
|
||||||
|
- strcpy (output_name.ds_string, pwd);
|
||||||
|
- strcat (output_name.ds_string, "/");
|
||||||
|
- strcat (output_name.ds_string, directory_name);
|
||||||
|
- }
|
||||||
|
- else
|
||||||
|
- {
|
||||||
|
- ds_init (&output_name, dirname_len + 2);
|
||||||
|
- strcpy (output_name.ds_string, directory_name);
|
||||||
|
+
|
||||||
|
+ ds_concat (&output_name, pwd);
|
||||||
|
+ ds_append (&output_name, '/');
|
||||||
|
}
|
||||||
|
- output_name.ds_string[dirname_len] = '/';
|
||||||
|
+ ds_concat (&output_name, directory_name);
|
||||||
|
+ ds_append (&output_name, '/');
|
||||||
|
+ dirname_len = ds_len (&output_name);
|
||||||
|
output_is_seekable = true;
|
||||||
|
|
||||||
|
change_dir ();
|
||||||
|
@@ -116,8 +111,8 @@ process_copy_pass ()
|
||||||
|
/* Make the name of the new file. */
|
||||||
|
for (slash = input_name.ds_string; *slash == '/'; ++slash)
|
||||||
|
;
|
||||||
|
- ds_resize (&output_name, dirname_len + strlen (slash) + 2);
|
||||||
|
- strcpy (output_name.ds_string + dirname_len + 1, slash);
|
||||||
|
+ ds_reset (&output_name, dirname_len);
|
||||||
|
+ ds_concat (&output_name, slash);
|
||||||
|
|
||||||
|
existing_dir = false;
|
||||||
|
if (lstat (output_name.ds_string, &out_file_stat) == 0)
|
||||||
|
@@ -333,6 +328,9 @@ process_copy_pass ()
|
||||||
|
(unsigned long) blocks),
|
||||||
|
(unsigned long) blocks);
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ ds_free (&input_name);
|
||||||
|
+ ds_free (&output_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Try and create a hard link from FILE_NAME to another file
|
||||||
|
Index: cpio-2.13/src/dstring.c
|
||||||
|
===================================================================
|
||||||
|
--- cpio-2.13.orig/src/dstring.c
|
||||||
|
+++ cpio-2.13/src/dstring.c
|
||||||
|
@@ -20,8 +20,8 @@
|
||||||
|
#if defined(HAVE_CONFIG_H)
|
||||||
|
# include <config.h>
|
||||||
|
#endif
|
||||||
|
-
|
||||||
|
#include <stdio.h>
|
||||||
|
+#include <stdlib.h>
|
||||||
|
#if defined(HAVE_STRING_H) || defined(STDC_HEADERS)
|
||||||
|
#include <string.h>
|
||||||
|
#else
|
||||||
|
@@ -33,24 +33,41 @@
|
||||||
|
/* Initialiaze dynamic string STRING with space for SIZE characters. */
|
||||||
|
|
||||||
|
void
|
||||||
|
-ds_init (dynamic_string *string, int size)
|
||||||
|
+ds_init (dynamic_string *string)
|
||||||
|
+{
|
||||||
|
+ memset (string, 0, sizeof *string);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+/* Free the dynamic string storage. */
|
||||||
|
+
|
||||||
|
+void
|
||||||
|
+ds_free (dynamic_string *string)
|
||||||
|
{
|
||||||
|
- string->ds_length = size;
|
||||||
|
- string->ds_string = (char *) xmalloc (size);
|
||||||
|
+ free (string->ds_string);
|
||||||
|
}
|
||||||
|
|
||||||
|
-/* Expand dynamic string STRING, if necessary, to hold SIZE characters. */
|
||||||
|
+/* Expand dynamic string STRING, if necessary. */
|
||||||
|
|
||||||
|
void
|
||||||
|
-ds_resize (dynamic_string *string, int size)
|
||||||
|
+ds_resize (dynamic_string *string)
|
||||||
|
{
|
||||||
|
- if (size > string->ds_length)
|
||||||
|
+ if (string->ds_idx == string->ds_size)
|
||||||
|
{
|
||||||
|
- string->ds_length = size;
|
||||||
|
- string->ds_string = (char *) xrealloc ((char *) string->ds_string, size);
|
||||||
|
+ string->ds_string = x2nrealloc (string->ds_string, &string->ds_size,
|
||||||
|
+ 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
+/* Reset the index of the dynamic string S to LEN. */
|
||||||
|
+
|
||||||
|
+void
|
||||||
|
+ds_reset (dynamic_string *s, size_t len)
|
||||||
|
+{
|
||||||
|
+ while (len > s->ds_size)
|
||||||
|
+ ds_resize (s);
|
||||||
|
+ s->ds_idx = len;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
/* Dynamic string S gets a string terminated by the EOS character
|
||||||
|
(which is removed) from file F. S will increase
|
||||||
|
in size during the function if the string from F is longer than
|
||||||
|
@@ -61,34 +78,50 @@ ds_resize (dynamic_string *string, int s
|
||||||
|
char *
|
||||||
|
ds_fgetstr (FILE *f, dynamic_string *s, char eos)
|
||||||
|
{
|
||||||
|
- int insize; /* Amount needed for line. */
|
||||||
|
- int strsize; /* Amount allocated for S. */
|
||||||
|
int next_ch;
|
||||||
|
|
||||||
|
/* Initialize. */
|
||||||
|
- insize = 0;
|
||||||
|
- strsize = s->ds_length;
|
||||||
|
+ s->ds_idx = 0;
|
||||||
|
|
||||||
|
/* Read the input string. */
|
||||||
|
- next_ch = getc (f);
|
||||||
|
- while (next_ch != eos && next_ch != EOF)
|
||||||
|
+ while ((next_ch = getc (f)) != eos && next_ch != EOF)
|
||||||
|
{
|
||||||
|
- if (insize >= strsize - 1)
|
||||||
|
- {
|
||||||
|
- ds_resize (s, strsize * 2 + 2);
|
||||||
|
- strsize = s->ds_length;
|
||||||
|
- }
|
||||||
|
- s->ds_string[insize++] = next_ch;
|
||||||
|
- next_ch = getc (f);
|
||||||
|
+ ds_resize (s);
|
||||||
|
+ s->ds_string[s->ds_idx++] = next_ch;
|
||||||
|
}
|
||||||
|
- s->ds_string[insize++] = '\0';
|
||||||
|
+ ds_resize (s);
|
||||||
|
+ s->ds_string[s->ds_idx] = '\0';
|
||||||
|
|
||||||
|
- if (insize == 1 && next_ch == EOF)
|
||||||
|
+ if (s->ds_idx == 0 && next_ch == EOF)
|
||||||
|
return NULL;
|
||||||
|
else
|
||||||
|
return s->ds_string;
|
||||||
|
}
|
||||||
|
|
||||||
|
+void
|
||||||
|
+ds_append (dynamic_string *s, int c)
|
||||||
|
+{
|
||||||
|
+ ds_resize (s);
|
||||||
|
+ s->ds_string[s->ds_idx] = c;
|
||||||
|
+ if (c)
|
||||||
|
+ {
|
||||||
|
+ s->ds_idx++;
|
||||||
|
+ ds_resize (s);
|
||||||
|
+ s->ds_string[s->ds_idx] = 0;
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+void
|
||||||
|
+ds_concat (dynamic_string *s, char const *str)
|
||||||
|
+{
|
||||||
|
+ size_t len = strlen (str);
|
||||||
|
+ while (len + 1 > s->ds_size)
|
||||||
|
+ ds_resize (s);
|
||||||
|
+ memcpy (s->ds_string + s->ds_idx, str, len);
|
||||||
|
+ s->ds_idx += len;
|
||||||
|
+ s->ds_string[s->ds_idx] = 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
char *
|
||||||
|
ds_fgets (FILE *f, dynamic_string *s)
|
||||||
|
{
|
||||||
|
@@ -100,3 +133,10 @@ ds_fgetname (FILE *f, dynamic_string *s)
|
||||||
|
{
|
||||||
|
return ds_fgetstr (f, s, '\0');
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+/* Return true if the dynamic string S ends with character C. */
|
||||||
|
+int
|
||||||
|
+ds_endswith (dynamic_string *s, int c)
|
||||||
|
+{
|
||||||
|
+ return (s->ds_idx > 0 && s->ds_string[s->ds_idx - 1] == c);
|
||||||
|
+}
|
||||||
|
Index: cpio-2.13/src/dstring.h
|
||||||
|
===================================================================
|
||||||
|
--- cpio-2.13.orig/src/dstring.h
|
||||||
|
+++ cpio-2.13/src/dstring.h
|
||||||
|
@@ -17,10 +17,6 @@
|
||||||
|
Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
||||||
|
Boston, MA 02110-1301 USA. */
|
||||||
|
|
||||||
|
-#ifndef NULL
|
||||||
|
-#define NULL 0
|
||||||
|
-#endif
|
||||||
|
-
|
||||||
|
/* A dynamic string consists of record that records the size of an
|
||||||
|
allocated string and the pointer to that string. The actual string
|
||||||
|
is a normal zero byte terminated string that can be used with the
|
||||||
|
@@ -30,22 +26,25 @@
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
- int ds_length; /* Actual amount of storage allocated. */
|
||||||
|
- char *ds_string; /* String. */
|
||||||
|
+ size_t ds_size; /* Actual amount of storage allocated. */
|
||||||
|
+ size_t ds_idx; /* Index of the next free byte in the string. */
|
||||||
|
+ char *ds_string; /* String storage. */
|
||||||
|
} dynamic_string;
|
||||||
|
|
||||||
|
+#define DYNAMIC_STRING_INITIALIZER { 0, 0, NULL }
|
||||||
|
|
||||||
|
-/* Macros that look similar to the original string functions.
|
||||||
|
- WARNING: These macros work only on pointers to dynamic string records.
|
||||||
|
- If used with a real record, an "&" must be used to get the pointer. */
|
||||||
|
-#define ds_strlen(s) strlen ((s)->ds_string)
|
||||||
|
-#define ds_strcmp(s1, s2) strcmp ((s1)->ds_string, (s2)->ds_string)
|
||||||
|
-#define ds_strncmp(s1, s2, n) strncmp ((s1)->ds_string, (s2)->ds_string, n)
|
||||||
|
-#define ds_index(s, c) index ((s)->ds_string, c)
|
||||||
|
-#define ds_rindex(s, c) rindex ((s)->ds_string, c)
|
||||||
|
+void ds_init (dynamic_string *string);
|
||||||
|
+void ds_free (dynamic_string *string);
|
||||||
|
+void ds_reset (dynamic_string *s, size_t len);
|
||||||
|
|
||||||
|
-void ds_init (dynamic_string *string, int size);
|
||||||
|
-void ds_resize (dynamic_string *string, int size);
|
||||||
|
+/* All functions below guarantee that s->ds_string[s->ds_idx] == '\0' */
|
||||||
|
char *ds_fgetname (FILE *f, dynamic_string *s);
|
||||||
|
char *ds_fgets (FILE *f, dynamic_string *s);
|
||||||
|
char *ds_fgetstr (FILE *f, dynamic_string *s, char eos);
|
||||||
|
+void ds_append (dynamic_string *s, int c);
|
||||||
|
+void ds_concat (dynamic_string *s, char const *str);
|
||||||
|
+
|
||||||
|
+#define ds_len(s) ((s)->ds_idx)
|
||||||
|
+
|
||||||
|
+int ds_endswith (dynamic_string *s, int c);
|
||||||
|
+
|
||||||
|
Index: cpio-2.13/src/util.c
|
||||||
|
===================================================================
|
||||||
|
--- cpio-2.13.orig/src/util.c
|
||||||
|
+++ cpio-2.13/src/util.c
|
||||||
|
@@ -894,11 +894,9 @@ get_next_reel (int tape_des)
|
||||||
|
FILE *tty_out; /* File for interacting with user. */
|
||||||
|
int old_tape_des;
|
||||||
|
char *next_archive_name;
|
||||||
|
- dynamic_string new_name;
|
||||||
|
+ dynamic_string new_name = DYNAMIC_STRING_INITIALIZER;
|
||||||
|
char *str_res;
|
||||||
|
|
||||||
|
- ds_init (&new_name, 128);
|
||||||
|
-
|
||||||
|
/* Open files for interactive communication. */
|
||||||
|
tty_in = fopen (TTY_NAME, "r");
|
||||||
|
if (tty_in == NULL)
|
||||||
|
@@ -973,7 +971,7 @@ get_next_reel (int tape_des)
|
||||||
|
error (PAXEXIT_FAILURE, 0, _("internal error: tape descriptor changed from %d to %d"),
|
||||||
|
old_tape_des, tape_des);
|
||||||
|
|
||||||
|
- free (new_name.ds_string);
|
||||||
|
+ ds_free (&new_name);
|
||||||
|
fclose (tty_in);
|
||||||
|
fclose (tty_out);
|
||||||
|
}
|
36
fix-CVE-2021-38185_2.patch
Normal file
36
fix-CVE-2021-38185_2.patch
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
From dfc801c44a93bed7b3951905b188823d6a0432c8 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Sergey Poznyakoff <gray@gnu.org>
|
||||||
|
Date: Wed, 11 Aug 2021 18:10:38 +0300
|
||||||
|
Subject: Fix previous commit
|
||||||
|
|
||||||
|
* src/dstring.c (ds_reset,ds_concat): Don't call ds_resize in a
|
||||||
|
loop.
|
||||||
|
---
|
||||||
|
src/dstring.c | 4 ++--
|
||||||
|
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/dstring.c b/src/dstring.c
|
||||||
|
index 692d3e7..b7e0bb5 100644
|
||||||
|
--- a/src/dstring.c
|
||||||
|
+++ b/src/dstring.c
|
||||||
|
@@ -64,7 +64,7 @@ void
|
||||||
|
ds_reset (dynamic_string *s, size_t len)
|
||||||
|
{
|
||||||
|
while (len > s->ds_size)
|
||||||
|
- ds_resize (s);
|
||||||
|
+ s->ds_string = x2nrealloc (s->ds_string, &s->ds_size, 1);
|
||||||
|
s->ds_idx = len;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -116,7 +116,7 @@ ds_concat (dynamic_string *s, char const *str)
|
||||||
|
{
|
||||||
|
size_t len = strlen (str);
|
||||||
|
while (len + 1 > s->ds_size)
|
||||||
|
- ds_resize (s);
|
||||||
|
+ s->ds_string = x2nrealloc (s->ds_string, &s->ds_size, 1);
|
||||||
|
memcpy (s->ds_string + s->ds_idx, str, len);
|
||||||
|
s->ds_idx += len;
|
||||||
|
s->ds_string[s->ds_idx] = 0;
|
||||||
|
--
|
||||||
|
cgit v1.2.1
|
||||||
|
|
13
fix-CVE-2021-38185_3.patch
Normal file
13
fix-CVE-2021-38185_3.patch
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
Index: cpio-2.13/src/dstring.c
|
||||||
|
===================================================================
|
||||||
|
--- cpio-2.13.orig/src/dstring.c
|
||||||
|
+++ cpio-2.13/src/dstring.c
|
||||||
|
@@ -115,7 +115,7 @@ void
|
||||||
|
ds_concat (dynamic_string *s, char const *str)
|
||||||
|
{
|
||||||
|
size_t len = strlen (str);
|
||||||
|
- while (len + 1 > s->ds_size)
|
||||||
|
+ while (len + s->ds_idx + 1 > s->ds_size)
|
||||||
|
s->ds_string = x2nrealloc (s->ds_string, &s->ds_size, 1);
|
||||||
|
memcpy (s->ds_string + s->ds_idx, str, len);
|
||||||
|
s->ds_idx += len;
|
223
fix-CVE-2023-7207.patch
Normal file
223
fix-CVE-2023-7207.patch
Normal file
|
@ -0,0 +1,223 @@
|
||||||
|
From 376d663340a9dc91c91a5849e5713f07571c1628 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Sergey Poznyakoff <gray@gnu.org>
|
||||||
|
Date: Thu, 27 Apr 2023 15:14:23 +0300
|
||||||
|
Subject: Fix 45b0ee2b407913c533f7ded8d6f8cbeec16ff6ca.
|
||||||
|
|
||||||
|
The commit in question brought in more problems than solutions. To
|
||||||
|
properly fix the issue, use symlink placeholders, modelled after
|
||||||
|
delayed symlinks in tar.
|
||||||
|
|
||||||
|
* src/copyin.c (symlink_placeholder)
|
||||||
|
(replace_symlink_placeholders): New functions.
|
||||||
|
(copyin_link): Create symlink placeholder if --no-absolute-filenames
|
||||||
|
was given.
|
||||||
|
(process_copy_in): Replace placeholders after extraction.
|
||||||
|
* tests/CVE-2015-1197.at: Update. Don't use /tmp.
|
||||||
|
---
|
||||||
|
src/copyin.c | 173 ++++++++++++++++++++++++++++++++++++++++++-------
|
||||||
|
tests/CVE-2015-1197.at | 7 +-
|
||||||
|
2 files changed, 153 insertions(+), 27 deletions(-)
|
||||||
|
|
||||||
|
Index: cpio-2.13/src/copyin.c
|
||||||
|
===================================================================
|
||||||
|
--- cpio-2.13.orig/src/copyin.c
|
||||||
|
+++ cpio-2.13/src/copyin.c
|
||||||
|
@@ -31,6 +31,7 @@
|
||||||
|
#ifndef FNM_PATHNAME
|
||||||
|
# include <fnmatch.h>
|
||||||
|
#endif
|
||||||
|
+#include <hash.h>
|
||||||
|
|
||||||
|
#ifndef HAVE_LCHOWN
|
||||||
|
# define lchown(f,u,g) 0
|
||||||
|
@@ -621,6 +622,136 @@ copyin_device (struct cpio_file_stat* fi
|
||||||
|
file_hdr->c_mtime);
|
||||||
|
}
|
||||||
|
|
||||||
|
+struct delayed_link
|
||||||
|
+ {
|
||||||
|
+ /* The device and inode number of the placeholder. */
|
||||||
|
+ dev_t dev;
|
||||||
|
+ ino_t ino;
|
||||||
|
+
|
||||||
|
+ /* The desired link metadata. */
|
||||||
|
+ mode_t mode;
|
||||||
|
+ uid_t uid;
|
||||||
|
+ gid_t gid;
|
||||||
|
+ time_t mtime;
|
||||||
|
+
|
||||||
|
+ /* Link source and target names. */
|
||||||
|
+ char *source;
|
||||||
|
+ char target[1];
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+static Hash_table *delayed_link_table;
|
||||||
|
+
|
||||||
|
+static size_t
|
||||||
|
+dl_hash (void const *entry, size_t table_size)
|
||||||
|
+{
|
||||||
|
+ struct delayed_link const *dl = entry;
|
||||||
|
+ uintmax_t n = dl->dev;
|
||||||
|
+ int nshift = (sizeof (n) - sizeof (dl->dev)) * CHAR_BIT;
|
||||||
|
+ if (0 < nshift)
|
||||||
|
+ n <<= nshift;
|
||||||
|
+ n ^= dl->ino;
|
||||||
|
+ return n % table_size;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static bool
|
||||||
|
+dl_compare (void const *a, void const *b)
|
||||||
|
+{
|
||||||
|
+ struct delayed_link const *da = a, *db = b;
|
||||||
|
+ return (da->dev == db->dev) & (da->ino == db->ino);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static int
|
||||||
|
+symlink_placeholder (char *oldpath, char *newpath, struct cpio_file_stat *file_stat)
|
||||||
|
+{
|
||||||
|
+ int fd = open (newpath, O_WRONLY | O_CREAT | O_EXCL, 0);
|
||||||
|
+ struct stat st;
|
||||||
|
+ struct delayed_link *p;
|
||||||
|
+ size_t newlen = strlen (newpath);
|
||||||
|
+
|
||||||
|
+ if (fd < 0)
|
||||||
|
+ {
|
||||||
|
+ open_error (newpath);
|
||||||
|
+ return -1;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (fstat (fd, &st) != 0)
|
||||||
|
+ {
|
||||||
|
+ stat_error (newpath);
|
||||||
|
+ close (fd);
|
||||||
|
+ return -1;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ close (fd);
|
||||||
|
+
|
||||||
|
+ p = xmalloc (sizeof (*p) + strlen (oldpath) + newlen + 1);
|
||||||
|
+ p->dev = st.st_dev;
|
||||||
|
+ p->ino = st.st_ino;
|
||||||
|
+
|
||||||
|
+ p->mode = file_stat->c_mode;
|
||||||
|
+ p->uid = file_stat->c_uid;
|
||||||
|
+ p->gid = file_stat->c_gid;
|
||||||
|
+ p->mtime = file_stat->c_mtime;
|
||||||
|
+
|
||||||
|
+ strcpy (p->target, newpath);
|
||||||
|
+ p->source = p->target + newlen + 1;
|
||||||
|
+ strcpy (p->source, oldpath);
|
||||||
|
+
|
||||||
|
+ if (!((delayed_link_table
|
||||||
|
+ || (delayed_link_table = hash_initialize (0, 0, dl_hash,
|
||||||
|
+ dl_compare, free)))
|
||||||
|
+ && hash_insert (delayed_link_table, p)))
|
||||||
|
+ xalloc_die ();
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void
|
||||||
|
+replace_symlink_placeholders (void)
|
||||||
|
+{
|
||||||
|
+ struct delayed_link *dl;
|
||||||
|
+
|
||||||
|
+ if (!delayed_link_table)
|
||||||
|
+ return;
|
||||||
|
+ for (dl = hash_get_first (delayed_link_table);
|
||||||
|
+ dl;
|
||||||
|
+ dl = hash_get_next (delayed_link_table, dl))
|
||||||
|
+ {
|
||||||
|
+ struct stat st;
|
||||||
|
+
|
||||||
|
+ /* Make sure the placeholder file is still there. If not,
|
||||||
|
+ don't create a link, as the placeholder was probably
|
||||||
|
+ removed by a later extraction. */
|
||||||
|
+ if (lstat (dl->target, &st) == 0
|
||||||
|
+ && st.st_dev == dl->dev
|
||||||
|
+ && st.st_ino == dl->ino)
|
||||||
|
+ {
|
||||||
|
+ if (unlink (dl->target))
|
||||||
|
+ unlink_error (dl->target);
|
||||||
|
+ else
|
||||||
|
+ {
|
||||||
|
+ int res = UMASKED_SYMLINK (dl->source, dl->target, dl->mode);
|
||||||
|
+ if (res < 0 && create_dir_flag)
|
||||||
|
+ {
|
||||||
|
+ create_all_directories (dl->target);
|
||||||
|
+ res = UMASKED_SYMLINK (dl->source, dl->target, dl->mode);
|
||||||
|
+ }
|
||||||
|
+ if (res < 0)
|
||||||
|
+ symlink_error (dl->source, dl->target);
|
||||||
|
+ else if (!no_chown_flag)
|
||||||
|
+ {
|
||||||
|
+ uid_t uid = set_owner_flag ? set_owner : dl->uid;
|
||||||
|
+ gid_t gid = set_group_flag ? set_group : dl->gid;
|
||||||
|
+ if (lchown (dl->target, uid, gid) < 0 && errno != EPERM)
|
||||||
|
+ chown_error_details (dl->target, uid, gid);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ hash_free (delayed_link_table);
|
||||||
|
+ delayed_link_table = NULL;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
static void
|
||||||
|
copyin_link (struct cpio_file_stat *file_hdr, int in_file_des)
|
||||||
|
{
|
||||||
|
@@ -646,28 +777,26 @@ copyin_link (struct cpio_file_stat *file
|
||||||
|
link_name = xstrdup (file_hdr->c_tar_linkname);
|
||||||
|
}
|
||||||
|
|
||||||
|
- res = UMASKED_SYMLINK (link_name, file_hdr->c_name,
|
||||||
|
- file_hdr->c_mode);
|
||||||
|
- if (res < 0 && create_dir_flag)
|
||||||
|
+ if (no_abs_paths_flag)
|
||||||
|
+ symlink_placeholder (link_name, file_hdr->c_name, file_hdr);
|
||||||
|
+ else
|
||||||
|
{
|
||||||
|
- create_all_directories (file_hdr->c_name);
|
||||||
|
res = UMASKED_SYMLINK (link_name, file_hdr->c_name,
|
||||||
|
file_hdr->c_mode);
|
||||||
|
- }
|
||||||
|
- if (res < 0)
|
||||||
|
- {
|
||||||
|
- error (0, errno, _("%s: Cannot symlink to %s"),
|
||||||
|
- quotearg_colon (link_name), quote_n (1, file_hdr->c_name));
|
||||||
|
- free (link_name);
|
||||||
|
- return;
|
||||||
|
- }
|
||||||
|
- if (!no_chown_flag)
|
||||||
|
- {
|
||||||
|
- uid_t uid = set_owner_flag ? set_owner : file_hdr->c_uid;
|
||||||
|
- gid_t gid = set_group_flag ? set_group : file_hdr->c_gid;
|
||||||
|
- if ((lchown (file_hdr->c_name, uid, gid) < 0)
|
||||||
|
- && errno != EPERM)
|
||||||
|
- chown_error_details (file_hdr->c_name, uid, gid);
|
||||||
|
+ if (res < 0 && create_dir_flag)
|
||||||
|
+ {
|
||||||
|
+ create_all_directories (file_hdr->c_name);
|
||||||
|
+ res = UMASKED_SYMLINK (link_name, file_hdr->c_name, file_hdr->c_mode);
|
||||||
|
+ }
|
||||||
|
+ if (res < 0)
|
||||||
|
+ symlink_error (link_name, file_hdr->c_name);
|
||||||
|
+ else if (!no_chown_flag)
|
||||||
|
+ {
|
||||||
|
+ uid_t uid = set_owner_flag ? set_owner : file_hdr->c_uid;
|
||||||
|
+ gid_t gid = set_group_flag ? set_group : file_hdr->c_gid;
|
||||||
|
+ if (lchown (file_hdr->c_name, uid, gid) < 0 && errno != EPERM)
|
||||||
|
+ chown_error_details (file_hdr->c_name, uid, gid);
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
free (link_name);
|
||||||
|
}
|
||||||
|
@@ -1418,6 +1547,7 @@ process_copy_in ()
|
||||||
|
if (dot_flag)
|
||||||
|
fputc ('\n', stderr);
|
||||||
|
|
||||||
|
+ replace_symlink_placeholders ();
|
||||||
|
apply_delayed_set_stat ();
|
||||||
|
|
||||||
|
cpio_file_stat_free (&file_hdr);
|
30
fix-bsc1219238.patch
Normal file
30
fix-bsc1219238.patch
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
From e3cc782c610729de7622a274e532817c18262a9d Mon Sep 17 00:00:00 2001
|
||||||
|
From: Sergey Poznyakoff <gray@gnu.org>
|
||||||
|
Date: Thu, 18 May 2023 09:00:12 +0300
|
||||||
|
Subject: Fix operation of --no-absolute-filenames --make-directories
|
||||||
|
|
||||||
|
* src/copyin.c (symlink_placeholder): Try to create leading
|
||||||
|
directories if unable to create placeholder.
|
||||||
|
---
|
||||||
|
src/copyin.c | 6 ++++++
|
||||||
|
1 file changed, 6 insertions(+)
|
||||||
|
|
||||||
|
Index: cpio-2.13/src/copyin.c
|
||||||
|
===================================================================
|
||||||
|
--- cpio-2.13.orig/src/copyin.c
|
||||||
|
+++ cpio-2.13/src/copyin.c
|
||||||
|
@@ -667,7 +667,13 @@ symlink_placeholder (char *oldpath, char
|
||||||
|
struct stat st;
|
||||||
|
struct delayed_link *p;
|
||||||
|
size_t newlen = strlen (newpath);
|
||||||
|
-
|
||||||
|
+
|
||||||
|
+ if (fd < 0 && create_dir_flag)
|
||||||
|
+ {
|
||||||
|
+ create_all_directories (newpath);
|
||||||
|
+ fd = open (newpath, O_WRONLY | O_CREAT | O_EXCL, 0);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
if (fd < 0)
|
||||||
|
{
|
||||||
|
open_error (newpath);
|
13
paxutils-rtapelib_mtget.patch
Normal file
13
paxutils-rtapelib_mtget.patch
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
Index: cpio-2.13/lib/rtapelib.c
|
||||||
|
===================================================================
|
||||||
|
--- cpio-2.13.orig/lib/rtapelib.c
|
||||||
|
+++ cpio-2.13/lib/rtapelib.c
|
||||||
|
@@ -711,7 +711,7 @@ rmt_ioctl__ (int handle, int operation,
|
||||||
|
|| (status = get_status (handle), status == -1))
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
- if (status > sizeof (struct mtop))
|
||||||
|
+ if (status > sizeof (struct mtget))
|
||||||
|
{
|
||||||
|
errno = EOVERFLOW;
|
||||||
|
return -1;
|
Loading…
Add table
Reference in a new issue