Reader-writer queue locks
[akaros.git] / Kconfig
1 #
2 # For a description of the syntax of this configuration file,
3 # see Linux's Documentation/kbuild/kconfig-language.txt.
4 #
5 mainmenu "Akaros/$SRCARCH Kernel Configuration"
6
7 # This is info, not a setable option.  Must make ARCH=arch to change.
8 config SRCARCH
9         string
10         option env="ARCH"
11
12 config 64BIT
13         bool "64-bit kernel"
14         default n
15         help
16                 Say yes to build a 64-bit kernel, amd64 / x86_64, riscv64, etc.
17
18 source "kern/arch/$SRCARCH/Kconfig"
19
20 source "kern/src/net/Kconfig"
21
22 source "kern/drivers/Kconfig"
23
24 menu "Filesystems"
25
26 config KFS
27         bool "KFS filesystem"
28         default y
29         help
30                 KFS is an initramfs bundled into the kernel, and contains your root
31                 filesystem.
32
33 config KFS_PATHS
34         depends on KFS
35         string "KFS/Initramfs paths"
36         default kern/kfs
37         help
38                 Space separated list of paths to directories to bundle into KFS.  This
39                 will be your root filesystem.
40
41 config KFS_CPIO_BIN
42         depends on KFS
43         string "KFS CPIO helper"
44         default ""
45         help
46                 This binary (relative to the root directory) will be run before
47                 bundling the KFS Paths into the CPIO.
48
49 config EXT2FS
50         bool "Ext2 filesystem"
51         default n
52         help
53                 Build in support for ext2.  Extremely experimental, and only works with
54                 a block device image, which will be mounted at /mnt.  If you select
55                 this, you must specify a block device.
56
57 config EXT2_BDEV
58         depends on EXT2FS
59         string "Ext2 image file"
60         default mnt/ext2fs.img
61         help
62                 This file needs to be an ext2 image (file that looks like a block
63                 device).  You should be able to mount this file in your host OS.  It
64                 will be bundled into the kernel and mounted at /mnt.
65
66 endmenu
67
68 menu "Memory Management"
69
70 config DEMAND_PAGING
71         bool "Demand paging"
72         default n
73         help
74                 When turned on, mmap() calls do not immediately populate their pages.
75                 This does not turn on any sort of real paging.  Saying 'n' will act
76                 like all mmap()s have MAP_POPULATE.
77
78 config PAGE_COLORING
79         bool "Page coloring"
80         default n
81         help
82                 Turns on internal support for page coloring.  When turned off, the page
83                 allocator acts like there is only one color.  Hasn't been used in a few
84                 years.
85
86 config BOXBORO
87         depends on PAGE_COLORING
88         bool "Boxboro-specific page coloring"
89         default n
90         help
91                 Say 'n'.
92
93 endmenu
94
95 menu "Kernel Debugging"
96
97 menu "Per-cpu Tracers"
98
99 config TRACE_KMSGS
100         bool "KMSG Tracing"
101         default n
102         help
103                 Turns on KMSG tracing, using the per-cpu ring buffer (holds about 256
104                 events).  You can access this from the monitor via "trace pcpui".  Turn
105                 this off for a slight performance improvement on every KMSG (and every
106                 MCP proc_yield).
107
108 config TRACE_LOCKS
109         bool "Lock Tracing"
110         depends on SPINLOCK_DEBUG
111         default n
112         help
113                 Turns on lock tracing, using the per-cpu ring buffer.  This records the
114                 a timestamp and lock address, in an over-write tracing style (meaning
115                 it'll clobber older events).  If you have locking issues, this may give
116                 you clues as to which locks were grabbed recently.
117
118 endmenu
119
120 config SPINLOCK_DEBUG
121         bool "Spinlock debugging"
122         default n
123         help
124                 Turns on debugging, which tracks the last time a lock was acquired and
125                 detects improper lock acquisition based on IRQ levels (e.g. using
126                 spin_lock() in IRQ context).  This will slow down all lock
127                 acquisitions.
128
129 config SEQLOCK_DEBUG
130         bool "Seqlock debugging"
131         default n
132         help
133                 Provides asserts to detect seqlock errors.  This will allow a malicious
134                 userspace to trigger a panic in the kernel.
135
136 config RESET_STACKS
137         bool "Reset Stacks"
138         default y
139         help
140                 When idling, the kernel will reset the stack of its kernel thread to
141                 the top of the stack, abandoning its context.  This is useful so we do
142                 not run off the end of our stacks, but makes backtracing difficult.
143
144 config KTHREAD_POISON
145         bool "Kthread Poison Canary"
146         default n
147         help
148                 Kthreads will use a bit of storage at the bottom of the stack to track
149                 the state of the kthread.  This is useful to catch various bugs with
150                 kthreading, such as launching the same kthread twice concurrently.
151
152 config DISABLE_SMT
153         bool "Disables symmetric multithreading"
154         default n
155         help
156                 Disables hyperthreading by telling the kernel to never give out even
157                 numbered cores to MCPs.  This does not check to see if the threads are
158                 in fact siblings, or if the target machine is hyperthreaded.
159
160 config PRINTK_NO_BACKSPACE
161         bool "Printk with no backspace"
162         default n
163         help
164                 One of the serial devices I was using a while back had issues printing
165                 backspaces.  This was an old hack to deal with that.
166
167 endmenu
168
169 menu "Misc/Old Options"
170
171 config ARSC_SERVER
172         bool "Asynchronous remote syscalls"
173         default n
174         help
175                 Code to run a syscall-server on a core.  A process can submit syscalls
176                 and get the results asynchronously.  Hasn't been used in years.  Say
177                 'n' unless you want to play around.
178
179 # SPARC auto-selects this
180 config APPSERVER
181         bool "Appserver"
182         default n
183         help
184                 Old school I/O was through a remote machine.  Not sure if anyone uses
185                 this anymore.
186
187 config SERIAL_IO
188         bool "Serial IO"
189         default n
190         help
191                 Like the appserver, serial I/O was an old attempt to process I/O on a
192                 remote machine across the serial port.
193
194 config SINGLE_CORE
195         bool "Single core"
196         default n
197         help
198                 Have the kernel boot only a single core.  Can be useful for debugging,
199                 but hasn't been used in years.
200
201 config BSD_ON_CORE0
202         bool "BSD on core 0"
203         default n
204         help
205                 This was an old joke.  Say 'n', since we can't simply #include <bsd>.
206
207 endmenu