android_system_core/logd
Mark Salyzyn d26b2cacad logd: sock_alloc_send_pskb starves pruning
(cherry pick from commit 5c77ad55d0)

Allow socket send syscall to terminate after 32 seconds if reader
stalled because of memory pressure allocating new network buffers

Add a gTest to catch regressions, add security buffer to log_dump

Bug: 27242723
Change-Id: Idaa6699d9d284e7f5f723ae0e76b3d6aa3371489
2016-02-25 12:43:12 -08:00
..
tests logd: sock_alloc_send_pskb starves pruning 2016-02-25 12:43:12 -08:00
Android.mk logd: enforce policy integrity 2016-02-22 14:00:43 -08:00
CommandListener.cpp logd: statistics per-pid filter 2015-12-18 13:17:37 -08:00
CommandListener.h
FlushCommand.cpp logd: Allow (some) headers to be individually importable 2016-02-25 12:42:31 -08:00
FlushCommand.h logd: security buffer only AID_SYSTEM reader 2016-02-01 13:29:06 -08:00
LogAudit.cpp logd: Allow (some) headers to be individually importable 2016-02-25 12:42:31 -08:00
LogAudit.h logd: Allow (some) headers to be individually importable 2016-02-25 12:42:31 -08:00
LogBuffer.cpp logd: security buffer only AID_SYSTEM reader 2016-02-01 13:29:06 -08:00
LogBuffer.h logd: security buffer only AID_SYSTEM reader 2016-02-01 13:29:06 -08:00
LogBufferElement.cpp logd: Allow (some) headers to be individually importable 2016-02-25 12:42:31 -08:00
LogBufferElement.h logd: readlog apps get logger_entry_v4 2015-12-09 08:12:07 -08:00
LogCommand.cpp
LogCommand.h
LogKlog.cpp logd: Allow (some) headers to be individually importable 2016-02-25 12:42:31 -08:00
LogKlog.h logd: Allow (some) headers to be individually importable 2016-02-25 12:42:31 -08:00
LogListener.cpp logd: Allow (some) headers to be individually importable 2016-02-25 12:42:31 -08:00
LogListener.h
LogReader.cpp logd: sock_alloc_send_pskb starves pruning 2016-02-25 12:43:12 -08:00
LogReader.h logd: sock_alloc_send_pskb starves pruning 2016-02-25 12:43:12 -08:00
LogStatistics.cpp logd: Add worst pid of system filter 2015-12-29 09:32:35 -08:00
LogStatistics.h logd: Add worst pid of system filter 2015-12-29 09:32:35 -08:00
LogTimes.cpp logd: security buffer only AID_SYSTEM reader 2016-02-01 13:29:06 -08:00
LogTimes.h logd: Allow (some) headers to be individually importable 2016-02-25 12:42:31 -08:00
LogUtils.h logd: Allow flags "eng" and "svelte" in boolean 2015-12-22 07:44:31 -08:00
LogWhiteBlackList.cpp logd: Add worst pid of system filter 2015-12-29 09:32:35 -08:00
LogWhiteBlackList.h logd: Add worst pid of system filter 2015-12-29 09:32:35 -08:00
README.auditd
README.property logd: enforce policy integrity 2016-02-22 14:00:43 -08:00
event.logtags
libaudit.c
libaudit.h
logd.rc init.rc: too many start logd 2016-02-02 16:01:17 -08:00
main.cpp logd: enforce policy integrity 2016-02-22 14:00:43 -08:00

README.property

The properties that logd responds to are:

name                       type default  description
ro.logd.auditd.dmesg       bool   true   selinux audit messages duplicated and
                                         sent on to dmesg log
persist.logd.security      bool   false  Enable security buffer.
ro.device_owner            bool   false  Override persist.logd.security to false
ro.logd.kernel             bool+ svelte+ Enable klogd daemon
ro.logd.statistics         bool+ svelte+ Enable logcat -S statistics.
ro.build.type              string        if user, logd.statistics &
                                         ro.logd.kernel default false.
persist.logd.logpersistd   string        Enable logpersist daemon, "logcatd"
                                         turns on logcat -f in logd context
persist.logd.size          number  ro    Global default size of the buffer for
                                         all log ids at initial startup, at
                                         runtime use: logcat -b all -G <value>
ro.logd.size               number svelte default for persist.logd.size. Larger
                                         platform default sizes than 256KB are
                                         known to not scale well under log spam
                                         pressure. Address the spam first,
                                         resist increasing the log buffer.
persist.logd.size.<buffer> number  ro    Size of the buffer for <buffer> log
ro.logd.size.<buffer>      number svelte default for persist.logd.size.<buffer>
ro.config.low_ram          bool   false  if true, logd.statistics, logd.kernel
                                         default false, logd.size 64K instead
                                         of 256K.
persist.logd.filter        string        Pruning filter to optimize content.
                                         At runtime use: logcat -P "<string>"
ro.logd.filter       string "~! ~1000/!" default for persist.logd.filter.
                                         This default means to prune the
                                         oldest entries of chattiest UID, and
                                         the chattiest PID of system
                                         (1000, or AID_SYSTEM).
persist.logd.timestamp     string  ro    The recording timestamp source.
                                         "m[onotonic]" is the only supported
                                         key character, otherwise realtime.
ro.logd.timestamp        string realtime default for persist.logd.timestamp
log.tag                   string persist The global logging level, VERBOSE,
                                         DEBUG, INFO, WARN, ERROR, ASSERT or
                                         SILENT. Only the first character is
                                         the key character.
persist.log.tag            string build  default for log.tag
log.tag.<tag>             string persist The <tag> specific logging level.
persist.log.tag.<tag>      string build  default for log.tag.<tag>

NB:
- bool+ - "true", "false" and comma separated list of "eng" (forced false if
  ro.build.type is "user") or "svelte" (forced false if ro.config.low_ram is
  true).
- svelte - see ro.config.low_ram for details.
- svelte+ - see ro.config.low_ram and ro.build.type for details.
- ro - <base property> temporary override, ro.<base property> platform default.
- persist - <base property> override, persist.<base property> platform default.
- build - VERBOSE for native, DEBUG for jvm isLoggable, or developer option.
- number - support multipliers (K or M) for convenience. Range is limited
  to between 64K and 256M for log buffer sizes. Individual log buffer ids
  such as main, system, ... override global default.
- Pruning filter is of form of a space-separated list of [~][UID][/PID]
  references, where '~' prefix means to blacklist otherwise whitelist. For
  blacklisting, UID or PID may be a '!' to instead reference the chattiest
  client, with the restriction that the PID must be in the UID group 1000
  (system or AID_SYSTEM).