nuttx-apps/system/embedlog/Kconfig
Michał Łyszczek ccc8ddaf5d system/embedlog: update to v0.6.0
Changes from v0.4.0
- add thread safety code
- add option to print function info (name) in logs
- abi/api stabilization
- bug fixes + increased reliability

Signed-off-by: Michał Łyszczek <michal.lyszczek@bofc.pl>

---
v1 -> v2 [suggested by Brennan Ashton]
 - fix path to embedlog_main.c in header comment
 - change license from bsd3 to apache2.0
2021-05-16 11:30:29 -03:00

226 lines
6.9 KiB
Plaintext

#
# For a description of the syntax of this configuration file,
# see the file kconfig-language.txt in the NuttX tools repository.
#
menuconfig SYSTEM_EMBEDLOG
bool "embedlog library"
default n
---help---
Highly configurable logger for embedded devices. Documentation and
more info available on: https://embedlog.bofc.pl (don't worry,
it's in english). Note: none of the options define how embedlog
will behave, it will simply configure whether given feature can be
enabled in runtime or no. So enabling CONFIG_EMBEDLOG_ENABLE_TIMESTAMP
won't make logger to add timestamp to every message - you will have to
also enable timestamp in runtime object. But when
CONFIG_EMBEDLOG_ENABLE_TIMESTAMP is disabled, setting timestamp print
in runtime will make no difference and timestamp still will not be
printed.
Library is licensed under BSD 2-clause license. See LICENSE file in
the downloaded code for license details
if SYSTEM_EMBEDLOG
config EMBEDLOG_ENABLE_PTHREAD
bool "Enable thread safety"
depends on !DISABLE_PTHREAD
default n
---help---
When enabled, you will be able to configure embedlog to use
EL_THREAD_SAFE option, which will provide full thread safety in all
circumstances. When printing to stdout or syslog, embedlog is
half thread-safe. Buffer is allocated for each print call, so
different calls will not interfere with each other, but once
buffer is handed over to the kernel, logs might get mangled.
To make sure this does not happen, enable this and enable
EL_THREAD_SAFE option in runtime.
When multiple threads print to single file, this must be
enabled, as there are global states in each 'el' object. If two
'el' objects print into two separate files, you do not need
thread safety.
comment "DISABLE_PTHREAD must be disabled to use thread safety"
depends on DISABLE_PTHREAD
config EMBEDLOG_ENABLE_OUT_FILE
bool "Enable logging to file"
default n
---help---
If enabled, you will be able to store logs in a file (like on
sdcard). Log rotation is available as well. LIbrary automatically
handles cases when files are deleted or mountpoint disappears and
appear again (like sd card switch). Disabling this will result in
smaller code.
if EMBEDLOG_ENABLE_OUT_FILE
config EMBEDLOG_ENABLE_BINARY_LOGS
bool "Enable binary logs"
default n
---help---
When enabled, you will be able to print binary data into file
to save space (on block device). Note: you will not be able to
read such logs with tools like 'less' or 'grep'. You will need to
create own reader or use 'hexdump'.
endif
config EMBEDLOG_ENABLE_OUT_STDERR
bool "Enable logging to standard error"
default y
---help---
If enabled, you will be able to log messages to standard error (stderr)
and/or standard output (stdout).
config EMBEDLOG_ENABLE_OUT_TTY
bool "Enable printing to tty device"
default y
---help---
If enabled, you will be able to configure logger to print directly
to tty serial device (like /dev/ttyS1). This might be useful if you
want to have nsh in one tty and logs on the other. This is suitable
if only one task will be printing logs to one tty, if you want
multiple tasks to print into one tty, it's better to enable syslog
printing and the syslog handle it.
config EMBEDLOG_ENABLE_OUT_CUSTOM
bool "Enable custom logging function"
default n
---help---
When enabled, you will be able to define own function that accepts
fully constructed log message as 'const char *'
config EMBEDLOG_ENABLE_TIMESTAMP
bool "Enable timestamp in messages"
default y
---help---
If enabled, you will be able to configure logger to add timestamp to
every logged message.
if EMBEDLOG_ENABLE_TIMESTAMP
config EMBEDLOG_ENABLE_FRACTIONS
bool "Enable fractions of seconds"
default y
---help---
If enabled, you will be able to configure logger to add fractions of
seconds to timestamp
endif
config EMBEDLOG_ENABLE_PREFIX
bool "Enable prefix"
default n
---help---
If enabled, you will be able to set prefix that will be added to
each message logged by embedlog. Useful when multiple tasks print
to one tty (via syslog) and you need an easy way to know which program
printed given log message.
if EMBEDLOG_ENABLE_PREFIX
config EMBEDLOG_PREFIX_MAX
int "Max prefix length"
default 16
---help---
Maximum length of prefix that can be printed. If prefix exceeds this
value it will be truncated.
endif # EMBEDLOG_ENABLE_PREFIX
config EMBEDLOG_ENABLE_FINFO
bool "Enable file info"
default y
---help---
If enabled, you will be able to turn on information about location
of the log. This uses __FILE__ and __LINE__ macros.
if EMBEDLOG_ENABLE_FINFO
config EMBEDLOG_FLEN_MAX
int "Max file name in finfo"
default 16
---help---
finfo look like this
[filename.c:123]
this parameter defines how long "filename.c" can be, if file name
exceeds this value it will be truncated.
config EMBEDLOG_ENABLE_FUNCINFO
bool "Enable function info in log"
default y
---help---
When enabled, embedlog can be configured to add information
about function name from which log originated. This uses __func__
macro, so you need compiler that supports that. This macro was
introduced in c99 standard.
if EMBEDLOG_ENABLE_FUNCINFO
config EMBEDLOG_FUNCLEN_MAX
int "Max length of function to print"
default 16
---help---
Max length of function name to print. If function is longer than
this value, it will be truncated. This directly impacts size of
buffer for each 'el' object allocated.
endif # EMBEDLOG_ENABLE_FUNCINFO
endif # EMBEDLOG_ENABLE_FINFO
comment "Function info requires EMBEDLOG_ENABLE_FINFO"
depends on !EMBEDLOG_ENABLE_FINFO
config EMBEDLOG_ENABLE_COLORS
bool "Enable output colors"
default n
---help---
If enabled, you will be able to turn on ANSI colors for messages
with different log severities. Disabling this will result in smaller
code.
config EMBEDLOG_LOG_MAX
int "Max length of log message"
default 128
---help---
Maximum length of single log message. This defines length of finall
message, so message "foo() returned %s" may consume for example
200 bytes since '%s' may be a long string. Metadata like timestamp
or file info uses this space too. Output log will be truncated if
it exceeds this value. Lowering/increasing will result in
appropriate higher/lower stack usage.
config EMBEDLOG_MEM_LINE_SIZE
int "Number of bytes in line"
default 16
---help---
How many bytes of memory to print in a single line of el_pmemory call.
Check https://embedlog.bofc.pl/manuals/el_pmemory.3.html
for more information about this.
config EMBEDLOG_DEMO_PROGRAMS
bool "Compile demo programs"
default n
---help---
Compile demo programs that visualise how embedlog works. Also good
for checking if embedlog behaves corectly.
if EMBEDLOG_DEMO_PROGRAMS
config EMBEDLOG_DEMO_PROGRAMS_PRIORITY
int "embedlog demo programs task priority"
default 100
config EMBEDLOG_DEMO_PROGRAMS_STACKSIZE
int "embedlog demo programs stack size"
default DEFAULT_TASK_STACKSIZE
endif # EMBEDLOG_DEMO_PROGRAMS
endif # SYSTEM_EMBEDLOG