Version 2.02.73 -
================================
+ Monitor origin -real device below snapshot instead of overlay device.
Don't really change monitoring status when in test mode.
Fix some exit statuses when starting/stopping monitoring fails.
Enable snapshot monitoring by default when dmeventd is enabled.
return path;
}
-int target_registered_with_dmeventd(struct cmd_context *cmd, const char *dso, const char *lvid, int *pending)
+int target_registered_with_dmeventd(struct cmd_context *cmd, const char *dso,
+ struct logical_volume *lv, int *pending)
{
char *uuid;
enum dm_event_mask evmask = 0;
if (!dso)
return_0;
- if (!(uuid = build_dm_uuid(cmd->mem, lvid, NULL)))
+ /* We always monitor the "real" device, never the "snapshot-origin" itself. */
+ if (!(uuid = build_dm_uuid(cmd->mem, lv->lvid.s, lv_is_origin(lv) ? "real" : NULL)))
return_0;
if (!(dmevh = _create_dm_event_handler(cmd, uuid, dso, 0, DM_EVENT_ALL_ERRORS)))
return evmask;
}
-int target_register_events(struct cmd_context *cmd, const char *dso, const char *lvid,
+int target_register_events(struct cmd_context *cmd, const char *dso, struct logical_volume *lv,
int evmask __attribute__((unused)), int set, int timeout)
{
char *uuid;
if (!dso)
return_0;
- if (!(uuid = build_dm_uuid(cmd->mem, lvid, NULL)))
+ /* We always monitor the "real" device, never the "snapshot-origin" itself. */
+ if (!(uuid = build_dm_uuid(cmd->mem, lv->lvid.s, lv_is_origin(lv) ? "real" : NULL)))
return_0;
if (!(dmevh = _create_dm_event_handler(cmd, uuid, dso, timeout,
/*
* In case this LV is a snapshot origin, we instead monitor
- * each of its respective snapshots (the origin itself does
- * not need to be monitored).
- *
- * TODO: This may change when snapshots of mirrors are allowed.
+ * each of its respective snapshots. The origin itself may
+ * also need to be monitored if it is a mirror, for example.
*/
- if (lv_is_origin(lv)) {
+ if (lv_is_origin(lv))
dm_list_iterate_safe(snh, snht, &lv->snapshot_segs)
if (!monitor_dev_for_events(cmd, dm_list_struct_base(snh,
struct lv_segment, origin_list)->cow, monitor))
r = 0;
- return r;
- }
/*
* If the volume is mirrored and its log is also mirrored, monitor
#ifdef DMEVENTD
# include "libdevmapper-event.h"
char *get_monitor_dso_path(struct cmd_context *cmd, const char *libpath);
-int target_registered_with_dmeventd(struct cmd_context *cmd, const char *libpath, const char *lvid, int *pending);
-int target_register_events(struct cmd_context *cmd, const char *dso, const char *lvid,
+int target_registered_with_dmeventd(struct cmd_context *cmd, const char *libpath,
+ struct logical_volume *lv, int *pending);
+int target_register_events(struct cmd_context *cmd, const char *dso, struct logical_volume *lv,
int evmask __attribute__((unused)), int set, int timeout);
#endif
DEFAULT_DMEVENTD_MIRROR_LIB));
}
+/* FIXME Cache this */
static int _target_registered(struct lv_segment *seg, int *pending)
{
return target_registered_with_dmeventd(seg->lv->vg->cmd, _get_mirror_dso_path(seg->lv->vg->cmd),
- seg->lv->lvid.s, pending);
+ seg->lv, pending);
}
/* FIXME This gets run while suspended and performs banned operations. */
static int _target_set_events(struct lv_segment *seg, int evmask, int set)
{
return target_register_events(seg->lv->vg->cmd, _get_mirror_dso_path(seg->lv->vg->cmd),
- seg->lv->lvid.s, evmask, set, 0);
+ seg->lv, evmask, set, 0);
}
static int _target_monitor_events(struct lv_segment *seg, int events)
DEFAULT_DMEVENTD_SNAPSHOT_LIB));
}
+/* FIXME Cache this */
static int _target_registered(struct lv_segment *seg, int *pending)
{
return target_registered_with_dmeventd(seg->lv->vg->cmd, _get_snapshot_dso_path(seg->lv->vg->cmd),
- seg->cow->lvid.s, pending);
+ seg->cow, pending);
}
/* FIXME This gets run while suspended and performs banned operations. */
{
/* FIXME Make timeout (10) configurable */
return target_register_events(seg->lv->vg->cmd, _get_snapshot_dso_path(seg->lv->vg->cmd),
- seg->cow->lvid.s, evmask, set, 10);
+ seg->cow, evmask, set, 10);
}
static int _target_register_events(struct lv_segment *seg,
static int _vgchange_available(struct cmd_context *cmd, struct volume_group *vg)
{
- int lv_open, active, monitored;
+ int lv_open, active, monitored = 0;
int available, ret_max = ECMD_PROCESSED;
int activate = 1;