diff --git a/agetty-replace-perms-660-to-620.patch b/agetty-replace-perms-660-to-620.patch deleted file mode 100644 index ebf59b7..0000000 --- a/agetty-replace-perms-660-to-620.patch +++ /dev/null @@ -1,45 +0,0 @@ -From 7afbf6f20e1de62fb5595411d998703c95af8965 Mon Sep 17 00:00:00 2001 -From: Karel Zak -Date: Wed, 2 Jan 2013 08:23:00 +0100 -Subject: [PATCH 1/3] agetty: replace perms 660 to 620 - - ... the default is root:tty 620 - -Signed-off-by: Karel Zak ---- - login-utils/login.1 | 5 ++++- - term-utils/agetty.c | 2 +- - 2 files changed, 5 insertions(+), 2 deletions(-) - -diff --git a/login-utils/login.1 b/login-utils/login.1 -index 092213d..e37e5e6 100644 ---- a/login-utils/login.1 -+++ b/login-utils/login.1 -@@ -184,7 +184,10 @@ login failure. The default value is - (string) - .RS 4 - The terminal permissions. The default value is --.IR 0600 . -+.IR 0600 -+or -+.IR 0620 -+if tty group is used. - .RE - .PP - .B TTYGROUP -diff --git a/term-utils/agetty.c b/term-utils/agetty.c -index 7ee252d..17ebfba 100644 ---- a/term-utils/agetty.c -+++ b/term-utils/agetty.c -@@ -894,7 +894,7 @@ static void open_tty(char *tty, struct termios *tp, struct options *op) - * Linux login(1) will change tty permissions. Use root owner and group - * with permission -rw------- for the period between getty and login. - */ -- if (chown(buf, 0, gid) || chmod(buf, (gid ? 0660 : 0600))) { -+ if (chown(buf, 0, gid) || chmod(buf, (gid ? 0620 : 0600))) { - if (errno == EROFS) - log_warn("%s: %m", buf); - else --- -1.8.1 - diff --git a/cal-don-t-mix-ncurses-output-functions-and-printf.patch b/cal-don-t-mix-ncurses-output-functions-and-printf.patch deleted file mode 100644 index 1641068..0000000 --- a/cal-don-t-mix-ncurses-output-functions-and-printf.patch +++ /dev/null @@ -1,139 +0,0 @@ -From c265cc40a8ece740084fbfb3ebd4c1894b3b29b7 Mon Sep 17 00:00:00 2001 -From: Karel Zak -Date: Thu, 17 Jan 2013 18:48:16 +0100 -Subject: [PATCH 3/3] cal: don't mix ncurses output functions and printf() - -Fedora 18 (ncurses-libs-5.9-7.20121017, glibc-2.16-28): - -$ cal | cat -Actual results: - January 2013 Su Mo Tu We Th Fr Sa 1 2 3 4 5 6 7 8 -9 10 11 1213 14 15 16 17 18 1920 21 22 23 24 25 2627 28 29 30 31 - -Not sure where is the problem, but it's too fragile to mix two -output methods in one code. - -Addresses: https://bugzilla.redhat.com/show_bug.cgi?id=896447 -Signed-off-by: Karel Zak ---- - misc-utils/cal.c | 43 +++++++++++++++++++++++++++---------------- - 1 file changed, 27 insertions(+), 16 deletions(-) - -diff --git a/misc-utils/cal.c b/misc-utils/cal.c -index 60e85df..0e204b9 100644 ---- a/misc-utils/cal.c -+++ b/misc-utils/cal.c -@@ -498,7 +498,7 @@ monthly(int day, int month, int year) { - do_monthly(day, month, year, &out); - for (i = 0; i < FMT_ST_LINES; i++) { - my_putstring(out.s[i]); -- putchar('\n'); -+ my_putstring("\n"); - } - } - -@@ -533,8 +533,11 @@ monthly3(int day, int month, int year) { - do_monthly(day, next_month, next_year, &out_next); - - width = (julian ? J_WEEK_LEN : WEEK_LEN) -1; -- for (i = 0; i < 2; i++) -- printf("%s %s %s\n", out_prev.s[i], out_curm.s[i], out_next.s[i]); -+ for (i = 0; i < 2; i++) { -+ snprintf(lineout, sizeof(lineout), -+ "%s %s %s\n", out_prev.s[i], out_curm.s[i], out_next.s[i]); -+ my_putstring(lineout); -+ } - for (i = 2; i < FMT_ST_LINES; i++) { - int w1, w2, w3; - w1 = w2 = w3 = width; -@@ -562,7 +565,7 @@ j_yearly(int day, int year) { - - snprintf(lineout, sizeof(lineout), "%d", year); - center(lineout, J_WEEK_LEN*2 + J_HEAD_SEP - 1, 0); -- printf("\n\n"); -+ my_putstring("\n\n"); - - for (i = 0; i < 12; i++) - day_array(day, i + 1, year, days[i]); -@@ -571,8 +574,10 @@ j_yearly(int day, int year) { - for (month = 0; month < 12; month += 2) { - center(full_month[month], J_WEEK_LEN-1, J_HEAD_SEP+1); - center(full_month[month + 1], J_WEEK_LEN-1, 0); -- printf("\n%s%*s %s\n", j_day_headings, J_HEAD_SEP, "", -- j_day_headings); -+ snprintf(lineout, sizeof(lineout), -+ "\n%s%*s %s\n", j_day_headings, J_HEAD_SEP, "", -+ j_day_headings); -+ my_putstring(lineout); - for (row = 0; row < 6; row++) { - p = lineout; - for (which_cal = 0; which_cal < 2; which_cal++) { -@@ -584,10 +589,10 @@ j_yearly(int day, int year) { - *p = '\0'; - trim_trailing_spaces(lineout); - my_putstring(lineout); -- putchar('\n'); -+ my_putstring("\n"); - } - } -- printf("\n"); -+ my_putstring("\n"); - } - - void -@@ -598,7 +603,7 @@ yearly(int day, int year) { - - snprintf(lineout, sizeof(lineout), "%d", year); - center(lineout, WEEK_LEN*3 + HEAD_SEP*2 - 1, 0); -- printf("\n\n"); -+ my_putstring("\n\n"); - - for (i = 0; i < 12; i++) - day_array(day, i + 1, year, days[i]); -@@ -608,8 +613,10 @@ yearly(int day, int year) { - center(full_month[month], WEEK_LEN-1, HEAD_SEP+1); - center(full_month[month + 1], WEEK_LEN-1, HEAD_SEP+1); - center(full_month[month + 2], WEEK_LEN-1, 0); -- printf("\n%s%*s %s%*s %s\n", day_headings, HEAD_SEP, -- "", day_headings, HEAD_SEP, "", day_headings); -+ snprintf(lineout, sizeof(lineout), -+ "\n%s%*s %s%*s %s\n", day_headings, HEAD_SEP, -+ "", day_headings, HEAD_SEP, "", day_headings); -+ my_putstring(lineout); - for (row = 0; row < 6; row++) { - p = lineout; - for (which_cal = 0; which_cal < 3; which_cal++) { -@@ -621,10 +628,10 @@ yearly(int day, int year) { - *p = '\0'; - trim_trailing_spaces(lineout); - my_putstring(lineout); -- putchar('\n'); -+ my_putstring("\n"); - } - } -- putchar('\n'); -+ my_putstring("\n"); - } - - /* -@@ -773,10 +780,14 @@ void - center(const char *str, size_t len, int separate) - { - char lineout[FMT_ST_CHARS]; -+ - center_str(str, lineout, ARRAY_SIZE(lineout), len); -- fputs(lineout, stdout); -- if (separate) -- printf("%*s", separate, ""); -+ my_putstring(lineout); -+ -+ if (separate) { -+ snprintf(lineout, sizeof(lineout), "%*s", separate, ""); -+ my_putstring(lineout); -+ } - } - - static void __attribute__ ((__noreturn__)) usage(FILE * out) --- -1.8.1 - diff --git a/hexdump-do-not-segfault-when-iterating-over-an-empty.patch b/hexdump-do-not-segfault-when-iterating-over-an-empty.patch deleted file mode 100644 index c9472bd..0000000 --- a/hexdump-do-not-segfault-when-iterating-over-an-empty.patch +++ /dev/null @@ -1,95 +0,0 @@ -From 85c24fe2b11cd136d43bbffd983014a3f967c25e Mon Sep 17 00:00:00 2001 -From: Ondrej Oprala -Date: Fri, 21 Dec 2012 13:04:04 +0100 -Subject: [PATCH 2/3] hexdump: do not segfault when iterating over an empty - format string - -Signed-off-by: Ondrej Oprala ---- - tests/commands.sh | 1 + - tests/expected/hexdump/empty-format | 1 + - tests/ts/hexdump/empty-format | 26 ++++++++++++++++++++++++++ - text-utils/parse.c | 16 +++++++++------- - 4 files changed, 37 insertions(+), 7 deletions(-) - create mode 100644 tests/expected/hexdump/empty-format - create mode 100755 tests/ts/hexdump/empty-format - -diff --git a/tests/commands.sh b/tests/commands.sh -index db1d4ac..3672095 100644 ---- a/tests/commands.sh -+++ b/tests/commands.sh -@@ -62,3 +62,4 @@ TS_CMD_FINDMNT=${TS_CMD_FINDMNT-"$top_builddir/findmnt"} - - TS_CMD_FDISK=${TS_CMD_FDISK-"$top_builddir/fdisk"} - -+TS_CMD_HEXDUMP=${TS_CMD_HEXDUMP-"$top_builddir/hexdump"} -diff --git a/tests/expected/hexdump/empty-format b/tests/expected/hexdump/empty-format -new file mode 100644 -index 0000000..9d60796 ---- /dev/null -+++ b/tests/expected/hexdump/empty-format -@@ -0,0 +1 @@ -+11 -\ No newline at end of file -diff --git a/tests/ts/hexdump/empty-format b/tests/ts/hexdump/empty-format -new file mode 100755 -index 0000000..4a3e528 ---- /dev/null -+++ b/tests/ts/hexdump/empty-format -@@ -0,0 +1,26 @@ -+#!/bin/bash -+ -+# This file is part of util-linux. -+# -+# This file 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 of the License, or -+# (at your option) any later version. -+# -+# This file 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. -+# -+TS_TOPDIR="$(dirname $0)/../.." -+TS_DESC="format-strings" -+ -+. $TS_TOPDIR/functions.sh -+ts_init "$*" -+ -+INPUT=$(printf \\1) -+$TS_CMD_HEXDUMP -n1 -ve '2 "" "%x"' <<< $INPUT 2>&1 >> $TS_OUTPUT -+ -+$TS_CMD_HEXDUMP -n1 -ve '4 "%x"' -e '2 ""' <<< $INPUT 2>&1 >> $TS_OUTPUT -+ -+ts_finalize -diff --git a/text-utils/parse.c b/text-utils/parse.c -index 5f1e2bd..bd96961 100644 ---- a/text-utils/parse.c -+++ b/text-utils/parse.c -@@ -421,13 +421,15 @@ isint2: switch(fu->bcnt) { - !(fu->flags&F_SETREP) && fu->bcnt) - fu->reps += (blocksize - fs->bcnt) / fu->bcnt; - if (fu->reps > 1) { -- for (pr = fu->nextpr;; pr = pr->nextpr) -- if (!pr->nextpr) -- break; -- for (p1 = pr->fmt, p2 = NULL; *p1; ++p1) -- p2 = isspace((unsigned char)*p1) ? p1 : NULL; -- if (p2) -- pr->nospace = p2; -+ if (fu->nextpr) { -+ for (pr = fu->nextpr; ; pr = pr->nextpr) -+ if (!pr->nextpr) -+ break; -+ for (p1 = pr->fmt, p2 = NULL; *p1; ++p1) -+ p2 = isspace((unsigned char)*p1) ? p1 : NULL; -+ if (p2) -+ pr->nospace = p2; -+ } - } - } - } --- -1.8.1 - diff --git a/libblkid-add-support-for-btrfs-backup-superblock.patch b/libblkid-add-support-for-btrfs-backup-superblock.patch deleted file mode 100644 index e8a3ea8..0000000 --- a/libblkid-add-support-for-btrfs-backup-superblock.patch +++ /dev/null @@ -1,46 +0,0 @@ -From d4a276491269b6502c15e0089fba6b616f5c5df8 Mon Sep 17 00:00:00 2001 -From: Goffredo Baroncelli -Date: Wed, 9 Jan 2013 22:14:43 +0100 -Subject: [PATCH] libblkid: add support for btrfs backup superblock - -Btrfs has three superblock. The first one is placed at 64KB, the second one at -64MB, the third one at 256GB. - -If the first superblock is valid except that the "magic field" is zeroed, btrfs -skips the check of the other superblocks. If the first superblock is fully -invalid, btrfs checks for the other superblock. - -So zeroing the first superblock "magic field" at the beginning seems that the -filesystem is wiped. But when the first superblock is overwritten (eg by -another filesystem), then the other two superblock may be considered valid, and -the filesystem may resurrect. - -This patch allow to find and wipe the other btrfs superblocks signature. - -Signed-off-by: Karel Zak ---- - libblkid/src/superblocks/btrfs.c | 8 ++++++++ - 1 file changed, 8 insertions(+) - -diff --git a/libblkid/src/superblocks/btrfs.c b/libblkid/src/superblocks/btrfs.c -index 039be42..1bd1df9 100644 ---- a/libblkid/src/superblocks/btrfs.c -+++ b/libblkid/src/superblocks/btrfs.c -@@ -87,6 +87,14 @@ const struct blkid_idinfo btrfs_idinfo = - .magics = - { - { .magic = "_BHRfS_M", .len = 8, .kboff = 64, .sboff = 0x40 }, -+ { .magic = "_BHRfS_M", -+ .len = 8, -+ .kboff = 64 * 1024, -+ .sboff = 0x40 }, -+ { .magic = "_BHRfS_M", -+ .len = 8, -+ .kboff = 256 * 1024 * 1024, -+ .sboff = 0x40 }, - { NULL } - } - }; --- -1.7.11.7 - diff --git a/libblkid-make-backup-superblock-visible-for-wipefs-8.patch b/libblkid-make-backup-superblock-visible-for-wipefs-8.patch deleted file mode 100644 index df06674..0000000 --- a/libblkid-make-backup-superblock-visible-for-wipefs-8.patch +++ /dev/null @@ -1,64 +0,0 @@ -diff -up util-linux-2.22.2/libblkid/src/blkidP.h.kzak util-linux-2.22.2/libblkid/src/blkidP.h ---- util-linux-2.22.2/libblkid/src/blkidP.h.kzak 2012-12-12 21:04:47.902355093 +0100 -+++ util-linux-2.22.2/libblkid/src/blkidP.h 2013-02-20 10:54:33.885606609 +0100 -@@ -224,6 +224,9 @@ struct blkid_struct_probe - - /* private per-probing flags */ - #define BLKID_PROBE_FL_IGNORE_PT (1 << 1) /* ignore partition table */ -+#define BLKID_PROBE_FL_IGNORE_BACKUP (1 << 2) /* ignore backup superblocks or PT */ -+ -+extern int blkid_probe_ignore_backup(blkid_probe pr); - - extern blkid_probe blkid_clone_probe(blkid_probe parent); - extern blkid_probe blkid_probe_get_wholedisk_probe(blkid_probe pr); -diff -up util-linux-2.22.2/libblkid/src/probe.c.kzak util-linux-2.22.2/libblkid/src/probe.c ---- util-linux-2.22.2/libblkid/src/probe.c.kzak 2012-12-12 21:04:47.903355101 +0100 -+++ util-linux-2.22.2/libblkid/src/probe.c 2013-02-20 11:02:48.525255696 +0100 -@@ -810,6 +810,7 @@ int blkid_probe_get_idmag(blkid_probe pr - static inline void blkid_probe_start(blkid_probe pr) - { - if (pr) { -+ DBG(DEBUG_LOWPROBE, printf("%p: start probe\n", pr)); - pr->cur_chain = NULL; - pr->prob_flags = 0; - blkid_probe_set_wiper(pr, 0, 0); -@@ -819,6 +820,7 @@ static inline void blkid_probe_start(blk - static inline void blkid_probe_end(blkid_probe pr) - { - if (pr) { -+ DBG(DEBUG_LOWPROBE, printf("%p: end probe\n", pr)); - pr->cur_chain = NULL; - pr->prob_flags = 0; - blkid_probe_set_wiper(pr, 0, 0); -@@ -1057,6 +1059,8 @@ int blkid_do_safeprobe(blkid_probe pr) - - blkid_probe_start(pr); - -+ pr->prob_flags |= BLKID_PROBE_FL_IGNORE_BACKUP; -+ - for (i = 0; i < BLKID_NCHAINS; i++) { - struct blkid_chain *chn; - -@@ -1679,3 +1683,7 @@ void blkid_probe_use_wiper(blkid_probe p - } - } - -+int blkid_probe_ignore_backup(blkid_probe pr) -+{ -+ return pr && (pr->prob_flags & BLKID_PROBE_FL_IGNORE_BACKUP); -+} -diff -up util-linux-2.22.2/libblkid/src/superblocks/btrfs.c.kzak util-linux-2.22.2/libblkid/src/superblocks/btrfs.c ---- util-linux-2.22.2/libblkid/src/superblocks/btrfs.c.kzak 2013-02-20 10:54:03.422381876 +0100 -+++ util-linux-2.22.2/libblkid/src/superblocks/btrfs.c 2013-02-20 10:54:33.886606616 +0100 -@@ -63,6 +63,11 @@ static int probe_btrfs(blkid_probe pr, c - { - struct btrfs_super_block *bfs; - -+ if (mag->kboff > 64 && blkid_probe_ignore_backup(pr)) { -+ DBG(DEBUG_LOWPROBE, printf("btrfs: found backup superblock, ignore\n")); -+ return 1; -+ } -+ - bfs = blkid_probe_get_sb(pr, mag, struct btrfs_super_block); - if (!bfs) - return -1; diff --git a/libblkid-remove-optimization-from-verify-function.patch b/libblkid-remove-optimization-from-verify-function.patch deleted file mode 100644 index 7d40835..0000000 --- a/libblkid-remove-optimization-from-verify-function.patch +++ /dev/null @@ -1,165 +0,0 @@ -From 2270b1ad90b394950f4fe215eb2fc1042020cef0 Mon Sep 17 00:00:00 2001 -From: Karel Zak -Date: Fri, 1 Feb 2013 15:59:58 +0100 -Subject: [PATCH] libblkid: remove optimization from verify( funrtion - -Now libblkid (the cache based part) tries to probe for the cached -filesystem firstly. This optimization is broken, because: - - * new another superblock could be on the device and the original - is already obsolete - * we still need to probe for partitions and raids - * the code was too fragile - -The patch also suggests lsblk --fs in blkid.8 for end users. lsblk -read information from used db. - -Reported-by: Andreas Hofmeister -Signed-off-by: Karel Zak ---- - libblkid/src/verify.c | 76 ++++++++------------------------------------------- - misc-utils/blkid.8 | 11 ++++++++ - 2 files changed, 22 insertions(+), 65 deletions(-) - -diff --git a/libblkid/src/verify.c b/libblkid/src/verify.c -index 4bab4de..0f48c48 100644 ---- a/libblkid/src/verify.c -+++ b/libblkid/src/verify.c -@@ -43,26 +43,6 @@ static void blkid_probe_to_tags(blkid_probe pr, blkid_dev dev) - blkid_set_tag(dev, name, data, len); - } - } -- -- /* -- * remove obsolete tags -- */ -- if (!nvals || !blkid_probe_has_value(pr, "LABEL")) -- blkid_set_tag(dev, "LABEL", NULL, 0); -- if (!nvals || !blkid_probe_has_value(pr, "UUID")) -- blkid_set_tag(dev, "UUID", NULL, 0); -- if (!nvals || !blkid_probe_has_value(pr, "PART_ENTRY_UUID")) -- blkid_set_tag(dev, "PARTUUID", NULL, 0); -- if (!nvals || !blkid_probe_has_value(pr, "PART_ENTRY_NAME")) -- blkid_set_tag(dev, "PARTLABEL", NULL, 0); -- if (!nvals || !blkid_probe_has_value(pr, "TYPE")) -- blkid_set_tag(dev, "TYPE", NULL, 0); -- if (!nvals || !blkid_probe_has_value(pr, "SEC_TYPE")) -- blkid_set_tag(dev, "SEC_TYPE", NULL, 0); -- if (!nvals || !blkid_probe_has_value(pr, "EXT_JOURNAL")) /* extN */ -- blkid_set_tag(dev, "EXT_JOURNAL", NULL, 0); -- if (!nvals || !blkid_probe_has_value(pr, "MOUNT")) /* ocfs */ -- blkid_set_tag(dev, "MOUNT", NULL, 0); - } - - /* -@@ -76,9 +56,10 @@ static void blkid_probe_to_tags(blkid_probe pr, blkid_dev dev) - */ - blkid_dev blkid_verify(blkid_cache cache, blkid_dev dev) - { -+ blkid_tag_iterate iter; -+ const char *type, *value; - struct stat st; - time_t diff, now; -- char *fltr[2]; - int fd; - - if (!dev) -@@ -155,64 +136,29 @@ blkid_dev blkid_verify(blkid_cache cache, blkid_dev dev) - return NULL; - } - -- blkid_probe_enable_superblocks(cache->probe, TRUE); -+ /* remove old cache info */ -+ iter = blkid_tag_iterate_begin(dev); -+ while (blkid_tag_next(iter, &type, &value) == 0) -+ blkid_set_tag(dev, type, NULL, 0); -+ blkid_tag_iterate_end(iter); - -+ /* enable superblocks probing */ -+ blkid_probe_enable_superblocks(cache->probe, TRUE); - blkid_probe_set_superblocks_flags(cache->probe, - BLKID_SUBLKS_LABEL | BLKID_SUBLKS_UUID | - BLKID_SUBLKS_TYPE | BLKID_SUBLKS_SECTYPE); - -- /* -- * If we already know the type, then try that first. -- */ -- if (dev->bid_type) { -- blkid_tag_iterate iter; -- const char *type, *value; -- -- fltr[0] = dev->bid_type; -- fltr[1] = NULL; -- -- blkid_probe_filter_superblocks_type(cache->probe, -- BLKID_FLTR_ONLYIN, fltr); -- -- if (blkid_do_probe(cache->probe) == 0) { -- /* -- * Cool, we found FS type, let's also read PART{UUID,LABEL} -- */ -- blkid_probe_enable_superblocks(cache->probe, FALSE); -- blkid_probe_enable_partitions(cache->probe, TRUE); -- blkid_probe_set_partitions_flags(cache->probe, BLKID_PARTS_ENTRY_DETAILS); -- if (blkid_do_probe(cache->probe) == 0) -- goto found_type; -- } -- -- blkid_probe_enable_superblocks(cache->probe, TRUE); -- blkid_probe_invert_superblocks_filter(cache->probe); -- -- /* -- * Zap the device filesystem information and try again -- */ -- DBG(DEBUG_PROBE, -- printf("previous fs type %s not valid, " -- "trying full probe\n", dev->bid_type)); -- iter = blkid_tag_iterate_begin(dev); -- while (blkid_tag_next(iter, &type, &value) == 0) -- blkid_set_tag(dev, type, 0, 0); -- blkid_tag_iterate_end(iter); -- } -- -+ /* enable partitions probing */ - blkid_probe_enable_partitions(cache->probe, TRUE); - blkid_probe_set_partitions_flags(cache->probe, BLKID_PARTS_ENTRY_DETAILS); - -- /* -- * Probe for all types. -- */ -+ /* probe */ - if (blkid_do_safeprobe(cache->probe)) { - /* found nothing or error */ - blkid_free_dev(dev); - dev = NULL; - } - --found_type: - if (dev) { - #ifdef HAVE_STRUCT_STAT_ST_MTIM_TV_NSEC - struct timeval tv; -diff --git a/misc-utils/blkid.8 b/misc-utils/blkid.8 -index 2ba1ab4..eb8d716 100644 ---- a/misc-utils/blkid.8 -+++ b/misc-utils/blkid.8 -@@ -64,6 +64,17 @@ library. It can determine the type of content (e.g. filesystem or swap) - that a block device holds, and also attributes (tokens, NAME=value pairs) - from the content metadata (e.g. LABEL or UUID fields). - .PP -+Note that -+.B blkid -+reads information directly from devices and for non-root users -+it returns cached unverified information. It's better to use -+.B lsblk --fs -+to get user-friendly overview about filesystems and devices. -+.BR lsblk (8) -+is also easy to use in scripts. -+.B blkid -+is mostly designed for system services and to test libblkid functionality. -+.PP - .B 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 --- -1.8.1 -