1# Copyright (c) 2021 Nordic Semiconductor ASA 2# SPDX-License-Identifier: Apache-2.0 3 4menu "Misc" 5 6config LOG_CMDS 7 bool "Shell commands" 8 depends on SHELL 9 depends on !LOG_MODE_MINIMAL 10 11config LOG_TEST_CLEAR_MESSAGE_SPACE 12 bool "Clear message after allocation" 13 default y 14 depends on ZTEST 15 help 16 Used in testing to simplify message comparision if message contains 17 paddings. 18 19config LOG_USE_VLA 20 bool "Using variable length arrays" 21 default y if !MISRA_SANE 22 help 23 Using VLA slightly decreases stack usage in some cases it may not be 24 supported. Note that VLA are used for arrays which size is resolved at 25 compile time so at runtime arrays have fixed size. 26 27config LOG_SIMPLE_MSG_OPTIMIZE 28 bool "Optimize simple messages for size" 29 depends on !64BIT && !CBPRINTF_PACKAGE_HEADER_STORE_CREATION_FLAGS 30 default y 31 help 32 Dedicated code for handling simple log messages (0-2 32 bit word arguments). 33 Approximately, 70%-80% log messages in the application fit into that category. 34 Depending on the architecture code size reduction is from 0-40% (highest seen on 35 RISCV32) and execution time also up to 40%. 36 37config LOG_ALWAYS_RUNTIME 38 bool "Always use runtime message creation (v2)" 39 default y if NO_OPTIMIZATIONS 40 default y if LOG_MODE_IMMEDIATE 41 default y if "$(ZEPHYR_TOOLCHAIN_VARIANT)" = "xcc" 42 help 43 If enabled, runtime method is always used for message creation. Static 44 creation relies on compiler being able to optimize and remove code 45 based on information known at compile time. Runtime only approach must 46 be used when optimization is disabled because some compilers 47 (seen on arm_cortex_m and x86) were using unrealistic amount of stack 48 for dead code. It is also required in immediate mode since it requires 49 less stack than static message creation and speed has lower priority 50 in that mode. 51 52config LOG_FMT_SECTION 53 bool "Keep log strings in dedicated section" 54 help 55 When enabled, logs are kept in dedicated memory section. It allows 56 removing strings from final binary and should be used for dictionary 57 logging. 58 59config LOG_FMT_SECTION_STRIP 60 bool "Strip log strings from binary" 61 depends on LOG_DICTIONARY_DB 62 depends on LOG_FMT_SECTION 63 depends on LINKER_DEVNULL_SUPPORT 64 depends on !LOG_ALWAYS_RUNTIME 65 depends on !LOG_OUTPUT 66 imply LINKER_DEVNULL_MEMORY 67 imply LOG_FMT_STRING_VALIDATE 68 69config LOG_FMT_STRING_VALIDATE 70 bool "Validate logging strings" 71 help 72 Logging strings cannot use %p with character pointers. They should be 73 casted to the pointer of another type (e.g. void *). With this feature 74 enabled, at compile time, the preprocessor detects strings with %p 75 without casting and reports an error at runtime. 76 77config LOG_USE_TAGGED_ARGUMENTS 78 bool "Using tagged arguments for packaging" 79 depends on !PICOLIBC 80 select CBPRINTF_PACKAGE_SUPPORT_TAGGED_ARGUMENTS 81 select LOG_ALWAYS_RUNTIME 82 help 83 If enabled, packaging uses tagged arguments. 84 85config LOG_MEM_UTILIZATION 86 bool "Tracking maximum memory utilization" 87 depends on LOG_MODE_DEFERRED 88 default y if LOG_CMDS 89 help 90 When enabled, maximum usage of memory used for log messages in deferred 91 mode is tracked. It can be used to trim LOG_BUFFER_SIZE. 92 93config LOG_DICTIONARY_DB 94 bool 95 96config LOG_DICTIONARY_DB_TARGET 97 bool "Only generated log dictionary database from target" 98 depends on LOG_DICTIONARY_DB 99 help 100 Enable this option to make generating the log dictionary database 101 only done by its own build target. 102 This removes the target from the ALL make target and the target 103 'log_dict_db_gen' has to be called in addition. 104 105config LOG_MSG_APPEND_RO_STRING_LOC 106 bool 107 help 108 Enable this option to force log messages to always append location of 109 read-only string arguments in the package. This should be selected by 110 backends if required. 111 112config LOG_FAILURE_REPORT_PERIOD 113 int "Failure report period (in milliseconds)" 114 default 1000 115 depends on LOG_MODE_DEFERRED 116 help 117 Determines how often failures are reported. Report contains number 118 of dropped messages. It may contain additional information depending 119 on the mode. 120 121config LOG_DOMAIN_NAME 122 string "Domain name" 123 default "" 124 125if LOG_MULTIDOMAIN 126 127config LOG_REMOTE_DOMAIN_MAX_COUNT 128 int "Maximum number of link domains" 129 default 4 130 help 131 Number of domains that can be handled by a link 132 133endif 134endmenu 135