mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-09 01:18:39 +03:00
9dbe25709e
New tools with PV header extension support will read the extension if it exists and it's not an error if it does not exist (so old PVs will still work seamlessly with new tools). Old tools without PV header extension support will just ignore any extension. As for the Embedding Area location information (its start and size), there are actually two places where this is stored: - PV header extension - VG metadata The VG metadata contains a copy of what's written in the PV header extension about the Embedding Area location (NULL value is not copied): physical_volumes { pv0 { id = "AkSSRf-difg-fCCZ-NjAN-qP49-1zzg-S0Fd4T" device = "/dev/sda" # Hint only status = ["ALLOCATABLE"] flags = [] dev_size = 262144 # 128 Megabytes pe_start = 67584 pe_count = 23 # 92 Megabytes ea_start = 2048 ea_size = 65536 # 32 Megabytes } } The new metadata fields are "ea_start" and "ea_size". This is mostly useful when restoring the PV by using existing metadata backups (e.g. pvcreate --restorefile ...). New tools does not require these two fields to exist in VG metadata, they're not compulsory. Therefore, reading old VG metadata which doesn't contain any Embedding Area information will not end up with any kind of error but only a debug message that the ea_start and ea_size values were not found. Old tools just ignore these extra fields in VG metadata.
98 lines
3.3 KiB
C
98 lines
3.3 KiB
C
/*
|
|
* Copyright (C) 2001-2004 Sistina Software, Inc. All rights reserved.
|
|
* Copyright (C) 2004-2010 Red Hat, Inc. All rights reserved.
|
|
*
|
|
* This file is part of LVM2.
|
|
*
|
|
* This copyrighted material is made available to anyone wishing to use,
|
|
* modify, copy, or redistribute it subject to the terms and conditions
|
|
* of the GNU Lesser General Public License v.2.1.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with this program; if not, write to the Free Software Foundation,
|
|
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*/
|
|
#ifndef _LVM_PV_H
|
|
#define _LVM_PV_H
|
|
|
|
struct id;
|
|
struct device;
|
|
struct format_type;
|
|
struct volume_group;
|
|
|
|
struct physical_volume {
|
|
struct id id;
|
|
struct id old_id; /* Set during pvchange -u. */
|
|
struct device *dev;
|
|
const struct format_type *fmt;
|
|
struct format_instance *fid;
|
|
|
|
/*
|
|
* vg_name and vgid are used before the parent VG struct exists.
|
|
* FIXME: Investigate removal/substitution with 'vg' fields.
|
|
*/
|
|
const char *vg_name;
|
|
struct id vgid;
|
|
|
|
/*
|
|
* 'vg' is set and maintained when the PV belongs to a 'pvs'
|
|
* list in a parent VG struct.
|
|
*/
|
|
struct volume_group *vg;
|
|
|
|
uint64_t status;
|
|
uint64_t size;
|
|
|
|
/* embedding area */
|
|
uint64_t ea_start;
|
|
uint64_t ea_size;
|
|
|
|
/* physical extents */
|
|
uint32_t pe_size;
|
|
uint64_t pe_start;
|
|
uint32_t pe_count;
|
|
uint32_t pe_alloc_count;
|
|
unsigned long pe_align;
|
|
unsigned long pe_align_offset;
|
|
|
|
/* This is true whenever the represented PV has a label associated. */
|
|
uint64_t is_labelled:1;
|
|
|
|
/* NB. label_sector is valid whenever is_labelled is true */
|
|
uint64_t label_sector;
|
|
|
|
struct dm_list segments; /* Ordered pv_segments covering complete PV */
|
|
struct dm_list tags;
|
|
};
|
|
|
|
char *pv_fmt_dup(const struct physical_volume *pv);
|
|
char *pv_name_dup(const struct physical_volume *pv);
|
|
struct device *pv_dev(const struct physical_volume *pv);
|
|
const char *pv_vg_name(const struct physical_volume *pv);
|
|
char *pv_attr_dup(struct dm_pool *mem, const struct physical_volume *pv);
|
|
const char *pv_dev_name(const struct physical_volume *pv);
|
|
char *pv_uuid_dup(const struct physical_volume *pv);
|
|
char *pv_tags_dup(const struct physical_volume *pv);
|
|
uint64_t pv_size(const struct physical_volume *pv);
|
|
uint64_t pv_size_field(const struct physical_volume *pv);
|
|
uint64_t pv_dev_size(const struct physical_volume *pv);
|
|
uint64_t pv_free(const struct physical_volume *pv);
|
|
uint64_t pv_status(const struct physical_volume *pv);
|
|
uint32_t pv_pe_size(const struct physical_volume *pv);
|
|
uint64_t pv_pe_start(const struct physical_volume *pv);
|
|
uint64_t pv_ea_start(const struct physical_volume *pv);
|
|
uint64_t pv_ea_size(const struct physical_volume *pv);
|
|
uint32_t pv_pe_count(const struct physical_volume *pv);
|
|
uint32_t pv_pe_alloc_count(const struct physical_volume *pv);
|
|
uint64_t pv_mda_size(const struct physical_volume *pv);
|
|
uint64_t pv_mda_free(const struct physical_volume *pv);
|
|
uint64_t pv_used(const struct physical_volume *pv);
|
|
uint32_t pv_mda_count(const struct physical_volume *pv);
|
|
uint32_t pv_mda_used_count(const struct physical_volume *pv);
|
|
unsigned pv_mda_set_ignored(const struct physical_volume *pv, unsigned ignored);
|
|
int is_orphan(const struct physical_volume *pv);
|
|
int is_missing_pv(const struct physical_volume *pv);
|
|
int is_pv(const struct physical_volume *pv);
|
|
|
|
#endif /* _LVM_PV_H */
|