mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-20 18:09:23 +03:00
Drop-in devmap_name replacement.
This commit is contained in:
parent
e46be0415f
commit
756731fc02
@ -1,5 +1,6 @@
|
|||||||
Version 1.01.01 -
|
Version 1.01.01 -
|
||||||
=============================
|
=============================
|
||||||
|
Drop-in devmap_name replacement.
|
||||||
Add option to compile without ioctl for testing.
|
Add option to compile without ioctl for testing.
|
||||||
Fix DM_LIB_VERSION sed.
|
Fix DM_LIB_VERSION sed.
|
||||||
|
|
||||||
|
122
tools/dmsetup.c
122
tools/dmsetup.c
@ -23,6 +23,7 @@
|
|||||||
#include <dirent.h>
|
#include <dirent.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <libgen.h>
|
||||||
|
|
||||||
#ifdef HAVE_GETOPTLONG
|
#ifdef HAVE_GETOPTLONG
|
||||||
# include <getopt.h>
|
# include <getopt.h>
|
||||||
@ -60,6 +61,7 @@ enum {
|
|||||||
NOHEADINGS_ARG,
|
NOHEADINGS_ARG,
|
||||||
NOOPENCOUNT_ARG,
|
NOOPENCOUNT_ARG,
|
||||||
NOTABLE_ARG,
|
NOTABLE_ARG,
|
||||||
|
OPTIONS_ARG,
|
||||||
UUID_ARG,
|
UUID_ARG,
|
||||||
VERBOSE_ARG,
|
VERBOSE_ARG,
|
||||||
VERSION_ARG,
|
VERSION_ARG,
|
||||||
@ -69,6 +71,7 @@ enum {
|
|||||||
static int _switches[NUM_SWITCHES];
|
static int _switches[NUM_SWITCHES];
|
||||||
static int _values[NUM_SWITCHES];
|
static int _values[NUM_SWITCHES];
|
||||||
static char *_uuid;
|
static char *_uuid;
|
||||||
|
static char *_fields;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Commands
|
* Commands
|
||||||
@ -137,15 +140,18 @@ static void _display_info_cols_noheadings(struct dm_task *dmt,
|
|||||||
|
|
||||||
uuid = dm_task_get_uuid(dmt);
|
uuid = dm_task_get_uuid(dmt);
|
||||||
|
|
||||||
printf("%s:%d:%d:%s%s%s%s:%d:%d:%" PRIu32 ":%s\n",
|
if (_switches[OPTIONS_ARG])
|
||||||
dm_task_get_name(dmt),
|
printf("%s\n", dm_task_get_name(dmt));
|
||||||
info->major, info->minor,
|
else
|
||||||
info->live_table ? "L" : "-",
|
printf("%s:%d:%d:%s%s%s%s:%d:%d:%" PRIu32 ":%s\n",
|
||||||
info->inactive_table ? "I" : "-",
|
dm_task_get_name(dmt),
|
||||||
info->suspended ? "s" : "-",
|
info->major, info->minor,
|
||||||
info->read_only ? "r" : "w",
|
info->live_table ? "L" : "-",
|
||||||
info->open_count, info->target_count, info->event_nr,
|
info->inactive_table ? "I" : "-",
|
||||||
uuid && *uuid ? uuid : "");
|
info->suspended ? "s" : "-",
|
||||||
|
info->read_only ? "r" : "w",
|
||||||
|
info->open_count, info->target_count, info->event_nr,
|
||||||
|
uuid && *uuid ? uuid : "");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void _display_info_cols(struct dm_task *dmt, struct dm_info *info)
|
static void _display_info_cols(struct dm_task *dmt, struct dm_info *info)
|
||||||
@ -159,24 +165,31 @@ static void _display_info_cols(struct dm_task *dmt, struct dm_info *info)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!_headings) {
|
if (!_headings) {
|
||||||
printf("Name Maj Min Stat Open Targ Event UUID\n");
|
if (_switches[OPTIONS_ARG])
|
||||||
|
printf("Name\n");
|
||||||
|
else
|
||||||
|
printf("Name Maj Min Stat Open Targ "
|
||||||
|
"Event UUID\n");
|
||||||
_headings = 1;
|
_headings = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("%-16s ", dm_task_get_name(dmt));
|
if (_switches[OPTIONS_ARG])
|
||||||
|
printf("%s\n", dm_task_get_name(dmt));
|
||||||
|
else {
|
||||||
|
printf("%-16s %3d %3d %s%s%s%s %4d %4d %6" PRIu32 " ",
|
||||||
|
dm_task_get_name(dmt),
|
||||||
|
info->major, info->minor,
|
||||||
|
info->live_table ? "L" : "-",
|
||||||
|
info->inactive_table ? "I" : "-",
|
||||||
|
info->suspended ? "s" : "-",
|
||||||
|
info->read_only ? "r" : "w",
|
||||||
|
info->open_count, info->target_count, info->event_nr);
|
||||||
|
|
||||||
printf("%3d %3d %s%s%s%s %4d %4d %6" PRIu32 " ",
|
if ((uuid = dm_task_get_uuid(dmt)) && *uuid)
|
||||||
info->major, info->minor,
|
printf("%s", uuid);
|
||||||
info->live_table ? "L" : "-",
|
|
||||||
info->inactive_table ? "I" : "-",
|
|
||||||
info->suspended ? "s" : "-",
|
|
||||||
info->read_only ? "r" : "w",
|
|
||||||
info->open_count, info->target_count, info->event_nr);
|
|
||||||
|
|
||||||
if ((uuid = dm_task_get_uuid(dmt)) && *uuid)
|
printf("\n");
|
||||||
printf("%s", uuid);
|
}
|
||||||
|
|
||||||
printf("\n");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void _display_info_long(struct dm_task *dmt, struct dm_info *info)
|
static void _display_info_long(struct dm_task *dmt, struct dm_info *info)
|
||||||
@ -217,12 +230,12 @@ static void _display_info_long(struct dm_task *dmt, struct dm_info *info)
|
|||||||
printf("\n");
|
printf("\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void _display_info(struct dm_task *dmt)
|
static int _display_info(struct dm_task *dmt)
|
||||||
{
|
{
|
||||||
struct dm_info info;
|
struct dm_info info;
|
||||||
|
|
||||||
if (!dm_task_get_info(dmt, &info))
|
if (!dm_task_get_info(dmt, &info))
|
||||||
return;
|
return 0;
|
||||||
|
|
||||||
if (!_switches[COLS_ARG])
|
if (!_switches[COLS_ARG])
|
||||||
_display_info_long(dmt, &info);
|
_display_info_long(dmt, &info);
|
||||||
@ -230,6 +243,8 @@ static void _display_info(struct dm_task *dmt)
|
|||||||
_display_info_cols_noheadings(dmt, &info);
|
_display_info_cols_noheadings(dmt, &info);
|
||||||
else
|
else
|
||||||
_display_info_cols(dmt, &info);
|
_display_info_cols(dmt, &info);
|
||||||
|
|
||||||
|
return info.exists ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int _set_task_device(struct dm_task *dmt, const char *name, int optional)
|
static int _set_task_device(struct dm_task *dmt, const char *name, int optional)
|
||||||
@ -301,7 +316,7 @@ static int _load(int argc, char **argv, void *data)
|
|||||||
r = 1;
|
r = 1;
|
||||||
|
|
||||||
if (_switches[VERBOSE_ARG])
|
if (_switches[VERBOSE_ARG])
|
||||||
_display_info(dmt);
|
r = _display_info(dmt);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
dm_task_destroy(dmt);
|
dm_task_destroy(dmt);
|
||||||
@ -348,7 +363,7 @@ static int _create(int argc, char **argv, void *data)
|
|||||||
r = 1;
|
r = 1;
|
||||||
|
|
||||||
if (_switches[VERBOSE_ARG])
|
if (_switches[VERBOSE_ARG])
|
||||||
_display_info(dmt);
|
r = _display_info(dmt);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
dm_task_destroy(dmt);
|
dm_task_destroy(dmt);
|
||||||
@ -495,7 +510,7 @@ static int _simple(int task, const char *name, uint32_t event_nr, int display)
|
|||||||
r = dm_task_run(dmt);
|
r = dm_task_run(dmt);
|
||||||
|
|
||||||
if (r && display && _switches[VERBOSE_ARG])
|
if (r && display && _switches[VERBOSE_ARG])
|
||||||
_display_info(dmt);
|
r = _display_info(dmt);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
dm_task_destroy(dmt);
|
dm_task_destroy(dmt);
|
||||||
@ -735,9 +750,7 @@ static int _info(int argc, char **argv, void *data)
|
|||||||
if (!dm_task_run(dmt))
|
if (!dm_task_run(dmt))
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
_display_info(dmt);
|
r = _display_info(dmt);
|
||||||
|
|
||||||
r = 1;
|
|
||||||
|
|
||||||
out:
|
out:
|
||||||
dm_task_destroy(dmt);
|
dm_task_destroy(dmt);
|
||||||
@ -891,6 +904,7 @@ static struct command *_find_command(const char *name)
|
|||||||
|
|
||||||
static int _process_switches(int *argc, char ***argv)
|
static int _process_switches(int *argc, char ***argv)
|
||||||
{
|
{
|
||||||
|
char *base, *namebase;
|
||||||
int ind;
|
int ind;
|
||||||
int c;
|
int c;
|
||||||
|
|
||||||
@ -903,6 +917,7 @@ static int _process_switches(int *argc, char ***argv)
|
|||||||
{"noheadings", 0, NULL, NOHEADINGS_ARG},
|
{"noheadings", 0, NULL, NOHEADINGS_ARG},
|
||||||
{"noopencount", 0, NULL, NOOPENCOUNT_ARG},
|
{"noopencount", 0, NULL, NOOPENCOUNT_ARG},
|
||||||
{"notable", 0, NULL, NOTABLE_ARG},
|
{"notable", 0, NULL, NOTABLE_ARG},
|
||||||
|
{"options", 1, NULL, OPTIONS_ARG},
|
||||||
{"uuid", 1, NULL, UUID_ARG},
|
{"uuid", 1, NULL, UUID_ARG},
|
||||||
{"verbose", 1, NULL, VERBOSE_ARG},
|
{"verbose", 1, NULL, VERBOSE_ARG},
|
||||||
{"version", 0, NULL, VERSION_ARG},
|
{"version", 0, NULL, VERSION_ARG},
|
||||||
@ -918,9 +933,43 @@ static int _process_switches(int *argc, char ***argv)
|
|||||||
memset(&_switches, 0, sizeof(_switches));
|
memset(&_switches, 0, sizeof(_switches));
|
||||||
memset(&_values, 0, sizeof(_values));
|
memset(&_values, 0, sizeof(_values));
|
||||||
|
|
||||||
|
namebase = strdup((*argv)[0]);
|
||||||
|
base = basename(namebase);
|
||||||
|
|
||||||
|
if (!strcmp(base, "devmap_name")) {
|
||||||
|
free(namebase);
|
||||||
|
_switches[COLS_ARG]++;
|
||||||
|
_switches[NOHEADINGS_ARG]++;
|
||||||
|
_switches[OPTIONS_ARG]++;
|
||||||
|
_switches[MAJOR_ARG]++;
|
||||||
|
_switches[MINOR_ARG]++;
|
||||||
|
_fields = (char *) "name";
|
||||||
|
|
||||||
|
if (*argc == 3) {
|
||||||
|
_values[MAJOR_ARG] = atoi((*argv)[1]);
|
||||||
|
_values[MINOR_ARG] = atoi((*argv)[2]);
|
||||||
|
*argc -= 2;
|
||||||
|
*argv += 2;
|
||||||
|
} else if ((*argc == 2) &&
|
||||||
|
(2 == sscanf((*argv)[1], "%i:%i",
|
||||||
|
&_values[MAJOR_ARG],
|
||||||
|
&_values[MINOR_ARG]))) {
|
||||||
|
*argc -= 1;
|
||||||
|
*argv += 1;
|
||||||
|
} else {
|
||||||
|
fprintf(stderr, "Usage: devmap_name <major> <minor>\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
(*argv)[0] = (char *) "info";
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
free(namebase);
|
||||||
|
|
||||||
optarg = 0;
|
optarg = 0;
|
||||||
optind = OPTIND_INIT;
|
optind = OPTIND_INIT;
|
||||||
while ((c = GETOPTLONG_FN(*argc, *argv, "cCj:m:nru:v",
|
while ((c = GETOPTLONG_FN(*argc, *argv, "cCj:m:no:ru:v",
|
||||||
long_options, &ind)) != -1) {
|
long_options, &ind)) != -1) {
|
||||||
if (c == 'c' || c == 'C' || ind == COLS_ARG)
|
if (c == 'c' || c == 'C' || ind == COLS_ARG)
|
||||||
_switches[COLS_ARG]++;
|
_switches[COLS_ARG]++;
|
||||||
@ -936,6 +985,10 @@ static int _process_switches(int *argc, char ***argv)
|
|||||||
}
|
}
|
||||||
if (c == 'n' || ind == NOTABLE_ARG)
|
if (c == 'n' || ind == NOTABLE_ARG)
|
||||||
_switches[NOTABLE_ARG]++;
|
_switches[NOTABLE_ARG]++;
|
||||||
|
if (c == 'o' || ind == OPTIONS_ARG) {
|
||||||
|
_switches[OPTIONS_ARG]++;
|
||||||
|
_fields = optarg;
|
||||||
|
}
|
||||||
if (c == 'v' || ind == VERBOSE_ARG)
|
if (c == 'v' || ind == VERBOSE_ARG)
|
||||||
_switches[VERBOSE_ARG]++;
|
_switches[VERBOSE_ARG]++;
|
||||||
if (c == 'u' || ind == UUID_ARG) {
|
if (c == 'u' || ind == UUID_ARG) {
|
||||||
@ -960,6 +1013,11 @@ static int _process_switches(int *argc, char ***argv)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (_switches[OPTIONS_ARG] && strcmp(_fields, "name")) {
|
||||||
|
fprintf(stderr, "Only -o name is supported so far.\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
*argv += optind;
|
*argv += optind;
|
||||||
*argc -= optind;
|
*argc -= optind;
|
||||||
return 1;
|
return 1;
|
||||||
@ -970,7 +1028,7 @@ int main(int argc, char **argv)
|
|||||||
struct command *c;
|
struct command *c;
|
||||||
|
|
||||||
if (!_process_switches(&argc, &argv)) {
|
if (!_process_switches(&argc, &argv)) {
|
||||||
fprintf(stderr, "Couldn't process command line switches.\n");
|
fprintf(stderr, "Couldn't process command line.\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user