CPIO(1)                         User Commands                        CPIO(1)
NAME
       cpio - copy file archives in and out
SYNOPSIS
       cpio -i [
-bBcdfkmPqrsStuvV6@/] [
-C bufsize] [
-E file]
            [
-H header] [
-I  [
-M message]] [
-R id] [
pattern]...       
cpio -o [
-aABcLPqvV@/] [
-C bufsize] [
-H header]
            [
-O file [
-M message]]       
cpio -p [
-adlLmPquvV@/] [
-R id] 
directoryDESCRIPTION
       The 
cpio command copies files into and out of a 
cpio archive. The       
cpio archive can span multiple volumes. The 
-i, 
-o, and 
-p options
       select the action to be performed. The following list describes each
       of the actions. These actions are mutually exclusive.
   Copy In Mode
       cpio -i (copy in) extracts files from the standard input, which is
       assumed to be the product of a previous 
cpio -o command. Only files
       with names that match one of the 
patterns are selected. See 
sh(1) and
       OPERANDS for more information about 
pattern. Extracted files are
       conditionally copied into the current directory tree, based on the
       options described below. The permissions of the files are those of
       the previous 
cpio -o command. The owner and group are the same as the
       current user, unless the current user has the 
{PRIV_FILE_CHOWN_SELF}       privilege. See 
chown(2). If this is the case, owner and group are the
       same as those resulting from the previous 
cpio -o command. Notice
       that if 
cpio -i tries to create a file that already exists and the
       existing file is the same age or younger (
newer), 
cpio outputs a
       warning message and not replace the file. The 
-u option can be used
       to unconditionally overwrite the existing file.
   Copy Out Mode
       cpio -o (copy out) reads a list of file path names from the standard
       input and copies those files to the standard output, together with
       path name and status information in the form of a 
cpio archive.
       Output is padded to an 8192-byte boundary by default or to the user-
       specified block size (with the 
-B or 
-C options) or to some device-
       dependent block size where necessary (as with the CTC tape).
   Pass Mode
       cpio -p (pass) reads a list of file path names from the standard
       input and conditionally copies those files into the destination
       directory tree, based on the options described below.
       If the underlying file system of the source file supports detection
       of holes as reported by 
pathconf(2), the file is a sparse file, and
       the destination file is seekable, then holes in sparse files are
       preserved in pass mode, otherwise holes are filled with zeros.       
cpio assumes four-byte words.
       If, when writing to a character device (
-o) or reading from a
       character device (
-i), 
cpio reaches the end of a medium (such as the
       end of a diskette), and the 
-O and 
-I options are not used, 
cpio       prints the following message:
         To continue, type device/file name when ready.
       To continue, you must replace the medium and type the character
       special device name (
/dev/rdiskette for example) and press RETURN.
       You might want to continue by directing 
cpio to use a different
       device. For example, if you have two floppy drives you might want to
       switch between them so 
cpio can proceed while you are changing the
       floppies. Press RETURN to cause the 
cpio process to exit.
OPTIONS
       The following options are supported:       
-i             (copy in) Reads an archive from the standard input and
             conditionally extracts the files contained in it and places
             them into the current directory tree.       
-o             (copy out) Reads a list of file path names from the standard
             input and copies those files to the standard output in the form
             of a 
cpio archive.       
-p             (pass) Reads a list of file path names from the standard input
             and conditionally copies those files into the destination
             directory tree.
       The following options can be appended in any sequence to the 
-i, 
-o,
       or 
-p options:       
-a                     Resets access times of input files after they have been
                     copied, making 
cpio's access invisible. Access times
                     are not reset for linked files when 
cpio -pla is
                     specified.       
-A                     Appends files to an archive. The 
-A option requires the                     
-O option.  Valid only with archives that are files, or
                     that are on floppy diskettes or hard disk partitions.
                     The effect on files that are linked in the existing
                     portion of the archive is unpredictable.       
-b                     Reverses the order of the bytes within each word. Use
                     only with the 
-i option.       
-B                     Blocks input/output 5120 bytes to the record. The
                     default buffer size is 8192 bytes when this and the 
-C                     options are not used. 
-B does not apply to the 
-p                     (pass) option.       
-c                     Reads or writes header information in 
ASCII character
                     form for portability. There are no 
UID or 
GID                     restrictions associated with this header format. Use
                     this option between SVR4-based machines, or the 
-H odc                     option between unknown machines. The 
-c option implies
                     the use of expanded device numbers, which are only
                     supported on SVR4-based systems. When transferring
                     files between SunOS 4 or Interactive UNIX and the
                     Solaris 2.6 Operating environment or compatible
                     versions, use 
-H odc.       
-C bufsize                     Blocks input/output 
bufsize bytes to the record, where                     
bufsize is replaced by a positive integer. The default
                     buffer size is 8192 bytes when this and 
