mksquashfs - tool to create and append to squashfs filesystems
mksquashfs source1 source2 ... FILESYSTEM
[OPTIONS] [-e list of exclude dirs/files]
Squashfs is a highly compressed read-only filesystem for Linux. It
uses either gzip/xz/lzo/lz4/zstd compression to compress both files, inodes
and directories. Inodes in the system are very small and all blocks are
packed to minimise data overhead. Block sizes greater than 4K are supported
up to a maximum of 1Mbytes (default block size 128K).
Squashfs is intended for general read-only filesystem use, for
archival use (i.e. in cases where a .tar.gz file may be used), and in
constrained block device/memory systems (e.g. embedded systems) where low
overhead is needed.
- -b BLOCK_SIZE
- set data block to BLOCK_SIZE. Default 128 Kbytes. Optionally a suffix of K
or M can be given to specify Kbytes or Mbytes respectively.
- -comp COMP
- select COMP compression. Compressors available: gzip (default), lzo, lz4,
xz, zstd, lzma.
- -noI
- do not compress inode table.
- -noId
- do not compress the uid/gid table (implied by -noI).
- -noD
- do not compress data blocks.
- -noF
- do not compress fragment blocks.
- -noX
- do not compress extended attributes.
- -no-compression
- do not compress any of the data or metadata. This is equivalent to
specifying -noI -noD -noF and -noX.
- -tar
- read uncompressed tar file from standard in (stdin).
- -no-strip
- act like tar, and do not strip leading directories from source files.
- -tarstyle
- alternative name for -no-strip.
- -cpiostyle
- act like cpio, and read file pathnames from standard in (stdin).
- -cpiostyle0
- like -cpiostyle, but filenames are null terminated. Can be used
with find -print0 action.
- -reproducible
- build filesystems that are reproducible (default).
- -not-reproducible
- build filesystems that are not reproducible.
- -mkfs-time
TIME
- set filesystem creation timestamp to TIME. TIME can be an unsigned 32-bit
int indicating seconds since the epoch (1970-01-01) or a string value
which is passed to the "date" command to parse. Any string value
which the date command recognises can be used such as "now",
"last week", or "Wed Feb 15 21:02:39 GMT 2023".
- -all-time TIME
- set all file timestamps to TIME. TIME can be an unsigned 32-bit int
indicating seconds since the epoch (1970-01-01) or a string value which is
passed to the "date" command to parse. Any string value which
the date command recognises can be used such as "now",
"last week", or "Wed Feb 15 21:02:39 GMT 2023".
- -root-time
TIME
- set root directory time to TIME. TIME can be an unsigned 32-bit int
indicating seconds since the epoch (1970-01-01) or a string value which is
passed to the "date" command to parse. Any string value which
the date command recognises can be used such as "now",
"last week", or "Wed Feb 15 21:02:39 GMT 2023".
- -root-mode
MODE
- set root directory permissions to octal MODE.
- -root-uid
VALUE
- set root directory owner to specified VALUE, VALUE can be either an
integer uid or user name.
- -root-gid
VALUE
- set root directory group to specified VALUE, VALUE can be either an
integer gid or group name.
- -all-root
- make all files owned by root.
- -force-uid
VALUE
- set all file uids to specified VALUE, VALUE can be either an integer uid
or user name.
- -force-gid
VALUE
- set all file gids to specified VALUE, VALUE can be either an integer gid
or group name.
- -pseudo-override
- make pseudo file uids and gids override -all-root,
-force-uid and -force-gid options.
- -no-exports
- do not make filesystem exportable via NFS (-tar default).
- -exports
- make filesystem exportable via NFS (default).
- -no-sparse
- do not detect sparse files.
- -no-tailends
- do not pack tail ends into fragments (default).
- -tailends
- pack tail ends into fragments.
- -no-fragments
- do not use fragments.
- -no-duplicates
- do not perform duplicate checking.
- -no-hardlinks
- do not hardlink files, instead store duplicates.
- -keep-as-directory
- if one source directory is specified, create a root directory containing
that directory, rather than the contents of the directory.
- -p PSEUDO-DEFINITION
- add pseudo file definition. The definition should be quoted.
- -pf PSEUDO-FILE
- add list of pseudo file definitions from PSEUDO-FILE, use - for stdin.
Pseudo file definitions should not be quoted.
- -sort
SORT_FILE
- sort files according to priorities in SORT_FILE. One file or dir with
priority per line. Priority -32768 to 32767, default priority
0.
- -ef EXCLUDE_FILE
- list of exclude dirs/files. One per line.
- -wildcards
- allow extended shell wildcards (globbing) to be used in exclude
dirs/files.
- -regex
- allow POSIX regular expressions to be used in exclude dirs/files.
- -max-depth
LEVELS
- descend at most LEVELS of directories when scanning filesystem.
- -one-file-system
- do not cross filesystem boundaries. If a directory crosses the boundary,
create an empty directory for each mount point. If a file crosses the
boundary ignore it.
- -one-file-system-x
- do not cross filesystem boundaries. Like -one-file-system option
except directories are also ignored if they cross the boundary.
- -no-xattrs
- do not store extended attributes.
- -xattrs
- store extended attributes (default).
- -xattrs-exclude
REGEX
- exclude any xattr names matching REGEX. REGEX is a POSIX regular
expression, e.g. -xattrs-exclude '^user.' excludes xattrs from the
user namespace.
- -xattrs-include
REGEX
- include any xattr names matching REGEX. REGEX is a POSIX regular
expression, e.g. -xattrs-include '^user.' includes xattrs from the
user namespace.
- -xattrs-add
NAME=VAL
- add the xattr NAME with VAL to files. If an user xattr it will be added to
regular files and directories (see man 7 xattr). Otherwise it will be
added to all files. VAL 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 val will be
treated as hexidecimal. Additionally it can be prefixed with 0t where this
encoding is similar to binary encoding, except backslashes are specially
treated, and a backslash followed by 3 octal digits can be used to encode
any ASCII character, which obviously can be used to encode control codes.
The option can be repeated multiple times to add multiple xattrs.
- -version
- print version, licence and copyright message.
- -exit-on-error
- treat normally ignored errors as fatal.
- -quiet
- no verbose output.
- -info
- print files written to filesystem.
- -no-progress
- do not display the progress bar.
- -progress
- display progress bar when using the -info option.
- -percentage
- display a percentage rather than the full progress bar. Can be used with
dialog --gauge etc.
- -throttle
PERCENTAGE
- throttle the I/O input rate by the given percentage. This can be used to
reduce the I/O and CPU consumption of Mksquashfs.
- -limit
PERCENTAGE
- limit the I/O input rate to the given percentage. This can be used to
reduce the I/O and CPU consumption of Mksquashfs (alternative to
-throttle).
- -processors
NUMBER
- use NUMBER processors. By default will use number of processors
available.
- -mem SIZE
- use SIZE physical memory for caches. Use K, M or G to specify Kbytes,
Mbytes or Gbytes respectively.
- -mem-percent
PERCENT
- use PERCENT physical memory for caches. Default 25%.
- -mem-default
- print default memory usage in Mbytes.
- -noappend
- do not append to existing filesystem.
- -root-becomes
NAME
- when appending source files/directories, make the original root become a
subdirectory in the new root called NAME, rather than adding the new
source items to the original root.
- -no-recovery
- do not generate a recovery file.
- -recovery-path
NAME
- use NAME as the directory to store the recovery file.
- -recover
NAME
- recover filesystem data using recovery file NAME.
- -default-mode
MODE
- tar files often do not store permissions for intermediate directories.
This option sets the default directory permissions to octal MODE, rather
than 0755. This also sets the root inode mode.
- -default-uid
UID
- tar files often do not store uids for intermediate directories. This
option sets the default directory owner to UID, rather than the user
running Mksquashfs. This also sets the root inode uid.
- -default-gid
GID
- tar files often do not store gids for intermediate directories. This
option sets the default directory group to GID, rather than the group of
the user running Mksquashfs. This also sets the root inode gid.
- -ignore-zeros
- allow tar files to be concatenated together and fed to Mksquashfs.
Normally a tarfile has two consecutive 512 byte blocks filled with zeros
which means EOF and Mksquashfs will stop reading after the first tar file
on encountering them. This option makes Mksquashfs ignore the zero filled
blocks.
- -nopad
- do not pad filesystem to a multiple of 4K.
- -offset
OFFSET
- skip OFFSET bytes at the beginning of FILESYSTEM. Optionally a suffix of
K, M or G can be given to specify Kbytes, Mbytes or Gbytes respectively.
Default 0 bytes.
- -o OFFSET
- synonym for -offset.
- -Xhc
- Compress using LZ4 High Compression.
- -Xbcj
filter1,filter2,...,filterN
- Compress using filter1,filter2,...,filterN in turn (in addition to no
filter), and choose the best compression. Available filters: x86, arm,
armthumb, powerpc, sparc, ia64.
- -Xdict-size
DICT-SIZE
- Use DICT-SIZE as the XZ dictionary size. The dictionary size can be
specified as a percentage of the block size, or as an absolute value. The
dictionary size must be less than or equal to the block size and 8192
bytes or larger. It must also be storable in the xz header as either 2^n
or as 2^n+2^(n+1). Example dict-sizes are 75%, 50%, 37.5%, 25%, or 32K,
16K, 8K etc.
- (no options) (deprecated - no kernel support)
- SOURCE_DATE_EPOCH
- If set, this is used as the filesystem creation timestamp. Also any file
timestamps which are after SOURCE_DATE_EPOCH will be clamped to
SOURCE_DATE_EPOCH. See
https://reproducible-builds.org/docs/source-date-epoch/ for more
information.
- mksquashfs
DIRECTORY IMAGE.SQFS
- Create a Squashfs filesystem from the contents of DIRECTORY, writing the
output to IMAGE.SQSH. Mksquashfs will use the default compressor (normally
gzip), and block size of 128 Kbytes.
- mksquashfs
DIRECTORY FILE1 FILE2 IMAGE.SQFS
- Create a Squashfs filesystem containing DIRECTORY and FILE1 and FILE2. If
multiple sources are specified on the command line they will be combined
into a single directory.
- mksquashfs
DIRECTORY IMAGE.SQFS -b 1M -comp zstd
- Use a block size of 1 Mbyte and Zstandard compression to create the
filesystem.
- mksquashfs
DIRECTORY IMAGE.SQFS -e file1 file2
- Exclude file1 and file2 from DIRECTORY when creating filesystem. No
wildcard matching of files.
- mksquashfs
DIRECTORY IMAGE.SQFS -wildcards -e "*.gz"
- Exclude anything in DIRECTORY which matches the wildcard pattern
"*.gz".
- mksquashfs
DIRECTORY IMAGE.SQFS -wildcards -e "... *.gz"
- Exclude files which match the wildcard pattern "*.gz" anywhere
within DIRECTORY and its sub-directories. The initial "..."
indicates the wildcard pattern is "non-anchored" and will match
anywhere.
Note: when passing wildcarded names to Mksquashfs, they should be
quoted (as in the above examples), to ensure that they are not processed by
the shell.
- mksquashfs
DIRECTORY IMAGE.SQFS -p "build_dir d 0644 0 0"
- Create a directory called "build_dir" in the output
filesystem.
- mksquashfs
DIRECTORY IMAGE.SQFS -p "version.txt l
/tmp/build/version"
- Create a reference called "version.txt" to a file outside
DIRECTORY, which acts as if the file "/tmp/build/version" was
copied or hard-linked into DIRECTORY before calling Mksquashfs.
- mksquashfs
DIRECTORY IMAGE.SQFS -p "date.txt f 0644 0 0 date"
- Create a file called "date.txt" which holds the output (stdout)
from running the "date" command.
- mksquashfs
DIRECTORY IMAGE.SQFS -p "\"hello world\" f 0644 0 0
date"
- As above, but, showing that filenames can have spaces, if they are quoted.
The quotes need to be blackslashed to protect them from the shell.
- mksquashfs -
IMAGE.SQFS -p "input f 0644 root root dd if=/dev/sda1 bs=1024" -p
"/ d 0644 0 0"
- Create a file containing the contents of partition /dev/sda1".
Ordinarily Mksquashfs given a device, fifo, or named socket will place
that special file within the Squashfs filesystem, the above allows input
from these special files to be captured and placed in the Squashfs
filesystem. Note there are no other sources than the pseudo file, and so
the command line source is "-". If there are no other sources
than pseudo files, the root (/) directory must be defined too, as seen in
this example.
- unsquashfs -pf -
IMAGE.SQFS | mksquashfs - NEW.SQFS -pf -
- Transcode IMAGE.SQFS to NEW.SQFS by piping the pseudo file output from
Unsquashfs to Mksquashfs using stdout and stdin. This can convert from
earlier Squashfs filesystems or change compression algorithm, block size
etc. without needing to unpack into an intermediate directory or
file.
Note: pseudo file definitions should be quoted (as in the above
examples), to ensure that they are passed to Mksquashfs as a single
argument, and to ensure that they are not processed by the shell.
- mksquashfs
DIRECTORY IMAGE.SQSH -action "uncompressed @ (name(*.jpg) ||
name(*.mpg) ) || (name(*.img) && filesize(+1G))"
- Specify that any files matching the wildcards "*.jpg" and
"*.mpg" should not be compressed. Additionally, it also
specifies any files matching the wildcard "*.img" and are larger
than 1 Gigabyte should be uncompressed too. This shows test operators can
be combined with logical expressions.
- mksquashfs
DIRECTORY IMAGE.SQSH -action "chmod(o+r)@! perm(o+r)"
- If any files within DIRECTORY are not readable by "others", then
make them readable by others in the Squashfs filesystem.
- mksquashfs
DIRECTORY IMAGE.SQSH -action "uid(phillip)@! perm(o+r)"
- As previous, match on any files which are not readable by
"others", but, in this case change the owner of the file to
"phillip" in the Squashfs filesystem.
- mksquashfs
DIRECTORY IMAGE.SQSH -action "prune @ type(l) && !
exists"
- Delete any symbolic link within DIRECTORY which points outside of
DIRECTORY, i.e. will be unresolvable in the Squashfs filesystem.
- mksquashfs
DIRECTORY IMAGE.SQSH -action "exclude @ depth(3)"
- Create a Squashfs filesystem containing the two top most levels (contents
of DIRECTORY and immediate sub-directories), and exclude anything at level
3 or below.
- mksquashfs
DIRECTORY IMAGE.SQFS -action "-xattrs-include(^user.) @
type(f)"
- Filter the extended attributes but only in regular files (type f), and
only store extended attributes in the user namespace.
Note: actions should be quoted (as in the above examples), to
ensure that they are passed to Mksquashfs as a single argument, and to
ensure that they are not processed by the shell.
Written by Phillip Lougher <phillip@squashfs.org.uk>
Copyright © 2023 Phillip Lougher
<phillip@squashfs.org.uk>
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 2, 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.
unsquashfs(1), sqfstar(1), sqfscat(1)
The README for the Squashfs-tools 4.6.1 release, describing the
new features can be read here
https://github.com/plougher/squashfs-tools/blob/master/README-4.6.1
The Squashfs-tools USAGE guide can be read here
https://github.com/plougher/squashfs-tools/blob/master/USAGE-4.6
The ACTIONS-README file describing how to use the new actions
feature can be read here
https://github.com/plougher/squashfs-tools/blob/master/ACTIONS-README