mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-06 17:18:29 +03:00
86f9271457
If duplicate orphan PVs exist, don't allow one of them to be used for vgcreate/pvcreate/vgextend.
219 lines
8.6 KiB
C
219 lines
8.6 KiB
C
/*
|
|
* Copyright (C) 2001-2004 Sistina Software, Inc. All rights reserved.
|
|
* Copyright (C) 2004-2008 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#ifndef _LVM_CACHE_H
|
|
#define _LVM_CACHE_H
|
|
|
|
#include "dev-cache.h"
|
|
#include "dev-type.h"
|
|
#include "uuid.h"
|
|
#include "label.h"
|
|
#include "locking.h"
|
|
|
|
#define ORPHAN_PREFIX VG_ORPHANS
|
|
#define ORPHAN_VG_NAME(fmt) ORPHAN_PREFIX "_" fmt
|
|
|
|
/* LVM specific per-volume info */
|
|
/* Eventual replacement for struct physical_volume perhaps? */
|
|
|
|
struct cmd_context;
|
|
struct format_type;
|
|
struct volume_group;
|
|
struct physical_volume;
|
|
struct dm_config_tree;
|
|
struct format_instance;
|
|
struct metadata_area;
|
|
struct disk_locn;
|
|
|
|
struct lvmcache_vginfo;
|
|
|
|
/*
|
|
* vgsummary represents a summary of the VG that is read
|
|
* without a lock. The info does not come through vg_read(),
|
|
* but through reading mdas. It provides information about
|
|
* the VG that is needed to lock the VG and then read it fully
|
|
* with vg_read(), after which the VG summary should be checked
|
|
* against the full VG metadata to verify it was correct (since
|
|
* it was read without a lock.)
|
|
*
|
|
* Once read, vgsummary information is saved in lvmcache_vginfo.
|
|
*/
|
|
struct lvmcache_vgsummary {
|
|
const char *vgname;
|
|
struct id vgid;
|
|
uint64_t vgstatus;
|
|
char *creation_host;
|
|
const char *system_id;
|
|
const char *lock_type;
|
|
uint32_t mda_checksum;
|
|
size_t mda_size;
|
|
};
|
|
|
|
int lvmcache_init(void);
|
|
void lvmcache_allow_reads_with_lvmetad(void);
|
|
|
|
void lvmcache_destroy(struct cmd_context *cmd, int retain_orphans, int reset);
|
|
|
|
/*
|
|
* lvmcache_label_scan() will scan labels the first time it's
|
|
* called, but not on subsequent calls, unless
|
|
* lvmcache_force_next_label_scan() is called first
|
|
* to force the next lvmcache_label_scan() to scan again.
|
|
*/
|
|
void lvmcache_force_next_label_scan(void);
|
|
int lvmcache_label_scan(struct cmd_context *cmd);
|
|
|
|
/* Add/delete a device */
|
|
struct lvmcache_info *lvmcache_add(struct labeller *labeller, const char *pvid,
|
|
struct device *dev,
|
|
const char *vgname, const char *vgid,
|
|
uint32_t vgstatus);
|
|
int lvmcache_add_orphan_vginfo(const char *vgname, struct format_type *fmt);
|
|
void lvmcache_del(struct lvmcache_info *info);
|
|
|
|
/* Update things */
|
|
int lvmcache_update_vgname_and_id(struct lvmcache_info *info,
|
|
struct lvmcache_vgsummary *vgsummary);
|
|
int lvmcache_update_vg(struct volume_group *vg, unsigned precommitted);
|
|
|
|
void lvmcache_lock_vgname(const char *vgname, int read_only);
|
|
void lvmcache_unlock_vgname(const char *vgname);
|
|
int lvmcache_verify_lock_order(const char *vgname);
|
|
|
|
/* Queries */
|
|
const struct format_type *lvmcache_fmt_from_vgname(struct cmd_context *cmd, const char *vgname, const char *vgid, unsigned revalidate_labels);
|
|
int lvmcache_lookup_mda(struct lvmcache_vgsummary *vgsummary);
|
|
|
|
/* Decrement and test if there are still vg holders in vginfo. */
|
|
int lvmcache_vginfo_holders_dec_and_test_for_zero(struct lvmcache_vginfo *vginfo);
|
|
|
|
struct lvmcache_vginfo *lvmcache_vginfo_from_vgname(const char *vgname,
|
|
const char *vgid);
|
|
struct lvmcache_vginfo *lvmcache_vginfo_from_vgid(const char *vgid);
|
|
struct lvmcache_info *lvmcache_info_from_pvid(const char *pvid, struct device *dev, int valid_only);
|
|
const char *lvmcache_vgname_from_vgid(struct dm_pool *mem, const char *vgid);
|
|
const char *lvmcache_vgid_from_vgname(struct cmd_context *cmd, const char *vgname);
|
|
struct device *lvmcache_device_from_pvid(struct cmd_context *cmd, const struct id *pvid,
|
|
unsigned *scan_done_once, uint64_t *label_sector);
|
|
const char *lvmcache_pvid_from_devname(struct cmd_context *cmd,
|
|
const char *devname);
|
|
char *lvmcache_vgname_from_pvid(struct cmd_context *cmd, const char *pvid);
|
|
const char *lvmcache_vgname_from_info(struct lvmcache_info *info);
|
|
const struct format_type *lvmcache_fmt_from_info(struct lvmcache_info *info);
|
|
int lvmcache_vgs_locked(void);
|
|
int lvmcache_vgname_is_locked(const char *vgname);
|
|
|
|
void lvmcache_seed_infos_from_lvmetad(struct cmd_context *cmd);
|
|
|
|
/* Returns list of struct dm_str_list containing pool-allocated copy of vgnames */
|
|
/* If include_internal is not set, return only proper vg names. */
|
|
struct dm_list *lvmcache_get_vgnames(struct cmd_context *cmd,
|
|
int include_internal);
|
|
|
|
/* Returns list of struct dm_str_list containing pool-allocated copy of vgids */
|
|
/* If include_internal is not set, return only proper vg ids. */
|
|
struct dm_list *lvmcache_get_vgids(struct cmd_context *cmd,
|
|
int include_internal);
|
|
|
|
int lvmcache_get_vgnameids(struct cmd_context *cmd, int include_internal,
|
|
struct dm_list *vgnameids);
|
|
|
|
/* Returns list of struct dm_str_list containing pool-allocated copy of pvids */
|
|
struct dm_list *lvmcache_get_pvids(struct cmd_context *cmd, const char *vgname,
|
|
const char *vgid);
|
|
|
|
/* Returns cached volume group metadata. */
|
|
struct volume_group *lvmcache_get_vg(struct cmd_context *cmd, const char *vgname,
|
|
const char *vgid, unsigned precommitted);
|
|
void lvmcache_drop_metadata(const char *vgname, int drop_precommitted);
|
|
void lvmcache_commit_metadata(const char *vgname);
|
|
|
|
int lvmcache_pvid_is_locked(const char *pvid);
|
|
int lvmcache_fid_add_mdas(struct lvmcache_info *info, struct format_instance *fid,
|
|
const char *id, int id_len);
|
|
int lvmcache_fid_add_mdas_pv(struct lvmcache_info *info, struct format_instance *fid);
|
|
int lvmcache_fid_add_mdas_vg(struct lvmcache_vginfo *vginfo, struct format_instance *fid);
|
|
int lvmcache_populate_pv_fields(struct lvmcache_info *info,
|
|
struct physical_volume *pv,
|
|
int scan_label_only);
|
|
int lvmcache_check_format(struct lvmcache_info *info, const struct format_type *fmt);
|
|
void lvmcache_del_mdas(struct lvmcache_info *info);
|
|
void lvmcache_del_das(struct lvmcache_info *info);
|
|
void lvmcache_del_bas(struct lvmcache_info *info);
|
|
int lvmcache_add_mda(struct lvmcache_info *info, struct device *dev,
|
|
uint64_t start, uint64_t size, unsigned ignored);
|
|
int lvmcache_add_da(struct lvmcache_info *info, uint64_t start, uint64_t size);
|
|
int lvmcache_add_ba(struct lvmcache_info *info, uint64_t start, uint64_t size);
|
|
|
|
void lvmcache_set_ext_version(struct lvmcache_info *info, uint32_t version);
|
|
uint32_t lvmcache_ext_version(struct lvmcache_info *info);
|
|
void lvmcache_set_ext_flags(struct lvmcache_info *info, uint32_t flags);
|
|
uint32_t lvmcache_ext_flags(struct lvmcache_info *info);
|
|
|
|
const struct format_type *lvmcache_fmt(struct lvmcache_info *info);
|
|
struct label *lvmcache_get_label(struct lvmcache_info *info);
|
|
|
|
void lvmcache_update_pv(struct lvmcache_info *info, struct physical_volume *pv,
|
|
const struct format_type *fmt);
|
|
int lvmcache_update_das(struct lvmcache_info *info, struct physical_volume *pv);
|
|
int lvmcache_update_bas(struct lvmcache_info *info, struct physical_volume *pv);
|
|
int lvmcache_foreach_mda(struct lvmcache_info *info,
|
|
int (*fun)(struct metadata_area *, void *),
|
|
void *baton);
|
|
|
|
int lvmcache_foreach_da(struct lvmcache_info *info,
|
|
int (*fun)(struct disk_locn *, void *),
|
|
void *baton);
|
|
|
|
int lvmcache_foreach_ba(struct lvmcache_info *info,
|
|
int (*fun)(struct disk_locn *, void *),
|
|
void *baton);
|
|
|
|
int lvmcache_foreach_pv(struct lvmcache_vginfo *vg,
|
|
int (*fun)(struct lvmcache_info *, void *), void * baton);
|
|
|
|
uint64_t lvmcache_device_size(struct lvmcache_info *info);
|
|
void lvmcache_set_device_size(struct lvmcache_info *info, uint64_t size);
|
|
struct device *lvmcache_device(struct lvmcache_info *info);
|
|
void lvmcache_make_valid(struct lvmcache_info *info);
|
|
int lvmcache_is_orphan(struct lvmcache_info *info);
|
|
int lvmcache_uncertain_ownership(struct lvmcache_info *info);
|
|
unsigned lvmcache_mda_count(struct lvmcache_info *info);
|
|
int lvmcache_vgid_is_cached(const char *vgid);
|
|
uint64_t lvmcache_smallest_mda_size(struct lvmcache_info *info);
|
|
|
|
int lvmcache_found_duplicate_pvs(void);
|
|
|
|
int lvmcache_get_unused_duplicate_devs(struct cmd_context *cmd, struct dm_list *head);
|
|
|
|
int vg_has_duplicate_pvs(struct volume_group *vg);
|
|
|
|
int lvmcache_contains_lock_type_sanlock(struct cmd_context *cmd);
|
|
|
|
void lvmcache_get_max_name_lengths(struct cmd_context *cmd,
|
|
unsigned *pv_max_name_len, unsigned *vg_max_name_len);
|
|
|
|
int lvmcache_vg_is_foreign(struct cmd_context *cmd, const char *vgname, const char *vgid);
|
|
|
|
void lvmcache_lock_ordering(int enable);
|
|
|
|
int lvmcache_dev_is_unchosen_duplicate(struct device *dev);
|
|
|
|
void lvmcache_remove_unchosen_duplicate(struct device *dev);
|
|
|
|
int lvmcache_pvid_in_unchosen_duplicates(const char *pvid);
|
|
|
|
#endif
|