1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-10 05:18:36 +03:00
lvm2/tools/pvdisplay.c

120 lines
3.1 KiB
C
Raw Normal View History

2001-09-25 16:49:28 +04:00
/*
2004-03-30 23:35:44 +04:00
* Copyright (C) 2001-2004 Sistina Software, Inc. All rights reserved.
* Copyright (C) 2004-2007 Red Hat, Inc. All rights reserved.
2001-09-25 16:49:28 +04:00
*
2004-03-30 23:35:44 +04:00
* This file is part of LVM2.
2001-09-25 16:49:28 +04:00
*
2004-03-30 23:35:44 +04:00
* 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.
2001-09-25 16:49:28 +04:00
*
* You should have received a copy of the GNU Lesser General Public License
2004-03-30 23:35:44 +04:00
* along with this program; if not, write to the Free Software Foundation,
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
2001-09-25 16:49:28 +04:00
*/
#include "tools.h"
static int _pvdisplay_single(struct cmd_context *cmd,
struct volume_group *vg,
struct physical_volume *pv, void *handle)
2001-09-25 16:49:28 +04:00
{
struct pv_list *pvl;
int ret = ECMD_PROCESSED;
uint64_t size;
struct volume_group *old_vg = vg;
2001-09-25 16:49:28 +04:00
const char *pv_name = pv_dev_name(pv);
const char *vg_name = NULL;
2001-09-25 16:49:28 +04:00
if (!is_orphan(pv) && !vg) {
vg_name = pv_vg_name(pv);
vg = vg_read(cmd, vg_name, (char *)&pv->vgid, 0);
if (vg_read_error(vg)) {
log_error("Skipping volume group %s", vg_name);
release_vg(vg);
2007-11-16 00:30:52 +03:00
/* FIXME If CLUSTERED should return ECMD_PROCESSED here */
return ECMD_FAILED;
}
/*
* Replace possibly incomplete PV structure with new one
* allocated in vg_read_internal() path.
*/
if (!(pvl = find_pv_in_vg(vg, pv_name))) {
log_error("Unable to find \"%s\" in volume group \"%s\"",
pv_name, vg->name);
2008-01-30 17:00:02 +03:00
ret = ECMD_FAILED;
goto out;
}
pv = pvl->pv;
}
if (is_orphan(pv))
size = pv_size(pv);
else
2012-08-16 22:07:30 +04:00
size = (uint64_t)(pv_pe_count(pv) - pv_pe_alloc_count(pv)) *
pv_pe_size(pv);
2001-09-25 16:49:28 +04:00
if (arg_count(cmd, short_ARG)) {
log_print("Device \"%s\" has a capacity of %s", pv_name,
display_size(cmd, size));
goto out;
2001-09-25 16:49:28 +04:00
}
if (pv_status(pv) & EXPORTED_VG)
log_print("Physical volume \"%s\" of volume group \"%s\" "
"is exported", pv_name, pv_vg_name(pv));
2001-09-25 16:49:28 +04:00
if (is_orphan(pv))
log_print("\"%s\" is a new physical volume of \"%s\"",
pv_name, display_size(cmd, size));
2001-09-25 16:49:28 +04:00
if (arg_count(cmd, colon_ARG)) {
2001-10-18 20:55:19 +04:00
pvdisplay_colons(pv);
goto out;
2001-09-25 16:49:28 +04:00
}
pvdisplay_full(cmd, pv, handle);
2001-09-25 16:49:28 +04:00
if (arg_count(cmd, maps_ARG))
pvdisplay_segments(pv);
out:
2008-01-30 17:00:02 +03:00
if (vg_name)
unlock_vg(cmd, vg_name);
if (!old_vg)
release_vg(vg);
2001-09-25 16:49:28 +04:00
return ret;
2002-11-18 17:04:08 +03:00
}
int pvdisplay(struct cmd_context *cmd, int argc, char **argv)
{
if (arg_count(cmd, columns_ARG)) {
if (arg_count(cmd, colon_ARG) || arg_count(cmd, maps_ARG) ||
arg_count(cmd, short_ARG)) {
log_error("Incompatible options selected");
return EINVALID_CMD_LINE;
}
return pvs(cmd, argc, argv);
} else if (arg_count(cmd, aligned_ARG) ||
2005-03-21 17:47:36 +03:00
arg_count(cmd, all_ARG) ||
arg_count(cmd, noheadings_ARG) ||
arg_count(cmd, options_ARG) ||
arg_count(cmd, separator_ARG) ||
arg_count(cmd, sort_ARG) || arg_count(cmd, unbuffered_ARG)) {
log_error("Incompatible options selected");
return EINVALID_CMD_LINE;
}
2002-11-18 17:04:08 +03:00
if (arg_count(cmd, colon_ARG) && arg_count(cmd, maps_ARG)) {
log_error("Option -v not allowed with option -c");
return EINVALID_CMD_LINE;
}
2009-07-15 09:50:22 +04:00
return process_each_pv(cmd, argc, argv, NULL, 0, 0, NULL,
_pvdisplay_single);
2001-09-25 16:49:28 +04:00
}