1
0
mirror of git://sourceware.org/git/lvm2.git synced 2024-12-21 13:34:40 +03:00

Move common libudev code to lvm-wrappers.[ch].

...so we can use it throughout.
This commit is contained in:
Peter Rajnoha 2011-04-22 11:59:59 +00:00
parent 71b29ddcc4
commit 40059f18d9
3 changed files with 96 additions and 1 deletions

View File

@ -17,6 +17,91 @@
#include <unistd.h> #include <unistd.h>
#include <fcntl.h> #include <fcntl.h>
#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
int lvm_getpagesize(void) int lvm_getpagesize(void)
{ {
return getpagesize(); return getpagesize();

View File

@ -16,6 +16,16 @@
#ifndef _LVM_WRAPPERS_H #ifndef _LVM_WRAPPERS_H
#define _LVM_WRAPPERS_H #define _LVM_WRAPPERS_H
#ifdef UDEV_SYNC_SUPPORT
#include <libudev.h>
struct udev *udev_get_library_context(void);
#endif
int udev_init_library_context(void);
void udev_fin_library_context(void);
int udev_is_running(void);
const char *udev_get_dev_dir(void);
int lvm_getpagesize(void); int lvm_getpagesize(void);
/* /*

View File

@ -38,7 +38,7 @@ CLDFLAGS += @CLDFLAGS@
LDDEPS += @LDDEPS@ LDDEPS += @LDDEPS@
LDFLAGS += @LDFLAGS@ LDFLAGS += @LDFLAGS@
LIB_SUFFIX = @LIB_SUFFIX@ LIB_SUFFIX = @LIB_SUFFIX@
LVMINTERNAL_LIBS = -llvm-internal $(DL_LIBS) LVMINTERNAL_LIBS = -llvm-internal $(UDEV_LIBS) $(DL_LIBS)
DL_LIBS = @DL_LIBS@ DL_LIBS = @DL_LIBS@
PTHREAD_LIBS = @PTHREAD_LIBS@ PTHREAD_LIBS = @PTHREAD_LIBS@
READLINE_LIBS = @READLINE_LIBS@ READLINE_LIBS = @READLINE_LIBS@