struct physical_volume;
struct volume_group;
struct logical_volume;
+struct lv_segment;
/**
* \class lvm_t
*/
typedef struct physical_volume *pv_t;
+/**
+ * \class lvseg_t
+ *
+ * This lv segment object is bound to a lv_t.
+ */
+typedef struct lv_segment *lvseg_t;
+
/**
* Logical Volume object list.
*
lv_t lv;
} lv_list_t;
+/**
+ * Logical Volume Segment object list.
+ *
+ * Lists of these structures are returned by lvm_lv_list_lvsegs().
+ */
+typedef struct lvm_lvseg_list {
+ struct dm_list list;
+ lvseg_t lvseg;
+} lvseg_list_t;
+
/**
* Physical volume object list.
*
*/
lv_t lvm_vg_create_lv_linear(vg_t vg, const char *name, uint64_t size);
+/**
+ * Return a list of lvseg handles for a given LV handle.
+ *
+ * \memberof lv_t
+ *
+ * \param lv
+ * Logical volume handle.
+ *
+ * \return
+ * A list of lvm_lvseg_list structures containing lvseg handles for this lv.
+ */
+struct dm_list *lvm_lv_list_lvsegs(lv_t lv);
+
/**
* Activate a logical volume.
*
return 0;
}
+struct dm_list *lvm_lv_list_lvsegs(lv_t lv)
+{
+ struct dm_list *list;
+ lvseg_list_t *lvseg;
+ struct lv_segment *lvl;
+
+ if (dm_list_empty(&lv->segments))
+ return NULL;
+
+ if (!(list = dm_pool_zalloc(lv->vg->vgmem, sizeof(*list)))) {
+ log_errno(ENOMEM, "Memory allocation fail for dm_list.");
+ return NULL;
+ }
+ dm_list_init(list);
+
+ dm_list_iterate_items(lvl, &lv->segments) {
+ if (!(lvseg = dm_pool_zalloc(lv->vg->vgmem, sizeof(*lvseg)))) {
+ log_errno(ENOMEM,
+ "Memory allocation fail for lvm_lvseg_list.");
+ return NULL;
+ }
+ lvseg->lvseg = lvl;
+ dm_list_add(list, &lvseg->list);
+ }
+ return list;
+}
+
int lvm_lv_resize(const lv_t lv, uint64_t new_size)
{
/* FIXME: add lv resize code here */