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 .
2007-08-21 00:55:30 +04:00
* 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 .
*
* This copyrighted material is made available to anyone wishing to use ,
* modify , copy , or redistribute it subject to the terms and conditions
2007-08-21 00:55:30 +04:00
* of the GNU Lesser General Public License v .2 .1 .
2004-03-30 23:35:44 +04:00
*
2007-08-21 00:55:30 +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
*/
# ifndef _LVM_DEVICE_H
# define _LVM_DEVICE_H
2002-11-18 17:01:16 +03:00
# include "uuid.h"
2005-10-17 03:03:59 +04:00
2003-07-05 02:34:56 +04:00
# include <fcntl.h>
2001-10-03 16:41:29 +04:00
2002-04-24 22:20:51 +04:00
# define DEV_ACCESSED_W 0x00000001 /* Device written to? */
2003-07-05 02:34:56 +04:00
# define DEV_REGULAR 0x00000002 /* Regular file? */
2005-10-17 03:03:59 +04:00
# define DEV_ALLOCED 0x00000004 /* dm_malloc used */
2004-12-10 19:01:35 +03:00
# define DEV_OPENED_RW 0x00000008 /* Opened RW */
2005-10-04 01:10:41 +04:00
# define DEV_OPENED_EXCL 0x00000010 /* Opened EXCL */
# define DEV_O_DIRECT 0x00000020 /* Use O_DIRECT */
# define DEV_O_DIRECT_TESTED 0x00000040 /* DEV_O_DIRECT is reliable */
2002-04-24 22:20:51 +04:00
2014-12-12 14:55:41 +03:00
/*
* Support for external device info .
* Any new external device info source needs to be
* registered using EXT_REGISTER macro in dev - ext . c .
*/
typedef enum {
DEV_EXT_NONE ,
DEV_EXT_UDEV ,
DEV_EXT_NUM
} dev_ext_t ;
struct dev_ext {
int enabled ;
dev_ext_t src ;
void * handle ;
} ;
2001-10-03 16:41:29 +04:00
/*
* All devices in LVM will be represented by one of these .
* pointer comparisons are valid .
*/
struct device {
2014-05-29 11:41:03 +04:00
struct dm_list aliases ; /* struct dm_str_list */
2001-10-03 16:41:29 +04:00
dev_t dev ;
2001-11-14 13:01:52 +03:00
/* private */
int fd ;
2003-07-05 02:34:56 +04:00
int open_count ;
2010-10-13 19:40:38 +04:00
int error_count ;
int max_error_count ;
2013-12-12 14:26:35 +04:00
int phys_block_size ;
2004-12-10 19:01:35 +03:00
int block_size ;
2009-05-20 15:09:49 +04:00
int read_ahead ;
2002-04-24 22:20:51 +04:00
uint32_t flags ;
2003-07-05 02:34:56 +04:00
uint64_t end ;
2008-11-04 01:14:30 +03:00
struct dm_list open_list ;
2014-12-12 14:55:41 +03:00
struct dev_ext ext ;
2002-11-18 17:01:16 +03:00
char pvid [ ID_LEN + 1 ] ;
2005-04-06 17:47:41 +04:00
char _padding [ 7 ] ;
2001-10-03 16:41:29 +04:00
} ;
2002-01-15 13:24:48 +03:00
struct device_list {
2008-11-04 01:14:30 +03:00
struct dm_list list ;
2002-01-15 13:24:48 +03:00
struct device * dev ;
} ;
2002-11-18 17:01:16 +03:00
struct device_area {
struct device * dev ;
uint64_t start ; /* Bytes */
uint64_t size ; /* Bytes */
} ;
2014-12-12 14:55:41 +03:00
/*
* Support for external device info .
*/
const char * dev_ext_name ( struct device * dev ) ;
int dev_ext_enable ( struct device * dev , dev_ext_t src ) ;
int dev_ext_disable ( struct device * dev ) ;
struct dev_ext * dev_ext_get ( struct device * dev ) ;
int dev_ext_release ( struct device * dev ) ;
2001-10-03 16:41:29 +04:00
/*
2001-11-14 13:01:52 +03:00
* All io should use these routines .
2001-10-03 16:41:29 +04:00
*/
2013-12-12 14:26:35 +04:00
int dev_get_block_size ( struct device * dev , unsigned int * phys_block_size , unsigned int * block_size ) ;
2004-08-11 17:15:35 +04:00
int dev_get_size ( const struct device * dev , uint64_t * size ) ;
2009-05-20 15:09:49 +04:00
int dev_get_read_ahead ( struct device * dev , uint32_t * read_ahead ) ;
2011-04-13 01:59:01 +04:00
int dev_discard_blocks ( struct device * dev , uint64_t offset_bytes , uint64_t size_bytes ) ;
2001-11-14 13:01:52 +03:00
2003-07-05 02:34:56 +04:00
/* Use quiet version if device number could change e.g. when opening LV */
int dev_open ( struct device * dev ) ;
int dev_open_quiet ( struct device * dev ) ;
2005-04-07 16:17:46 +04:00
int dev_open_flags ( struct device * dev , int flags , int direct , int quiet ) ;
2011-05-24 17:36:57 +04:00
int dev_open_readonly ( struct device * dev ) ;
int dev_open_readonly_buffered ( struct device * dev ) ;
int dev_open_readonly_quiet ( struct device * dev ) ;
2001-11-14 13:01:52 +03:00
int dev_close ( struct device * dev ) ;
2003-11-14 20:55:39 +03:00
int dev_close_immediate ( struct device * dev ) ;
2003-07-05 02:34:56 +04:00
void dev_close_all ( void ) ;
2005-10-04 01:10:41 +04:00
int dev_test_excl ( struct device * dev ) ;
2001-11-14 13:01:52 +03:00
2006-04-19 19:33:07 +04:00
int dev_fd ( struct device * dev ) ;
const char * dev_name ( const struct device * dev ) ;
2002-11-18 17:01:16 +03:00
2003-07-05 02:34:56 +04:00
int dev_read ( struct device * dev , uint64_t offset , size_t len , void * buffer ) ;
2007-04-19 06:10:42 +04:00
int dev_read_circular ( struct device * dev , uint64_t offset , size_t len ,
2011-02-19 02:09:55 +03:00
uint64_t offset2 , size_t len2 , char * buf ) ;
2003-07-05 02:34:56 +04:00
int dev_write ( struct device * dev , uint64_t offset , size_t len , void * buffer ) ;
2011-02-19 02:09:55 +03:00
int dev_append ( struct device * dev , size_t len , char * buffer ) ;
2006-05-11 22:39:24 +04:00
int dev_set ( struct device * dev , uint64_t offset , size_t len , int value ) ;
2003-07-05 02:34:56 +04:00
void dev_flush ( struct device * dev ) ;
struct device * dev_create_file ( const char * filename , struct device * dev ,
2014-05-29 11:41:03 +04:00
struct dm_str_list * alias , int use_malloc ) ;
2001-10-03 16:41:29 +04:00
2002-01-25 02:16:19 +03:00
/* Return a valid device name from the alias list; NULL otherwise */
2003-07-05 02:34:56 +04:00
const char * dev_name_confirmed ( struct device * dev , int quiet ) ;
2001-09-25 16:49:28 +04:00
2002-11-18 17:01:16 +03:00
# endif