-B options are
                     not used. 
-C does not apply to the 
-p (pass) option.       
-d                     Creates directories as needed.       
-E file                     Specifies an input file (
file) that contains a list of
                     filenames to be extracted from the archive (one
                     filename per line).       
-f                     Copies in all files except those in 
patterns. See
                     OPERANDS for a description of 
pattern.       
-H header                     Reads or writes header information in 
header format.
                     Always use this option or the 
-c option when the origin
                     and the destination machines are different types. This
                     option is mutually exclusive with options 
-c and 
-6.
                     Valid values for 
header are:                     
bar                                      bar head and format. Used only with
                                      the 
-i option (read only).                     
crc | 
CRC                                      ASCII header with expanded device
                                      numbers and an additional per-file
                                      checksum. There are no 
UID or 
GID                                      restrictions associated with this
                                      header format.                     
odc                                      ASCII header with small device
                                      numbers. This is the IEEE/P1003 Data
                                      Interchange Standard cpio header and
                                      format. It has the widest range of
                                      portability of any of the header
                                      formats. It is the official format for
                                      transferring files between POSIX-
                                      conforming systems (see 
standards(7)).
                                      Use this format to communicate with
                                      SunOS 4 and Interactive UNIX. This
                                      header format allows 
UIDs and 
GIDs up
                                      to 262143 to be stored in the header.                     
tar | 
TAR                                      tar header and format. This is an
                                      older 
tar header format that allows                                      
UIDs and 
GIDs up to 2097151 to be
                                      stored in the header. It is provided
                                      for the reading of legacy archives
                                      only, that is, in conjunction with
                                      option 
-i.
                                      Specifying this archive format with
                                      option 
-o has the same effect as
                                      specifying the "ustar" format: the
                                      output archive is in 
ustar format, and
                                      must be read using 
-H ustar.                     
ustar | 
USTAR                                      IEEE/P1003 Data Interchange Standard
                                      tar header and format. This header
                                      format allows 
UIDs and 
GIDs up to
                                      2097151 to be stored in the header.
                     Files with 
UIDs and 
GIDs greater than the limit stated
                     above are archived with the 
UID and 
GID of 
60001. To
                     transfer a large file (8 Gb - 1 byte), the header
                     format can be 
tar|TAR, 
ustar|USTAR, or 
odc only.       
-I file                     Reads the contents of 
file as an input archive, instead
                     of the standard input. If 
file is a character special
                     device, and the current medium has been completely
                     read, replace the medium and press RETURN to continue
                     to the next medium. This option is used only with the                     
-i option.       
-k                     Attempts to skip corrupted file headers and I/O errors
                     that might be encountered. If you want to copy files
                     from a medium that is corrupted or out of sequence,
                     this option lets you read only those files with good
                     headers. For 
cpio archives that contain other 
cpio                     archives, if an error is encountered, 
cpio can
                     terminate prematurely. 
cpio finds the next good header,
                     which can be one for a smaller archive, and terminate
                     when the smaller archive's trailer is encountered. Use
                     only with the 
-i option.       
-l                     In pass mode, makes hard links between the source and
                     destination whenever possible. If the 
-L option is also
                     specified, the hard link is to the file referred to by
                     the symbolic link. Otherwise, the hard link is to the
                     symbolic link itself. Use only with the 
-p option.       
-L                     Follows symbolic links. If a symbolic link to a
                     directory is encountered, archives the directory
                     referred to by the link, using the name of the link.
                     Otherwise, archives the file referred to by the link,
                     using the name of the link.       
-m                     Retains previous file modification time. This option is
                     ineffective on directories that are being copied.       
-M message                     Defines a 
message to use when switching media. When you
                     use the 
-O or 
-I options and specify a character
                     special device, you can use this option to define the
                     message that is printed when you reach the end of the
                     medium. One 
%d can be placed in 
message to print the
                     sequence number of the next medium needed to continue.       
-O file                     Directs the output of 
cpio to 
file, instead of the
                     standard output.  If 
file is a character special device
                     and the current medium is full, replace the medium and
                     type a carriage return to continue to the next medium.
                     Use only with the 
-o option.       
-P                     Preserves 
ACLs. If the option is used for output,
                     existing 
ACLs are written along with other attributes,
                     except for extended attributes, to the standard output.                     
ACLs are created as special files with a special file
                     type. If the option is used for input, existing 
ACLs
                     are extracted along with other attributes from standard
                     input. The option recognizes the special file type.
                     Notice that errors occurs if a 
cpio archive with 
ACLs
                     is extracted by previous versions of 
cpio. This option
                     should not be used with the 
-c option, as 
ACL support
                     might not be present on all systems, and hence is not
                     portable. Use 
