1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-02 01:18:26 +03:00

Add LV column to reports listing kernel modules needed for activation.

This commit is contained in:
Alasdair Kergon 2006-10-03 17:55:20 +00:00
parent 1baed0e1ae
commit 6c81ed26f0
11 changed files with 165 additions and 0 deletions

View File

@ -1,5 +1,6 @@
Version 2.02.11 - Version 2.02.11 -
===================================== =====================================
Add LV column to reports listing kernel modules needed for activation.
Show available fields if report given invalid field. (e.g. lvs -o list) Show available fields if report given invalid field. (e.g. lvs -o list)
Add timestamp functions with --disable-realtime configure option. Add timestamp functions with --disable-realtime configure option.
Add %VG, %LV and %FREE suffices to lvcreate/lvresize --extents arg. Add %VG, %LV and %FREE suffices to lvcreate/lvresize --extents arg.

View File

@ -51,6 +51,66 @@ int lvm1_present(struct cmd_context *cmd)
return 0; return 0;
} }
int list_segment_modules(struct dm_pool *mem, const struct lv_segment *seg,
struct list *modules)
{
unsigned int s;
struct lv_segment *seg2, *snap_seg;
struct list *snh;
if (seg->segtype->ops->modules_needed &&
!seg->segtype->ops->modules_needed(mem, seg, modules)) {
log_error("module string allocation failed");
return 0;
}
if (lv_is_origin(seg->lv))
list_iterate(snh, &seg->lv->snapshot_segs)
if (!list_lv_modules(mem,
list_struct_base(snh,
struct lv_segment,
origin_list)->cow,
modules))
return_0;
if (lv_is_cow(seg->lv)) {
snap_seg = find_cow(seg->lv);
if (snap_seg->segtype->ops->modules_needed &&
!snap_seg->segtype->ops->modules_needed(mem, snap_seg,
modules)) {
log_error("snap_seg module string allocation failed");
return 0;
}
}
for (s = 0; s < seg->area_count; s++) {
switch (seg_type(seg, s)) {
case AREA_LV:
seg2 = find_seg_by_le(seg_lv(seg, s), seg_le(seg, s));
if (seg2 && !list_segment_modules(mem, seg2, modules))
return_0;
break;
case AREA_PV:
case AREA_UNASSIGNED:
;
}
}
return 1;
}
int list_lv_modules(struct dm_pool *mem, const struct logical_volume *lv,
struct list *modules)
{
struct lv_segment *seg;
list_iterate_items(seg, &lv->segments)
if (!list_segment_modules(mem, seg, modules))
return_0;
return 1;
}
#ifndef DEVMAPPER_SUPPORT #ifndef DEVMAPPER_SUPPORT
void set_activation(int act) void set_activation(int act)
{ {

View File

@ -39,6 +39,10 @@ int lvm1_present(struct cmd_context *cmd);
int target_present(const char *target_name, int use_modprobe); int target_present(const char *target_name, int use_modprobe);
int target_version(const char *target_name, uint32_t *maj, int target_version(const char *target_name, uint32_t *maj,
uint32_t *min, uint32_t *patchlevel); uint32_t *min, uint32_t *patchlevel);
int list_segment_modules(struct dm_pool *mem, const struct lv_segment *seg,
struct list *modules);
int list_lv_modules(struct dm_pool *mem, const struct logical_volume *lv,
struct list *modules);
void activation_release(void); void activation_release(void);
void activation_exit(void); void activation_exit(void);

View File

@ -23,6 +23,7 @@
#include "targets.h" #include "targets.h"
#include "lvm-string.h" #include "lvm-string.h"
#include "activate.h" #include "activate.h"
#include "str_list.h"
static const char *_errseg_name(const struct lv_segment *seg) static const char *_errseg_name(const struct lv_segment *seg)
{ {
@ -64,6 +65,18 @@ static int _errseg_target_present(void)
} }
#endif #endif
static int _errseg_modules_needed(struct dm_pool *mem,
const struct lv_segment *seg,
struct list *modules)
{
if (!str_list_add(mem, modules, "error")) {
log_error("error module string list allocation failed");
return 0;
}
return 1;
}
static void _errseg_destroy(const struct segment_type *segtype) static void _errseg_destroy(const struct segment_type *segtype)
{ {
dm_free((void *)segtype); dm_free((void *)segtype);
@ -76,6 +89,7 @@ static struct segtype_handler _error_ops = {
.add_target_line = _errseg_add_target_line, .add_target_line = _errseg_add_target_line,
.target_present = _errseg_target_present, .target_present = _errseg_target_present,
#endif #endif
.modules_needed = _errseg_modules_needed,
.destroy = _errseg_destroy, .destroy = _errseg_destroy,
}; };

View File

@ -77,6 +77,9 @@ struct segtype_handler {
uint64_t *total_numerator, uint64_t *total_numerator,
uint64_t *total_denominator, float *percent); uint64_t *total_denominator, float *percent);
int (*target_present) (void); int (*target_present) (void);
int (*modules_needed) (struct dm_pool *mem,
const struct lv_segment *seg,
struct list *modules);
void (*destroy) (const struct segment_type * segtype); void (*destroy) (const struct segment_type * segtype);
int (*target_register_events) (struct lv_segment *seg, int events); int (*target_register_events) (struct lv_segment *seg, int events);
int (*target_unregister_events) (struct lv_segment *seg, int events); int (*target_unregister_events) (struct lv_segment *seg, int events);

View File

@ -26,6 +26,7 @@
#include "targets.h" #include "targets.h"
#include "activate.h" #include "activate.h"
#include "sharedlib.h" #include "sharedlib.h"
#include "str_list.h"
#ifdef DMEVENTD #ifdef DMEVENTD
# include <libdevmapper-event.h> # include <libdevmapper-event.h>
@ -447,6 +448,28 @@ static int _target_unregister_events(struct lv_segment *seg,
#endif /* DMEVENTD */ #endif /* DMEVENTD */
#endif /* DEVMAPPER_SUPPORT */ #endif /* DEVMAPPER_SUPPORT */
static int _mirrored_modules_needed(struct dm_pool *mem,
const struct lv_segment *seg,
struct list *modules)
{
if (seg->log_lv &&
!list_segment_modules(mem, first_seg(seg->log_lv), modules))
return_0;
if ((seg->lv->vg->status & CLUSTERED) &&
!str_list_add(mem, modules, "clog")) {
log_error("cluster log string list allocation failed");
return 0;
}
if (!str_list_add(mem, modules, "mirror")) {
log_error("mirror string list allocation failed");
return 0;
}
return 1;
}
static void _mirrored_destroy(const struct segment_type *segtype) static void _mirrored_destroy(const struct segment_type *segtype)
{ {
dm_free((void *) segtype); dm_free((void *) segtype);
@ -467,6 +490,7 @@ static struct segtype_handler _mirrored_ops = {
.target_unregister_events = _target_unregister_events, .target_unregister_events = _target_unregister_events,
#endif #endif
#endif #endif
.modules_needed = _mirrored_modules_needed,
.destroy = _mirrored_destroy, .destroy = _mirrored_destroy,
}; };

View File

@ -33,6 +33,7 @@ FIELD(LVS, lv, NUM, "Copy%", lvid, 6, copypercent, "copy_percent")
FIELD(LVS, lv, STR, "Move", lvid, 4, movepv, "move_pv") FIELD(LVS, lv, STR, "Move", lvid, 4, movepv, "move_pv")
FIELD(LVS, lv, STR, "LV Tags", tags, 7, tags, "lv_tags") FIELD(LVS, lv, STR, "LV Tags", tags, 7, tags, "lv_tags")
FIELD(LVS, lv, STR, "Log", lvid, 3, loglv, "mirror_log") FIELD(LVS, lv, STR, "Log", lvid, 3, loglv, "mirror_log")
FIELD(LVS, lv, STR, "Modules", lvid, 7, modules, "modules")
FIELD(PVS, pv, STR, "Fmt", id, 3, pvfmt, "pv_fmt") FIELD(PVS, pv, STR, "Fmt", id, 3, pvfmt, "pv_fmt")
FIELD(PVS, pv, STR, "PV UUID", id, 38, uuid, "pv_uuid") FIELD(PVS, pv, STR, "PV UUID", id, 38, uuid, "pv_uuid")

View File

@ -21,6 +21,7 @@
#include "display.h" #include "display.h"
#include "activate.h" #include "activate.h"
#include "segtype.h" #include "segtype.h"
#include "str_list.h"
/* /*
* For macro use * For macro use
@ -200,6 +201,7 @@ static int _devices_disp(struct report_handle *rh, struct field *field,
return 1; return 1;
} }
static int _tags_disp(struct report_handle *rh, struct field *field, static int _tags_disp(struct report_handle *rh, struct field *field,
const void *data) const void *data)
{ {
@ -230,6 +232,23 @@ static int _tags_disp(struct report_handle *rh, struct field *field,
return 1; return 1;
} }
static int _modules_disp(struct report_handle *rh, struct field *field,
const void *data)
{
const struct logical_volume *lv = (const struct logical_volume *) data;
struct list *modules;
if (!(modules = str_list_create(rh->mem))) {
log_error("modules str_list allocation failed");
return 0;
}
if (!list_lv_modules(rh->mem, lv, modules))
return_0;
return _tags_disp(rh, field, modules);
}
static int _vgfmt_disp(struct report_handle *rh, struct field *field, static int _vgfmt_disp(struct report_handle *rh, struct field *field,
const void *data) const void *data)
{ {

View File

@ -20,6 +20,7 @@
#include "text_export.h" #include "text_export.h"
#include "config.h" #include "config.h"
#include "activate.h" #include "activate.h"
#include "str_list.h"
static const char *_snap_name(const struct lv_segment *seg) static const char *_snap_name(const struct lv_segment *seg)
{ {
@ -126,6 +127,18 @@ static int _snap_target_present(void)
} }
#endif #endif
static int _snap_modules_needed(struct dm_pool *mem,
const struct lv_segment *seg,
struct list *modules)
{
if (!str_list_add(mem, modules, "snapshot")) {
log_error("snapshot string list allocation failed");
return 0;
}
return 1;
}
static void _snap_destroy(const struct segment_type *segtype) static void _snap_destroy(const struct segment_type *segtype)
{ {
dm_free((void *)segtype); dm_free((void *)segtype);
@ -139,6 +152,7 @@ static struct segtype_handler _snapshot_ops = {
.target_percent = _snap_target_percent, .target_percent = _snap_target_percent,
.target_present = _snap_target_present, .target_present = _snap_target_present,
#endif #endif
.modules_needed = _snap_modules_needed,
.destroy = _snap_destroy, .destroy = _snap_destroy,
}; };

View File

@ -189,6 +189,17 @@ static int _striped_target_present(void)
} }
#endif #endif
static int _striped_modules_needed(struct dm_pool *mem,
const struct lv_segment *seg,
struct list *modules)
{
const char *module;
module = (seg->area_count == 1) ? "linear" : "striped";
return str_list_add(mem, modules, module);
}
static void _striped_destroy(const struct segment_type *segtype) static void _striped_destroy(const struct segment_type *segtype)
{ {
dm_free((void *)segtype); dm_free((void *)segtype);
@ -205,6 +216,7 @@ static struct segtype_handler _striped_ops = {
.add_target_line = _striped_add_target_line, .add_target_line = _striped_add_target_line,
.target_present = _striped_target_present, .target_present = _striped_target_present,
#endif #endif
.modules_needed = _striped_modules_needed,
.destroy = _striped_destroy, .destroy = _striped_destroy,
}; };

View File

@ -63,6 +63,18 @@ static int _zero_target_present(void)
} }
#endif #endif
static int _zero_modules_needed(struct dm_pool *mem,
const struct lv_segment *seg,
struct list *modules)
{
if (!str_list_add(mem, modules, "zero")) {
log_error("zero module string list allocation failed");
return 0;
}
return 1;
}
static void _zero_destroy(const struct segment_type *segtype) static void _zero_destroy(const struct segment_type *segtype)
{ {
dm_free((void *) segtype); dm_free((void *) segtype);
@ -75,6 +87,7 @@ static struct segtype_handler _zero_ops = {
.add_target_line = _zero_add_target_line, .add_target_line = _zero_add_target_line,
.target_present = _zero_target_present, .target_present = _zero_target_present,
#endif #endif
.modules_needed = _zero_modules_needed,
.destroy = _zero_destroy, .destroy = _zero_destroy,
}; };