2009-02-24 16:03:45 +03:00
/*
* Copyright ( C ) 2008 , 2009 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 . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*/
# ifndef _LIB_LVM_H
# define _LIB_LVM_H
# include "lvm-version.h"
2009-07-24 03:37:24 +04:00
# include "libdevmapper.h"
2009-02-24 16:03:45 +03:00
# include <stdint.h>
Define handles to liblvm objects for pv, vg, lv, lvseg, pvseg.
Define the 5 main liblvm objects to be the pv, vg, lv, lvseg, and pvseg.
We need handles defined to all these objects in order for liblvm to be
equivalent to the reporting commands pvs, vgs, and lvs.
- move vg_t, lv_t, and pv_t from metadata-exported.h into lvm.h
- move lv_segment and pv_segment forward declarations into lvm.h
- add lvseg_t and pvseg_t to lvm.h
NOTE: We currently have an inconsistency in handle definitions.
lvm_t is defined as a pointer, while these other handles are just
structures. We should pick one scheme and be consistent - perhaps
define all handles as pointers (this is what I've seen elsewhere).
Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
Acked-by: Alasdair G Kergon <agk@redhat.com>
2009-07-14 07:00:30 +04:00
/* Internal object structures */
struct volume_group ;
struct physical_volume ;
struct logical_volume ;
/* liblvm handles to objects pv, vg, lv, pvseg, lvseg */
typedef struct volume_group vg_t ;
typedef struct physical_volume pv_t ;
typedef struct logical_volume lv_t ;
2009-07-24 03:37:24 +04:00
typedef struct lvm_vg_list {
struct dm_list list ;
vg_t * vg ;
} vg_list_t ;
typedef struct lvm_pv_list {
struct dm_list list ;
pv_t * pv ;
} pv_list_t ;
typedef struct lvm_lv_list {
struct dm_list list ;
lv_t * lv ;
} lv_list_t ;
2009-07-24 03:39:02 +04:00
/**
* Return a list of LV handles for a given VG handle .
*
* \ return A list of lv_list_t structures containing lv handles for this vg .
* If no LVs exist on the given VG , NULL is returned .
*/
struct dm_list * lvm_vg_list_lvs ( vg_t * vg ) ;
2009-07-24 03:37:24 +04:00
2009-02-24 16:03:45 +03:00
struct lvm ; /* internal data */
/**
* The lvm handle .
*/
typedef struct lvm * lvm_t ;
/**
* Create a LVM handle .
*
2009-07-14 07:02:14 +04:00
* Once all LVM operations have been completed , use lvm_destroy to release
* the handle and any associated resources .
*
2009-02-24 16:03:45 +03:00
* \ param system_dir
* Set an alternative LVM system directory . Use NULL to use the
* default value . If the environment variable LVM_SYSTEM_DIR is set ,
* it will override any LVM system directory setting .
* \ return A valid LVM handle is returned or NULL if there has been a
* memory allocation problem . You have to check if an error occured
* with the lvm_error function .
*/
lvm_t lvm_create ( const char * system_dir ) ;
/**
* Destroy a LVM handle allocated with lvm_create .
*
* \ param libh
* Handle obtained from lvm_create .
*/
void lvm_destroy ( lvm_t libh ) ;
/**
* Reload the original configuration from the system directory .
*
* \ param libh
* Handle obtained from lvm_create .
*/
int lvm_reload_config ( lvm_t libh ) ;
2009-07-16 07:07:45 +04:00
/**
* Return stored error no describing last LVM API error .
*
* Users of liblvm should use lvm_errno to determine success or failure
* of the last call , unless the API indicates another method of determining
* success or failure .
*
* \ param libh
* Handle obtained from lvm_create .
*
* \ return An errno value describing the last LVM error .
*/
int lvm_errno ( lvm_t libh ) ;
/**
* Return stored error message describing last LVM error .
*
* \ param libh
* Handle obtained from lvm_create .
*
* \ return An error string describing the last LVM error .
*/
const char * lvm_errmsg ( lvm_t libh ) ;
2009-07-14 07:02:14 +04:00
/**
* Create a VG with default parameters .
*
* This API requires calling lvm_vg_write to commit the change to disk .
* Upon success , other APIs may be used to set non - default parameters .
* For example , to set a non - default extent size , use lvm_vg_set_extent_size .
* Next , to add physical storage devices to the volume group , use
* lvm_vg_extend for each device .
* Once all parameters are set appropriately and all devices are added to the
* VG , use lvm_vg_write to commit the new VG to disk , and lvm_vg_close to
* release the VG handle .
*
* \ param libh
* Handle obtained from lvm_create .
*
2009-07-23 05:20:22 +04:00
* \ return non - NULL vg handle ( success ) or NULL ( failure )
2009-07-14 07:02:14 +04:00
*/
vg_t * lvm_vg_create ( lvm_t libh , const char * vg_name ) ;
/**
* Extend a VG by adding a device .
*
* This API requires calling lvm_vg_write to commit the change to disk .
* After successfully adding a device , use lvm_vg_write to commit the new VG
* to disk . Upon failure , retry the operation or release the VG handle with
* lvm_vg_close .
*
* \ param vg
* VG handle obtained from lvm_vg_create .
*
* \ param device
* Name of device to add to VG .
*
* \ return Status code of 1 ( success ) or 0 ( failure ) .
*/
int lvm_vg_extend ( vg_t * vg , const char * device ) ;
/**
* Set the extent size of a VG .
*
* This API requires calling lvm_vg_write to commit the change to disk .
* After successfully setting a new extent size , use lvm_vg_write to commit
* the new VG to disk . Upon failure , retry the operation or release the VG
* handle with lvm_vg_close .
*
* \ param vg
* VG handle obtained from lvm_vg_create .
*
* \ param new_size
* New extent size to set ( in sectors ) .
*
* \ return Status code of 1 ( success ) or 0 ( failure ) .
*/
int lvm_vg_set_extent_size ( vg_t * vg , uint32_t new_size ) ;
/**
* Write a VG to disk .
*
* This API commits the VG to disk .
* Upon failure , retry the operation and / or release the VG handle with
* lvm_vg_close .
*
* \ param vg
* VG handle obtained from lvm_vg_create .
*
* \ return Status code of 1 ( success ) or 0 ( failure ) .
*/
int lvm_vg_write ( vg_t * vg ) ;
/**
* Remove a VG from the system .
*
* This API commits the change to disk and does not require calling
* lvm_vg_write .
*
* \ param vg
* VG handle obtained from lvm_vg_create .
*
* \ return Status code of 1 ( success ) or 0 ( failure ) .
*/
int lvm_vg_remove ( vg_t * vg ) ;
2009-07-24 03:40:05 +04:00
/**
* Get the current name or uuid of a PV , VG , or LV .
*
* Returns a copy of the current name or uuid for the given PV ,
* VG , or LV .
*
* Memory is allocated using malloc ( ) and caller must free the memory
* using free ( ) .
*/
char * lvm_pv_get_uuid ( const pv_t * pv ) ;
char * lvm_vg_get_uuid ( const vg_t * vg ) ;
char * lvm_lv_get_uuid ( const lv_t * lv ) ;
char * lvm_pv_get_name ( const pv_t * pv ) ;
char * lvm_vg_get_name ( const vg_t * vg ) ;
char * lvm_lv_get_name ( const lv_t * lv ) ;
2009-07-14 07:02:14 +04:00
/**
* Close a VG opened with lvm_vg_create
*
* This API releases a VG handle and any resources associated with the handle .
*
* \ param vg
* VG handle obtained from lvm_vg_create .
*
* \ return Status code of 1 ( success ) or 0 ( failure ) .
*/
int lvm_vg_close ( vg_t * vg ) ;
Define handles to liblvm objects for pv, vg, lv, lvseg, pvseg.
Define the 5 main liblvm objects to be the pv, vg, lv, lvseg, and pvseg.
We need handles defined to all these objects in order for liblvm to be
equivalent to the reporting commands pvs, vgs, and lvs.
- move vg_t, lv_t, and pv_t from metadata-exported.h into lvm.h
- move lv_segment and pv_segment forward declarations into lvm.h
- add lvseg_t and pvseg_t to lvm.h
NOTE: We currently have an inconsistency in handle definitions.
lvm_t is defined as a pointer, while these other handles are just
structures. We should pick one scheme and be consistent - perhaps
define all handles as pointers (this is what I've seen elsewhere).
Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
Acked-by: Alasdair G Kergon <agk@redhat.com>
2009-07-14 07:00:30 +04:00
2009-07-23 02:24:16 +04:00
/**
* Open an existing VG .
*
* Open a VG for reading or writing .
*
* \ param libh
* Handle obtained from lvm_create .
*
* \ param vgname
* Name of the VG to open .
*
* \ param mode
* Open mode - either " r " ( read ) or " w " ( read / write ) .
* Any other character results in an error with EINVAL set .
*
* \ param flags
* Open flags - currently ignored .
*
* \ return non - NULL VG handle ( success ) or NULL ( failure ) .
*/
vg_t * lvm_vg_open ( lvm_t libh , const char * vgname , const char * mode ,
uint32_t flags ) ;
2009-07-24 03:39:02 +04:00
/**
* Return a list of PV handles for a given VG handle .
*
* \ return A list of pv_list_t structures containing pv handles for this vg .
* If no PVs exist on the given VG , NULL is returned .
*/
struct dm_list * lvm_vg_list_pvs ( vg_t * vg ) ;
2009-02-24 16:03:45 +03:00
# endif /* _LIB_LVM_H */