summaryrefslogtreecommitdiffstats
path: root/misc-utils/lsblk.c
diff options
context:
space:
mode:
authorMilan Broz2012-10-19 14:10:40 +0200
committerKarel Zak2012-10-23 10:27:06 +0200
commit699e5c4f96bb69b3462032386a90cc4f82b77dc9 (patch)
treee4f5c5167a1b58f3004f14b67f71609d9305f8e8 /misc-utils/lsblk.c
parentlsblk: add parent kernel name column (diff)
downloadkernel-qcow2-util-linux-699e5c4f96bb69b3462032386a90cc4f82b77dc9.tar.gz
kernel-qcow2-util-linux-699e5c4f96bb69b3462032386a90cc4f82b77dc9.tar.xz
kernel-qcow2-util-linux-699e5c4f96bb69b3462032386a90cc4f82b77dc9.zip
lsblk: add SCSI H:C:T:L attribute
For block devices it is sometimes useful to print SCSI device ID" Host:Channel:Target:LUN. Patch adds column name HCTL which can be used in lsblk. Signed-off-by: Milan Broz <mbroz@redhat.com>
Diffstat (limited to 'misc-utils/lsblk.c')
-rw-r--r--misc-utils/lsblk.c32
1 files changed, 32 insertions, 0 deletions
diff --git a/misc-utils/lsblk.c b/misc-utils/lsblk.c
index 1118e7eb9..7101eed4d 100644
--- a/misc-utils/lsblk.c
+++ b/misc-utils/lsblk.c
@@ -98,6 +98,7 @@ enum {
COL_WWN,
COL_RAND,
COL_PKNAME,
+ COL_HCTL,
};
/* column names */
@@ -146,6 +147,7 @@ static struct colinfo infos[] = {
[COL_DMAX] = { "DISC-MAX", 6, TT_FL_RIGHT, N_("discard max bytes") },
[COL_DZERO] = { "DISC-ZERO", 1, TT_FL_RIGHT, N_("discard zeroes data") },
[COL_WWN] = { "WWN", 18, 0, N_("unique storage identifier") },
+ [COL_HCTL] = { "HCTL", 10, 0, N_("Host:Channel:Target:Lun for SCSI") },
};
struct lsblk {
@@ -573,6 +575,27 @@ static char *get_type(struct blkdev_cxt *cxt)
return res;
}
+/* H:C:T:L - Host:Channel:Target:LUN */
+static int get_hctl(struct blkdev_cxt *cxt, int *h, int *c, int *t, int *l)
+{
+ char buf[PATH_MAX], *hctl;
+ ssize_t len;
+
+ len = sysfs_readlink(&cxt->sysfs, "device", buf, sizeof(buf));
+ if (len < 0)
+ return 0;
+
+ buf[len] = '\0';
+ hctl = strrchr(buf, '/') + 1;
+ if (!hctl)
+ return 0;
+
+ if (sscanf(hctl, "%d:%d:%d:%d", h, c, t, l) != 4)
+ return 0;
+
+ return 1;
+}
+
#define is_parsable(_l) (((_l)->tt->flags & TT_FL_RAW) || \
((_l)->tt->flags & TT_FL_EXPORT))
@@ -771,6 +794,15 @@ static void set_tt_data(struct blkdev_cxt *cxt, int col, int id, struct tt_line
if (p)
tt_line_set_data(ln, col, p);
break;
+ case COL_HCTL:
+ {
+ int h, c, t, l;
+ if (get_hctl(cxt, &h, &c, &t, &l)) {
+ snprintf(buf, sizeof(buf), "%d:%d:%d:%d", h, c, t, l);
+ tt_line_set_data(ln, col, xstrdup(buf));
+ }
+ break;
+ }
case COL_DALIGN:
p = sysfs_strdup(&cxt->sysfs, "discard_alignment");
if (cxt->discard && p)