]> git.ipfire.org Git - thirdparty/util-linux.git/blame - misc-utils/blkid.8.adoc
Merge branch 'PR/libmount-utab-event' of github.com:karelzak/util-linux-work
[thirdparty/util-linux.git] / misc-utils / blkid.8.adoc
CommitLineData
295b3979 1//po4a: entry man manual
6c64d12d
MB
2// Copyright 2000 Andreas Dilger (adilger@turbolinux.com)
3// This file may be copied under the terms of the GNU Public License.
4= blkid(8)
5:doctype: manpage
6:man manual: System Administration
7:man source: util-linux {release-version}
8:page-layout: base
9:command: blkid
2c646c80 10:underscore: _
6c64d12d
MB
11
12== NAME
13
14blkid - locate/print block device attributes
15
16== SYNOPSIS
17
18*blkid* *--label* _label_ | *--uuid* _uuid_
19
89456be7 20*blkid* [*--no-encoding* *--garbage-collect* *--list-one* *--cache-file* _file_] [*--output* _format_] [*--match-tag* _tag_] [*--match-token* _NAME=value_] [_device_...]
6c64d12d
MB
21
22*blkid* *--probe* [*--offset* _offset_] [*--output* _format_] [*--size* _size_] [*--match-tag* _tag_] [*--match-types* _list_] [*--usages* _list_] [*--no-part-details*] _device_...
23
24*blkid* *--info* [*--output format*] [*--match-tag* _tag_] _device_...
25
26== DESCRIPTION
27
28The *blkid* program is the command-line interface to working with the *libblkid*(3) library. It can determine the type of content (e.g., filesystem or swap) that a block device holds, and also the attributes (tokens, NAME=value pairs) from the content metadata (e.g., LABEL or UUID fields).
29
30*It is recommended to use* *lsblk*(8) *command to get information about block devices, or lsblk --fs to get an overview of filesystems, or* *findmnt*(8) *to search in already mounted filesystems.*
31
32____
33*lsblk*(8) provides more information, better control on output formatting, easy to use in scripts and it does not require root permissions to get actual information. *blkid* reads information directly from devices and for non-root users it returns cached unverified information. *blkid* is mostly designed for system services and to test *libblkid*(3) functionality.
34____
35
36When _device_ is specified, tokens from only this device are displayed. It is possible to specify multiple _device_ arguments on the command line. If none is given, all partitions or unpartitioned devices which appear in _/proc/partitions_ are shown, if they are recognized.
37
38*blkid* has two main forms of operation: either searching for a device with a specific NAME=value pair, or displaying NAME=value pairs for one or more specified devices.
39
40For security reasons *blkid* silently ignores all devices where the probing result is ambivalent (multiple colliding filesystems are detected). The low-level probing mode (*-p*) provides more information and extra exit status in this case. It's recommended to use *wipefs*(8) to get a detailed overview and to erase obsolete stuff (magic strings) from the device.
41
42== OPTIONS
43
44The _size_ and _offset_ arguments may be followed by the multiplicative suffixes like KiB (=1024), MiB (=1024*1024), and so on for GiB, TiB, PiB, EiB, ZiB and YiB (the "iB" is optional, e.g., "K" has the same meaning as "KiB"), or the suffixes KB (=1000), MB (=1000*1000), and so on for GB, TB, PB, EB, ZB and YB.
45
46*-c*, *--cache-file* _cachefile_::
c83a52f0 47Read from _cachefile_ instead of reading from the default cache file (see the *CONFIGURATION FILE* section for more details). If you want to start with a clean cache (i.e., don't report devices previously scanned but not necessarily available at this time), specify _/dev/null_.
6c64d12d
MB
48
49*-d*, *--no-encoding*::
2c646c80 50Don't encode non-printing characters. The non-printing characters are encoded by ^ and M- notation by default. Note that the *--output udev* output format uses a different encoding which cannot be disabled.
6c64d12d
MB
51
52*-D*, *--no-part-details*::
2c646c80 53Don't print information (PART_ENTRY_* tags) from partition table in low-level probing mode.
6c64d12d
MB
54
55*-g*, *--garbage-collect*::
2c646c80 56Perform a garbage collection pass on the blkid cache to remove devices which no longer exist.
6c64d12d 57
27c4353b 58*-H*, *--hint* _setting_::
4a3e0a1b 59Set probing hint. The hints are an optional way to force probing functions to
60check, for example, another location. The currently supported is
27c4353b
KZ
61"session_offset=_number_" to set session offset on multi-session UDF.
62
6c64d12d 63*-i*, *--info*::
2c646c80 64Display information about I/O Limits (aka I/O topology). The 'export' output format is automatically enabled. This option can be used together with the *--probe* option.
6c64d12d
MB
65
66*-k*, *--list-filesystems*::
2c646c80 67List all known filesystems and RAIDs and exit.
6c64d12d
MB
68
69*-l*, *--list-one*::
2c646c80
MB
70Look up only one device that matches the search parameter specified with the *--match-token* option. If there are multiple devices that match the specified search parameter, then the device with the highest priority is returned, and/or the first device found at a given priority (but see below note about udev). Device types in order of decreasing priority are: Device Mapper, EVMS, LVM, MD, and finally regular block devices. If this option is not specified, *blkid* will print all of the devices that match the search parameter.
71+
72This option forces *blkid* to use udev when used for LABEL or UUID tokens in *--match-token*. The goal is to provide output consistent with other utils (like *mount*(8), etc.) on systems where the same tag is used for multiple devices.
6c64d12d
MB
73
74*-L*, *--label* _label_::
2c646c80
MB
75Look up the device that uses this filesystem _label_; this is equal to **--list-one --output device --match-token LABEL=**__label__. This lookup method is able to reliably use /dev/disk/by-label udev symlinks (dependent on a setting in _/etc/blkid.conf_). Avoid using the symlinks directly; it is not reliable to use the symlinks without verification. The *--label* option works on systems with and without udev.
76+
77Unfortunately, the original *blkid*(8) from e2fsprogs uses the *-L* option as a synonym for *-o list*. For better portability, use **-l -o device -t LABEL=**__label__ and *-o list* in your scripts rather than the *-L* option.
6c64d12d
MB
78
79*-n*, *--match-types* _list_::
2c646c80
MB
80Restrict the probing functions to the specified (comma-separated) _list_ of superblock types (names). The list items may be prefixed with "no" to specify the types which should be ignored. For example:
81+
82*blkid --probe --match-types vfat,ext3,ext4 /dev/sda1*
83+
84probes for vfat, ext3 and ext4 filesystems, and
85+
86*blkid --probe --match-types nominix /dev/sda1*
87+
88probes for all supported formats except minix filesystems. This option is only useful together with *--probe*.
6c64d12d
MB
89
90*-o*, *--output* _format_::
2c646c80
MB
91Use the specified output format. Note that the order of variables and devices is not fixed. See also option *-s*. The _format_ parameter may be:
92+
93*full*;;
94print all tags (the default)
95*value*;;
96print the value of the tags
97*list*;;
98print the devices in a user-friendly format; this output format is unsupported for low-level probing (*--probe* or *--info*).
99+
100This output format is *DEPRECATED* in favour of the *lsblk*(8) command.
101*device*;;
102print the device name only; this output format is always enabled for the *--label* and *--uuid* options
103*udev*;;
104//TRANSLATORS: Please keep {underscore} untranslated.
105print key="value" pairs for easy import into the udev environment; the keys are prefixed by ID_FS_ or ID_PART_ prefixes. The value may be modified to be safe for udev environment; allowed is plain ASCII, hex-escaping and valid UTF-8, everything else (including whitespaces) is replaced with '{underscore}'. The keys with __ENC_ postfix use hex-escaping for unsafe chars.
106+
107The udev output returns the ID_FS_AMBIVALENT tag if more superblocks are detected, and ID_PART_ENTRY_* tags are always returned for all partitions including empty partitions.
108+
109This output format is *DEPRECATED*.
110*export*;;
111print key=value pairs for easy import into the environment; this output format is automatically enabled when I/O Limits (*--info* option) are requested.
112+
113The non-printing characters are encoded by ^ and M- notation and all potentially unsafe characters are escaped.
6c64d12d
MB
114
115*-O*, *--offset* _offset_::
2c646c80 116Probe at the given _offset_ (only useful with *--probe*). This option can be used together with the *--info* option.
6c64d12d
MB
117
118*-p*, *--probe*::
2c646c80
MB
119Switch to low-level superblock probing mode (bypassing the cache).
120+
121Note that low-level probing also returns information about partition table type (PTTYPE tag) and partitions (PART_ENTRY_* tags). The tag names produced by low-level probing are based on names used internally by libblkid and it may be different than when executed without *--probe* (for example PART_ENTRY_UUID= vs PARTUUID=). See also *--no-part-details*.
6c64d12d
MB
122
123*-s*, *--match-tag* _tag_::
2c646c80 124For each (specified) device, show only the tags that match _tag_. It is possible to specify multiple *--match-tag* options. If no tag is specified, then all tokens are shown for all (specified) devices. In order to just refresh the cache without showing any tokens, use *--match-tag none* with no other options.
6c64d12d
MB
125
126*-S*, *--size* _size_::
2c646c80 127Override the size of device/file (only useful with *--probe*).
6c64d12d
MB
128
129*-t*, *--match-token* _NAME=value_::
2c646c80 130Search for block devices with tokens named _NAME_ that have the value _value_, and display any devices which are found. Common values for _NAME_ include *TYPE*, *LABEL*, and *UUID*. If there are no devices specified on the command line, all block devices will be searched; otherwise only the specified devices are searched.
6c64d12d
MB
131
132*-u*, *--usages* _list_::
2c646c80
MB
133Restrict the probing functions to the specified (comma-separated) _list_ of "usage" types. Supported usage types are: filesystem, raid, crypto and other. The list items may be prefixed with "no" to specify the usage types which should be ignored. For example:
134+
135*blkid --probe --usages filesystem,other /dev/sda1*
136+
137probes for all filesystem and other (e.g., swap) formats, and
138+
139*blkid --probe --usages noraid /dev/sda1*
140+
141probes for all supported formats except RAIDs. This option is only useful together with *--probe*.
6c64d12d
MB
142
143*-U*, *--uuid* _uuid_::
2c646c80 144Look up the device that uses this filesystem _uuid_. For more details see the *--label* option.
6c64d12d 145
2b2d3172 146include::man-common/help-version.adoc[]
6c64d12d
MB
147
148== EXIT STATUS
149
150If the specified device or device addressed by specified token (option *--match-token*) was found and it's possible to gather any information about the device, an exit status 0 is returned. Note the option *--match-tag* filters output tags, but it does not affect exit status.
151
152If the specified token was not found, or no (specified) devices could be identified, or it is impossible to gather any information about the device identifiers or device content an exit status of 2 is returned.
153
154For usage or other errors, an exit status of 4 is returned.
155
156If an ambivalent probing result was detected by low-level probing mode (*-p*), an exit status of 8 is returned.
157
158== CONFIGURATION FILE
159
e6743239 160The standard location of the _/etc/blkid.conf_ config file can be overridden by the environment variable *BLKID_CONF*. The following options control the libblkid library:
6c64d12d
MB
161
162_SEND_UEVENT=<yes|not>_::
2c646c80 163Sends uevent when _/dev/disk/by-{label,uuid,partuuid,partlabel}/_ symlink does not match with LABEL, UUID, PARTUUID or PARTLABEL on the device. Default is "yes".
6c64d12d
MB
164
165_CACHE_FILE=<path>_::
2c646c80 166Overrides the standard location of the cache file. This setting can be overridden by the environment variable *BLKID_FILE*. Default is _/run/blkid/blkid.tab_, or _/etc/blkid.tab_ on systems without a _/run_ directory.
6c64d12d
MB
167
168_EVALUATE=<methods>_::
2c646c80 169Defines LABEL and UUID evaluation method(s). Currently, the libblkid library supports the "udev" and "scan" methods. More than one method may be specified in a comma-separated list. Default is "udev,scan". The "udev" method uses udev _/dev/disk/by-*_ symlinks and the "scan" method scans all block devices from the _/proc/partitions_ file.
6c64d12d
MB
170
171== ENVIRONMENT
172
173Setting _LIBBLKID_DEBUG=all_ enables debug output.
174
175== AUTHORS
176
177*blkid* was written by Andreas Dilger for libblkid and improved by Theodore Ts'o and Karel Zak.
178
179== SEE ALSO
180
181*libblkid*(3),
182*findfs*(8),
183*lsblk*(8),
184*wipefs*(8)
185
625e9c61 186include::man-common/bugreports.adoc[]
6c64d12d 187
625e9c61 188include::man-common/footer.adoc[]
6c64d12d
MB
189
190ifdef::translation[]
625e9c61 191include::man-common/translation.adoc[]
6c64d12d 192endif::[]