summaryrefslogtreecommitdiffstats
path: root/README-4.6.1
diff options
context:
space:
mode:
Diffstat (limited to 'README-4.6.1')
-rw-r--r--README-4.6.1340
1 files changed, 340 insertions, 0 deletions
diff --git a/README-4.6.1 b/README-4.6.1
new file mode 100644
index 0000000..a259db3
--- /dev/null
+++ b/README-4.6.1
@@ -0,0 +1,340 @@
+ SQUASHFS-TOOLS 4.6.1 - A squashed read-only filesystem for Linux
+
+ Copyright 2002-2023 Phillip Lougher <phillip@squashfs.org.uk>
+
+ Released under the GPL licence (version 2 or later).
+
+Welcome to Squashfs-Tools 4.6.1. This is a bug fix update release to
+Squashfs-Tools 4.6.
+
+Please see the INSTALL file for instructions on installing the tools, and the
+USAGE-4.6 files for documentation on how to use the tools.
+
+This README will describe the improvements, and has the following sections:
+
+1. Bug fixes in 4.6.1
+2. Summary of changes in 4.6
+3. Filtering and adding extended attributes (XATTRs)
+4. Squashfs filesystems conversion (piping Unsquashfs output to Mksquashfs)
+5. Author info
+
+1. Bug fixes in 4.6.1
+---------------------
+
+1. Race condition which can cause corruption of the "fragment table" fixed.
+ This is a regression introduced in August 2022, and it has been seen when
+ tailend packing is used (-tailends option).
+2. Fix build failure when the tools are being built without extended attribute
+ (XATTRs) support.
+3. Fix XATTR error message when an unrecognised prefix is found (Christian Hesse).
+4. Fix incorrect free of pointer when an unrecognised XATTR prefix is found.
+
+2. Summary of changes in 4.6
+----------------------------
+
+1. Extended attribute handling improved in Mksquashfs and Sqfstar
+
+ 1.1.New -xattrs-exclude option to exclude extended attributes from files
+ using a regular expression.
+ 1.2 New -xattrs-include option to include extended attributes from files
+ using a regular expression.
+ 1.3 New -xattrs-add option to add extended attributes to files.
+ 1.4 New Pseudo file xattr definition to add extended attributes to
+ files.
+ 1.5 New xattrs-add Action to add extended attributes to files
+ (Mksquashfs only).
+
+2. Extended attribute handling improved in Unsquashfs
+
+ 2.1 New -xattrs-exclude option to exclude extended attributes from files
+ using a regular expression.
+ 2.2 New -xattrs-include option to include extended attributes from files
+ using a regular expression.
+ 2.3 Extended attributes are now supported in Pseudo file output.
+
+3. Other major improvements
+
+ 3.1 Unsquashfs can now output Pseudo files to standard out.
+ 3.2 Mksquashfs can now input Pseudo files from standard in.
+ 3.3 Squashfs filesystems can now be converted (different block size
+ compression etc) without unpacking to an intermediate filesystem or
+ mounting, by piping the output of Unsquashfs to Mksquashfs.
+ 3.4 Pseudo files are now supported by Sqfstar.
+ 3.5 "Non-anchored" excludes are now supported by Unsquashfs.
+
+4. Mksquashfs minor improvements
+
+ 4.1 A new -max-depth option has been added, which limits the depth
+ Mksquashfs descends when creating the filesystem.
+ 4.2 A new -mem-percent option which allows memory for caches to be
+ specified as a percentage of physical RAM, rather than requiring an
+ absolute value.
+ 4.3 A new -percentage option added which rather than generating the full
+ progress-bar instead outputs a percentage. This can be used with
+ dialog --gauge etc.
+ 4.4 -mkfs-time, -all-time and -root-time options now take a human date
+ string, in addition to the seconds since the epoch of 1970 00:00
+ UTC. For example "now", "last week", "Wed Mar 8 05:55:01 GMT 2023"
+ are supported.
+ 4.5 -root-uid, -root-gid, -force-uid and -force-gid options now take a
+ user/group name in addition to the integer uid/gid.
+ 4.6 A new -mem-default option which displays default memory usage for
+ caches in Mbytes.
+ 4.7 A new -no-compression option which produces no compression, and it
+ is a short-cut for -noI, -noD, -noF and -noX.
+ 4.8 A new -pseudo-override option which makes pseudo file uids and gids
+ override -all-root, -force-uid and -force-gid options. Normally
+ these options take precedence.
+
+5. Unsquashfs minor improvements
+
+ 5.1 New -all-time option which sets all file timestamps to <time>,
+ rather than the time stored in the filesystem inode. <time> can be
+ an integer indicating seconds since the epoch (1970-01-01) or a
+ human string value such as "now", "last week", or
+ "Wed Feb 15 21:02:39 GMT 2023".
+ 5.2 New -full-precision option which uses full precision when displaying
+ times including seconds. Use with -linfo, -lls, -lln and -llc
+ options.
+ 5.3 New -match option where Unsquashfs will abort if any extract file
+ does not match on anything, and can not be resolved.
+ 5.4 New -percentage option added which rather than generating the full
+ progress-bar instead outputs a percentage. This can be used with
+ dialog --gauge etc.
+
+6. Sqfstar minor improvements
+
+ 6.1 New -ignore-zeros option added which allows tar files to be
+ concatenated together and fed to Sqfstar. Normally a tarfile has
+ two consecutive 512 byte blocks filled with zeros which means EOF
+ and Sqfstar will stop reading after the first tar file on
+ encountering them. This option makes Sqfstar ignore the zero filled
+ blocks.
+ 6.2 A new -mem-percent option which allows memory for caches to be
+ specified as a percentage of physical RAM, rather than requiring an
+ absolute value.
+ 6.3 A new -percentage option added which rather than generating the full
+ progress-bar instead outputs a percentage. This can be used with
+ dialog --gauge etc.
+ 6.4 -mkfs-time, -all-time and -root-time options now take a human date
+ string, in addition to the seconds since the epoch of 1970 00:00
+ UTC. For example "now", "last week", "Wed Mar 8 05:55:01 GMT 2023"
+ are supported.
+ 6.5 -root-uid, -root-gid, -force-uid and -force-gid options now take a
+ user/group name in addition to the integer uid/gid.
+ 6.6 A new -mem-default option which displays default memory usage for
+ caches in Mbytes.
+ 6.7 A new -no-compression option which produces no compression, and it
+ is a short-cut for -noI, -noD, -noF and -noX.
+ 6.8 A new -pseudo-override option which makes pseudo file uids and gids
+ override -all-root, -force-uid and -force-gid options. Normally
+ these options take precedence.
+ 6.9 Do not abort if ZERO filled blocks indicating end of the TAR archive
+ are missing.
+
+7. Other minor improvements
+
+ 7.1 If Mksquashfs/Unsquashfs fails to execute generating the manpages
+ because they have been cross-compiled, fall back to using the
+ pre-built manpages.
+ 7.2 Add new Makefile configure option USE_PREBUILT_MANPAGES to always
+ use pre-built manpages rather than generating them when "make
+ install" is run.
+
+8. Major bug fixes
+
+ 8.1 Following a symlink in Sqfscat or where -follow-symlinks option is
+ given with Unsquashfs, incorrectly triggered the corrupted
+ filesystem loop detection code.
+ 8.2 In Unsquashfs if a file was not writable it could not add extended
+ attributes to it.
+ 8.3 Sqfstar would incorrectly reject compressor specific options that
+ have an argument.
+ 8.4 Sqfstar would incorrectly strip pathname components in PAX header
+ linkpath if symbolic.
+ 8.5 Sqfstar -root-uid, -root-gid and -root-time options were documented
+ but not implemented.
+ 8.6 Mksquashfs -one-file-system option would not create empty mount
+ point directory when filesystem boundary crossed.
+ 8.7 Mksquashfs did not check the close() return result.
+
+
+3. Filtering and adding extended attributes (XATTRs)
+----------------------------------------------------
+
+Mksquashfs, Unsquashfs and Sqfstar have a number of new options which allow
+extended attributes (xattrs) to be filtered from the source files or added to
+the created Squashfs filesystem.
+
+The -xattrs-exclude option specifies a regular expression (regex), which
+removes any extended attribute that matches the regular expression from all
+files.
+
+The -xattrs-include option instead specifies a regular expression (regex)
+which includes any extended attribute that matches, and removes anything
+that does't match.
+
+Examples:
+
+% mksquashfs directory image.sqsh -xattrs-exclude "^user."
+
+Exclude any extended attributes in the User namespace from the Squashfs
+filesystem.
+
+% unsquashfs -xattrs-exclude "^user." image.sqsh
+
+As above, but exclude them from the Squashfs filesystem when extracting.
+
+% mksquashfs directory image.sqsh -xattrs-include "^user."
+
+Only include extended attributes in the User namespace in the Squashfs
+filesystem.
+
+3.1 Adding extended attributes
+------------------------------
+
+Mksquashfs and Sqfstar also allows you to add extended attributes to files in
+the Squashfs filesystem using the -xattrs-add option and the Pseudo file "x"
+definition. Both options take an xattr name and value pair separated by the
+'=' character.
+
+The extended attribute name can be any valid name and can be in the namespaces
+security, system, trusted, or user. User extended attributes are added to files
+and directories (see man 7 xattr for explanation), and the others are added to
+all files.
+
+The extended attribute value by default will be treated as binary (i.e. an
+uninterpreted byte sequence), but it can be prefixed with 0s, where it will be
+treated as base64 encoded, or prefixed with 0x, where it will be treated as
+hexidecimal.
+
+Obviously using base64 or hexidecimal allows values to be used that cannot be
+entered on the command line such as non-printable characters etc. But it
+renders the string non-human readable. To keep readability and to allow
+non-printable characters to be entered, the 0t prefix is supported. This
+encoding is similar to binary encoding, except backslashes are specially
+treated, and a backslash followed by three octal digits can be used to encode
+any ASCII character, which obviously can be used to encode non-printable values.
+The following four command lines are equivalent, and will add the extended
+attribute "user.comment" to all files:
+
+mksquashfs dir image.sqfs -xattrs-add "user.comment=hello world"
+mksquashfs dir image.sqfs -xattrs-add "user.comment=0saGVsbG8gd29ybGQ="
+mksquashfs dir image.sqfs -xattrs-add "user.comment=0x68656c6c6f20776f726c64"
+mksquashfs dir image.sqfs -xattrs-add "user.comment=0thello world"
+
+Obviously in the above example there are no non-printable characters and so
+the 0t prefixed string is identical to the first line. The following three
+command lines are identical, but where the space has been replaced by the
+non-printable NUL '\0' (null character):
+
+mksquashfs dir image.sqfs -xattrs-add "user.comment=0thello\000world"
+mksquashfs dir image.sqfs -xattrs-add "user.comment=0saGVsbG8Ad29ybGQ="
+mksquashfs dir image.sqfs -xattrs-add "user.comment=0x68656c6c6f00776f726c64"
+
+The following will add an extended attribute to the file named "Hello_World"
+using the Pseudo file "x" definition.
+
+% mksquashfs dir image.sqsh -p "Hello_Word x user.comment=Hello_World"
+
+Again, as above, the following are equivalent:
+
+% mksquashfs dir image.sqfs -p "Hello_World x user.comment=0thello\000world"
+% mksquashfs dir image.sqfs -p "Hello_World x user.comment=0saGVsbG8Ad29ybGQ="
+% mksquashfs dir image.sqfs -p "Hello_World x user.comment=0x68656c6c6f00776f726c64"
+
+3.2 Filtering and adding extended attributes using Actions
+----------------------------------------------------------
+
+Finally Mksquashfs allows extended attributes to be filtered and added to files
+using the xattrs-exclude, xattrs-include and xattrs-add actions.
+
+xattrs-exclude(regex), this action excludes any extended attributes matching
+the regular expression, for any file matching the action tests.
+
+xattrs-include(regex), this action includes any extended attributes matching
+the regular expression, for any file matching the action tests.
+
+xattrs-add(name=val), this action will add the extended attribute <name>
+with contents <val>, to any file matching the action tests.
+
+Examples:
+
+% mksquashfs dir image.sqfs -action "xattrs-exclude(^user.)@true"
+
+This will exclude all extended attributes in the User namespace for all
+files (true matches on everything). It is directly equivalent to
+-xattrs-exclude(^user.).
+
+% mksquashfs dir image.sqfs -action "xattrs-exclude(^user.)@type(f)"
+
+This will exclude all extended attributes in the User namespace but only for
+regular files.
+
+% mksquashfs dir image.sqfs -action "xattrs-include(^user.)@user(phillip)&&type(f)"
+
+Likewise this will include only extended attributes in the User namespace, but
+it will only be applied to regular files owned by user Phillip.
+
+% mksquashfs dir image.sqsh -action "xattrs-add(user.comment=Hello_World)@name(hello*)"
+
+This will add the extended attribute "user.comment" to any file named "hello*".
+
+The following two commands are equivalent:
+
+% mksquashfs dir image.sqsh -action "xattrs-add(user.comment=Hello_World)@pathname(Hello_World)"
+% mksquashfs dir image.sqsh -p "Hello_Word x user.comment=Hello_World"
+
+
+4. Squashfs filesystems conversion (piping Unsquashfs output to Mksquashfs)
+---------------------------------------------------------------------------
+
+Sometimes you have an existing Squashfs filesystem which you want to
+regenerate using a different set of compression options, such as compression
+algorithm, block-size, tail-packing etc. Or you want to modify some parts of
+the filesystem such as excluding files, change ownership etc.
+
+Obviously you have been able to mount the Squashfs filesystem and regenerate
+the filesystem by running Mksquashfs on the mounted directory. But, this
+requires root access (which sometimes isn't available). The only other
+alternative until now has been to extract the Squashfs filesystem to an
+intermediate uncompressed directory, and then regenerate the filesystem by
+running Mksquashfs on that. This, however, is slow and requires storage to
+store the uncompressed filesystem.
+
+Unsquashfs can now output a Pseudo file representing the input filesystem
+to stdout, and Mksquashfs can now read a Pseudo file from stdin. This allows
+the output of Unsquashfs to be piped to Mksquashfs.
+
+Some examples follow.
+
+If you had a GZIP filesystem and wanted to convert it to ZSTD, you can do:
+
+% unsquashfs -pf - image.sqsh | mksquashfs - new.sqsh -pf - -comp zstd
+
+If you wanted to change to XZ compression, increase to a 1 Mbyte block size, and
+use -tailend packing, you could do:
+
+% unsquashfs -pf - image.sqsh | mksquashfs - new.sqsh -pf - -comp xz -b 1M -tailends
+
+If you only want the directory "foobar" you can tell Unsquashfs to only
+extract that:
+
+% unsquashfs -pf - image.sqsh foobar | mksquashfs - new.sqsh -pf -
+
+If you had inadvertantly stored binary ".o" files, you can remove them by
+using the new "non-anchored" Unsquashfs exclude file functionality:
+
+% unsquashfs -excludes -pf - image.sqsh "... *.o" | mksquashfs - new.sqsh -pf -
+
+If you want to update all the file timestamps to "now", and make every
+file owned by "phillip":
+
+% unsquashfs -pf - image.sqsh | mksquashfs - new.sqsh -all-time now -force-uid phillip -pf -
+
+5. AUTHOR INFO
+--------------
+
+Squashfs was written by Phillip Lougher, email phillip@squashfs.org.uk,
+in Chepstow, Wales, UK. If you like the program, or have any problems,
+then please email me, as it's nice to get feedback!