Our preferred shared logging system is exported via the libqb library. As a result, the corosync project no longer needs to export logsys.so and the code can be directly included in the binary. The header file can also be removed. Signed-off-by: Steven Dake <sdake@xxxxxxxxxx> --- corosync.spec.in | 3 - cts/agents/syncv2.c | 2 +- exec/Makefile.am | 29 +---- exec/apidef.c | 2 +- exec/coroparse.c | 2 +- exec/evil.c | 4 +- exec/ipc_glue.c | 2 +- exec/logsys.c | 2 +- exec/main.c | 2 +- exec/mainconfig.c | 2 +- exec/mainconfig.h | 2 +- exec/quorum.c | 2 +- exec/service.c | 2 +- exec/sync.c | 2 +- exec/syncv2.c | 2 +- exec/totemconfig.c | 4 +- exec/totemiba.c | 2 +- exec/totemnet.c | 2 +- exec/totempg.c | 2 +- exec/totemrrp.c | 2 +- exec/totemsrp.c | 2 +- exec/totemudp.c | 2 +- exec/totemudpu.c | 2 +- exec/util.c | 2 +- exec/vsf_quorum.c | 2 +- exec/vsf_ykd.c | 2 +- include/Makefile.am | 4 +- include/corosync/engine/logsys.h | 218 -------------------------------------- include/corosync/logsys.h | 218 ++++++++++++++++++++++++++++++++++++++ services/cfg.c | 2 +- services/cmap.c | 2 +- services/cpg.c | 2 +- services/evs.c | 2 +- services/mon.c | 2 +- services/pload.c | 2 +- services/testquorum.c | 2 +- services/votequorum.c | 2 +- services/wd.c | 2 +- test/logsys_s.c | 2 +- test/logsys_s1.c | 2 +- test/logsys_s2.c | 2 +- test/logsys_t1.c | 2 +- test/logsys_t2.c | 2 +- test/logsysrec.c | 2 +- 44 files changed, 266 insertions(+), 288 deletions(-) delete mode 100644 include/corosync/engine/logsys.h create mode 100644 include/corosync/logsys.h diff --git a/corosync.spec.in b/corosync.spec.in index a6f4d26..36956fd 100644 --- a/corosync.spec.in +++ b/corosync.spec.in @@ -244,7 +244,6 @@ This package contains corosync libraries. %{_libdir}/libcmap.so.* %{_libdir}/libevs.so.* %{_libdir}/libtotem_pg.so.* -%{_libdir}/liblogsys.so.* %{_libdir}/libicmap.so.* %{_libdir}/libquorum.so.* %{_libdir}/libvotequorum.so.* @@ -296,7 +295,6 @@ The Corosync Cluster Engine APIs. %dir %{_includedir}/corosync/engine %{_includedir}/corosync/engine/config.h %{_includedir}/corosync/engine/coroapi.h -%{_includedir}/corosync/engine/logsys.h %{_includedir}/corosync/engine/icmap.h %{_includedir}/corosync/engine/quorum.h %{_libdir}/libcfg.so @@ -304,7 +302,6 @@ The Corosync Cluster Engine APIs. %{_libdir}/libcmap.so %{_libdir}/libevs.so %{_libdir}/libtotem_pg.so -%{_libdir}/liblogsys.so %{_libdir}/libquorum.so %{_libdir}/libvotequorum.so %{_libdir}/libpload.so diff --git a/cts/agents/syncv2.c b/cts/agents/syncv2.c index 0b46558..d5d6eba 100644 --- a/cts/agents/syncv2.c +++ b/cts/agents/syncv2.c @@ -59,7 +59,7 @@ #include <corosync/mar_gen.h> #include <corosync/engine/coroapi.h> #include <corosync/list.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> LOGSYS_DECLARE_SUBSYS ("TST2"); diff --git a/exec/Makefile.am b/exec/Makefile.am index 7c63f9c..c738570 100644 --- a/exec/Makefile.am +++ b/exec/Makefile.am @@ -42,24 +42,22 @@ if BUILD_RDMA TOTEM_SRC += totemiba.c endif -LOGSYS_SRC = logsys.c ICMAP_SRC = icmap.c LCRSO_SRC = vsf_ykd.c coroparse.c vsf_quorum.c LCRSO_OBJS = $(LCRSO_SRC:%.c=%.o) LCRSO = $(LCRSO_SRC:%.c=%.lcrso) -lib_LIBRARIES = libtotem_pg.a liblogsys.a libicmap.a +lib_LIBRARIES = libtotem_pg.a libicmap.a sbin_PROGRAMS = corosync libtotem_pg_a_SOURCES = $(TOTEM_SRC) -liblogsys_a_SOURCES = $(LOGSYS_SRC) libicmap_a_SOURCES = $(ICMAP_SRC) corosync_SOURCES = main.c ipc_glue.c util.c sync.c apidef.c service.c \ timer.c totemconfig.c mainconfig.c quorum.c schedwrk.c \ - ../lcr/lcr_ifact.c evil.c syncv2.c -corosync_LDADD = -ltotem_pg -llogsys -licmap $(LIBQB_LIBS) $(statgrab_LIBS) -corosync_DEPENDENCIES = libtotem_pg.so.$(SONAME) liblogsys.so.$(SONAME) libicmap.so.$(SONAME) + ../lcr/lcr_ifact.c evil.c syncv2.c logsys.c +corosync_LDADD = -ltotem_pg -licmap $(LIBQB_LIBS) $(statgrab_LIBS) +corosync_DEPENDENCIES = libtotem_pg.so.$(SONAME) libicmap.so.$(SONAME) corosync_LDFLAGS = $(OS_DYFLAGS) -L./ TOTEM_OBJS = $(TOTEM_SRC:%.c=%.o) @@ -80,18 +78,13 @@ EXTRA_DIST = $(LCRSO_SRC) if BUILD_DARWIN %.lcrso: %.o - $(CC) $(LDFLAGS) $(CFLAGS) -L$(top_builddir)/exec -llogsys -licmap -bundle -bind_at_load -bundle_loader ./corosync $^ -o $@ + $(CC) $(LDFLAGS) $(CFLAGS) -L$(top_builddir)/exec -licmap -bundle -bind_at_load -bundle_loader ./corosync $^ -o $@ libtotem_pg.so.$(SONAME): $(TOTEM_OBJS) $(CC) $(LDFLAGS) $(DARWIN_OPTS) $(TOTEM_OBJS) -o $@ -lpthread ln -sf libtotem_pg.so.$(SONAME) libtotem_pg.so ln -sf libtotem_pg.so.$(SONAME) libtotem_pg.so.$(SOMAJOR) -liblogsys.so.$(SONAME): $(LOGSYS_OBJS) - $(CC) $(LDFLAGS) $(DARWIN_OPTS) $(LOGSYS_OBJS) -o $@ -lpthread - ln -sf liblogsys.so.$(SONAME) liblogsys.so - ln -sf liblogsys.so.$(SONAME) liblogsys.so.$(SOMAJOR) - libicmap.so.$(SONAME): $(ICMAP_OBJS) $(CC) $(LDFLAGS) $(DARWIN_OPTS) $(ICMAP_OBJS) -o $@ -lpthread ln -sf libicmap.so.$(SONAME) libicmap.so @@ -108,11 +101,6 @@ libtotem_pg.so.$(SONAME): $(TOTEM_OBJS) ln -sf libtotem_pg.so.$(SONAME) libtotem_pg.so ln -sf libtotem_pg.so.$(SONAME) libtotem_pg.so.$(SOMAJOR) -liblogsys.so.$(SONAME): $(LOGSYS_OBJS) - $(LD) $(LDFLAGS) -G $(LOGSYS_OBJS) -o $@ -lpthread - ln -sf liblogsys.so.$(SONAME) liblogsys.so - ln -sf liblogsys.so.$(SONAME) liblogsys.so.$(SOMAJOR) - else %.lcrso: %.o @@ -125,13 +113,6 @@ libtotem_pg.so.$(SONAME): $(TOTEM_OBJS) ln -sf libtotem_pg.so.$(SONAME) libtotem_pg.so ln -sf libtotem_pg.so.$(SONAME) libtotem_pg.so.$(SOMAJOR) -liblogsys.so.$(SONAME): $(LOGSYS_OBJS) - $(CC) -shared -o $@ \ - -Wl,-soname=liblogsys.so.$(SOMAJOR) \ - $(LDFLAGS) $^ -lpthread - ln -sf liblogsys.so.$(SONAME) liblogsys.so - ln -sf liblogsys.so.$(SONAME) liblogsys.so.$(SOMAJOR) - libicmap.so.$(SONAME): $(ICMAP_OBJS) $(CC) -shared -o $@ \ -Wl,-soname=libicmap.so.$(SOMAJOR) \ diff --git a/exec/apidef.c b/exec/apidef.c index 5d738c9..795b594 100644 --- a/exec/apidef.c +++ b/exec/apidef.c @@ -46,7 +46,7 @@ #include <corosync/totem/totempg.h> #include <corosync/totem/totemip.h> #include <corosync/totem/totem.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include "util.h" #include "timer.h" #include "sync.h" diff --git a/exec/coroparse.c b/exec/coroparse.c index e88f9cf..98e5189 100644 --- a/exec/coroparse.c +++ b/exec/coroparse.c @@ -58,7 +58,7 @@ #include <corosync/lcr/lcr_comp.h> #include <qb/qbutil.h> #define LOGSYS_UTILS_ONLY 1 -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/engine/icmap.h> #include <corosync/engine/config.h> diff --git a/exec/evil.c b/exec/evil.c index 94db799..ba4bde9 100644 --- a/exec/evil.c +++ b/exec/evil.c @@ -70,9 +70,9 @@ #include <corosync/corodefs.h> #include <corosync/list.h> #include <corosync/lcr/lcr_ifact.h> -#include <corosync/engine/config.h> +#include <corosync/config.h> #include <corosync/engine/coroapi.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <qb/qbipcs.h> #include "sync.h" #include "evil.h" diff --git a/exec/ipc_glue.c b/exec/ipc_glue.c index 4df5b6d..9a5d06d 100644 --- a/exec/ipc_glue.c +++ b/exec/ipc_glue.c @@ -51,7 +51,7 @@ #include <corosync/corotypes.h> #include <corosync/corodefs.h> #include <corosync/totem/totempg.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/engine/icmap.h> #include "mainconfig.h" diff --git a/exec/logsys.c b/exec/logsys.c index 0a44454..12e70fc 100644 --- a/exec/logsys.c +++ b/exec/logsys.c @@ -48,7 +48,7 @@ #include <qb/qblog.h> #include <corosync/list.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> /* * syslog prioritynames, facility names to value mapping diff --git a/exec/main.c b/exec/main.c index 019f659..bb4d13f 100644 --- a/exec/main.c +++ b/exec/main.c @@ -108,7 +108,7 @@ #include <corosync/lcr/lcr_ifact.h> #include <corosync/totem/totempg.h> #include <corosync/engine/config.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/engine/icmap.h> #include "quorum.h" diff --git a/exec/mainconfig.c b/exec/mainconfig.c index 1c0d4a9..282f02c 100644 --- a/exec/mainconfig.c +++ b/exec/mainconfig.c @@ -49,7 +49,7 @@ #include <corosync/corotypes.h> #include <corosync/list.h> #include <corosync/totem/totem.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/engine/icmap.h> #include "util.h" diff --git a/exec/mainconfig.h b/exec/mainconfig.h index 5f7a2c2..3de7a7e 100644 --- a/exec/mainconfig.h +++ b/exec/mainconfig.h @@ -35,7 +35,7 @@ #ifndef MAINCONFIG_H_DEFINED #define MAINCONFIG_H_DEFINED -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/list.h> #include <corosync/engine/coroapi.h> diff --git a/exec/quorum.c b/exec/quorum.c index b81708c..1e76827 100644 --- a/exec/quorum.c +++ b/exec/quorum.c @@ -55,7 +55,7 @@ #include <corosync/totem/totempg.h> #include <corosync/totem/totem.h> #include <corosync/lcr/lcr_ifact.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include "quorum.h" #include "main.h" diff --git a/exec/service.c b/exec/service.c index 53a7798..a7be311 100644 --- a/exec/service.c +++ b/exec/service.c @@ -45,7 +45,7 @@ #include <corosync/corotypes.h> #include "mainconfig.h" #include "util.h" -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/engine/icmap.h> #include "timer.h" diff --git a/exec/sync.c b/exec/sync.c index ce99129..0cf01b3 100644 --- a/exec/sync.c +++ b/exec/sync.c @@ -55,7 +55,7 @@ #include <corosync/totem/totempg.h> #include <corosync/totem/totem.h> #include <corosync/lcr/lcr_ifact.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <qb/qbipc_common.h> #include "quorum.h" #include "sync.h" diff --git a/exec/syncv2.c b/exec/syncv2.c index 8a96615..a278be8 100644 --- a/exec/syncv2.c +++ b/exec/syncv2.c @@ -54,7 +54,7 @@ #include <corosync/totem/totempg.h> #include <corosync/totem/totem.h> #include <corosync/lcr/lcr_ifact.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <qb/qbipc_common.h> #include "schedwrk.h" #include "quorum.h" diff --git a/exec/totemconfig.c b/exec/totemconfig.c index b0292b1..e5893b9 100644 --- a/exec/totemconfig.c +++ b/exec/totemconfig.c @@ -53,8 +53,8 @@ #include <corosync/list.h> #include <qb/qbdefs.h> #include <corosync/totem/totem.h> -#include <corosync/engine/config.h> -#include <corosync/engine/logsys.h> +#include <corosync/config.h> +#include <corosync/logsys.h> #include <corosync/engine/icmap.h> #ifdef HAVE_LIBNSS diff --git a/exec/totemiba.c b/exec/totemiba.c index ffcfceb..b0b178d 100644 --- a/exec/totemiba.c +++ b/exec/totemiba.c @@ -74,7 +74,7 @@ #include <qb/qbdefs.h> #include <qb/qbloop.h> #define LOGSYS_UTILS_ONLY 1 -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include "totemiba.h" #include "wthread.h" diff --git a/exec/totemnet.c b/exec/totemnet.c index 9b211f7..0343b31 100644 --- a/exec/totemnet.c +++ b/exec/totemnet.c @@ -46,7 +46,7 @@ #include <qb/qbloop.h> #define LOGSYS_UTILS_ONLY 1 -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> struct transport { const char *name; diff --git a/exec/totempg.c b/exec/totempg.c index 3f07c95..acc0c2f 100644 --- a/exec/totempg.c +++ b/exec/totempg.c @@ -103,7 +103,7 @@ #include <qb/qbipcs.h> #include <corosync/totem/totempg.h> #define LOGSYS_UTILS_ONLY 1 -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include "totemmrp.h" #include "totemsrp.h" diff --git a/exec/totemrrp.c b/exec/totemrrp.c index 452a1e6..89b9fd6 100644 --- a/exec/totemrrp.c +++ b/exec/totemrrp.c @@ -64,7 +64,7 @@ #include <qb/qbdefs.h> #include <qb/qbloop.h> #define LOGSYS_UTILS_ONLY 1 -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include "totemnet.h" #include "totemrrp.h" diff --git a/exec/totemsrp.c b/exec/totemsrp.c index 5a78962..9d3d32d 100644 --- a/exec/totemsrp.c +++ b/exec/totemsrp.c @@ -83,7 +83,7 @@ #include <corosync/list.h> #define LOGSYS_UTILS_ONLY 1 -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include "totemsrp.h" #include "totemrrp.h" diff --git a/exec/totemudp.c b/exec/totemudp.c index b3fcb1b..200b9b8 100644 --- a/exec/totemudp.c +++ b/exec/totemudp.c @@ -64,7 +64,7 @@ #include <qb/qbdefs.h> #include <qb/qbloop.h> #define LOGSYS_UTILS_ONLY 1 -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include "totemudp.h" #include "crypto.h" diff --git a/exec/totemudpu.c b/exec/totemudpu.c index f9e07d0..6c6eae1 100644 --- a/exec/totemudpu.c +++ b/exec/totemudpu.c @@ -64,7 +64,7 @@ #include <corosync/list.h> #include <corosync/swab.h> #define LOGSYS_UTILS_ONLY 1 -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include "totemudpu.h" #include "crypto.h" diff --git a/exec/util.c b/exec/util.c index 848a080..6fde9f0 100644 --- a/exec/util.c +++ b/exec/util.c @@ -46,7 +46,7 @@ #include <corosync/corotypes.h> #include <corosync/corodefs.h> #include <corosync/list.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include "util.h" LOGSYS_DECLARE_SUBSYS ("MAIN"); diff --git a/exec/vsf_quorum.c b/exec/vsf_quorum.c index 15db962..79bea03 100644 --- a/exec/vsf_quorum.c +++ b/exec/vsf_quorum.c @@ -65,7 +65,7 @@ #include <corosync/lcr/lcr_ifact.h> #include <corosync/mar_gen.h> #include <corosync/engine/coroapi.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/engine/quorum.h> #include <corosync/engine/icmap.h> diff --git a/exec/vsf_ykd.c b/exec/vsf_ykd.c index 3e3dfa8..f8cdd04 100644 --- a/exec/vsf_ykd.c +++ b/exec/vsf_ykd.c @@ -56,7 +56,7 @@ #include <sched.h> #include <time.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/corotypes.h> #include <qb/qbipc_common.h> #include <corosync/mar_gen.h> diff --git a/include/Makefile.am b/include/Makefile.am index 5c0aab7..a36cfc0 100644 --- a/include/Makefile.am +++ b/include/Makefile.am @@ -36,11 +36,11 @@ CS_H = hdb.h cs_config.h cpg.h cfg.h evs.h mar_gen.h swab.h \ list.h corotypes.h quorum.h votequorum.h sam.h cmap.h CS_INTERNAL_H = ipc_cfg.h ipc_cpg.h ipc_evs.h ipc_pload.h ipc_quorum.h \ - jhash.h pload.h quorum.h sq.h ipc_votequorum.h ipc_cmap.h + jhash.h pload.h quorum.h sq.h ipc_votequorum.h ipc_cmap.h logsys.h LCR_H = lcr_ckpt.h lcr_comp.h lcr_ifact.h -ENGINE_H = config.h coroapi.h logsys.h quorum.h icmap.h +ENGINE_H = config.h coroapi.h quorum.h icmap.h TOTEM_H = totem.h totemip.h totempg.h diff --git a/include/corosync/engine/logsys.h b/include/corosync/engine/logsys.h deleted file mode 100644 index 247881e..0000000 --- a/include/corosync/engine/logsys.h +++ /dev/null @@ -1,218 +0,0 @@ -/* - * Copyright (c) 2002-2004 MontaVista Software, Inc. - * Copyright (c) 2006-2009 Red Hat, Inc. - * - * Author: Steven Dake (sdake@xxxxxxxxxx) - * Author: Lon Hohberger (lhh@xxxxxxxxxx) - * Author: Fabio M. Di Nitto (fdinitto@xxxxxxxxxx) - * - * All rights reserved. - * - * This software licensed under BSD license, the text of which follows: - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are met: - * - * - Redistributions of source code must retain the above copyright notice, - * this list of conditions and the following disclaimer. - * - Redistributions in binary form must reproduce the above copyright notice, - * this list of conditions and the following disclaimer in the documentation - * and/or other materials provided with the distribution. - * - Neither the name of the MontaVista Software, Inc. nor the names of its - * contributors may be used to endorse or promote products derived from this - * software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE - * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR - * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF - * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS - * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN - * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) - * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF - * THE POSSIBILITY OF SUCH DAMAGE. - */ -#ifndef LOGSYS_H_DEFINED -#define LOGSYS_H_DEFINED - -#include <stdarg.h> -#include <stdlib.h> -#include <syslog.h> -#include <pthread.h> -#include <limits.h> - -#include <qb/qblog.h> - -#ifdef __cplusplus -extern "C" { -#endif - -/* - * All of the LOGSYS_MODE's can be ORed together for combined behavior - * - * FORK and THREADED are ignored for SUBSYSTEMS - */ -#define LOGSYS_MODE_OUTPUT_FILE (1<<0) -#define LOGSYS_MODE_OUTPUT_STDERR (1<<1) -#define LOGSYS_MODE_OUTPUT_SYSLOG (1<<2) -#define LOGSYS_MODE_FORK (1<<3) -#define LOGSYS_MODE_THREADED (1<<4) - -/* - * Log priorities, compliant with syslog and SA Forum Log spec. - */ -#define LOGSYS_LEVEL_EMERG LOG_EMERG -#define LOGSYS_LEVEL_ALERT LOG_ALERT -#define LOGSYS_LEVEL_CRIT LOG_CRIT -#define LOGSYS_LEVEL_ERROR LOG_ERR -#define LOGSYS_LEVEL_WARNING LOG_WARNING -#define LOGSYS_LEVEL_NOTICE LOG_NOTICE -#define LOGSYS_LEVEL_INFO LOG_INFO -#define LOGSYS_LEVEL_DEBUG LOG_DEBUG - -/* - * logsys_logger bits - * - * SUBSYS_COUNT defines the maximum number of subsystems - * SUBSYS_NAMELEN defines the maximum len of a subsystem name - */ -#define LOGSYS_MAX_SUBSYS_COUNT 64 -#define LOGSYS_MAX_SUBSYS_NAMELEN 64 -#define LOGSYS_MAX_PERROR_MSG_LEN 128 - -#ifndef LOGSYS_UTILS_ONLY - -/* - * configuration bits that can only be done for the whole system - */ -extern int logsys_format_set ( - const char *format); - -extern char *logsys_format_get (void); - -/* - * per system/subsystem settings. - * - * NOTE: once a subsystem is created and configured, changing - * the default does NOT affect the subsystems. - * - * Pass a NULL subsystem to change them all - */ -extern int logsys_config_syslog_facility_set ( - const char *subsys, - unsigned int facility); - -extern int logsys_config_syslog_priority_set ( - const char *subsys, - unsigned int priority); - -extern int logsys_config_mode_set ( - const char *subsys, - unsigned int mode); - -extern unsigned int logsys_config_mode_get ( - const char *subsys); - -void logsys_config_apply(void); - -/* - * to close a logfile, just invoke this function with a NULL - * file or if you want to change logfile, the old one will - * be closed for you. - */ -extern int logsys_config_file_set ( - const char *subsys, - const char **error_string, - const char *file); - -extern int logsys_config_logfile_priority_set ( - const char *subsys, - unsigned int priority); - -/* - * enabling debug, disable message priority filtering. - * everything is sent everywhere. priority values - * for file and syslog are not overwritten. - */ -extern int logsys_config_debug_set ( - const char *subsys, - unsigned int value); - -/* - * External API - helpers - * - * convert facility/priority to/from name/values - */ -extern int logsys_priority_id_get ( - const char *name); - -extern const char *logsys_priority_name_get ( - unsigned int priority); - -extern int _logsys_system_setup( - const char *mainsystem, - unsigned int mode, - int syslog_facility, - int syslog_priority); - -extern void logsys_system_fini (void); - -extern int _logsys_config_subsys_get ( - const char *subsys); - -extern int _logsys_subsys_create (const char *subsys, const char *filename); - -static int logsys_subsys_id __attribute__((unused)) = LOGSYS_MAX_SUBSYS_COUNT; - -#define LOGSYS_DECLARE_SYSTEM(name,mode,syslog_facility,syslog_priority)\ -__attribute__ ((constructor)) \ -static void logsys_system_init (void) \ -{ \ - if (_logsys_system_setup (name,mode,syslog_facility,syslog_priority) < 0) { \ - fprintf (stderr, \ - "Unable to setup logging system: %s.\n", name); \ - exit (-1); \ - } \ -} - -#define LOGSYS_DECLARE_SUBSYS(subsys) \ -__attribute__ ((constructor)) \ -static void logsys_subsys_init (void) \ -{ \ - assert(__start___verbose != __stop___verbose); \ - logsys_subsys_id = \ - _logsys_subsys_create ((subsys), __FILE__); \ - if (logsys_subsys_id == -1) { \ - fprintf (stderr, \ - "Unable to create logging subsystem: %s.\n", subsys); \ - exit (-1); \ - } \ -} - -#define LOGSYS_PERROR(err_num, level, fmt, args...) do { \ - char _error_str[LOGSYS_MAX_PERROR_MSG_LEN]; \ - const char *_error_ptr = qb_strerror_r(err_num, _error_str, sizeof(_error_str)); \ - qb_log(level, fmt ": %s (%d)\n", ##args, _error_ptr, err_num); \ - } while(0) - -#define log_printf(level, format, args...) qb_log(level, format, ##args) -#define ENTER qb_enter -#define LEAVE qb_leave -#define TRACE1(format, args...) qb_log(LOG_TRACE, "TRACE1:" #format, ##args) -#define TRACE2(format, args...) qb_log(LOG_TRACE, "TRACE2:" #format, ##args) -#define TRACE3(format, args...) qb_log(LOG_TRACE, "TRACE3:" #format, ##args) -#define TRACE4(format, args...) qb_log(LOG_TRACE, "TRACE4:" #format, ##args) -#define TRACE5(format, args...) qb_log(LOG_TRACE, "TRACE5:" #format, ##args) -#define TRACE6(format, args...) qb_log(LOG_TRACE, "TRACE6:" #format, ##args) -#define TRACE7(format, args...) qb_log(LOG_TRACE, "TRACE7:" #format, ##args) -#define TRACE8(format, args...) qb_log(LOG_TRACE, "TRACE8:" #format, ##args) - -#endif /* LOGSYS_UTILS_ONLY */ - -#ifdef __cplusplus -} -#endif - -#endif /* LOGSYS_H_DEFINED */ diff --git a/include/corosync/logsys.h b/include/corosync/logsys.h new file mode 100644 index 0000000..247881e --- /dev/null +++ b/include/corosync/logsys.h @@ -0,0 +1,218 @@ +/* + * Copyright (c) 2002-2004 MontaVista Software, Inc. + * Copyright (c) 2006-2009 Red Hat, Inc. + * + * Author: Steven Dake (sdake@xxxxxxxxxx) + * Author: Lon Hohberger (lhh@xxxxxxxxxx) + * Author: Fabio M. Di Nitto (fdinitto@xxxxxxxxxx) + * + * All rights reserved. + * + * This software licensed under BSD license, the text of which follows: + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * + * - Redistributions of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * - Redistributions in binary form must reproduce the above copyright notice, + * this list of conditions and the following disclaimer in the documentation + * and/or other materials provided with the distribution. + * - Neither the name of the MontaVista Software, Inc. nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE + * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF + * THE POSSIBILITY OF SUCH DAMAGE. + */ +#ifndef LOGSYS_H_DEFINED +#define LOGSYS_H_DEFINED + +#include <stdarg.h> +#include <stdlib.h> +#include <syslog.h> +#include <pthread.h> +#include <limits.h> + +#include <qb/qblog.h> + +#ifdef __cplusplus +extern "C" { +#endif + +/* + * All of the LOGSYS_MODE's can be ORed together for combined behavior + * + * FORK and THREADED are ignored for SUBSYSTEMS + */ +#define LOGSYS_MODE_OUTPUT_FILE (1<<0) +#define LOGSYS_MODE_OUTPUT_STDERR (1<<1) +#define LOGSYS_MODE_OUTPUT_SYSLOG (1<<2) +#define LOGSYS_MODE_FORK (1<<3) +#define LOGSYS_MODE_THREADED (1<<4) + +/* + * Log priorities, compliant with syslog and SA Forum Log spec. + */ +#define LOGSYS_LEVEL_EMERG LOG_EMERG +#define LOGSYS_LEVEL_ALERT LOG_ALERT +#define LOGSYS_LEVEL_CRIT LOG_CRIT +#define LOGSYS_LEVEL_ERROR LOG_ERR +#define LOGSYS_LEVEL_WARNING LOG_WARNING +#define LOGSYS_LEVEL_NOTICE LOG_NOTICE +#define LOGSYS_LEVEL_INFO LOG_INFO +#define LOGSYS_LEVEL_DEBUG LOG_DEBUG + +/* + * logsys_logger bits + * + * SUBSYS_COUNT defines the maximum number of subsystems + * SUBSYS_NAMELEN defines the maximum len of a subsystem name + */ +#define LOGSYS_MAX_SUBSYS_COUNT 64 +#define LOGSYS_MAX_SUBSYS_NAMELEN 64 +#define LOGSYS_MAX_PERROR_MSG_LEN 128 + +#ifndef LOGSYS_UTILS_ONLY + +/* + * configuration bits that can only be done for the whole system + */ +extern int logsys_format_set ( + const char *format); + +extern char *logsys_format_get (void); + +/* + * per system/subsystem settings. + * + * NOTE: once a subsystem is created and configured, changing + * the default does NOT affect the subsystems. + * + * Pass a NULL subsystem to change them all + */ +extern int logsys_config_syslog_facility_set ( + const char *subsys, + unsigned int facility); + +extern int logsys_config_syslog_priority_set ( + const char *subsys, + unsigned int priority); + +extern int logsys_config_mode_set ( + const char *subsys, + unsigned int mode); + +extern unsigned int logsys_config_mode_get ( + const char *subsys); + +void logsys_config_apply(void); + +/* + * to close a logfile, just invoke this function with a NULL + * file or if you want to change logfile, the old one will + * be closed for you. + */ +extern int logsys_config_file_set ( + const char *subsys, + const char **error_string, + const char *file); + +extern int logsys_config_logfile_priority_set ( + const char *subsys, + unsigned int priority); + +/* + * enabling debug, disable message priority filtering. + * everything is sent everywhere. priority values + * for file and syslog are not overwritten. + */ +extern int logsys_config_debug_set ( + const char *subsys, + unsigned int value); + +/* + * External API - helpers + * + * convert facility/priority to/from name/values + */ +extern int logsys_priority_id_get ( + const char *name); + +extern const char *logsys_priority_name_get ( + unsigned int priority); + +extern int _logsys_system_setup( + const char *mainsystem, + unsigned int mode, + int syslog_facility, + int syslog_priority); + +extern void logsys_system_fini (void); + +extern int _logsys_config_subsys_get ( + const char *subsys); + +extern int _logsys_subsys_create (const char *subsys, const char *filename); + +static int logsys_subsys_id __attribute__((unused)) = LOGSYS_MAX_SUBSYS_COUNT; + +#define LOGSYS_DECLARE_SYSTEM(name,mode,syslog_facility,syslog_priority)\ +__attribute__ ((constructor)) \ +static void logsys_system_init (void) \ +{ \ + if (_logsys_system_setup (name,mode,syslog_facility,syslog_priority) < 0) { \ + fprintf (stderr, \ + "Unable to setup logging system: %s.\n", name); \ + exit (-1); \ + } \ +} + +#define LOGSYS_DECLARE_SUBSYS(subsys) \ +__attribute__ ((constructor)) \ +static void logsys_subsys_init (void) \ +{ \ + assert(__start___verbose != __stop___verbose); \ + logsys_subsys_id = \ + _logsys_subsys_create ((subsys), __FILE__); \ + if (logsys_subsys_id == -1) { \ + fprintf (stderr, \ + "Unable to create logging subsystem: %s.\n", subsys); \ + exit (-1); \ + } \ +} + +#define LOGSYS_PERROR(err_num, level, fmt, args...) do { \ + char _error_str[LOGSYS_MAX_PERROR_MSG_LEN]; \ + const char *_error_ptr = qb_strerror_r(err_num, _error_str, sizeof(_error_str)); \ + qb_log(level, fmt ": %s (%d)\n", ##args, _error_ptr, err_num); \ + } while(0) + +#define log_printf(level, format, args...) qb_log(level, format, ##args) +#define ENTER qb_enter +#define LEAVE qb_leave +#define TRACE1(format, args...) qb_log(LOG_TRACE, "TRACE1:" #format, ##args) +#define TRACE2(format, args...) qb_log(LOG_TRACE, "TRACE2:" #format, ##args) +#define TRACE3(format, args...) qb_log(LOG_TRACE, "TRACE3:" #format, ##args) +#define TRACE4(format, args...) qb_log(LOG_TRACE, "TRACE4:" #format, ##args) +#define TRACE5(format, args...) qb_log(LOG_TRACE, "TRACE5:" #format, ##args) +#define TRACE6(format, args...) qb_log(LOG_TRACE, "TRACE6:" #format, ##args) +#define TRACE7(format, args...) qb_log(LOG_TRACE, "TRACE7:" #format, ##args) +#define TRACE8(format, args...) qb_log(LOG_TRACE, "TRACE8:" #format, ##args) + +#endif /* LOGSYS_UTILS_ONLY */ + +#ifdef __cplusplus +} +#endif + +#endif /* LOGSYS_H_DEFINED */ diff --git a/services/cfg.c b/services/cfg.c index ae42baf..b00ae93 100644 --- a/services/cfg.c +++ b/services/cfg.c @@ -59,7 +59,7 @@ #include <corosync/totem/totem.h> #include <corosync/ipc_cfg.h> #include <corosync/lcr/lcr_comp.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/engine/coroapi.h> #include <corosync/engine/icmap.h> #include <corosync/corodefs.h> diff --git a/services/cmap.c b/services/cmap.c index 92f0574..076d8db 100644 --- a/services/cmap.c +++ b/services/cmap.c @@ -52,7 +52,7 @@ #include <corosync/mar_gen.h> #include <corosync/ipc_cmap.h> #include <corosync/lcr/lcr_comp.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/engine/coroapi.h> #include <corosync/engine/icmap.h> diff --git a/services/cpg.c b/services/cpg.c index 56b5ca1..008a3ea 100644 --- a/services/cpg.c +++ b/services/cpg.c @@ -63,7 +63,7 @@ #include <corosync/list.h> #include <corosync/jhash.h> #include <corosync/lcr/lcr_comp.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/engine/coroapi.h> #include <corosync/cpg.h> diff --git a/services/evs.c b/services/evs.c index 43c65d6..e8d5879 100644 --- a/services/evs.c +++ b/services/evs.c @@ -58,7 +58,7 @@ #include <corosync/mar_gen.h> #include <corosync/lcr/lcr_comp.h> #include <corosync/engine/coroapi.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/list.h> #include <corosync/evs.h> diff --git a/services/mon.c b/services/mon.c index 15d32b5..a0bc705 100644 --- a/services/mon.c +++ b/services/mon.c @@ -44,7 +44,7 @@ #include <corosync/lcr/lcr_comp.h> #include <corosync/engine/coroapi.h> #include <corosync/list.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/engine/icmap.h> #include "../exec/fsm.h" diff --git a/services/pload.c b/services/pload.c index e2f6e77..85a485f 100644 --- a/services/pload.c +++ b/services/pload.c @@ -64,7 +64,7 @@ #include <corosync/engine/coroapi.h> #include <corosync/ipc_pload.h> #include <corosync/list.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> LOGSYS_DECLARE_SUBSYS ("PLOAD"); diff --git a/services/testquorum.c b/services/testquorum.c index 806040a..3cdf9cd 100644 --- a/services/testquorum.c +++ b/services/testquorum.c @@ -57,7 +57,7 @@ #include <corosync/corotypes.h> #include <qb/qbipc_common.h> #include <corosync/corodefs.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/engine/icmap.h> #include <corosync/mar_gen.h> diff --git a/services/votequorum.c b/services/votequorum.c index cc13a1b..d9930fb 100644 --- a/services/votequorum.c +++ b/services/votequorum.c @@ -64,7 +64,7 @@ #include <corosync/cfg.h> #include <corosync/list.h> #include <corosync/lcr/lcr_comp.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/mar_gen.h> #include <corosync/engine/coroapi.h> #include <corosync/engine/quorum.h> diff --git a/services/wd.c b/services/wd.c index 58c5939..72544ae 100644 --- a/services/wd.c +++ b/services/wd.c @@ -46,7 +46,7 @@ #include <corosync/lcr/lcr_comp.h> #include <corosync/engine/coroapi.h> #include <corosync/list.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> #include <corosync/engine/icmap.h> #include "../exec/fsm.h" diff --git a/test/logsys_s.c b/test/logsys_s.c index 7eabacd..7b1f6e0 100644 --- a/test/logsys_s.c +++ b/test/logsys_s.c @@ -38,7 +38,7 @@ #include <syslog.h> #include <assert.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> LOGSYS_DECLARE_SYSTEM ("logsystestsubsystems", LOGSYS_MODE_OUTPUT_STDERR | LOGSYS_MODE_OUTPUT_SYSLOG, diff --git a/test/logsys_s1.c b/test/logsys_s1.c index fb689dd..687f857 100644 --- a/test/logsys_s1.c +++ b/test/logsys_s1.c @@ -38,7 +38,7 @@ #include <syslog.h> #include <assert.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> void logsys_s1_print (void); diff --git a/test/logsys_s2.c b/test/logsys_s2.c index 8082886..56e013f 100644 --- a/test/logsys_s2.c +++ b/test/logsys_s2.c @@ -38,7 +38,7 @@ #include <syslog.h> #include <assert.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> void logsys_s2_print (void); diff --git a/test/logsys_t1.c b/test/logsys_t1.c index 06b2c59..8a295ae 100644 --- a/test/logsys_t1.c +++ b/test/logsys_t1.c @@ -38,7 +38,7 @@ #include <syslog.h> #include <assert.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> LOGSYS_DECLARE_SYSTEM ("logsystestNOsubsystems", LOGSYS_MODE_OUTPUT_STDERR | LOGSYS_MODE_OUTPUT_SYSLOG, diff --git a/test/logsys_t2.c b/test/logsys_t2.c index fcee399..0b886e0 100644 --- a/test/logsys_t2.c +++ b/test/logsys_t2.c @@ -38,7 +38,7 @@ #include <stdint.h> #include <assert.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> LOGSYS_DECLARE_SYSTEM ("logtest_t2", LOGSYS_MODE_OUTPUT_STDERR | LOGSYS_MODE_THREADED, diff --git a/test/logsysrec.c b/test/logsysrec.c index 2d05435..354c544 100644 --- a/test/logsysrec.c +++ b/test/logsysrec.c @@ -36,7 +36,7 @@ #include <stdio.h> #include <stdint.h> -#include <corosync/engine/logsys.h> +#include <corosync/logsys.h> LOGSYS_DECLARE_SYSTEM ("logtest_rec", LOGSYS_MODE_OUTPUT_STDERR | LOGSYS_MODE_THREADED, -- 1.7.7.4 _______________________________________________ discuss mailing list discuss@xxxxxxxxxxxx http://lists.corosync.org/mailman/listinfo/discuss