2006-08-17 23:56:28 +04:00
/*
* Copyright ( C ) 2006 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
2007-08-21 00:55:30 +04:00
* of the GNU Lesser General Public License v .2 .1 .
2006-08-17 23:56:28 +04:00
*
2007-08-21 00:55:30 +04:00
* You should have received a copy of the GNU Lesser General Public License
2006-08-17 23:56:28 +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
*/
# include "lib.h"
# include <unistd.h>
2008-12-07 07:23:37 +03:00
# include <fcntl.h>
2006-08-17 23:56:28 +04:00
2011-04-22 15:59:59 +04:00
# ifdef UDEV_SYNC_SUPPORT
static const char _no_context_msg [ ] = " Udev library context not set. " ;
struct udev * _udev ;
int udev_init_library_context ( void )
{
if ( _udev )
udev_unref ( _udev ) ;
if ( ! ( _udev = udev_new ( ) ) ) {
log_error ( " Failed to create udev library context. " ) ;
return 0 ;
}
return 1 ;
}
void udev_fin_library_context ( void )
{
udev_unref ( _udev ) ;
_udev = NULL ;
}
int udev_is_running ( void )
{
struct udev_queue * udev_queue ;
int r ;
if ( ! _udev ) {
log_debug ( _no_context_msg ) ;
goto bad ;
}
if ( ! ( udev_queue = udev_queue_new ( _udev ) ) ) {
log_debug ( " Could not get udev state. " ) ;
goto bad ;
}
r = udev_queue_get_udev_is_active ( udev_queue ) ;
udev_queue_unref ( udev_queue ) ;
return r ;
bad :
log_debug ( " Assuming udev is not running. " ) ;
return 0 ;
}
const char * udev_get_dev_dir ( void )
{
if ( ! _udev ) {
log_debug ( _no_context_msg ) ;
return NULL ;
}
return udev_get_dev_path ( _udev ) ;
}
struct udev * udev_get_library_context ( void )
{
return _udev ;
}
# else /* UDEV_SYNC_SUPPORT */
int udev_init_library_context ( void )
{
return 1 ;
}
void udev_fin_library_context ( void )
{
}
int udev_is_running ( void )
{
return 0 ;
}
const char * udev_get_dev_dir ( void )
{
return NULL ;
}
# endif
2006-08-17 23:56:28 +04:00
int lvm_getpagesize ( void )
{
return getpagesize ( ) ;
}
2008-12-07 07:23:37 +03:00
int read_urandom ( void * buf , size_t len )
{
int fd ;
/* FIXME: we should stat here, and handle other cases */
/* FIXME: use common _io() routine's open/read/close */
if ( ( fd = open ( " /dev/urandom " , O_RDONLY ) ) < 0 ) {
log_sys_error ( " open " , " read_urandom: /dev/urandom " ) ;
return 0 ;
}
if ( read ( fd , buf , len ) ! = ( ssize_t ) len ) {
log_sys_error ( " read " , " read_urandom: /dev/urandom " ) ;
if ( close ( fd ) )
stack ;
return 0 ;
}
if ( close ( fd ) )
stack ;
return 1 ;
}