ASCII headers for portability.       
-q                     Quiet. Suppresses the number of blocks message that
                     normally is printed after the copy is completed.       
-r                     Interactively renames files. If the user types a
                     carriage return alone, the file is skipped. If the user
                     types a ``.'', the original pathname is retained.  Not
                     available with 
cpio -p.       
-R id                     Reassigns ownership and group information for each file
                     to user ID. (ID must be a valid login ID from the                     
passwd database.) This option is valid only when id is
                     the invoking user or the super-user. See 
NOTES.       
-s                     Swaps bytes within each half word.       
-S                     Swaps halfwords within each word.       
-t                     Prints a table of contents of the input. If any file in
                     the table of contents has extended attributes, these
                     are also listed. No files are created. 
-t and 
-V are
                     mutually exclusive.       
-u                     Copies unconditionally. Normally, an older file is not
                     replaced a newer file with the same name, although an
                     older directory updates a newer directory.       
-v                     Verbose. Prints a list of file and extended attribute
                     names. When used with the 
-t option, the table of
                     contents looks like the output of an 
ls -l command (see                     
ls(1)).       
-V                     Special verbose. Prints a dot for each file read or
                     written. Useful to assure the user that 
cpio is working
                     without printing out all file names.       
-6                     Processes a UNIX System Sixth Edition archive format
                     file. Use only with the 
-i option. This option is
                     mutually exclusive with 
-c and 
-H.       
-@                     Includes extended attributes in archive. By default,                     
cpio does not place extended attributes in the archive.
                     With this flag, 
cpio looks for extended attributes on
                     the files to be placed in the archive and add them, as
                     regular files, to the archive. The extended attribute
                     files go in the archive as special files with special
                     file types. When the 
-@ flag is used with 
-i or 
-p, it
                     instructs 
cpio to restore extended attribute data along
                     with the normal file data. Extended attribute files can
                     only be extracted from an archive as part of a normal
                     file extract. Attempts to explicitly extract attribute
                     records are ignored.       
-/                     Includes extended system attributes in archive. By
                     default, 
cpio does not place extended system attributes
                     in the archive. With this flag, 
cpio looks for extended
                     system attributes on the files to be placed in the
                     archive and add them, as regular files, to the archive.
                     The extended attribute files go in the archive as
                     special files with special file types. When the 
-/ flag
                     is used with 
-i or 
-p, it instructs 
cpio to restore
                     extended system attribute data along with the normal
                     file data. Extended system attribute files can only be
                     extracted from an archive as part of a normal file
                     extract. Attempts to explicitly extract attribute
                     records are ignored.
OPERANDS
       The following operands are supported:       
directory                    A path name of an existing directory to be used as the
                    target of 
cpio -p.       
pattern                    Expressions making use of a pattern-matching notation
                    similar to that used by the shell (see 
sh(1)) for
                    filename pattern matching, and similar to regular
                    expressions. The following metacharacters are defined:                    
