xref: /dflybsd-src/contrib/lvm2/dist/tools/lvmdiskscan.c (revision 86d7f5d305c6adaa56ff4582ece9859d73106103)
1*86d7f5d3SJohn Marino /*	$NetBSD: lvmdiskscan.c,v 1.1.1.1 2008/12/22 00:19:05 haad Exp $	*/
2*86d7f5d3SJohn Marino 
3*86d7f5d3SJohn Marino /*
4*86d7f5d3SJohn Marino  * Copyright (C) 2002-2004 Sistina Software, Inc. All rights reserved.
5*86d7f5d3SJohn Marino  * Copyright (C) 2004-2007 Red Hat, Inc. All rights reserved.
6*86d7f5d3SJohn Marino  *
7*86d7f5d3SJohn Marino  * This file is part of LVM2.
8*86d7f5d3SJohn Marino  *
9*86d7f5d3SJohn Marino  * This copyrighted material is made available to anyone wishing to use,
10*86d7f5d3SJohn Marino  * modify, copy, or redistribute it subject to the terms and conditions
11*86d7f5d3SJohn Marino  * of the GNU Lesser General Public License v.2.1.
12*86d7f5d3SJohn Marino  *
13*86d7f5d3SJohn Marino  * You should have received a copy of the GNU Lesser General Public License
14*86d7f5d3SJohn Marino  * along with this program; if not, write to the Free Software Foundation,
15*86d7f5d3SJohn Marino  * Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16*86d7f5d3SJohn Marino  */
17*86d7f5d3SJohn Marino 
18*86d7f5d3SJohn Marino /*
19*86d7f5d3SJohn Marino  * Changelog
20*86d7f5d3SJohn Marino  *
21*86d7f5d3SJohn Marino  *   05/02/2002 - First drop [HM]
22*86d7f5d3SJohn Marino  */
23*86d7f5d3SJohn Marino 
24*86d7f5d3SJohn Marino #include "tools.h"
25*86d7f5d3SJohn Marino 
26*86d7f5d3SJohn Marino int disks_found;
27*86d7f5d3SJohn Marino int parts_found;
28*86d7f5d3SJohn Marino int pv_disks_found;
29*86d7f5d3SJohn Marino int pv_parts_found;
30*86d7f5d3SJohn Marino int max_len;
31*86d7f5d3SJohn Marino 
_get_max_dev_name_len(struct dev_filter * filter)32*86d7f5d3SJohn Marino static int _get_max_dev_name_len(struct dev_filter *filter)
33*86d7f5d3SJohn Marino {
34*86d7f5d3SJohn Marino 	int len = 0;
35*86d7f5d3SJohn Marino 	int maxlen = 0;
36*86d7f5d3SJohn Marino 	struct dev_iter *iter;
37*86d7f5d3SJohn Marino 	struct device *dev;
38*86d7f5d3SJohn Marino 
39*86d7f5d3SJohn Marino 	if (!(iter = dev_iter_create(filter, 1))) {
40*86d7f5d3SJohn Marino 		log_error("dev_iter_create failed");
41*86d7f5d3SJohn Marino 		return 0;
42*86d7f5d3SJohn Marino 	}
43*86d7f5d3SJohn Marino 
44*86d7f5d3SJohn Marino 	/* Do scan */
45*86d7f5d3SJohn Marino 	for (dev = dev_iter_get(iter); dev; dev = dev_iter_get(iter)) {
46*86d7f5d3SJohn Marino 		len = strlen(dev_name(dev));
47*86d7f5d3SJohn Marino 		if (len > maxlen)
48*86d7f5d3SJohn Marino 			maxlen = len;
49*86d7f5d3SJohn Marino 	}
50*86d7f5d3SJohn Marino 	dev_iter_destroy(iter);
51*86d7f5d3SJohn Marino 
52*86d7f5d3SJohn Marino 	return maxlen;
53*86d7f5d3SJohn Marino }
54*86d7f5d3SJohn Marino 
_count(struct device * dev,int * disks,int * parts)55*86d7f5d3SJohn Marino static void _count(struct device *dev, int *disks, int *parts)
56*86d7f5d3SJohn Marino {
57*86d7f5d3SJohn Marino 	int c = dev_name(dev)[strlen(dev_name(dev)) - 1];
58*86d7f5d3SJohn Marino 
59*86d7f5d3SJohn Marino 	if (!isdigit(c))
60*86d7f5d3SJohn Marino 		(*disks)++;
61*86d7f5d3SJohn Marino 	else
62*86d7f5d3SJohn Marino 		(*parts)++;
63*86d7f5d3SJohn Marino }
64*86d7f5d3SJohn Marino 
_print(struct cmd_context * cmd,const struct device * dev,uint64_t size,const char * what)65*86d7f5d3SJohn Marino static void _print(struct cmd_context *cmd, const struct device *dev,
66*86d7f5d3SJohn Marino 		   uint64_t size, const char *what)
67*86d7f5d3SJohn Marino {
68*86d7f5d3SJohn Marino 	log_print("%-*s [%15s] %s", max_len, dev_name(dev),
69*86d7f5d3SJohn Marino 		  display_size(cmd, size), what ? : "");
70*86d7f5d3SJohn Marino }
71*86d7f5d3SJohn Marino 
_check_device(struct cmd_context * cmd,struct device * dev)72*86d7f5d3SJohn Marino static int _check_device(struct cmd_context *cmd, struct device *dev)
73*86d7f5d3SJohn Marino {
74*86d7f5d3SJohn Marino 	char buffer;
75*86d7f5d3SJohn Marino 	uint64_t size;
76*86d7f5d3SJohn Marino 
77*86d7f5d3SJohn Marino 	if (!dev_open(dev)) {
78*86d7f5d3SJohn Marino 		return 0;
79*86d7f5d3SJohn Marino 	}
80*86d7f5d3SJohn Marino 	if (!dev_read(dev, UINT64_C(0), (size_t) 1, &buffer)) {
81*86d7f5d3SJohn Marino 		dev_close(dev);
82*86d7f5d3SJohn Marino 		return 0;
83*86d7f5d3SJohn Marino 	}
84*86d7f5d3SJohn Marino 	if (!dev_get_size(dev, &size)) {
85*86d7f5d3SJohn Marino 		log_error("Couldn't get size of \"%s\"", dev_name(dev));
86*86d7f5d3SJohn Marino 	}
87*86d7f5d3SJohn Marino 	_print(cmd, dev, size, NULL);
88*86d7f5d3SJohn Marino 	_count(dev, &disks_found, &parts_found);
89*86d7f5d3SJohn Marino 	if (!dev_close(dev)) {
90*86d7f5d3SJohn Marino 		log_error("dev_close on \"%s\" failed", dev_name(dev));
91*86d7f5d3SJohn Marino 		return 0;
92*86d7f5d3SJohn Marino 	}
93*86d7f5d3SJohn Marino 	return 1;
94*86d7f5d3SJohn Marino }
95*86d7f5d3SJohn Marino 
lvmdiskscan(struct cmd_context * cmd,int argc __attribute ((unused)),char ** argv __attribute ((unused)))96*86d7f5d3SJohn Marino int lvmdiskscan(struct cmd_context *cmd, int argc __attribute((unused)),
97*86d7f5d3SJohn Marino 		char **argv __attribute((unused)))
98*86d7f5d3SJohn Marino {
99*86d7f5d3SJohn Marino 	uint64_t size;
100*86d7f5d3SJohn Marino 	struct dev_iter *iter;
101*86d7f5d3SJohn Marino 	struct device *dev;
102*86d7f5d3SJohn Marino 	struct label *label;
103*86d7f5d3SJohn Marino 
104*86d7f5d3SJohn Marino 	/* initialise these here to avoid problems with the lvm shell */
105*86d7f5d3SJohn Marino 	disks_found = 0;
106*86d7f5d3SJohn Marino 	parts_found = 0;
107*86d7f5d3SJohn Marino 	pv_disks_found = 0;
108*86d7f5d3SJohn Marino 	pv_parts_found = 0;
109*86d7f5d3SJohn Marino 
110*86d7f5d3SJohn Marino 	if (arg_count(cmd, lvmpartition_ARG))
111*86d7f5d3SJohn Marino 		log_warn("WARNING: only considering LVM devices");
112*86d7f5d3SJohn Marino 
113*86d7f5d3SJohn Marino 	max_len = _get_max_dev_name_len(cmd->filter);
114*86d7f5d3SJohn Marino 
115*86d7f5d3SJohn Marino 	if (!(iter = dev_iter_create(cmd->filter, 0))) {
116*86d7f5d3SJohn Marino 		log_error("dev_iter_create failed");
117*86d7f5d3SJohn Marino 		return ECMD_FAILED;
118*86d7f5d3SJohn Marino 	}
119*86d7f5d3SJohn Marino 
120*86d7f5d3SJohn Marino 	/* Do scan */
121*86d7f5d3SJohn Marino 	for (dev = dev_iter_get(iter); dev; dev = dev_iter_get(iter)) {
122*86d7f5d3SJohn Marino 		/* Try if it is a PV first */
123*86d7f5d3SJohn Marino 		if ((label_read(dev, &label, UINT64_C(0)))) {
124*86d7f5d3SJohn Marino 			if (!dev_get_size(dev, &size)) {
125*86d7f5d3SJohn Marino 				log_error("Couldn't get size of \"%s\"",
126*86d7f5d3SJohn Marino 					  dev_name(dev));
127*86d7f5d3SJohn Marino 				continue;
128*86d7f5d3SJohn Marino 			}
129*86d7f5d3SJohn Marino 			_print(cmd, dev, size, "LVM physical volume");
130*86d7f5d3SJohn Marino 			_count(dev, &pv_disks_found, &pv_parts_found);
131*86d7f5d3SJohn Marino 			continue;
132*86d7f5d3SJohn Marino 		}
133*86d7f5d3SJohn Marino 		/* If user just wants PVs we are done */
134*86d7f5d3SJohn Marino 		if (arg_count(cmd, lvmpartition_ARG))
135*86d7f5d3SJohn Marino 			continue;
136*86d7f5d3SJohn Marino 
137*86d7f5d3SJohn Marino 		/* What other device is it? */
138*86d7f5d3SJohn Marino 		if (!_check_device(cmd, dev))
139*86d7f5d3SJohn Marino 			continue;
140*86d7f5d3SJohn Marino 	}
141*86d7f5d3SJohn Marino 	dev_iter_destroy(iter);
142*86d7f5d3SJohn Marino 
143*86d7f5d3SJohn Marino 	/* Display totals */
144*86d7f5d3SJohn Marino 	if (!arg_count(cmd, lvmpartition_ARG)) {
145*86d7f5d3SJohn Marino 		log_print("%d disk%s",
146*86d7f5d3SJohn Marino 			  disks_found, disks_found == 1 ? "" : "s");
147*86d7f5d3SJohn Marino 		log_print("%d partition%s",
148*86d7f5d3SJohn Marino 			  parts_found, parts_found == 1 ? "" : "s");
149*86d7f5d3SJohn Marino 	}
150*86d7f5d3SJohn Marino 	log_print("%d LVM physical volume whole disk%s",
151*86d7f5d3SJohn Marino 		  pv_disks_found, pv_disks_found == 1 ? "" : "s");
152*86d7f5d3SJohn Marino 	log_print("%d LVM physical volume%s",
153*86d7f5d3SJohn Marino 		  pv_parts_found, pv_parts_found == 1 ? "" : "s");
154*86d7f5d3SJohn Marino 
155*86d7f5d3SJohn Marino 	return ECMD_PROCESSED;
156*86d7f5d3SJohn Marino }
157