1# Copyright (c) 2021 Nordic Semiconductor ASA 2# SPDX-License-Identifier: Apache-2.0 3 4menu "Processing" 5 6if !LOG_MODE_MINIMAL 7 8config LOG_PRINTK 9 bool "Process printk messages" 10 depends on !USERSPACE 11 default y if PRINTK 12 help 13 If enabled, printk messages are redirected to the logging subsystem. 14 The messages are formatted in place and logged unconditionally. 15 16if LOG_MODE_DEFERRED && !LOG_FRONTEND_ONLY 17 18config LOG_MODE_OVERFLOW 19 bool "Drop oldest message when full" 20 default y 21 help 22 If enabled, then if there is no space to log a new message, the 23 oldest one is dropped. If disabled, current message is dropped. 24 25config LOG_BLOCK_IN_THREAD 26 bool "Block in thread context on full" 27 depends on MULTITHREADING 28 help 29 When enabled logger will block (if in the thread context) when 30 internal logger buffer is full and new message cannot be allocated. 31 32config LOG_BLOCK_IN_THREAD_TIMEOUT_MS 33 int "Maximum time (in milliseconds) thread can be blocked" 34 default 1000 35 range -1 10000 36 depends on LOG_BLOCK_IN_THREAD 37 help 38 If new buffer for a log message cannot be allocated in that time, log 39 message is dropped. Forever blocking (-1) is possible however may lead 40 to the logger deadlock if logging is enabled in threads used for 41 logging (e.g. logger or shell thread). 42 43config LOG_PROCESS_TRIGGER_THRESHOLD 44 int "Number of buffered log messages before flushing" 45 default 10 46 depends on MULTITHREADING 47 help 48 When number of buffered messages reaches the threshold thread is waken 49 up. Log processing thread ID is provided during log initialization. 50 Set 0 to disable the feature. If LOG_PROCESS_THREAD is enabled then 51 this threshold is used by the internal thread. 52 53config LOG_PROCESS_THREAD 54 bool "Use internal thread for log processing" 55 depends on MULTITHREADING 56 default y 57 help 58 When enabled thread is created by the logger subsystem. Thread is 59 waken up periodically (see LOG_PROCESS_THREAD_SLEEP_MS) and whenever 60 number of buffered messages exceeds the threshold (see 61 LOG_PROCESS_TRIGGER_THR). 62 63if LOG_PROCESS_THREAD 64 65config LOG_PROCESS_THREAD_STARTUP_DELAY_MS 66 int "Set log processing thread startup delay" 67 default 0 68 help 69 Log processing thread starts after requested delay given in 70 milliseconds. When started, thread process any buffered messages. 71 72config LOG_PROCESS_THREAD_SLEEP_MS 73 int "Set internal log processing thread sleep period" 74 default 1000 75 help 76 Log processing thread sleeps for requested period given in 77 milliseconds. When waken up, thread process any buffered messages. 78 79config LOG_PROCESS_THREAD_STACK_SIZE 80 int "Stack size for the internal log processing thread" 81 default 4096 if (X86 && X86_64) 82 default 4096 if ARM64 83 default 4096 if (ARC && 64BIT) 84 default 4096 if SPARC 85 default 2048 if COVERAGE_GCOV 86 default 2048 if (RISCV && 64BIT) 87 default 2048 if LOG_BACKEND_FS 88 default 1152 if LOG_BACKEND_NET 89 default 4096 if NO_OPTIMIZATIONS 90 default 1024 if XTENSA 91 default 2048 if ASSERT || SPIN_VALIDATE 92 default 768 93 help 94 Set the internal stack size for log processing thread. 95 96config LOG_PROCESSING_LATENCY_US 97 int "Maximum remote message latency (in microseconds)" 98 default 100000 99 depends on LOG_MULTIDOMAIN 100 help 101 Arbitrary time between log message creation in the remote domain and 102 processing in the local domain. Higher value increases message processing 103 latency but increases chances of maintaining correct ordering of the 104 messages. Option is used only if links are using dedicated buffers 105 for remote messages. 106 107config LOG_PROCESS_THREAD_CUSTOM_PRIORITY 108 bool "Custom log thread priority" 109 help 110 Set a custom value for the log processing thread. 111 112config LOG_PROCESS_THREAD_PRIORITY 113 int "Priority of the log processing thread" 114 default 0 115 depends on LOG_PROCESS_THREAD_CUSTOM_PRIORITY 116 help 117 The priority of the log processing thread. 118 When not set the prority is set to K_LOWEST_APPLICATION_THREAD_PRIO. 119 120endif # LOG_PROCESS_THREAD 121 122config LOG_BUFFER_SIZE 123 int "Number of bytes dedicated for the logger internal buffer" 124 default 1024 125 range 128 1048576 126 help 127 Number of bytes dedicated for the logger internal buffer. 128 129endif # LOG_MODE_DEFERRED && !LOG_FRONTEND_ONLY 130 131if LOG_MULTIDOMAIN 132 133config LOG_DOMAIN_NAME_CACHE_ENTRY_SIZE 134 int "Cache slot size of domain name" 135 default 8 136 137config LOG_DOMAIN_NAME_CACHE_ENTRY_COUNT 138 int "Number of entries in domain name cache" 139 default 2 140 141config LOG_SOURCE_NAME_CACHE_ENTRY_SIZE 142 int "Cache slot size of source name" 143 default 16 144 145config LOG_SOURCE_NAME_CACHE_ENTRY_COUNT 146 int "Number of entries in source name cache" 147 default 8 148 149endif # LOG_MULTIDOMAIN 150 151config LOG_TRACE_SHORT_TIMESTAMP 152 bool "Use 24 bit timestamp for tracing" 153 default y 154 help 155 When enabled, shorter timestamp is used and trace message is 156 compressed. 157 158config LOG_TIMESTAMP_64BIT 159 bool "Use 64 bit timestamp" 160 161config LOG_TIMESTAMP_USE_REALTIME 162 bool "Use real time clock for timestamp" 163 select LOG_TIMESTAMP_64BIT 164 depends on POSIX_TIMERS 165 help 166 When enabled, real time clock is used for timestamping. 167 168config LOG_SPEED 169 bool "Prefer performance over size" 170 depends on LOG_MODE_DEFERRED 171 depends on !LOG_FRONTEND 172 help 173 If enabled, logging may take more code size to get faster logging. 174 175endif # !LOG_MODE_MINIMAL 176 177endmenu 178