2001-10-11 14:10:18 +00:00
/*
2004-03-30 19:35:44 +00:00
* Copyright ( C ) 2001 - 2004 Sistina Software , Inc . All rights reserved .
* Copyright ( C ) 2004 Red Hat , Inc . All rights reserved .
2001-10-11 14:10:18 +00:00
*
2004-03-30 19:35:44 +00:00
* 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 General Public License v .2 .
*
* You should have received a copy of the GNU 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
2001-10-11 14:10:18 +00:00
*/
2002-11-18 14:01:16 +00:00
# include "lib.h"
2001-10-11 14:10:18 +00:00
# include "disk-rep.h"
/*
* FIXME : Quick hack . We can use caching to
* prevent a total re - read , even so vg_number
* causes the tools to check * every * pv . Yuck .
2002-01-23 15:50:34 +00:00
* Put in separate file so it wouldn ' t contaminate
2001-10-11 14:10:18 +00:00
* other code .
*/
2002-04-24 18:20:51 +00:00
int get_free_vg_number ( struct format_instance * fid , struct dev_filter * filter ,
const char * candidate_vg , int * result )
2001-10-11 14:10:18 +00:00
{
2001-10-31 12:47:01 +00:00
struct list all_pvs ;
2001-10-11 14:10:18 +00:00
struct disk_list * dl ;
2005-10-16 23:03:59 +00:00
struct dm_pool * mem = dm_pool_create ( " lvm1 vg_number " , 10 * 1024 ) ;
2001-10-11 14:10:18 +00:00
int numbers [ MAX_VG ] , i , r = 0 ;
2001-10-31 12:47:01 +00:00
list_init ( & all_pvs ) ;
2001-10-11 14:21:38 +00:00
2001-10-11 14:10:18 +00:00
if ( ! mem ) {
stack ;
return 0 ;
}
2002-04-24 18:20:51 +00:00
if ( ! read_pvs_in_vg ( fid - > fmt , NULL , filter , mem , & all_pvs ) ) {
2001-10-11 14:10:18 +00:00
stack ;
goto out ;
}
memset ( numbers , 0 , sizeof ( numbers ) ) ;
2005-06-01 16:51:55 +00:00
list_iterate_items ( dl , & all_pvs ) {
2006-05-09 21:23:51 +00:00
if ( ! * dl - > pvd . vg_name | | ! strcmp ( ( char * ) dl - > pvd . vg_name , candidate_vg ) )
2001-10-11 14:10:18 +00:00
continue ;
2001-10-31 17:59:52 +00:00
numbers [ dl - > vgd . vg_number ] = 1 ;
2001-10-11 14:10:18 +00:00
}
for ( i = 0 ; i < MAX_VG ; i + + ) {
if ( ! numbers [ i ] ) {
r = 1 ;
* result = i ;
break ;
}
}
2002-04-24 18:20:51 +00:00
out :
2005-10-16 23:03:59 +00:00
dm_pool_destroy ( mem ) ;
2001-10-11 14:10:18 +00:00
return r ;
}