*                             Matches any string, including the empty string.                    
?                             Matches any single character.                    
[...]                             Matches any one of the enclosed characters. A
                             pair of characters separated by `-' matches any
                             symbol between the pair (inclusive), as defined
                             by the system default collating sequence. If
                             the first character following the opening 
`['                             is a 
`!', the results are unspecified.                    
!                             The ! (exclamation point) means 
not. For
                             example, the 
!abc* pattern would exclude all
                             files that begin with 
abc.
                    In 
pattern, metacharacters 
?, 
*, and 
[...
] match the
                    slash (
/) character, and backslash (
\) is an escape
                    character. Multiple cases of 
pattern can be specified
                    and if no 
pattern is specified, the default for 
pattern                    is 
* (that is, select all files).
                    Each pattern must be enclosed in double quotes.
                    Otherwise, the name of a file in the current directory
                    might be used.
USAGE
       See 
largefile(7) for the description of the behavior of 
cpio when
       encountering files greater than or equal to 2 Gbyte (2^31 bytes).
EXAMPLES
       The following examples show three uses of 
cpio.
       Example 1: Using standard input
         example% 
ls | cpio -oc > ../newfile       When standard input is directed through a pipe to 
cpio -o, as in the
       example above, it groups the files so they can be directed (>) to a
       single file (
../newfile). The 
-c option insures that the file is
       portable to other machines (as would the 
-H option). Instead of       
ls(1), you could use 
find(1), 
echo(1), 
cat(1), and so on, to pipe a
       list of names to 
cpio. You could direct the output to a device
       instead of a file.
       Example 2: Extracting files into directories
         example% 
cat newfile | cpio -icd "memo/a1" "memo/b*"       In this example, 
cpio -i uses the output file of 
cpio -o (directed
       through a pipe with 
cat), extracts those files that match the
       patterns (
memo/a1, 
memo/b*), creates directories below the current
       directory as needed (
-d option), and places the files in the
       appropriate directories. The 
-c option is used if the input file was
       created with a portable header. If no patterns were given, all files
       from 
newfile would be placed in the directory.
       Example 3: Copying or linking files to another directory
         example% 
find . -depth -print | cpio -pdlmv newdir       In this example, 
cpio -p takes the file names piped to it and copies
       or links (
-l option) those files to another directory, 
newdir. The 
-d       option says to create directories as needed. The 
-m option says to
       retain the modification time. (It is important to use the 
-depth       option of 
find(1) to generate path names for 
cpio.  This eliminates
       problems that 
cpio could have trying to create files under read-only
       directories.) The destination directory, 
newdir, must exist.
       Notice that when you use 
cpio in conjunction with 
find, if you use
       the 
-L option with 
cpio, you must use the 
-follow option with 
find       and vice versa. Otherwise, there are undesirable results.
       For multi-reel archives, dismount the old volume, mount the new one,
       and continue to the next tape by typing the name of the next device
       (probably the same as the first reel). To stop, type a RETURN and       
cpio ends.
ENVIRONMENT VARIABLES
       See 
environ(7) for descriptions of the following environment
       variables that affect the execution of 
cpio: 
LC_COLLATE, 
LC_CTYPE,       
LC_MESSAGES, 
LC_TIME, 
TZ, and 
NLSPATH.       
TMPDIR                 cpio creates its temporary file in 
/var/tmp by default.
                 Otherwise, it uses the directory specified by 
TMPDIR.
EXIT STATUS
       The following exit values are returned:       
0             Successful completion.       
>0             An error occurred.
ATTRIBUTES
       See 
attributes(7) for descriptions of the following attributes:
       +--------------------+-----------------+
       |  ATTRIBUTE TYPE    | ATTRIBUTE VALUE |
       +--------------------+-----------------+
       |CSI                 | Enabled         |
       +--------------------+-----------------+
       |Interface Stability | Committed       |
       +--------------------+-----------------+
SEE ALSO
       ar(1), 
cat(1), 
echo(1), 
find(1), 
ls(1), 
pax(1), 
setfacl(1), 
sh(1),       
tar(1), 
chown(2), 
archives.h(3HEAD), 
attributes(7), 
environ(7),       
fsattr(7), 
largefile(7), 
standards(7)NOTES
       The maximum path name length allowed in a 
cpio archive is determined
       by the header type involved. The following table shows the proper
       value for each supported archive header type.
       Header type   Command line options   Maximum path name length
       BINARY        "
-o"                   256
       POSIX         "
-oH odc"              256
       ASCII         "
-oc"                  1023
       CRC           "
-oH crc"              1023
       USTAR         "
-oH ustar"            255
       When the command line options "
-o -H tar" are specified, the archive
       created is of type 
USTAR. This means that it is an error to read this
       same archive using the command line options "
-i -H tar".  The archive
       should be read using the command line options "
-i -H ustar". The
       options "
-i -H tar" refer to an older tar archive format.
       An error message is output for files whose 
UID or 
GID are too large
       to fit in the selected header format. Use 
-H crc or 
-c to create
       archives that allow all 
UID or 
GID values.
       Only the super-user can copy special files.
       Blocks are reported in 512-byte quantities.
       If a file has 
000 permissions, contains more than 0 characters of
       data, and the user is not root, the file is not saved or restored.
       When cpio is invoked in 
Copy In or 
Pass Mode by a user with       
{PRIV_FILE_CHOWN_SELF} privilege, and in particular on a system where       
{_POSIX_CHOWN_RESTRICTED} is not in effect (effectively granting this
       privilege to all users where not overridden), extracted or copied
       files can end up with owners and groups determined by those of the
       original archived files, which can differ from the invoking user's.
       This might not be what the user intended. The 
-R option can be used
       to retain file ownership, if desired, if you specify the user's id.
       The inode number stored in the header (
/usr/include/archives.h) is an
       unsigned short, which is 2 bytes. This limits the range of inode
       numbers from 
0 to 
65535. Files which are hard linked must fall in
       this inode range. This could be a problem when moving 
cpio archives
       between different vendors' machines.
       You must use the same blocking factor when you retrieve or copy files
       from the tape to the hard disk as you did when you copied files from
       the hard disk to the tape. Therefore, you must specify the 
-B or 
-C       option.
       During 
-p and 
-o processing, 
cpio buffers the file list presented on
       stdin in a temporary file.
       The new 
pax(1) format, with a command that supports it (for example,       
tar), should be used for large files. The 
cpio command is no longer
       part of the current POSIX standard and is deprecated in favor of 
pax.
                              February 17, 2023                      CPIO(1)