LIBBLKID(3)LIBBLKID(3)NAMElibblkid - block device identification library
SYNOPSIS
#include <blkid/blkid.h>
cc file.c -lblkid
DESCRIPTION
The libblkid library is used to identify block devices (disks) as to
their content (e.g. filesystem type) as well as extracting additional
information such as filesystem labels/volume names, unique identi‐
fiers/serial numbers, etc. A common use is to allow use of LABEL= and
UUID= tags instead of hard-coding specific block device names into con‐
figuration files.
Block device information is normally kept in a cache file
/etc/blkid/blkid.tab and is verified to still be valid before being
returned to the user (if the user has read permission on the raw block
device, otherwise not). The cache file also allows unprivileged users
(normally anyone other than root, or those not in the "disk" group) to
locate devices by label/id. The standard location of the cache file
can be overridden by the environment variable BLKID_FILE.
In situations where one is getting information about a single known
device, it does not impact performance whether the cache is used or not
(unless you are not able to read the block device directly). If you
are dealing with multiple devices, use of the cache is highly recom‐
mended (even if empty) as devices will be scanned at most one time and
the on-disk cache will be updated if possible. There is rarely a rea‐
son not to use the cache.
In some cases (modular kernels), block devices are not even visible
until after they are accessed the first time, so it is critical that
there is some way to locate these devices without enumerating only vis‐
ible devices, so the use of the cache file is required in this situa‐
tion.
CONFIGURATION FILE
The standard location of the /etc/blkid.conf config file can be over‐
ridden by the environment variable BLKID_CONF. The following options
control the libblkid library:
SEND_UEVENT=<yes|not>
Sends uevent when /dev/disk/by-{label,uuid}/ symlink does not
match with LABEL or UUID on the device. Default is "yes".
CACHE_FILE=<path>
Overrides the standard location of the cache file. This setting
can be overridden by the environment variable BLKID_FILE.
Default is /etc/blkid/blkid.tab.
EVALUATE=<methods>
Defines LABEL and UUID evaluation method(s). Currently, the lib‐
blkid library supports "udev" and "scan" methods. More than one
methods 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.
AUTHORlibblkid was written by Andreas Dilger for the ext2 filesystem util‐
ties, with input from Ted Ts'o. The library was subsequently heavily
modified by Ted Ts'o.
The low-level probing code was rewritten by Karel Zak.
FILES
/etc/blkid/blkid.tab
caches data extracted from each recognized block
device
/etc/blkid.conf configuration file
AVAILABILITYlibblkid is part of the util-linux-ng package since version 2.15 and is
available from ftp://ftp.kernel.org/pub/linux/utils/util-linux-ng/.
COPYINGlibblkid is available under the terms of the GNU Library General Public
License (LGPL), version 2 (or at your discretion any later version). A
copy of the LGPL should be included with this library in the file COPY‐
ING. If not, write to
Free Software Foundation, Inc.
51 Franklin St
Fifth Floor
Boston, MA 02110-1301 USA
or visit http://www.gnu.org/licenses/licenses.html#LGPL
⟨http://www.gnu.org/licenses/licenses.html#LGPL⟩
SEE ALSOblkid(8)findfs(8)util-linux-ng May 2009 LIBBLKID(3)