]> sourceware.org Git - lvm2.git/commitdiff
report: show dmeventd monitoring status
authorZdenek Kabelac <zkabelac@redhat.com>
Thu, 25 Apr 2013 10:07:57 +0000 (12:07 +0200)
committerZdenek Kabelac <zkabelac@redhat.com>
Thu, 25 Apr 2013 15:33:24 +0000 (17:33 +0200)
Add new lvs segment field 'Monitor' showing 3 states:

"monitored" - LV is monitored by dmeventd.

"not monitored" - LV is currently not being monitored by dmeventd

"" (empty) - LV does not support monitoring, or dmeventd support
             is not compiled in.

WHATS_NEW
lib/metadata/lv.c
lib/metadata/lv.h
lib/report/columns.h
lib/report/properties.c
lib/report/report.c

index 27ebcecf67d78e0850392c9f3528184852e83699..a625dbaabbe8b04e1a6090e3b6f8413e2fb591ef 100644 (file)
--- a/WHATS_NEW
+++ b/WHATS_NEW
@@ -1,5 +1,6 @@
 Version 2.02.99 - 
 ===================================
+  Add "monitor" segment reporting field to show dmevent monitoring status.
   Document lvextend --use-policies option in man.
   Fix creation and removal of clustered snapshot.
   Fix clvmd caching of metadata when suspending inactive volumes.
index 6afa468f41f2ede87fdcb3378ef5758a75c5e02f..e515e02224671240a4158212c75e7f04ee4df744 100644 (file)
@@ -128,6 +128,40 @@ char *lvseg_discards_dup(struct dm_pool *mem, const struct lv_segment *seg)
        return  dm_pool_strdup(mem, get_pool_discards_name(seg->discards));
 }
 
+#ifdef DMEVENTD
+#  include "libdevmapper-event.h"
+#endif
+char *lvseg_monitor_dup(struct dm_pool *mem, const struct lv_segment *seg)
+{
+       const char *s = "";
+
+#ifdef DMEVENTD
+       struct lvinfo info;
+       int pending = 0, monitored;
+       struct lv_segment *segm = (struct lv_segment *) seg;
+
+       if (lv_is_cow(seg->lv) && !lv_is_merging_cow(seg->lv))
+               segm = first_seg(seg->lv->snapshot->lv);
+       else if (seg->log_lv)
+               segm = first_seg(seg->log_lv);
+
+       // log_debug("Query LV:%s mon:%s segm:%s tgtm:%p  segmon:%d statusm:%d", seg->lv->name, segm->lv->name, segm->segtype->name, segm->segtype->ops->target_monitored, seg_monitored(segm), (int)(segm->status & PVMOVE));
+       if (!segm->segtype->ops->target_monitored)
+               /* Nothing to do, monitoring not supported */;
+       else if (!seg_monitored(segm) || (segm->status & PVMOVE))
+               s = "not monitored";
+       else if (lv_info(seg->lv->vg->cmd, seg->lv, 1, &info, 0, 0) && info.exists) {
+               monitored = segm->segtype->ops->
+                       target_monitored((struct lv_segment*)segm, &pending);
+               if (pending)
+                       s = "pending";
+               else
+                       s = (monitored) ? "monitored" : "not monitored";
+       } // else log_debug("Not active");
+#endif
+       return dm_pool_strdup(mem, s);
+}
+
 uint64_t lvseg_chunksize(const struct lv_segment *seg)
 {
        uint64_t size;
index 03255fbffe873e9bb0f387d4e4a148e467175306..7652cd49225662c02df479fe214f7d91766455c6 100644 (file)
@@ -76,6 +76,7 @@ uint64_t lvseg_size(const struct lv_segment *seg);
 uint64_t lvseg_chunksize(const struct lv_segment *seg);
 char *lvseg_segtype_dup(struct dm_pool *mem, const struct lv_segment *seg);
 char *lvseg_discards_dup(struct dm_pool *mem, const struct lv_segment *seg);
+char *lvseg_monitor_dup(struct dm_pool *mem, const struct lv_segment *seg);
 char *lvseg_tags_dup(const struct lv_segment *seg);
 char *lvseg_devices(struct dm_pool *mem, const struct lv_segment *seg);
 char *lvseg_seg_pe_ranges(struct dm_pool *mem, const struct lv_segment *seg);
index 42858f149502076dae3093fb0328393b1f7581ad..07c9b7bb4c7777ff27e2a195de6073076e0281fa 100644 (file)
@@ -155,6 +155,7 @@ FIELD(SEGS, seg, NUM, "SSize", list, 5, segsize, seg_size, "Size of segment in c
 FIELD(SEGS, seg, STR, "Seg Tags", tags, 8, tags, seg_tags, "Tags, if any.", 0)
 FIELD(SEGS, seg, STR, "PE Ranges", list, 9, peranges, seg_pe_ranges, "Ranges of Physical Extents of underlying devices in command line format.", 0)
 FIELD(SEGS, seg, STR, "Devices", list, 7, devices, devices, "Underlying devices used with starting extent numbers.", 0)
+FIELD(SEGS, seg, STR, "Monitor", list, 7, segmonitor, monitor, "Dmeventd monitoring status of the segment.", 0)
 
 FIELD(PVSEGS, pvseg, NUM, "Start", pe, 5, uint32, pvseg_start, "Physical Extent number of start of segment.", 0)
 FIELD(PVSEGS, pvseg, NUM, "SSize", len, 5, uint32, pvseg_size, "Number of extents in segment.", 0)
index 71b3cb147a3014472731ab954e0d970302e3035f..6f0d98069f90579fe7a635bbdf5856deabf6b759 100644 (file)
@@ -332,6 +332,8 @@ GET_LVSEG_STR_PROPERTY_FN(seg_pe_ranges,
 #define _seg_pe_ranges_set _not_implemented_set
 GET_LVSEG_STR_PROPERTY_FN(devices, lvseg_devices(lvseg->lv->vg->vgmem, lvseg))
 #define _devices_set _not_implemented_set
+GET_LVSEG_STR_PROPERTY_FN(monitor, lvseg_monitor_dup(lvseg->lv->vg->vgmem, lvseg))
+#define _monitor_set _not_implemented_set
 
 
 /* PVSEG */
index 8578ff719a2d464592f63ae78cef8a41a5afd9ac..9ef2687bdbdf5d50e78fde519c6742f4940f7f3f 100644 (file)
@@ -489,6 +489,20 @@ static int _vgsize_disp(struct dm_report *rh, struct dm_pool *mem,
        return _size64_disp(rh, mem, field, &size, private);
 }
 
+static int _segmonitor_disp(struct dm_report *rh, struct dm_pool *mem,
+                           struct dm_report_field *field,
+                           const void *data, void *private)
+{
+       char *str;
+
+       if (!(str = lvseg_monitor_dup(mem, (const struct lv_segment *)data)))
+               return_0;
+
+       dm_report_field_set_value(field, str, NULL);
+
+       return 1;
+}
+
 static int _segstart_disp(struct dm_report *rh, struct dm_pool *mem,
                          struct dm_report_field *field,
                          const void *data, void *private)
This page took 0.049106 seconds and 5 git commands to generate.