1
0
mirror of git://sourceware.org/git/lvm2.git synced 2024-12-22 17:35:59 +03:00
lvm2/tools/lvmdiskscan.c

145 lines
3.5 KiB
C
Raw Normal View History

2002-02-05 17:31:57 +03:00
/*
2004-03-30 23:35:44 +04:00
* Copyright (C) 2002-2004 Sistina Software, Inc. All rights reserved.
* Copyright (C) 2004-2007 Red Hat, Inc. All rights reserved.
2002-02-05 17:31:57 +03:00
*
2004-03-30 23:35:44 +04:00
* This file is part of LVM2.
2002-02-05 17:31:57 +03: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.
2004-03-30 23:35:44 +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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
2002-02-05 17:31:57 +03:00
*/
/*
* Changelog
*
* 05/02/2002 - First drop [HM]
*/
#include "tools.h"
2024-05-13 01:04:28 +03:00
static int _disks_found;
static int _parts_found;
static int _pv_disks_found;
static int _pv_parts_found;
static int _max_len;
2002-02-05 17:31:57 +03:00
static int _get_max_dev_name_len(struct cmd_context *cmd, struct dev_filter *filter)
2002-02-05 17:31:57 +03:00
{
int len = 0;
int maxlen = 0;
struct dev_iter *iter;
struct device *dev;
2002-02-05 17:31:57 +03:00
if (!(iter = dev_iter_create(filter, 1))) {
log_error("dev_iter_create failed");
return 0;
}
2002-02-05 17:31:57 +03:00
/* Do scan */
while ((dev = dev_iter_get(cmd, iter))) {
len = strlen(dev_name(dev));
if (len > maxlen)
maxlen = len;
}
dev_iter_destroy(iter);
2002-02-05 17:31:57 +03:00
return maxlen;
}
2002-02-05 17:31:57 +03:00
static void _count(struct device *dev, int *disks, int *parts)
{
int c = dev_name(dev)[strlen(dev_name(dev)) - 1];
if (!isdigit(c))
(*disks)++;
else
(*parts)++;
}
static void _print(struct cmd_context *cmd, const struct device *dev,
uint64_t size, const char *what)
{
2024-05-13 01:04:28 +03:00
log_print("%-*s [%15s] %s", _max_len, dev_name(dev),
display_size(cmd, size), what ? : "");
2002-02-05 17:31:57 +03:00
}
static int _check_device(struct cmd_context *cmd, struct device *dev)
{
2002-02-05 17:31:57 +03:00
uint64_t size;
if (!dev_get_size(dev, &size)) {
log_error("Couldn't get size of \"%s\"", dev_name(dev));
size = 0;
2002-02-05 17:31:57 +03:00
}
_print(cmd, dev, size, NULL);
2024-05-13 01:04:28 +03:00
_count(dev, &_disks_found, &_parts_found);
2002-02-05 17:31:57 +03:00
return 1;
}
int lvmdiskscan(struct cmd_context *cmd, int argc __attribute__((unused)),
char **argv __attribute__((unused)))
{
uint64_t size;
struct dev_iter *iter;
struct device *dev;
2002-02-05 17:31:57 +03:00
/* initialise these here to avoid problems with the lvm shell */
2024-05-13 01:04:28 +03:00
_disks_found = 0;
_parts_found = 0;
_pv_disks_found = 0;
_pv_parts_found = 0;
if (arg_is_set(cmd, lvmpartition_ARG))
log_warn("WARNING: only considering LVM devices");
/* Call before using dev_iter which uses filters which want bcache data. */
label_scan(cmd);
2024-05-13 01:04:28 +03:00
_max_len = _get_max_dev_name_len(cmd, cmd->filter);
if (!(iter = dev_iter_create(cmd->filter, 0))) {
log_error("dev_iter_create failed");
2003-10-22 02:06:07 +04:00
return ECMD_FAILED;
}
2002-02-05 17:31:57 +03:00
while ((dev = dev_iter_get(cmd, iter))) {
if (lvmcache_has_dev_info(dev)) {
if (!dev_get_size(dev, &size)) {
log_error("Couldn't get size of \"%s\"",
dev_name(dev));
continue;
}
_print(cmd, dev, size, "LVM physical volume");
2024-05-13 01:04:28 +03:00
_count(dev, &_pv_disks_found, &_pv_parts_found);
continue;
}
/* If user just wants PVs we are done */
if (arg_is_set(cmd, lvmpartition_ARG))
continue;
/* What other device is it? */
if (!_check_device(cmd, dev))
continue;
2002-02-05 17:31:57 +03:00
}
dev_iter_destroy(iter);
2002-02-05 17:31:57 +03:00
/* Display totals */
if (!arg_is_set(cmd, lvmpartition_ARG)) {
log_print("%d disk%s",
2024-05-13 01:04:28 +03:00
_disks_found, _disks_found == 1 ? "" : "s");
log_print("%d partition%s",
2024-05-13 01:04:28 +03:00
_parts_found, _parts_found == 1 ? "" : "s");
}
log_print("%d LVM physical volume whole disk%s",
2024-05-13 01:04:28 +03:00
_pv_disks_found, _pv_disks_found == 1 ? "" : "s");
log_print("%d LVM physical volume%s",
2024-05-13 01:04:28 +03:00
_pv_parts_found, _pv_parts_found == 1 ? "" : "s");
2002-02-05 17:31:57 +03:00
2003-10-22 02:06:07 +04:00
return ECMD_PROCESSED;
2002-02-05 17:31:57 +03:00
}