mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
Add get_pv_* functions to return PV fields in prep for external LVM library
This commit is contained in:
parent
4e5f3e7331
commit
0e2f6120ee
@ -1,5 +1,6 @@
|
||||
Version 2.02.26 -
|
||||
=================================
|
||||
Add get_pv_* functions to return PV members (external LVM library).
|
||||
Add wrappers to some functions in preparation for external LVM library.
|
||||
Allow vgcfgrestore to list metadata backup files using -f
|
||||
Add vg_check_status to consolidate vg status checks and error messages.
|
||||
|
@ -28,6 +28,12 @@
|
||||
|
||||
#include <sys/param.h>
|
||||
|
||||
/*
|
||||
* FIXME: Check for valid handle before dereferencing member or log error?
|
||||
*/
|
||||
#define PV_HANDLE_DEREF(H, M) \
|
||||
(((struct physical_volume *)H)->M)
|
||||
|
||||
static struct physical_volume *_pv_read(struct cmd_context *cmd,
|
||||
const char *pv_name,
|
||||
struct list *mdas,
|
||||
@ -1452,7 +1458,21 @@ struct logical_volume *lv_from_lvid(struct cmd_context *cmd, const char *lvid_s,
|
||||
return lvl->lv;
|
||||
}
|
||||
|
||||
/* FIXME: liblvm todo - make into function that returns handle */
|
||||
/**
|
||||
* pv_read - read and return a handle to a physical volume
|
||||
* @cmd: LVM command initiating the pv_read
|
||||
* @pv_name: full device name of the PV, including the path
|
||||
* @mdas: list of metadata areas of the PV
|
||||
* @label_sector: sector number where the PV label is stored on @pv_name
|
||||
* @warnings:
|
||||
*
|
||||
* Returns:
|
||||
* PV handle - valid pv_name and successful read of the PV, or
|
||||
* NULL - invalid parameter or error in reading the PV
|
||||
*
|
||||
* Note:
|
||||
* FIXME - liblvm todo - make into function that returns handle
|
||||
*/
|
||||
struct physical_volume *pv_read(struct cmd_context *cmd, const char *pv_name,
|
||||
struct list *mdas, uint64_t *label_sector,
|
||||
int warnings)
|
||||
@ -1684,7 +1704,6 @@ int pv_analyze(struct cmd_context *cmd, const char *pv_name,
|
||||
|
||||
/**
|
||||
* vg_check_status - check volume group status flags and log error
|
||||
*
|
||||
* @vg - volume group to check status flags
|
||||
* @status_flags - specific status flags to check (e.g. EXPORTED_VG)
|
||||
*
|
||||
@ -1720,3 +1739,62 @@ int vg_check_status(struct volume_group *vg, uint32_t status_flags)
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Gets/Sets for external LVM library
|
||||
*/
|
||||
struct id get_pv_id (void *pv_handle)
|
||||
{
|
||||
return PV_HANDLE_DEREF(pv_handle, id);
|
||||
}
|
||||
|
||||
const struct format_type *get_pv_format_type (void *pv_handle)
|
||||
{
|
||||
return PV_HANDLE_DEREF(pv_handle, fmt);
|
||||
}
|
||||
|
||||
struct id get_pv_vgid (void *pv_handle)
|
||||
{
|
||||
return PV_HANDLE_DEREF(pv_handle, vgid);
|
||||
}
|
||||
|
||||
struct device *get_pv_dev (void *pv_handle)
|
||||
{
|
||||
return PV_HANDLE_DEREF(pv_handle, dev);
|
||||
}
|
||||
|
||||
const char *get_pv_vg_name (void *pv_handle)
|
||||
{
|
||||
return PV_HANDLE_DEREF(pv_handle, vg_name);
|
||||
}
|
||||
|
||||
uint64_t get_pv_size(void *pv_handle)
|
||||
{
|
||||
return PV_HANDLE_DEREF(pv_handle, size);
|
||||
}
|
||||
|
||||
uint32_t get_pv_status (void *pv_handle)
|
||||
{
|
||||
return PV_HANDLE_DEREF(pv_handle, status);
|
||||
}
|
||||
|
||||
uint32_t get_pv_pe_size (void *pv_handle)
|
||||
{
|
||||
return PV_HANDLE_DEREF(pv_handle, pe_size);
|
||||
}
|
||||
|
||||
uint64_t get_pv_pe_start (void *pv_handle)
|
||||
{
|
||||
return PV_HANDLE_DEREF(pv_handle, pe_start);
|
||||
}
|
||||
|
||||
uint32_t get_pv_pe_count (void *pv_handle)
|
||||
{
|
||||
return PV_HANDLE_DEREF(pv_handle, pe_count);
|
||||
}
|
||||
|
||||
uint32_t get_pv_pe_alloc_count (void *pv_handle)
|
||||
{
|
||||
return PV_HANDLE_DEREF(pv_handle, pe_alloc_count);
|
||||
}
|
||||
|
@ -635,4 +635,19 @@ uint32_t find_free_lvnum(struct logical_volume *lv);
|
||||
char *generate_lv_name(struct volume_group *vg, const char *format,
|
||||
char *buffer, size_t len);
|
||||
|
||||
/*
|
||||
* Gets/Sets for external LVM library
|
||||
*/
|
||||
struct id get_pv_id (void *pv_handle);
|
||||
const struct format_type *get_pv_format_type (void *pv_handle);
|
||||
struct id get_pv_vgid (void *pv_handle);
|
||||
struct device *get_pv_dev (void *pv_handle);
|
||||
const char *get_pv_vg_name (void *pv_handle);
|
||||
uint64_t get_pv_size(void *pv_handle);
|
||||
uint32_t get_pv_status (void *pv_handle);
|
||||
uint32_t get_pv_pe_size (void *pv_handle);
|
||||
uint64_t get_pv_pe_start (void *pv_handle);
|
||||
uint32_t get_pv_pe_count (void *pv_handle);
|
||||
uint32_t get_pv_pe_alloc_count (void *pv_handle);
|
||||
|
||||
#endif
|
||||
|
Loading…
Reference in New Issue
Block a user