Home | History | Annotate | Download | only in liblog
      1 LIBLOG(3)               Android NDK Programming Manual               LIBLOG(3)
      2 
      3 
      4 
      5 NAME
      6        liblog - Android NDK logger interfaces
      7 
      8 SYNOPSIS
      9        #include <log/log.h>
     10 
     11        ALOG(android_priority, tag, format, ...)
     12        IF_ALOG(android_priority, tag)
     13        LOG_PRI(priority, tag, format, ...)
     14        LOG_PRI_VA(priority, tag, format, args)
     15        #define LOG_TAG NULL
     16        ALOGV(format, ...)
     17        SLOGV(format, ...)
     18        RLOGV(format, ...)
     19        ALOGV_IF(cond, format, ...)
     20        SLOGV_IF(cond, format, ...)
     21        RLOGV_IF(cond, format, ...)
     22        IF_ALOGC()
     23        ALOGD(format, ...)
     24        SLOGD(format, ...)
     25        RLOGD(format, ...)
     26        ALOGD_IF(cond, format, ...)
     27        SLOGD_IF(cond, format, ...)
     28        RLOGD_IF(cond, format, ...)
     29        IF_ALOGD()
     30        ALOGI(format, ...)
     31        SLOGI(format, ...)
     32        RLOGI(format, ...)
     33        ALOGI_IF(cond, format, ...)
     34        SLOGI_IF(cond, format, ...)
     35        RLOGI_IF(cond, format, ...)
     36        IF_ALOGI()
     37        ALOGW(format, ...)
     38        SLOGW(format, ...)
     39        RLOGW(format, ...)
     40        ALOGW_IF(cond, format, ...)
     41        SLOGW_IF(cond, format, ...)
     42        RLOGW_IF(cond, format, ...)
     43        IF_ALOGW()
     44        ALOGE(format, ...)
     45        SLOGE(format, ...)
     46        RLOGE(format, ...)
     47        ALOGE_IF(cond, format, ...)
     48        SLOGE_IF(cond, format, ...)
     49        RLOGE_IF(cond, format, ...)
     50        IF_ALOGE()
     51        LOG_FATAL(format, ...)
     52        LOG_ALWAYS_FATAL(format, ...)
     53        LOG_FATAL_IF(cond, format, ...)
     54        LOG_ALWAYS_FATAL_IF(cond, format, ...)
     55        ALOG_ASSERT(cond, format, ...)
     56        LOG_EVENT_INT(tag, value)
     57        LOG_EVENT_LONG(tag, value)
     58 
     59        Link with -llog
     60 
     61        #include <log/logger.h>
     62 
     63        log_id_t android_logger_get_id(struct logger *logger)
     64        int android_logger_clear(struct logger *logger)
     65        int android_logger_get_log_size(struct logger *logger)
     66        int android_logger_get_log_readable_size(struct logger *logger)
     67        int android_logger_get_log_version(struct logger *logger)
     68 
     69        struct  logger_list  *android_logger_list_alloc(int  mode, unsigned int
     70        tail, pid_t pid)
     71        struct  logger  *android_logger_open(struct  logger_list  *logger_list,
     72        log_id_t id)
     73        struct  logger_list  *android_logger_list_open(log_id_t  id,  int mode,
     74        unsigned int tail, pid_t pid)
     75 
     76        int android_logger_list_read(struct  logger_list  *logger_list,  struct
     77        log_msg *log_msg
     78 
     79        void android_logger_list_free(struct logger_list *logger_list)
     80 
     81        log_id_t android_name_to_log_id(const char *logName)
     82        const char *android_log_id_to_name(log_id_t log_id)
     83 
     84        Link with -llog
     85 
     86 DESCRIPTION
     87        liblog  represents  an interface to the volatile Android Logging system
     88        for NDK (Native) applications  and  libraries.  Interfaces  for  either
     89        writing  or reading logs.  The log buffers are divided up in Main, Sys
     90        tem, Radio and Events sub-logs.
     91 
     92        The logging interfaces are a series of macros,  all  of  which  can  be
     93        overridden individually in order to control the verbosity of the appli
     94        cation or library.  [ASR]LOG[VDIWE] calls are used  to  log  to  BAsic,
     95        System or Radio sub-logs in either the Verbose, Debug, Info, Warning or
     96        Error priorities.  [ASR]LOG[VDIWE]_IF calls are used  to  perform  thus
     97        based  on a condition being true.  IF_ALOG[VDIWE] calls are true if the
     98        current LOG_TAG is enabled at the specified priority.  LOG_ALWAYS_FATAL
     99        is  used to ALOG a message, then kill the process.  LOG_FATAL call is a
    100        variant of LOG_ALWAYS_FATAL,  only  enabled  in  engineering,  and  not
    101        release builds.  ALOG_ASSERT is used to ALOG a message if the condition
    102        is  false;   the   condition   is   part   of   the   logged   message.
    103        LOG_EVENT_(INT|LONG)  is  used  to  drop binary content into the Events
    104        sub-log.
    105 
    106        The log reading interfaces permit opening the  logs  either  singly  or
    107        multiply,  retrieving  a  log  entry  at  a  time in time sorted order,
    108        optionally limited to a specific pid and tail of the log(s) and finally
    109        a  call closing the logs.  A single log can be opened with android_log
    110        ger_list_open;  or  multiple  logs  can  be  opened  with  android_log
    111        ger_list_alloc,  calling  in  turn the android_logger_open for each log
    112        id.  Each entry can be retrieved  with  android_logger_list_read.   The
    113        log(s) can be closed with android_logger_list_free.  The logs should be
    114        opened  with an  ANDROID_LOG_RDONLY  mode.   ANDROID_LOG_NONBLOCK  mode
    115        will report when the  log reading is done with an  EAGAIN  error return
    116        code,  otherwise the  android_logger_list_read  call will block for new
    117        entries.
    118 
    119        The  ANDROID_LOG_WRAP  mode flag to the  android_logger_list_alloc_time
    120        signals  logd to quiesce  the reader until the buffer is about to prune
    121        at the start time then proceed to dumping content.
    122 
    123        The  ANDROID_LOG_PSTORE mode flag to the android_logger_open is used to
    124        switch from the active logs to the persistent logs from before the last
    125        reboot.
    126 
    127        The value returned by android_logger_open can be used as a parameter to
    128        the  android_logger_clear  function to empty the sub-log.  It is recom
    129        mended to only open log ANDROID_LOG_WRONLY in that case.
    130 
    131        The value returned by android_logger_open can be used as a parameter to
    132        the android_logger_get_log_(size|readable_size|version) to retrieve the
    133        sub-log maximum size, readable size and log buffer format protocol ver
    134        sion  respectively.  android_logger_get_id returns the id that was used
    135        when  opening  the  sub-log.    It  is  recommended  to  open  the  log
    136        ANDROID_LOG_RDONLY in these cases.
    137 
    138 ERRORS
    139        If messages fail, a negative error code will be returned to the caller.
    140 
    141        The -ENOTCONN return code indicates that the logger daemon is stopped.
    142 
    143        The  -EBADF return code indicates that the log access point can not be
    144        opened, or the log buffer id is out of range.
    145 
    146        For the  -EAGAIN  return code,  this means that the logging message was
    147        temporarily backed-up either because of Denial Of Service (DOS) logging
    148        pressure from some chatty application or service in the Android system,
    149        or if too small of a value is set in /proc/sys/net/unix/max_dgram_qlen.
    150        To aid in diagnosing the occurence of this,  a binary event from liblog
    151        will be sent to the  log  daemon  once a  new  message  can get through
    152        indicating how many  messages were  dropped  as a result.   Please take
    153        action to resolve the structural problems at the source.
    154 
    155        It is generally not advised for the caller to retry the  -EAGAIN return
    156        code as  this  will  only  make the  problem(s)  worse  and  cause your
    157        application to temporarily drop to the  logger daemon  priority,  BATCH
    158        scheduling policy and background task cgroup. If you require a group of
    159        messages to be passed atomically,  merge  them  into  one  message with
    160        embedded newlines to the maximum length LOGGER_ENTRY_MAX_PAYLOAD.
    161 
    162        Other return codes  from  writing operation can be returned.  Since the
    163        library retries on EINTR, -EINTR should never be returned.
    164 
    165 SEE ALSO
    166        syslogd(8)
    167 
    168 
    169 
    170                                   24 Jan 2014                        LIBLOG(3)
    171