libosmocore 1.9.0.191-50e38
Osmocom core library
Osmocom logging framework

libosmocore Logging sub-system More...

Files

file  logging.h
 
file  logging.c
 Debugging/Logging support code.
 
file  logging_gsmtap.c
 libosmocore log output encapsulated in GSMTAP.
 
file  logging_syslog.c
 Syslog logging support code.
 
file  logging_systemd.c
 

Data Structures

struct  log_category
 Configuration of single log category / sub-system. More...
 
struct  log_info_cat
 Information regarding one logging category. More...
 
struct  log_context
 Log context information, passed to filter. More...
 
struct  log_info
 Logging configuration, passed to log_init. More...
 
struct  log_target
 structure representing a logging target More...
 

Macros

#define DEBUG
 
#define DEBUGP(ss, fmt, args...)   LOGP(ss, LOGL_DEBUG, fmt, ##args)
 Log a debug message through the Osmocom logging framework. More...
 
#define DEBUGPC(ss, fmt, args...)   LOGPC(ss, LOGL_DEBUG, fmt, ##args)
 
#define LOGP(ss, level, fmt, args...)    LOGPSRC(ss, level, NULL, 0, fmt, ## args)
 Log a new message through the Osmocom logging framework. More...
 
#define LOGPC(ss, level, fmt, args...)
 Continue a log message through the Osmocom logging framework. More...
 
#define LOGPSRC(ss, level, caller_file, caller_line, fmt, args...)    LOGPSRCC(ss, level, caller_file, caller_line, 0, fmt, ##args)
 Log through the Osmocom logging framework with explicit source. More...
 
#define LOGPSRCC(ss, level, caller_file, caller_line, cont, fmt, args...)
 Log through the Osmocom logging framework with explicit source. More...
 
#define LOGL_DEBUG   1
 different log levels More...
 
#define LOGL_INFO   3
 general information More...
 
#define LOGL_NOTICE   5
 abnormal/unexpected condition More...
 
#define LOGL_ERROR   7
 error condition, requires user action More...
 
#define LOGL_FATAL   8
 fatal, program aborted More...
 
#define DLGLOBAL   -1
 global logging More...
 
#define DLLAPD   -2
 LAPD implementation. More...
 
#define DLINP   -3
 (A-bis) Input sub-system More...
 
#define DLMUX   -4
 Osmocom Multiplex (Osmux) More...
 
#define DLMI   -5
 ISDN-layer below input sub-system. More...
 
#define DLMIB   -6
 ISDN layer B-channel. More...
 
#define DLSMS   -7
 SMS sub-system. More...
 
#define DLCTRL   -8
 Control Interface. More...
 
