1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-05 13:18:20 +03:00

Drop-in devmap_name replacement.

This commit is contained in:
Alasdair Kergon 2005-03-27 11:37:46 +00:00
parent e46be0415f
commit 756731fc02
2 changed files with 91 additions and 32 deletions

View File

@ -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.

View File

@ -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,6 +140,9 @@ static void _display_info_cols_noheadings(struct dm_task *dmt,
uuid = dm_task_get_uuid(dmt); uuid = dm_task_get_uuid(dmt);
if (_switches[OPTIONS_ARG])
printf("%s\n", dm_task_get_name(dmt));
else
printf("%s:%d:%d:%s%s%s%s:%d:%d:%" PRIu32 ":%s\n", printf("%s:%d:%d:%s%s%s%s:%d:%d:%" PRIu32 ":%s\n",
dm_task_get_name(dmt), dm_task_get_name(dmt),
info->major, info->minor, info->major, info->minor,
@ -159,13 +165,19 @@ 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));
printf("%3d %3d %s%s%s%s %4d %4d %6" PRIu32 " ", else {
printf("%-16s %3d %3d %s%s%s%s %4d %4d %6" PRIu32 " ",
dm_task_get_name(dmt),
info->major, info->minor, info->major, info->minor,
info->live_table ? "L" : "-", info->live_table ? "L" : "-",
info->inactive_table ? "I" : "-", info->inactive_table ? "I" : "-",
@ -178,6 +190,7 @@ static void _display_info_cols(struct dm_task *dmt, struct dm_info *info)
printf("\n"); 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);
} }