From 74cfa0a04f51f0629093ac11fafb9c8aba881eee Mon Sep 17 00:00:00 2001 From: Eric Ren Date: Tue, 11 Apr 2017 10:58:56 +0800 Subject: [PATCH] DM: add dmsetup export bsc#479104 Patch-refreshed-by: Eric Ren --- man/dmsetup.8_main | 16 ++++++- tools/dmsetup.c | 124 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 139 insertions(+), 1 deletion(-) diff --git a/man/dmsetup.8_main b/man/dmsetup.8_main index 4421882..5a31f76 100644 --- a/man/dmsetup.8_main +++ b/man/dmsetup.8_main @@ -97,7 +97,15 @@ dmsetup \(em low level logical volume management .. .CMD_LOAD . -.HP +. HP +.B dmsetup +.de CMD_EXPORT +. BR export +. RI [device_name] +.. +.CMD_EXPORT +. +. HP .B dmsetup .de CMD_LS . ad l @@ -564,6 +572,12 @@ Specify a one-line table directly on the command line. See below for more information on the table format. . .HP +.BR --export +.IR export +.br +Outputs information in key/value format to be imported by other programs. +. +.HP .BR --udevcookie .IR cookie .br diff --git a/tools/dmsetup.c b/tools/dmsetup.c index 5c5c14c..2b0aed6 100644 --- a/tools/dmsetup.c +++ b/tools/dmsetup.c @@ -2231,6 +2231,129 @@ static int _status(CMD_ARGS) return r; } +static int _export(CMD_ARGS) +{ + int r = 0; + struct dm_task *dmt = NULL; + void *next = NULL; + uint64_t start, length; + char *target_type = NULL; + char *params; + const char *name = NULL; + const char *old_name = NULL; + const char *uuid = NULL; + struct dm_info info; + struct dm_deps *deps; + + if (names) + name = names->name; + else if (argc == 2) + name = argv[1]; + old_name = name; + + if (!(dmt = dm_task_create(DM_DEVICE_STATUS))) + goto out; + + if (!_set_task_device(dmt, name, 0)) + goto out; + + if (!dm_task_run(dmt)) + goto out; + + if (!dm_task_get_info(dmt, &info) || !info.exists) + goto out; + + if (!name) + name = dm_task_get_name(dmt); + + uuid = dm_task_get_uuid(dmt); + printf("DM_NAME=%s\n", name); + + if ((uuid = dm_task_get_uuid(dmt)) && *uuid) + printf("DM_UUID=%s\n", uuid); + + if (!info.exists) { + printf("DM_STATE=NOTPRESENT\n"); + goto out; + } + + if (!name) + name = dm_task_get_name(dmt); + + uuid = dm_task_get_uuid(dmt); + printf("DM_NAME=%s\n", name); + + if ((uuid = dm_task_get_uuid(dmt)) && *uuid) + printf("DM_UUID=%s\n", uuid); + + if (!info.exists) { + printf("DM_STATE=NOTPRESENT\n"); + goto out; + } + + printf("DM_STATE=%s\n", + info.suspended ? "SUSPENDED" : + (info.read_only ? "READONLY" : "ACTIVE")); + + if (!info.live_table && !info.inactive_table) + printf("DM_TABLE_STATE=NONE\n"); + else + printf("DM_TABLE_STATE=%s%s%s\n", + info.live_table ? "LIVE" : "", + info.live_table && info.inactive_table ? "/" : "", + info.inactive_table ? "INACTIVE" : ""); + + if (info.open_count != -1) + printf("DM_OPENCOUNT=%d\n", info.open_count); + + printf("DM_LAST_EVENT_NR=%" PRIu32 "\n", info.event_nr); + + printf("DM_MAJOR=%d\n", info.major); + printf("DM_MINOR=%d\n", info.minor); + + if (info.target_count != -1) + printf("DM_TARGET_COUNT=%d\n", info.target_count); + + /* export all table types */ + next = dm_get_next_target(dmt, next, &start, &length, + &target_type, ¶ms); + if (target_type) { + printf("DM_TARGET_TYPES=%s", target_type); + while (next) { + next = dm_get_next_target(dmt, next, &start, &length, + &target_type, ¶ms); + if (target_type) + printf(",%s", target_type); + } + printf("\n"); + } + + dm_task_destroy(dmt); + + // bnc#707614, revert to the original name + + if (!(dmt = dm_task_create(DM_DEVICE_DEPS))) + goto out; + + name = old_name; + if (!_set_task_device(dmt, name, 0)) + goto out; + + if (!dm_task_run(dmt)) + goto out; + + if (!(deps = dm_task_get_deps(dmt))) + goto out; + + printf("DM_DEPS=%d\n", deps->count); + + r = 1; + out: + if (dmt) + dm_task_destroy(dmt); + return r; +} + /* Show target names and their version numbers */ static int _targets(CMD_ARGS) { @@ -5903,6 +6026,7 @@ static struct command _dmsetup_commands[] = { {"deps", "[-o ] [...]", 0, -1, 1, 0, _deps}, {"stats", " [] [...]", 1, -1, 1, 1, _stats}, {"status", "[...] [--noflush] [--target ]", 0, -1, 1, 0, _status}, + {"export", "[]", 0, -1, 1, 0, _export}, {"table", "[...] [--target ] [--showkeys]", 0, -1, 1, 0, _status}, {"wait", " [] [--noflush]", 0, 2, 0, 0, _wait}, {"mknodes", "[...]", 0, -1, 1, 0, _mknodes}, -- 2.10.2