#define DLGTP   -9
 GTP (GPRS Tunneling Protocol. More...
 
#define DLSTATS   -10
 Statistics. More...
 
#define DLGSUP   -11
 Generic Subscriber Update Protocol. More...
 
#define DLOAP   -12
 Osmocom Authentication Protocol. More...
 
#define DLSS7   -13
 Osmocom SS7. More...
 
#define DLSCCP   -14
 Osmocom SCCP. More...
 
#define DLSUA   -15
 Osmocom SUA. More...
 
#define DLM3UA   -16
 Osmocom M3UA. More...
 
#define DLMGCP   -17
 Osmocom MGCP. More...
 
#define DLJIBUF   -18
 Osmocom Jitter Buffer. More...
 
#define DLRSPRO   -19
 Osmocom Remote SIM Protocol. More...
 
#define DLNS   -20
 Osmocom NS layer. More...
 
#define DLBSSGP   -21
 Osmocom BSSGP layer. More...
 
#define DLNSDATA   -22
 Osmocom NS layer data pdus. More...
 
#define DLNSSIGNAL   -23
 Osmocom NS layer signal pdus. More...
 
#define DLIUUP   -24
 Osmocom IuUP layer. More...
 
#define DLPFCP   -25
 Osmocom Packet Forwarding Control Protocol. More...
 
#define DLCSN1   -26
 CSN.1 (Concrete Syntax Notation 1) codec. More...
 
#define DLM2PA   -27
 Osmocom M2PA (libosmo-sigtran) More...
 
#define DLM2UA   -28
 Reserved for future Osmocom M2UA (libosmo-sigtran) More...
 
#define DLIO   -29
 Osmocom IO sub-system. More...
 
#define OSMO_NUM_DLIB   29
 Number of logging sub-systems in libraries. More...
 
#define OSMO_LOGCOLOR_NORMAL   NULL
 
#define OSMO_LOGCOLOR_RED   "\033[1;31m"
 
#define OSMO_LOGCOLOR_GREEN   "\033[1;32m"
 
#define OSMO_LOGCOLOR_YELLOW   "\033[1;33m"
 
#define OSMO_LOGCOLOR_BLUE   "\033[1;34m"
 
#define OSMO_LOGCOLOR_PURPLE   "\033[1;35m"
 
#define OSMO_LOGCOLOR_CYAN   "\033[1;36m"
 
#define OSMO_LOGCOLOR_DARKRED   "\033[31m"
 
#define OSMO_LOGCOLOR_DARKGREEN   "\033[32m"
 
#define OSMO_LOGCOLOR_DARKYELLOW   "\033[33m"
 
#define OSMO_LOGCOLOR_DARKBLUE   "\033[34m"
 
#define OSMO_LOGCOLOR_DARKPURPLE   "\033[35m"
 
#define OSMO_LOGCOLOR_DARKCYAN   "\033[36m"
 
#define OSMO_LOGCOLOR_DARKGREY   "\033[1;30m"
 
#define OSMO_LOGCOLOR_GREY   "\033[37m"
 
#define OSMO_LOGCOLOR_BRIGHTWHITE   "\033[1;37m"
 
#define OSMO_LOGCOLOR_END   "\033[0;m"
 
#define LOG_MAX_CTX   _LOG_CTX_COUNT
 Maximum number of logging contexts. More...
 
#define LOG_MAX_FILTERS   _LOG_FLT_COUNT
 Maximum number of logging filters. More...
 
#define LOG_FILTER_ALL   (1<<LOG_FLT_ALL)
 Compatibility with older libosmocore versions. More...
 
#define GPRS_CTX_NSVC   LOG_CTX_GB_NSVC
 Compatibility with older libosmocore versions. More...
 
#define GPRS_CTX_BVC   LOG_CTX_GB_BVC
 Compatibility with older libosmocore versions. More...
 
#define LOG_MTX_DEBUG   0
 
#define log_tgt_mutex_lock()   log_tgt_mutex_lock_impl()
 
#define log_tgt_mutex_unlock()   log_tgt_mutex_unlock_impl()
 
#define TRACE(probe)
 
#define TRACE_ENABLED(probe)   (0)
 
#define MAX_LOG_SIZE   4096
 
#define LOG_WQUEUE_LEN   156
 
#define INT2IDX(x)   (-1*(x)-1)
 
#define GSMTAP_LOG_MAX_SIZE   4096
 
#define SD_JOURNAL_SUPPRESS_LOCATION
 

Typedefs

typedef int log_filter(const struct log_context *ctx, struct log_target *target)
 Log filter function. More...
 
typedef void log_print_filters(struct vty *vty, const struct log_info *info, const struct log_target *tgt)
 
typedef void log_save_filters(struct vty *vty, const struct log_info *info, const struct log_target *tgt)
 

Enumerations

enum  log_ctx_index {
  LOG_CTX_GB_NSVC ,
  LOG_CTX_GB_BVC ,
  LOG_CTX_BSC_SUBSCR ,
  LOG_CTX_VLR_SUBSCR ,
  LOG_CTX_L1_SAPI ,
  LOG_CTX_GB_NSE ,
  _LOG_CTX_COUNT
}
 Indexes to indicate the object currently acted upon. More...
 
enum  log_filter_index {
  LOG_FLT_ALL ,
  LOG_FLT_GB_NSVC ,
  LOG_FLT_GB_BVC ,
  LOG_FLT_BSC_SUBSCR ,
  LOG_FLT_VLR_SUBSCR ,
  LOG_FLT_L1_SAPI ,
  LOG_FLT_GB_NSE ,
  _LOG_FLT_COUNT
}
 Indexes to indicate objects that should be logged. More...
 
enum  log_target_type {
  LOG_TGT_TYPE_VTY ,
  LOG_TGT_TYPE_SYSLOG ,
  LOG_TGT_TYPE_FILE ,
  LOG_TGT_TYPE_STDERR ,
  LOG_TGT_TYPE_STRRB ,
  LOG_TGT_TYPE_GSMTAP ,
  LOG_TGT_TYPE_SYSTEMD
}
 Type of logging target. More...
 
enum  log_filename_type {
  LOG_FILENAME_NONE ,
  LOG_FILENAME_PATH ,
  LOG_FILENAME_BASENAME
}
 Whether/how to log the source filename (and line number). More...
 
enum  log_filename_pos {
  LOG_FILENAME_POS_HEADER_END ,
  LOG_FILENAME_POS_LINE_END
}
 Where on a log line source file and line should be logged. More...
 

Functions

void osmo_vlogp (int subsys, int level, const char *file, int line, int cont, const char *format, va_list ap)
 vararg version of logging function More...
 
void logp (int subsys, const char *file, int line, int cont, const char *format,...)
 logging function used by DEBUGP() macro More...
 
void logp2 (int subsys, unsigned int level, const char *file, int line, int cont, const char *format,...)
 logging function used by LOGP() macro More...
 
void void logp_stub (const char *file, int line, int cont, const char *format,...)
 
int log_init (const struct log_info *inf, void *ctx)
 Initialize the Osmocom logging core. More...
 
void log_fini (void)
 
int log_check_level (int subsys, unsigned int level)
 Check whether a log entry will be generated. More...
 
void log_reset_context (void)
 Reset (clear) the logging context. More...
 
int log_set_context (uint8_t ctx_nr, void *value)
 Set the logging context. More...
 
void log_set_all_filter (struct log_target *target, int all)
 Enable the LOG_FLT_ALL log filter. More...
 
int log_cache_enable (void)
 Enable the log level lookup cache to bypass string formatting and other code for log statements which are not actually enabled/needed by any existing log target. More...
 
void log_cache_update (int mapped_subsys, uint8_t enabled, uint8_t level)
 Updates single cache entry, caller must hold osmo_log_tgt_mutex. More...
 
void log_set_use_color (struct log_target *target, int use_color)
 Enable or disable the use of colored output. More...
 
void log_set_print_extended_timestamp (struct log_target *target, int print_timestamp)
 Enable or disable printing of extended timestamps while logging. More...
 
void log_set_print_timestamp (struct log_target *target, int print_timestamp)
 Enable or disable printing of timestamps while logging. More...
 
void log_set_print_tid (struct log_target *target, int print_tid)
 Enable or disable printing of timestamps while logging. More...
 
void log_set_print_filename (struct log_target *target, int print_filename)
 Use log_set_print_filename2() instead. More...
 
void log_set_print_filename2 (struct log_target *target, enum log_filename_type lft)
 Enable or disable printing of the filename while logging. More...
 
void log_set_print_filename_pos (struct log_target *target, enum log_filename_pos pos)
 Set the position where on a log line the source file info should be logged. More...
 
void log_set_print_category (struct log_target *target, int print_category)
 Enable or disable printing of the category name. More...
 
void log_set_print_category_hex (struct log_target *target, int print_category_hex)
 Enable or disable printing of the category number in hex ('<000b>'). More...
 
void log_set_print_level (struct log_target *target, int print_level)
 Enable or disable printing of the log level name. More...
 
void log_set_log_level (struct log_target *target, int log_level)
 Set the global log level for a given log target. More...
 
void log_parse_category_mask (struct log_target *target, const char *_mask)
 parse the log category mask More...
 
const char * log_category_name (int subsys)
 
int log_parse_level (const char *lvl)
 Parse a human-readable log level into a numeric value. More...
 
const char * log_level_str (unsigned int lvl)
 convert a numeric log level into human-readable string More...
 
int log_parse_category (const char *category)
 parse a human-readable log category into numeric form More...
 
void log_set_category_filter (struct log_target *target, int category, int enable, int level)
 Set a category filter on a given log target. More...
 
struct log_targetlog_target_create (void)
 Create a new log target skeleton. More...
 
void log_target_destroy (struct log_target *target)
 Unregister, close and delete a log target. More...
 
struct log_targetlog_target_create_stderr (void)
 Create the STDERR log target. More...
 
struct log_targetlog_target_create_file (const char *fname)
 Create a new file-based log target using non-blocking write_queue. More...
 
struct log_targetlog_target_create_syslog (const char *ident, int option, int facility)
 
struct log_targetlog_target_create_gsmtap (const char *host, uint16_t port, const char *ident, bool ofd_wq_mode, bool add_sink)
 Create a new logging target for GSMTAP logging. More...
 
struct log_targetlog_target_create_systemd (bool raw)
 Create a new logging target for systemd journal logging. More...
 
void log_target_systemd_set_raw (struct log_target *target, bool raw)
 Change meta information handling of an existing logging target. More...
 
int log_target_file_reopen (struct log_target *target)
 close and re-open a log file (for log file rotation) More...
 
int log_target_file_switch_to_stream (struct log_target *target)
 switch from non-blocking/write-queue to blocking + buffered stream output More...
 
int log_target_file_switch_to_wqueue (struct log_target *target)
 switch from blocking + buffered file output to non-blocking write-queue based output. More...
 
int log_targets_reopen (void)
 close and re-open all log files (for log file rotation) More...
 
void log_add_target (struct log_target *target)
 Register a new log target with the logging core. More...
 
void log_del_target (struct log_target *target)
 Unregister a log target from the logging core. More...
 
struct log_targetlog_target_find (enum log_target_type type, const char *fname)
 Find a registered log target. More...
 
void log_enable_multithread (void)
 Enable multithread support (mutex) in libosmocore logging system. More...
 
void log_tgt_mutex_lock_impl (void)
 Acquire the osmo_log_tgt_mutex. More...
 
void log_tgt_mutex_unlock_impl (void)
 Release the osmo_log_tgt_mutex. More...
 
 osmo_static_assert (_LOG_CTX_COUNT<=ARRAY_SIZE(((struct log_context *) NULL) ->ctx), enum_logging_ctx_items_fit_in_struct_log_context)
 
 osmo_static_assert (_LOG_FLT_COUNT<=ARRAY_SIZE(((struct log_target *) NULL) ->filter_data), enum_logging_filters_fit_in_log_target_filter_data)
 
 osmo_static_assert (_LOG_FLT_COUNT<=8 *sizeof(((struct log_target *) NULL) ->filter_map), enum_logging_filters_fit_in_log_target_filter_map)
 
 LLIST_HEAD (osmo_log_target_list)
 
static void log_cache_update_all (void)
 Updates cache for all targets for all categies, caller must hold osmo_log_tgt_mutex. More...
 
static bool log_cache_check (int mapped_subsys, int level)
 Queries log level cache. More...
 
void assert_loginfo (const char *src)
 
static int subsys_lib2index (int subsys)
 
static const char * color (int subsys)
 
static const char * level_color (int level)
 
static const char * const_basename (const char *path)
 
static int _output_buf (char *buf, int buf_len, struct log_target *target, unsigned int subsys, unsigned int level, const char *file, int line, int cont, const char *format, va_list ap)
 main output formatting function for log lines. More...
 
static void _output (struct log_target *target, unsigned int subsys, unsigned int level, const char *file, int line, int cont, const char *format, va_list ap)
 
static int map_subsys (int subsys)
 
static bool should_log_to_target (struct log_target *tar, int subsys, int level)
 
static int _file_wq_write_cb (struct osmo_fd *ofd, struct msgb *msg)
 
static void _file_output_stream (struct log_target *target, unsigned int level, const char *log)
 
static void _file_raw_output (struct log_target *target, int subsys, unsigned int level, const char *file, int line, int cont, const char *format, va_list ap)
 
struct log_targetlog_target_create_file_stream (const char *fname)
 Create a new file-based log target using buffered, blocking stream output. More...
 
static void _gsmtap_raw_output (struct log_target *target, int subsys, unsigned int level, const char *file, int line, int cont, const char *format, va_list ap)
 
static int logp2syslog_level (unsigned int level)
 
static void _systemd_output (struct log_target *target, unsigned int level, const char *log)
 
static void _systemd_raw_output (struct log_target *target, int subsys, unsigned int level, const char *file, int line, int cont, const char *format, va_list ap)
 

Variables

struct log_infoosmo_log_info
 
struct log_infoosmo_log_info
 
static struct log_context log_context
 
void * tall_log_ctx = NULL
 
static __thread long int logging_tid
 
static volatile uint8_t * log_level_lookup_cache
 One global copy that contains the union of log levels for all targets for all categories, used for quick lock free checks of log targets. More...
 
static pthread_mutex_t osmo_log_tgt_mutex
 This mutex must be held while using osmo_log_target_list or any of its log_targets in a multithread program. More...
 
static bool osmo_log_tgt_mutex_on = false
 
const struct value_string loglevel_strs []
 
static const struct log_info_cat internal_cat [OSMO_NUM_DLIB]
 
static const struct value_string level_colors []
 
static __thread uint32_t logging_gsmtap_tid
 

Detailed Description

libosmocore Logging sub-system

Macro Definition Documentation

◆ DEBUG

#define DEBUG

◆ DEBUGP

#define DEBUGP (   ss,
  fmt,
  args... 
)    LOGP(ss, LOGL_DEBUG, fmt, ##args)

Log a debug message through the Osmocom logging framework.

Parameters
[in]sslogging subsystem (e.g. DLGLOBAL)
[in]fmtformat string
[in]argsvariable argument list

◆ DEBUGPC

#define DEBUGPC (   ss,
  fmt,
  args... 
)    LOGPC(ss, LOGL_DEBUG, fmt, ##args)

◆ DLBSSGP

#define DLBSSGP   -21

Osmocom BSSGP layer.

◆ DLCSN1

#define DLCSN1   -26

CSN.1 (Concrete Syntax Notation 1) codec.

◆ DLCTRL

#define DLCTRL   -8

Control Interface.

◆ DLGLOBAL

#define DLGLOBAL   -1

global logging

◆ DLGSUP

#define DLGSUP   -11

Generic Subscriber Update Protocol.

◆ DLGTP

#define DLGTP   -9

GTP (GPRS Tunneling Protocol.

◆ DLINP

#define DLINP   -3

(A-bis) Input sub-system

◆ DLIO

#define DLIO   -29

Osmocom IO sub-system.

◆ DLIUUP

#define DLIUUP   -24

Osmocom IuUP layer.

◆ DLJIBUF

#define DLJIBUF   -18

Osmocom Jitter Buffer.

◆ DLLAPD

#define DLLAPD   -2

LAPD implementation.

◆ DLM2PA

#define DLM2PA   -27

Osmocom M2PA (libosmo-sigtran)

◆ DLM2UA

#define DLM2UA   -28

Reserved for future Osmocom M2UA (libosmo-sigtran)

◆ DLM3UA

#define DLM3UA   -16

Osmocom M3UA.

◆ DLMGCP

#define DLMGCP   -17

Osmocom MGCP.

◆ DLMI

#define DLMI   -5

ISDN-layer below input sub-system.

◆ DLMIB

#define DLMIB   -6

ISDN layer B-channel.

◆ DLMUX

#define DLMUX   -4

Osmocom Multiplex (Osmux)

◆ DLNS

#define DLNS   -20

Osmocom NS layer.

◆ DLNSDATA

#define DLNSDATA   -22

Osmocom NS layer data pdus.

◆ DLNSSIGNAL

#define DLNSSIGNAL   -23

Osmocom NS layer signal pdus.

◆ DLOAP

#define DLOAP   -12

Osmocom Authentication Protocol.

◆ DLPFCP

#define DLPFCP   -25

Osmocom Packet Forwarding Control Protocol.

◆ DLRSPRO

#define DLRSPRO   -19

Osmocom Remote SIM Protocol.

◆ DLSCCP

#define DLSCCP   -14

Osmocom SCCP.

◆ DLSMS

#define DLSMS   -7

SMS sub-system.

◆ DLSS7

#define DLSS7   -13

Osmocom SS7.

◆ DLSTATS

#define DLSTATS   -10

Statistics.

◆ DLSUA

#define DLSUA   -15

Osmocom SUA.

◆ GPRS_CTX_BVC

#define GPRS_CTX_BVC   LOG_CTX_GB_BVC

Compatibility with older libosmocore versions.

◆ GPRS_CTX_NSVC

#define GPRS_CTX_NSVC   LOG_CTX_GB_NSVC

Compatibility with older libosmocore versions.

◆ GSMTAP_LOG_MAX_SIZE

#define GSMTAP_LOG_MAX_SIZE   4096

◆ INT2IDX

#define INT2IDX (   x)    (-1*(x)-1)

◆ LOG_FILTER_ALL

#define LOG_FILTER_ALL   (1<<LOG_FLT_ALL)

Compatibility with older libosmocore versions.

◆ LOG_MAX_CTX

#define LOG_MAX_CTX   _LOG_CTX_COUNT

Maximum number of logging contexts.

◆ LOG_MAX_FILTERS

#define LOG_MAX_FILTERS   _LOG_FLT_COUNT

Maximum number of logging filters.

◆ LOG_MTX_DEBUG

#define LOG_MTX_DEBUG   0

◆ log_tgt_mutex_lock

#define log_tgt_mutex_lock ( )    log_tgt_mutex_lock_impl()

◆ log_tgt_mutex_unlock

#define log_tgt_mutex_unlock ( )    log_tgt_mutex_unlock_impl()

◆ LOG_WQUEUE_LEN

#define LOG_WQUEUE_LEN   156

◆ LOGL_DEBUG

#define LOGL_DEBUG   1

different log levels

debugging information

◆ LOGL_ERROR

#define LOGL_ERROR   7

error condition, requires user action

◆ LOGL_FATAL

#define LOGL_FATAL   8

fatal, program aborted

◆ LOGL_INFO

#define LOGL_INFO   3

general information

◆ LOGL_NOTICE

#define LOGL_NOTICE   5

abnormal/unexpected condition

◆ LOGP

#define LOGP (   ss,
  level,
  fmt,
  args... 
)     LOGPSRC(ss, level, NULL, 0, fmt, ## args)

Log a new message through the Osmocom logging framework.

Parameters
[in]sslogging subsystem (e.g. DLGLOBAL)
[in]levellogging level (e.g. LOGL_NOTICE)
[in]fmtformat string
[in]argsvariable argument list

◆ LOGPC

#define LOGPC (   ss,
  level,
  fmt,
  args... 
)
Value:
do { \
if (!osmo_log_info) { \
logp_stub(__FILE__, __LINE__, 1, fmt, ##args); \
break; \
} \
if (log_check_level(ss, level)) \
logp2(ss, level, __FILE__, __LINE__, 1, fmt, ##args); \
} while(0)
int log_check_level(int subsys, unsigned int level)
Check whether a log entry will be generated.
Definition: logging.c:1611
struct log_info * osmo_log_info
Definition: logging.c:87
uint8_t level
logging level
Definition: gsmtap.h:6

Continue a log message through the Osmocom logging framework.

Parameters
[in]sslogging subsystem (e.g. DLGLOBAL)
[in]levellogging level (e.g. LOGL_NOTICE)
[in]fmtformat string
[in]argsvariable argument list

◆ LOGPSRC

#define LOGPSRC (   ss,
  level,
  caller_file,
  caller_line,
  fmt,
  args... 
)     LOGPSRCC(ss, level, caller_file, caller_line, 0, fmt, ##args)

Log through the Osmocom logging framework with explicit source.

If caller_file is passed as NULL, FILE and LINE are used instead of caller_file and caller_line (so that this macro here defines both cases in the same place, and to catch cases where callers fail to pass a non-null filename string).

Parameters
[in]sslogging subsystem (e.g. DLGLOBAL)
[in]levellogging level (e.g. LOGL_NOTICE)
[in]caller_filecaller's source file string (e.g. FILE)
[in]caller_linecaller's source line nr (e.g. LINE)
[in]fmtformat string
[in]argsvariable argument list

◆ LOGPSRCC

#define LOGPSRCC (   ss,
  level,
  caller_file,
  caller_line,
  cont,
  fmt,
  args... 
)
Value:
do { \
if (!osmo_log_info) { \
if (caller_file) \
logp_stub(caller_file, caller_line, cont, fmt, ##args); \
logp_stub(__FILE__, __LINE__, cont, fmt, ##args); \
break; \
} \
if (log_check_level(ss, level)) {\
if (caller_file) \
logp2(ss, level, caller_file, caller_line, cont, fmt, ##args); \
logp2(ss, level, __FILE__, __LINE__, cont, fmt, ##args); \
}\
} while(0)
void void logp_stub(const char *file, int line, int cont, const char *format,...)
Definition: logging.c:824
void logp2(int subsys, unsigned int level, const char *file, int line, int cont, const char *format,...) __attribute__((format(printf
logging function used by LOGP() macro
Definition: logging.c:811

Log through the Osmocom logging framework with explicit source.

If caller_file is passed as NULL, FILE and LINE are used instead of caller_file and caller_line (so that this macro here defines both cases in the same place, and to catch cases where callers fail to pass a non-null filename string).

Parameters
[in]sslogging subsystem (e.g. DLGLOBAL)
[in]levellogging level (e.g. LOGL_NOTICE)
[in]caller_filecaller's source file string (e.g. FILE)
[in]caller_linecaller's source line nr (e.g. LINE)
[in]contcontinuation (1) or new line (0)
[in]fmtformat string
[in]argsvariable argument list

◆ MAX_LOG_SIZE

#define MAX_LOG_SIZE   4096

◆ OSMO_LOGCOLOR_BLUE

#define OSMO_LOGCOLOR_BLUE   "\033[1;34m"

◆ OSMO_LOGCOLOR_BRIGHTWHITE

#define OSMO_LOGCOLOR_BRIGHTWHITE   "\033[1;37m"

◆ OSMO_LOGCOLOR_CYAN

#define OSMO_LOGCOLOR_CYAN   "\033[1;36m"

◆ OSMO_LOGCOLOR_DARKBLUE

#define OSMO_LOGCOLOR_DARKBLUE   "\033[34m"

◆ OSMO_LOGCOLOR_DARKCYAN

#define OSMO_LOGCOLOR_DARKCYAN   "\033[36m"

◆ OSMO_LOGCOLOR_DARKGREEN

#define OSMO_LOGCOLOR_DARKGREEN   "\033[32m"

◆ OSMO_LOGCOLOR_DARKGREY

#define OSMO_LOGCOLOR_DARKGREY   "\033[1;30m"

◆ OSMO_LOGCOLOR_DARKPURPLE

#define OSMO_LOGCOLOR_DARKPURPLE   "\033[35m"

◆ OSMO_LOGCOLOR_DARKRED

#define OSMO_LOGCOLOR_DARKRED   "\033[31m"

◆ OSMO_LOGCOLOR_DARKYELLOW

#define OSMO_LOGCOLOR_DARKYELLOW   "\033[33m"

◆ OSMO_LOGCOLOR_END

#define OSMO_LOGCOLOR_END   "\033[0;m"

◆ OSMO_LOGCOLOR_GREEN

#define OSMO_LOGCOLOR_GREEN   "\033[1;32m"

◆ OSMO_LOGCOLOR_GREY

#define OSMO_LOGCOLOR_GREY   "\033[37m"

◆ OSMO_LOGCOLOR_NORMAL

#define OSMO_LOGCOLOR_NORMAL   NULL

◆ OSMO_LOGCOLOR_PURPLE

#define OSMO_LOGCOLOR_PURPLE   "\033[1;35m"

◆ OSMO_LOGCOLOR_RED

#define OSMO_LOGCOLOR_RED   "\033[1;31m"

◆ OSMO_LOGCOLOR_YELLOW

#define OSMO_LOGCOLOR_YELLOW   "\033[1;33m"

◆ OSMO_NUM_DLIB

#define OSMO_NUM_DLIB   29

Number of logging sub-systems in libraries.

◆ SD_JOURNAL_SUPPRESS_LOCATION

#define SD_JOURNAL_SUPPRESS_LOCATION

◆ TRACE

#define TRACE (   probe)

◆ TRACE_ENABLED

#define TRACE_ENABLED (   probe)    (0)

Typedef Documentation

◆ log_filter

typedef int log_filter(const struct log_context *ctx, struct log_target *target)

Log filter function.

◆ log_print_filters

typedef void log_print_filters(struct vty *vty, const struct log_info *info, const struct log_target *tgt)

◆ log_save_filters

typedef void log_save_filters(struct vty *vty, const struct log_info *info, const struct log_target *tgt)

Enumeration Type Documentation

◆ log_ctx_index

Indexes to indicate the object currently acted upon.

Array indexes for the global log_context array.

Enumerator
LOG_CTX_GB_NSVC 
LOG_CTX_GB_BVC 
LOG_CTX_BSC_SUBSCR 
LOG_CTX_VLR_SUBSCR 
LOG_CTX_L1_SAPI 
LOG_CTX_GB_NSE 
_LOG_CTX_COUNT 

◆ log_filename_pos

Where on a log line source file and line should be logged.

Enumerator
LOG_FILENAME_POS_HEADER_END 
LOG_FILENAME_POS_LINE_END 

◆ log_filename_type

Whether/how to log the source filename (and line number).

Enumerator
LOG_FILENAME_NONE 
LOG_FILENAME_PATH 
LOG_FILENAME_BASENAME 

◆ log_filter_index

Indexes to indicate objects that should be logged.

Array indexes to log_target->filter_data and bit indexes for log_target->filter_map.

Enumerator
LOG_FLT_ALL 
LOG_FLT_GB_NSVC 
LOG_FLT_GB_BVC 
LOG_FLT_BSC_SUBSCR 
LOG_FLT_VLR_SUBSCR 
LOG_FLT_L1_SAPI 
LOG_FLT_GB_NSE 
_LOG_FLT_COUNT 

◆ log_target_type

Type of logging target.

Enumerator
LOG_TGT_TYPE_VTY 

VTY logging.

LOG_TGT_TYPE_SYSLOG 

syslog based logging

LOG_TGT_TYPE_FILE 

text file logging

LOG_TGT_TYPE_STDERR 

stderr logging

LOG_TGT_TYPE_STRRB 

osmo_strrb-backed logging

LOG_TGT_TYPE_GSMTAP 

GSMTAP network logging.

LOG_TGT_TYPE_SYSTEMD 

systemd journal logging

Function Documentation

◆ _file_output_stream()

static void _file_output_stream ( struct log_target target,
unsigned int  level,
const char *  log 
)
static

◆ _file_raw_output()

static void _file_raw_output ( struct log_target target,
int  subsys,
unsigned int  level,
const char *  file,
int  line,
int  cont,
const char *  format,
va_list  ap 
)
static

◆ _file_wq_write_cb()

static int _file_wq_write_cb ( struct osmo_fd ofd,
struct msgb msg 
)
static

◆ _gsmtap_raw_output()

◆ _output()

static void _output ( struct log_target target,
unsigned int  subsys,
unsigned int  level,
const char *  file,
int  line,
int  cont,
const char *  format,
va_list  ap 
)
static

◆ _output_buf()

static int _output_buf ( char *  buf,
int  buf_len,
struct log_target target,
unsigned int  subsys,
unsigned int  level,
const char *  file,
int  line,
int  cont,
const char *  format,
va_list  ap 
)
static

main output formatting function for log lines.

Parameters
[out]bufcaller-allocated output buffer for the generated string
[in]buf_lennumber of bytes available in buf
[in]targetlog target for which the string is to be formatted
[in]subsysLog sub-system number
[in]levelLog level
[in]filename of source code file generating the log
[in]lineline source code line number within 'file' generating the log
[in]contis this a continuation (true) or not (false)
[in]formatformat string
[in]apvariable argument list for format
Returns
number of bytes written to out

References osmo_strbuf::buf, color(), const_basename(), file(), level, level_color(), log_category_name(), LOG_FILENAME_BASENAME, LOG_FILENAME_NONE, LOG_FILENAME_PATH, LOG_FILENAME_POS_HEADER_END, LOG_FILENAME_POS_LINE_END, log_level_str(), logging_tid, osmo_gettid(), osmo_gettimeofday(), OSMO_LOGCOLOR_END, OSMO_STRBUF_ADDED_TAIL, OSMO_STRBUF_APPEND, OSMO_STRBUF_CHAR_COUNT, OSMO_STRBUF_DROP_TAIL, OSMO_STRBUF_PRINTF, OSMO_STRBUF_REMAIN, osmo_strbuf::pos, log_target::print_category, log_target::print_category_hex, log_target::print_ext_timestamp, log_target::print_filename2, log_target::print_filename_pos, log_target::print_level, log_target::print_tid, log_target::print_timestamp, subsys, time, and log_target::use_color.

Referenced by _file_raw_output(), and _output().

◆ _systemd_output()

static void _systemd_output ( struct log_target target,
unsigned int  level,
const char *  log 
)
static

References level, and logp2syslog_level().

Referenced by log_target_systemd_set_raw().

◆ _systemd_raw_output()

static void _systemd_raw_output ( struct log_target target,
int  subsys,
unsigned int  level,
const char *  file,
int  line,
int  cont,
const char *  format,
va_list  ap 
)
static

◆ assert_loginfo()

void assert_loginfo ( const char *  src)

◆ color()

static const char * color ( int  subsys)
static

◆ const_basename()

static const char * const_basename ( const char *  path)
static

Referenced by _output_buf().

◆ level_color()

static const char * level_color ( int  level)
static

◆ LLIST_HEAD()

LLIST_HEAD ( osmo_log_target_list  )

◆ log_add_target()

void log_add_target ( struct log_target target)

Register a new log target with the logging core.

Parameters
[in]targetLog target to be registered

References log_target::entry, llist_add_tail(), log_cache_update_all(), and osmo_log_target_list.

Referenced by osmo_init_logging2().

◆ log_cache_check()

static bool log_cache_check ( int  mapped_subsys,
int  level 
)
static

Queries log level cache.

Parameters
[in]mapped_subsysplain category index (after mapping)
[in]levellog level
Returns
true if logging should happen for at least one log target

References level, and log_level_lookup_cache.

Referenced by log_check_level(), and osmo_vlogp().

◆ log_cache_enable()

int log_cache_enable ( void  )

Enable the log level lookup cache to bypass string formatting and other code for log statements which are not actually enabled/needed by any existing log target.

\retruns 0 in case of success, negative -errno in case of error.

References ENOTSUP, log_cache_update_all(), log_level_lookup_cache, log_tgt_mutex_lock, log_tgt_mutex_unlock, log_info::num_cat, and osmo_log_info.

◆ log_cache_update()

void log_cache_update ( int  mapped_subsys,
uint8_t  enabled,
uint8_t  level 
)

Updates single cache entry, caller must hold osmo_log_tgt_mutex.

Parameters
[in]mapped_subsysplain category index (after mapping)
[in]enabledlog category enabled?
[in]levellog level

References log_target::categories, log_category::enabled, level, llist_for_each_entry, log_level_lookup_cache, log_category::loglevel, log_target::loglevel, osmo_log_target_list, OSMO_MAX, and OSMO_MIN.

Referenced by log_set_category_filter(), and log_target_create().

◆ log_cache_update_all()

static void log_cache_update_all ( void  )
static

◆ log_category_name()

const char * log_category_name ( int  subsys)

◆ log_check_level()

int log_check_level ( int  subsys,
unsigned int  level 
)

Check whether a log entry will be generated.

Returns
!= 0 if a log entry might get generated by at least one target

References assert_loginfo(), log_target::entry, level, llist_for_each_entry, log_cache_check(), log_tgt_mutex_lock, log_tgt_mutex_unlock, map_subsys(), osmo_log_target_list, should_log_to_target(), and subsys.

◆ log_del_target()

void log_del_target ( struct log_target target)

Unregister a log target from the logging core.

Parameters
[in]targetLog target to be unregistered

References log_target::entry, llist_del(), and log_cache_update_all().

Referenced by log_target_destroy().

◆ log_enable_multithread()

void log_enable_multithread ( void  )

Enable multithread support (mutex) in libosmocore logging system.

Must be called by processes willing to use logging subsystem from several threads. Once enabled, it's not possible to disable it again.

References osmo_log_tgt_mutex, and osmo_log_tgt_mutex_on.

◆ log_fini()

◆ log_init()

int log_init ( const struct log_info inf,
void *  ctx 
)

Initialize the Osmocom logging core.

Parameters
[in]infInformation regarding logging categories, could be NULL
[in]ctxtalloc context for logging allocations
Returns
0 in case of success, negative in case of error

If inf is NULL then only library-internal categories are initialized.

References ARRAY_SIZE, log_info::cat, log_info::filter_fn, internal_cat, LOGL_NOTICE, log_info_cat::loglevel, log_info::num_cat, log_info::num_cat_user, OSMO_ASSERT, osmo_log_info, and tall_log_ctx.

Referenced by osmo_init_logging2().

◆ log_level_str()

const char * log_level_str ( unsigned int  lvl)

convert a numeric log level into human-readable string

Parameters
[in]lvlnumeric log level
Returns
zero-terminated string (log level name)

References get_value_string(), and loglevel_strs.

Referenced by _output_buf().

◆ log_parse_category()

int log_parse_category ( const char *  category)

parse a human-readable log category into numeric form

Parameters
[in]categoryhuman-readable log category name
Returns
numeric category value, or -EINVAL otherwise

References assert_loginfo(), log_info::cat, log_info_cat::name, log_info::num_cat, and osmo_log_info.

◆ log_parse_category_mask()

void log_parse_category_mask ( struct log_target target,
const char *  _mask 
)

parse the log category mask

Parameters
[in]targetlog target to be configured
[in]_masklog category mask string

The format can be this: category1:category2:category3 or category1,2:category2,3:...

References assert_loginfo(), log_info::cat, log_target::categories, log_category::enabled, length, level, log_cache_update_all(), log_category::loglevel, log_info_cat::name, log_info::num_cat, OSMO_ASSERT, and osmo_log_info.

◆ log_parse_level()

int log_parse_level ( const char *  lvl)

Parse a human-readable log level into a numeric value.

Parameters
[in]lvlzero-terminated string containing log level name
Returns
numeric log level

References get_string_value(), and loglevel_strs.

◆ log_reset_context()

void log_reset_context ( void  )

Reset (clear) the logging context.

◆ log_set_all_filter()

void log_set_all_filter ( struct log_target target,
int  all 
)

Enable the LOG_FLT_ALL log filter.

Parameters
[in]targetLog target to be affected
[in]allenable (1) or disable (0) the ALL filter

When the LOG_FLT_ALL filter is enabled, all log messages will be printed. It acts as a wildcard. Setting it to 1 means there is no filtering.

References log_target::filter_map, and LOG_FLT_ALL.

Referenced by osmo_init_logging2().

◆ log_set_category_filter()

void log_set_category_filter ( struct log_target target,
int  category,
int  enable,
int  level 
)

Set a category filter on a given log target.

Parameters
[in]targetLog target to be affected
[in]categoryLog category to be affected
[in]enablewhether to enable or disable the filter
[in]levelLog level of the filter

References log_target::categories, log_category::enabled, level, log_cache_update(), log_category::loglevel, and map_subsys().

◆ log_set_context()

int log_set_context ( uint8_t  ctx_nr,
void *  value 
)

Set the logging context.

Parameters
[in]ctx_nrlogging context number
[in]valuevalue to which the context is to be set
Returns
0 in case of success; negative otherwise

A logging context is something like the subscriber identity to which the currently processed message relates, or the BTS through which it was received. As soon as this data is known, it can be set using this function. The main use of context information is for logging filters.

References log_context::ctx, and LOG_MAX_CTX.

◆ log_set_log_level()

void log_set_log_level ( struct log_target target,
int  log_level 
)

Set the global log level for a given log target.

Parameters
[in]targetLog target to be affected
[in]log_levelNew global log level

References log_cache_update_all(), and log_target::loglevel.

◆ log_set_print_category()

void log_set_print_category ( struct log_target target,
int  print_category 
)

Enable or disable printing of the category name.

Parameters
[in]targetLog target to be affected
[in]print_categoryEnable (1) or disable (0) filenames

Print the category/subsys name in front of every log message.

References log_target::print_category.

◆ log_set_print_category_hex()

void log_set_print_category_hex ( struct log_target target,
int  print_category_hex 
)

Enable or disable printing of the category number in hex ('<000b>').

Parameters
[in]targetLog target to be affected.
[in]print_category_hexEnable (1) or disable (0) hex category.

References log_target::print_category_hex.

Referenced by log_set_print_filename().

◆ log_set_print_extended_timestamp()

void log_set_print_extended_timestamp ( struct log_target target,
int  print_timestamp 
)

Enable or disable printing of extended timestamps while logging.

Parameters
[in]targetLog target to be affected
[in]print_timestampEnable (1) or disable (0) timestamps

When both timestamp and extended timestamp is enabled then only the extended timestamp will be used. The format of the timestamp is YYYYMMDDhhmmssnnn.

References log_target::print_ext_timestamp, and log_target::print_timestamp.

◆ log_set_print_filename()

void log_set_print_filename ( struct log_target target,
int  print_filename 
)

Use log_set_print_filename2() instead.

Call log_set_print_filename2() with LOG_FILENAME_PATH or LOG_FILENAME_NONE, as well as call log_set_print_category_hex() with the argument passed to this function. This is to mirror legacy behavior, which combined the category in hex with the filename. For example, if the category-hex output were no longer affected by log_set_print_filename(), many unit tests (in libosmocore as well as dependent projects) would fail since they expect the category to disappear along with the filename.

Parameters
[in]targetLog target to be affected
[in]print_filenameEnable (1) or disable (0) filenames

References LOG_FILENAME_NONE, LOG_FILENAME_PATH, log_set_print_category_hex(), log_set_print_filename2(), and log_target::print_filename.

◆ log_set_print_filename2()

void log_set_print_filename2 ( struct log_target target,
enum log_filename_type  lft 
)

Enable or disable printing of the filename while logging.

Parameters
[in]targetLog target to be affected.
[in]lftAn LOG_FILENAME_* enum value. LOG_FILENAME_NONE omits the source file and line information from logs. LOG_FILENAME_PATH prints the entire source file path as passed to LOGP macros.

References log_target::print_filename2.

Referenced by log_set_print_filename().

◆ log_set_print_filename_pos()

void log_set_print_filename_pos ( struct log_target target,
enum log_filename_pos  pos 
)

Set the position where on a log line the source file info should be logged.

Parameters
[in]targetLog target to be affected.
[in]posA LOG_FILENAME_POS_* enum value. LOG_FILENAME_POS_DEFAULT logs just before the caller supplied log message. LOG_FILENAME_POS_LAST logs only at the end of a log line, where the caller issued an '
' to end the

References log_target::print_filename_pos.

◆ log_set_print_level()

void log_set_print_level ( struct log_target target,
int  print_level 
)

Enable or disable printing of the log level name.

Parameters
[in]targetLog target to be affected
[in]print_levelEnable (1) or disable (0) log level name

Print the log level name in front of every log message.

References log_target::print_level.

◆ log_set_print_tid()

void log_set_print_tid ( struct log_target target,
int  print_tid 
)

Enable or disable printing of timestamps while logging.

Parameters
[in]targetLog target to be affected
[in]print_tidEnable (1) or disable (0) Thread ID logging

References log_target::print_tid.

◆ log_set_print_timestamp()

void log_set_print_timestamp ( struct log_target target,
int  print_timestamp 
)

Enable or disable printing of timestamps while logging.

Parameters
[in]targetLog target to be affected
[in]print_timestampEnable (1) or disable (0) timestamps

References log_target::print_timestamp.

◆ log_set_use_color()

void log_set_use_color ( struct log_target target,
int  use_color 
)

Enable or disable the use of colored output.

Parameters
[in]targetLog target to be affected
[in]use_colorUse color (1) or don't use color (0)

References log_target::use_color.

◆ log_target_create()

◆ log_target_create_file()

struct log_target * log_target_create_file ( const char *  fname)

Create a new file-based log target using non-blocking write_queue.

Parameters
[in]fnameFile name of the new log file
Returns
Log target in case of success, NULL otherwise

References _file_raw_output(), _file_wq_write_cb(), osmo_wqueue::bfd, osmo_fd::fd, log_target::fname, log_target_create(), log_target_destroy(), LOG_TGT_TYPE_FILE, LOG_WQUEUE_LEN, MAX_LOG_SIZE, osmo_fd_register(), OSMO_FD_WRITE, osmo_wqueue_init(), log_target::raw_output, log_target::tgt_file, log_target::type, osmo_fd::when, log_target::wqueue, and osmo_wqueue::write_cb.

◆ log_target_create_file_stream()

struct log_target * log_target_create_file_stream ( const char *  fname)

Create a new file-based log target using buffered, blocking stream output.

Parameters
[in]fnameFile name of the new log file
Returns
Log target in case of success, NULL otherwise

References _file_output_stream(), log_target::fname, log_target_create(), log_target_destroy(), LOG_TGT_TYPE_FILE, log_target::out, log_target::output, log_target::tgt_file, and log_target::type.

◆ log_target_create_gsmtap()

struct log_target * log_target_create_gsmtap ( const char *  host,
uint16_t  port,
const char *  ident,
bool  ofd_wq_mode,
bool  add_sink 
)

Create a new logging target for GSMTAP logging.

Parameters
[in]hostremote host to send the logs to
[in]portremote port to send the logs to
[in]identstring identifier
[in]ofd_wq_moderegister osmo_wqueue (1) or not (0)
[in]add_sinkadd GSMTAP sink or not
Returns
Log target in case of success, NULL in case of error

References _gsmtap_raw_output(), log_target::gsmtap_inst, gsmtap_source_add_sink(), gsmtap_source_init(), log_target::hostname, log_target::ident, log_target_create(), log_target_destroy(), LOG_TGT_TYPE_GSMTAP, log_target::raw_output, log_target::tgt_gsmtap, and log_target::type.

◆ log_target_create_stderr()

struct log_target * log_target_create_stderr ( void  )

Create the STDERR log target.

Returns
dynamically-allocated log_target for STDERR

References _file_output_stream(), log_target_create(), LOG_TGT_TYPE_STDERR, log_target::out, log_target::output, log_target::tgt_file, and log_target::type.

Referenced by osmo_init_logging2().

◆ log_target_create_syslog()

struct log_target * log_target_create_syslog ( const char *  ident,
int  option,
int  facility 
)

◆ log_target_create_systemd()

struct log_target * log_target_create_systemd ( bool  raw)

Create a new logging target for systemd journal logging.

Parameters
[in]rawwhether to offload rendering of the meta information (location, category) to systemd-journal.
Returns
Log target in case of success, NULL in case of error.

References log_target_create(), log_target_systemd_set_raw(), LOG_TGT_TYPE_SYSTEMD, log_target::raw, and log_target::type.

◆ log_target_destroy()

◆ log_target_file_reopen()

int log_target_file_reopen ( struct log_target target)

close and re-open a log file (for log file rotation)

Parameters
[in]targetlog target to re-open
Returns
0 in case of success; negative otherwise

References osmo_wqueue::bfd, osmo_fd::fd, log_target::fname, LOG_TGT_TYPE_FILE, LOG_TGT_TYPE_STDERR, OSMO_ASSERT, osmo_fd_register(), osmo_fd_unregister(), log_target::out, log_target::tgt_file, log_target::type, and log_target::wqueue.

Referenced by log_targets_reopen().

◆ log_target_file_switch_to_stream()

int log_target_file_switch_to_stream ( struct log_target target)

switch from non-blocking/write-queue to blocking + buffered stream output

Parameters
[in]targetlog target which we should switch
Returns
0 on success; 1 if already switched before; negative on error Must be called with mutex osmo_log_tgt_mutex held, see log_tgt_mutex_lock.

References _file_output_stream(), osmo_wqueue::bfd, osmo_fd::fd, log_target::fname, llist_empty(), LOG_TGT_TYPE_FILE, LOG_TGT_TYPE_STDERR, msg, osmo_wqueue::msg_queue, msgb_data(), msgb_dequeue(), msgb_free(), msgb_length(), OSMO_ASSERT, osmo_fd_unregister(), log_target::out, log_target::output, log_target::raw_output, log_target::tgt_file, log_target::type, and log_target::wqueue.

◆ log_target_file_switch_to_wqueue()

int log_target_file_switch_to_wqueue ( struct log_target target)

switch from blocking + buffered file output to non-blocking write-queue based output.

Parameters
[in]targetlog target which we should switch
Returns
0 on success; 1 if already switched before; negative on error Must be called with mutex osmo_log_tgt_mutex held, see log_tgt_mutex_lock.

References _file_raw_output(), _file_wq_write_cb(), osmo_wqueue::bfd, osmo_fd::fd, log_target::fname, LOG_TGT_TYPE_FILE, LOG_WQUEUE_LEN, MAX_LOG_SIZE, osmo_fd_register(), OSMO_FD_WRITE, osmo_wqueue_init(), log_target::out, log_target::output, log_target::raw_output, log_target::tgt_file, log_target::type, osmo_fd::when, log_target::wqueue, and osmo_wqueue::write_cb.

◆ log_target_find()

struct log_target * log_target_find ( enum log_target_type  type,
const char *  fname 
)

Find a registered log target.

Parameters
[in]typeLog target type
[in]fnameFile name
Returns
Log target (if found), NULL otherwise Must be called with mutex osmo_log_tgt_mutex held, see log_tgt_mutex_lock.

References log_target::entry, log_target::fname, log_target::hostname, llist_for_each_entry, LOG_TGT_TYPE_FILE, LOG_TGT_TYPE_GSMTAP, osmo_log_target_list, log_target::tgt_file, log_target::tgt_gsmtap, type, and log_target::type.

◆ log_target_systemd_set_raw()

void log_target_systemd_set_raw ( struct log_target target,
bool  raw 
)

Change meta information handling of an existing logging target.

Parameters
[in]targetlogging target to be modified.
[in]rawwhether to offload rendering of the meta information (location, category) to systemd-journal.

References _systemd_output(), _systemd_raw_output(), log_target::output, log_target::raw, log_target::raw_output, and log_target::sd_journal.

Referenced by log_target_create_systemd().

◆ log_targets_reopen()

int log_targets_reopen ( void  )

close and re-open all log files (for log file rotation)

Returns
0 in case of success; negative otherwise

References log_target::entry, llist_for_each_entry, log_target_file_reopen(), log_tgt_mutex_lock, log_tgt_mutex_unlock, LOG_TGT_TYPE_FILE, osmo_log_target_list, and log_target::type.

Referenced by sighup_hdlr().

◆ log_tgt_mutex_lock_impl()

void log_tgt_mutex_lock_impl ( void  )

Acquire the osmo_log_tgt_mutex.

Don't use this function directly, always use macro log_tgt_mutex_lock() instead.

References osmo_log_tgt_mutex, and osmo_log_tgt_mutex_on.

◆ log_tgt_mutex_unlock_impl()

void log_tgt_mutex_unlock_impl ( void  )

Release the osmo_log_tgt_mutex.

Don't use this function directly, always use macro log_tgt_mutex_unlock() instead.

References osmo_log_tgt_mutex, and osmo_log_tgt_mutex_on.

◆ logp()

void logp ( int  subsys,
const char *  file,
int  line,
int  cont,
const char *  format,
  ... 
)

logging function used by DEBUGP() macro

Parameters
[in]subsysLogging sub-system
[in]filename of source code file
[in]contcontinuation (1) or new line (0)
[in]formatformat string

References file(), LOGL_DEBUG, osmo_vlogp(), and subsys.

◆ logp2()

void logp2 ( int  subsys,
unsigned int  level,
const char *  file,
int  line,
int  cont,
const char *  format,
  ... 
)

logging function used by LOGP() macro

Parameters
[in]subsysLogging sub-system
[in]levelLog level
[in]filename of source code file
[in]contcontinuation (1) or new line (0)
[in]formatformat string

References file(), level, osmo_vlogp(), subsys, and TRACE.

◆ logp2syslog_level()

static int logp2syslog_level ( unsigned int  level)
static

◆ logp_stub()

void logp_stub ( const char *  file,
int  line,
int  cont,
const char *  format,
  ... 
)

References file().

◆ map_subsys()

static int map_subsys ( int  subsys)
inlinestatic

◆ osmo_static_assert() [1/3]

osmo_static_assert ( _LOG_CTX_COUNT<=  ARRAY_SIZE((struct log_context *) NULL) ->ctx,
enum_logging_ctx_items_fit_in_struct_log_context   
)

◆ osmo_static_assert() [2/3]

osmo_static_assert ( _LOG_FLT_COUNT<=8 *  sizeof((struct log_target *) NULL) ->filter_map,
enum_logging_filters_fit_in_log_target_filter_map   
)

◆ osmo_static_assert() [3/3]

osmo_static_assert ( _LOG_FLT_COUNT<=  ARRAY_SIZE((struct log_target *) NULL) ->filter_data,
enum_logging_filters_fit_in_log_target_filter_data   
)

◆ osmo_vlogp()

void osmo_vlogp ( int  subsys,
int  level,
const char *  file,
int  line,
int  cont,
const char *  format,
va_list  ap 
)

vararg version of logging function

Parameters
[in]subsysLogging sub-system
[in]levelLog level
[in]filename of source code file
[in]contcontinuation (1) or new line (0)
[in]formatformat string
[in]apvararg-list containing format string arguments

References _output(), log_target::entry, file(), level, llist_for_each_entry, log_cache_check(), log_tgt_mutex_lock, log_tgt_mutex_unlock, map_subsys(), osmo_log_target_list, log_target::raw_output, should_log_to_target(), and subsys.

Referenced by logp(), and logp2().

◆ should_log_to_target()

static bool should_log_to_target ( struct log_target tar,
int  subsys,
int  level 
)
inlinestatic

◆ subsys_lib2index()

static int subsys_lib2index ( int  subsys)
static

References log_info::num_cat_user, osmo_log_info, and subsys.

Referenced by map_subsys().

Variable Documentation

◆ internal_cat

const struct log_info_cat internal_cat[OSMO_NUM_DLIB]
static

Referenced by log_init().

◆ level_colors

const struct value_string level_colors[]
static
Initial value:
= {
{ 0, NULL }
}
#define LOGL_NOTICE
abnormal/unexpected condition
Definition: logging.h:124
#define LOGL_FATAL
fatal, program aborted
Definition: logging.h:126
#define LOGL_ERROR
error condition, requires user action
Definition: logging.h:125
#define LOGL_INFO
general information
Definition: logging.h:123
#define OSMO_LOGCOLOR_BLUE
Definition: logging.h:165
#define LOGL_DEBUG
different log levels
Definition: logging.h:122
#define OSMO_LOGCOLOR_RED
Definition: logging.h:162
#define OSMO_LOGCOLOR_GREEN
Definition: logging.h:163
#define OSMO_LOGCOLOR_YELLOW
Definition: logging.h:164

Referenced by level_color().

◆ log_context

struct log_context log_context
static

◆ log_level_lookup_cache

volatile uint8_t* log_level_lookup_cache
static

One global copy that contains the union of log levels for all targets for all categories, used for quick lock free checks of log targets.

Referenced by log_cache_check(), log_cache_enable(), log_cache_update(), and log_cache_update_all().

◆ logging_gsmtap_tid

__thread uint32_t logging_gsmtap_tid
static

Referenced by _gsmtap_raw_output().

◆ logging_tid

__thread long int logging_tid
static

Referenced by _output_buf().

◆ loglevel_strs

const struct value_string loglevel_strs[]
Initial value:
= {
{ LOGL_DEBUG, "DEBUG" },
{ LOGL_INFO, "INFO" },
{ LOGL_NOTICE, "NOTICE" },
{ LOGL_ERROR, "ERROR" },
{ LOGL_FATAL, "FATAL" },
{ 0, NULL },
}

Referenced by log_level_str(), and log_parse_level().

◆ osmo_log_info [1/2]

struct log_info* osmo_log_info
extern

◆ osmo_log_info [2/2]

◆ osmo_log_tgt_mutex

pthread_mutex_t osmo_log_tgt_mutex
static

This mutex must be held while using osmo_log_target_list or any of its log_targets in a multithread program.

Prevents race conditions between threads like producing unordered timestamps or VTY deleting a target while another thread is writing to it

Referenced by log_enable_multithread(), log_tgt_mutex_lock_impl(), and log_tgt_mutex_unlock_impl().

◆ osmo_log_tgt_mutex_on

bool osmo_log_tgt_mutex_on = false
static

◆ tall_log_ctx

void* tall_log_ctx = NULL