FreeBSD manual

download PDF document: geom_uzip.4.pdf

GEOM_UZIP(4) FreeBSD Kernel Interfaces Manual GEOM_UZIP(4)
NAME geom_uzip - GEOM based compressed disk images and partitions
SYNOPSIS To compile this driver into the kernel, place the following line in your kernel configuration file:
device xz options zstd options GEOM_UZIP
Alternatively, to load the driver as a module at boot time, place the following line in loader.conf(5):
geom_uzip_load="YES"
DESCRIPTION The geom_uzip framework provides support for compressed read-only disk images. This allows significant storage savings at the expense of some CPU time on each read. Data written in the GEOM label area allows geom_uzip to detect compressed images which have been created with mkuzip(8) and presented to the kernel as a logical disk device via md(4). geom_uzip creates a unique md#.uzip device for each image.
geom_uzip is not limited to supporting only md(4) images. The image can also reside on a block device. (For example, a disk, USB flash drive, DVD-ROM, etc). The appropriate device node will appear with the .uzip suffix.
# gpart show da0 => 0 7833600 da0 BSD (3.7G) 0 2097152 1 freebsd-ufs (1.0G) 2097152 5736448 - free - (2.7G) # gpart add -t freebsd-ufs -s 1G da0 da0b added # dd if=/tmp/20160217_dcomp_zcomp.uzip bs=256k of=/dev/da0b 3190+1 records in 3190+1 records out 836331008 bytes transferred in 111.021489 secs (7533055 bytes/sec) # fsck -t ffs /dev/da0b.uzip ** /dev/da0b.uzip (NO WRITE) ** Last Mounted on /mnt ** Phase 1 - Check Blocks and Sizes ** Phase 2 - Check Pathnames ** Phase 3 - Check Connectivity ** Phase 4 - Check Reference Counts ** Phase 5 - Check Cyl groups 97455 files, 604242 used, 184741 free (2349 frags, 22799 blocks, 0.3% fragmentation) # mount -o ro /dev/da0b.uzip /mnt # df /dev/da0b.uzip Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/da0b.uzip 3155932 2416968 738964 77% /mnt
The geom_uzip device is subsequently used by FreeBSD kernel to access the uncompressed data. The geom_uzip driver does not allow write operations to the underlying disk image. To check which "providers" match a given Sectorsize: 512 Consumers: 1. Name: md1 Mediasize: 9563648 (9.1M) Sectorsize: 512
Geom name: da0b.uzip Providers: 1. Name: da0b.uzip Mediasize: 3355443200 (3.1G) Sectorsize: 512 Consumers: 1. Name: da0b Mediasize: 1073741824 (1.0G) Sectorsize: 512
geom_uzip allows mounting the root file system from a compressed disk partition by setting the vfs.root.mountfrom tunable. See loader.conf(5) for details.
DIAGNOSTICS Several flags are provided for tracing geom_uzip I/O operations and TOC parsing via the following sysctls.
kern.geom.uzip.debug Log level. Zero disables logging. Higher values enable more verbose debug logging for geom_uzip. Supported levels are from 0 (no logging) to 4 (maximum amount of logging).
kern.geom.uzip.debug_block Log operations involving compressed cluster number.
SEE ALSO GEOM(4), md(4), geom(8), mkuzip(8)
HISTORY Zstd support was added in FreeBSD 13.0.
AUTHORS The geom_uzip driver was written by Max Khon <fjoe@FreeBSD.org>. The block de-duplication code as well as some geom_uzip driver optimizations have been contributed by Maxim Sobolev <sobomax@FreeBSD.org>. The LZMA decompression support and CLOOP 3.0 support have been added by Aleksandr Rybalko <ray@FreeBSD.org>.
This manual page was written by Ceri Davies <ceri@FreeBSD.org>.
FreeBSD 14.0-RELEASE-p11 April 28, 2021 FreeBSD 14.0-RELEASE-p11