2019-11-01 13:45:29 +01:00
|
|
|
# General configuration options
|
2017-10-03 16:31:55 +02:00
|
|
|
|
|
|
|
# Copyright (c) 2017 Intel Corporation
|
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
|
|
|
menu "POSIX (native) Options"
|
|
|
|
depends on ARCH_POSIX
|
|
|
|
|
|
|
|
config ARCH
|
|
|
|
default "posix"
|
|
|
|
|
2018-01-26 15:46:47 +01:00
|
|
|
config ARCH_POSIX_RECOMMENDED_STACK_SIZE
|
|
|
|
int
|
2022-09-20 12:19:44 +02:00
|
|
|
default 44 if 64BIT && STACK_SENTINEL
|
2019-08-23 20:54:42 +02:00
|
|
|
default 40 if 64BIT
|
2022-09-20 12:19:44 +02:00
|
|
|
default 28 if STACK_SENTINEL
|
2018-01-26 15:46:47 +01:00
|
|
|
default 24
|
|
|
|
help
|
|
|
|
In bytes, stack size for Zephyr threads meant only for the POSIX
|
|
|
|
architecture.
|
|
|
|
(In this architecture only part of the thread status is kept in the Zephyr
|
|
|
|
thread stack, the real stack is the native underlying pthread stack.
|
|
|
|
Therefore the allocated stack can be limited to this size)
|
2017-10-03 16:31:55 +02:00
|
|
|
|
2023-07-09 06:50:13 +02:00
|
|
|
menuconfig ARCH_POSIX_LIBFUZZER
|
2022-08-23 21:24:14 +02:00
|
|
|
bool "Build fuzz test target"
|
|
|
|
help
|
|
|
|
Build the posix app as a LLVM libfuzzer target. Requires
|
|
|
|
support from the toolchain (currently only clang works, and
|
2024-03-14 14:24:38 +01:00
|
|
|
only on native_posix/native/64), and should normally be used in
|
2022-08-23 21:24:14 +02:00
|
|
|
concert with some of CONFIG_ASAN/UBSAN/MSAN for validation.
|
|
|
|
The application needs to implement the
|
|
|
|
LLVMFuzzerTestOneInput() entry point, which runs in the host
|
|
|
|
environment "outside" the OS. See Zephyr documentation and
|
|
|
|
sample and https://llvm.org/docs/LibFuzzer.html for more
|
|
|
|
information.
|
|
|
|
|
2023-07-09 06:50:13 +02:00
|
|
|
if ARCH_POSIX_LIBFUZZER
|
|
|
|
|
2022-08-23 21:24:14 +02:00
|
|
|
config ARCH_POSIX_FUZZ_IRQ
|
|
|
|
int "OS interrupt via which to deliver fuzz cases"
|
|
|
|
default 3
|
|
|
|
help
|
|
|
|
When using libfuzzer, new fuzz cases are delivered to Zephyr
|
|
|
|
via interrupts. The IRQ should be otherwise unused, but can
|
|
|
|
be any value desired by the app.
|
|
|
|
|
|
|
|
config ARCH_POSIX_FUZZ_TICKS
|
|
|
|
int "Ticks to allow for fuzz case processing"
|
|
|
|
default 2
|
|
|
|
help
|
|
|
|
Fuzz interrupts are delivered, from the perspective of the
|
|
|
|
OS, at a steady cadence in simulated time. In general most
|
|
|
|
apps won't require much time to reach an idle state
|
|
|
|
following a unit-test style case, so the default is short to
|
|
|
|
prevent interaction with regular timer workloads.
|
|
|
|
|
2023-07-09 06:50:13 +02:00
|
|
|
endif # CONFIG_ARCH_POSIX_LIBFUZZER
|
|
|
|
|
2023-07-12 17:26:25 +02:00
|
|
|
config ARCH_POSIX_TRAP_ON_FATAL
|
|
|
|
bool "Raise a SIGTRAP on fatal error"
|
|
|
|
help
|
|
|
|
Raise a SIGTRAP signal on fatal error before exiting.
|
|
|
|
This automatically suspends the target if a debugger is attached.
|
|
|
|
|
2017-10-03 16:31:55 +02:00
|
|
|
endmenu
|