public inbox for lvm2-cvs@sourceware.org help / color / mirror / Atom feed
From: mornfall@sourceware.org To: lvm-devel@redhat.com, lvm2-cvs@sourceware.org Subject: LVM2/liblvm lvm2app.h lvm_lv.c lvm_pv.c Date: Thu, 25 Nov 2010 14:34:00 -0000 [thread overview] Message-ID: <20101125143456.10117.qmail@sourceware.org> (raw) CVSROOT: /cvs/lvm2 Module name: LVM2 Changes by: mornfall@sourceware.org 2010-11-25 14:34:52 Modified files: liblvm : lvm2app.h lvm_lv.c lvm_pv.c Log message: This patch adds helpers to allow users to lookup a lv or pv handle by uuid (given a vg_t of course). Signed-off-by: Dave Wysochanski <wysochanski@pobox.com> Reviewed-by: Petr Rockai <prockai@redhat.com> Patches: http://sourceware.org/cgi-bin/cvsweb.cgi/LVM2/liblvm/lvm2app.h.diff?cvsroot=lvm2&r1=1.29&r2=1.30 http://sourceware.org/cgi-bin/cvsweb.cgi/LVM2/liblvm/lvm_lv.c.diff?cvsroot=lvm2&r1=1.32&r2=1.33 http://sourceware.org/cgi-bin/cvsweb.cgi/LVM2/liblvm/lvm_pv.c.diff?cvsroot=lvm2&r1=1.18&r2=1.19 --- LVM2/liblvm/lvm2app.h 2010/11/25 14:33:44 1.29 +++ LVM2/liblvm/lvm2app.h 2010/11/25 14:34:51 1.30 @@ -1032,6 +1032,25 @@ lv_t lvm_lv_from_name(vg_t vg, const char *name); /** + * Lookup an LV handle in a VG by the LV uuid. + * The form of the uuid may be either the formatted, human-readable form, + * or the non-formatted form. + * + * \memberof lv_t + * + * \param vg + * VG handle obtained from lvm_vg_create() or lvm_vg_open(). + * + * \param uuid + * UUID of LV to lookup. + * + * \return + * non-NULL handle to the LV with 'uuid' attached to the VG. + * NULL is returned if the LV uuid is not associated with the VG handle. + */ +lv_t lvm_lv_from_uuid(vg_t vg, const char *uuid); + +/** * Activate a logical volume. * * \memberof lv_t @@ -1523,6 +1542,25 @@ pv_t lvm_pv_from_name(vg_t vg, const char *name); /** + * Lookup an PV handle in a VG by the PV uuid. + * The form of the uuid may be either the formatted, human-readable form, + * or the non-formatted form. + * + * \memberof pv_t + * + * \param vg + * VG handle obtained from lvm_vg_create() or lvm_vg_open(). + * + * \param uuid + * UUID of PV to lookup. + * + * \return + * non-NULL handle to the PV with 'uuid' attached to the VG. + * NULL is returned if the PV uuid is not associated with the VG handle. + */ +pv_t lvm_pv_from_uuid(vg_t vg, const char *uuid); + +/** * Resize physical volume to new_size bytes. * * \memberof pv_t --- LVM2/liblvm/lvm_lv.c 2010/11/25 14:33:44 1.32 +++ LVM2/liblvm/lvm_lv.c 2010/11/25 14:34:51 1.33 @@ -260,6 +260,28 @@ return NULL; } +lv_t lvm_lv_from_uuid(vg_t vg, const char *uuid) +{ + struct lv_list *lvl; + struct id id; + + if (strlen(uuid) < ID_LEN) { + log_errno (EINVAL, "Invalid UUID string length"); + return NULL; + } + if (strlen(uuid) >= ID_LEN) { + if (!id_read_format(&id, uuid)) { + log_errno(EINVAL, "Invalid UUID format"); + return NULL; + } + } + dm_list_iterate_items(lvl, &vg->lvs) { + if (id_equal(&vg->id, &lvl->lv->lvid.id[0]) && + id_equal(&id, &lvl->lv->lvid.id[1])) + return lvl->lv; + } + return NULL; +} int lvm_lv_resize(const lv_t lv, uint64_t new_size) { /* FIXME: add lv resize code here */ --- LVM2/liblvm/lvm_pv.c 2010/11/25 14:33:44 1.18 +++ LVM2/liblvm/lvm_pv.c 2010/11/25 14:34:51 1.19 @@ -98,6 +98,28 @@ return NULL; } +pv_t lvm_pv_from_uuid(vg_t vg, const char *uuid) +{ + struct pv_list *pvl; + struct id id; + + if (strlen(uuid) < ID_LEN) { + log_errno (EINVAL, "Invalid UUID string length"); + return NULL; + } + if (strlen(uuid) >= ID_LEN) { + if (!id_read_format(&id, uuid)) { + log_errno(EINVAL, "Invalid UUID format"); + return NULL; + } + } + dm_list_iterate_items(pvl, &vg->pvs) { + if (id_equal(&id, &pvl->pv->id)) + return pvl->pv; + } + return NULL; +} + int lvm_pv_resize(const pv_t pv, uint64_t new_size) {
next reply other threads:[~2010-11-25 14:34 UTC|newest] Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top 2010-11-25 14:34 mornfall [this message] -- strict thread matches above, loose matches on Subject: below -- 2010-11-25 14:33 mornfall
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20101125143456.10117.qmail@sourceware.org \ --to=mornfall@sourceware.org \ --cc=lvm-devel@redhat.com \ --cc=lvm2-cvs@sourceware.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).