parlib: Add cpu_relax_any()
[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 y
15         help
16                 Say yes to build a 64-bit kernel.  Must be 'y' for x86.
17
18 menuconfig RUN_INIT_SCRIPT
19         bool "Run init script after boot"
20         default n
21         help
22                 Run an init script after boot instead of dropping into the monitor
23
24 config INIT_SCRIPT_PATH_AND_ARGS
25     depends on RUN_INIT_SCRIPT
26     string "Path to init script, followed by its arguments."
27     default /bin/init.sh
28     help
29                 Path to the init script run at boot time, followed by a space separated
30                 list of arguments
31
32 source "kern/arch/$SRCARCH/Kconfig"
33
34 source "kern/src/net/Kconfig"
35
36 source "kern/drivers/Kconfig"
37
38 menu "Filesystems"
39
40 config KFS
41         bool "KFS filesystem"
42         default y
43         help
44                 KFS is an initramfs bundled into the kernel, and contains your root
45                 filesystem.
46
47 config KFS_PATHS
48         depends on KFS
49         string "KFS/Initramfs paths"
50         default kern/kfs
51         help
52                 Space separated list of paths to directories to bundle into KFS.  This
53                 will be your root filesystem.
54
55 config KFS_CPIO_BIN
56         depends on KFS
57         string "KFS CPIO helper"
58         default ""
59         help
60                 This binary (relative to the root directory) will be run before
61                 bundling the KFS Paths into the CPIO.
62
63 config EXT2FS
64         bool "Ext2 filesystem"
65         default n
66         help
67                 Build in support for ext2.  Extremely experimental, and only works with
68                 a block device image, which will be mounted at /mnt.  If you select
69                 this, you must specify a block device.
70
71 config EXT2_BDEV
72         depends on EXT2FS
73         string "Ext2 image file"
74         default mnt/ext2fs.img
75         help
76                 This file needs to be an ext2 image (file that looks like a block
77                 device).  You should be able to mount this file in your host OS.  It
78                 will be bundled into the kernel and mounted at /mnt.
79
80 endmenu
81
82 choice COREALLOC_POLICY
83         prompt "Core Allocation Policy"
84         help
85                 Select a policy for allocating cores to a process upon request.  All
86                 strategies first allocate cores from the set of provisioned cores for a
87                 process, but differ in how they select cores beyond this.
88
89 config COREALLOC_FCFS
90         bool "Simple FCFS"
91         help
92                 Allocate cores to processes on a first-come-first-served basis. All
93                 cores are treated equally, and no topology information is used to try
94                 and optimize which cores are given to which processes upon request.
95
96 endchoice
97
98 menu "Kernel Debugging"
99
100 menu "Per-cpu Tracers"
101
102 config TRACE_KMSGS
103         bool "KMSG Tracing"
104         default n
105         help
106                 Turns on KMSG tracing, using the per-cpu ring buffer (holds about 256
107                 events).  You can access this from the monitor via "trace pcpui".  Turn
108                 this off for a slight performance improvement on every KMSG (and every
109                 MCP proc_yield).
110
111 config TRACE_LOCKS
112         bool "Lock Tracing"
113         depends on SPINLOCK_DEBUG
114         default n
115         help
116                 Turns on lock tracing, using the per-cpu ring buffer.  This records the
117                 a timestamp and lock address, in an over-write tracing style (meaning
118                 it'll clobber older events).  If you have locking issues, this may give
119                 you clues as to which locks were grabbed recently.
120
121 endmenu
122
123 config DEVELOPMENT_ASSERTIONS
124         bool "dasserts"
125         default n
126         help
127                 Turn on dassert() in code, dassert will compile to assert().
128
129 config SPINLOCK_DEBUG
130         bool "Spinlock debugging"
131         default n
132         help
133                 Turns on debugging, which tracks the last time a lock was acquired and
134                 detects improper lock acquisition based on IRQ levels (e.g. using
135                 spin_lock() in IRQ context).  This will slow down all lock
136                 acquisitions.
137
138 config SEQLOCK_DEBUG
139         bool "Seqlock debugging"
140         default n
141         help
142                 Provides asserts to detect seqlock errors.  This will allow a malicious
143                 userspace to trigger a panic in the kernel.
144
145 config SEMAPHORE_DEBUG
146         bool "Semaphore debugging"
147         default n
148         help
149                 Turns on debugging, which tracks the last time and location that a
150                 semaphore was downed, and provides a linked list of all semaphores that
151                 have waiters.  This will slow down all semaphore ups and downs.
152
153 config SEM_SPINWAIT
154         bool "Semaphore spinwaiting"
155         default n
156         help
157                 Turns on semaphore spinwaiting.  In lieu of intelligent Adaptive
158                 Mutexes, busy semaphores will just spin for a while before fully
159                 sleeping.
160
161 config SEM_SPINWAIT_NR_LOOPS
162         int "Number of polls before sleeping"
163         depends on SEM_SPINWAIT
164         default 100
165         help
166                 How many times to poll a busy semaphore before going to sleep.
167
168 config LARGE_KSTACKS
169         bool "Large (two-page) Kernel Stacks"
170         default y
171         help
172                 Ideally, we'd like to use single-page stacks, which are easier on the
173                 memory allocator.  Some of the Plan 9 code hogs stack space, and we may
174                 run off the end of a single-page stack.
175
176                 Say 'y' to play it safe and use the larger, slower stacks.  Say 'n' for
177                 higher performance, and mention this setting if you have any weird
178                 crashes or panics.
179
180 config DISABLE_SMT
181         bool "Disables symmetric multithreading"
182         default n
183         help
184                 Disables hyperthreading by telling the kernel to never give out even
185                 numbered cores to MCPs.  This does not check to see if the threads are
186                 in fact siblings, or if the target machine is hyperthreaded.
187
188 config PRINTK_NO_BACKSPACE
189         bool "Printk with no backspace"
190         default n
191         help
192                 One of the serial devices I was using a while back had issues printing
193                 backspaces.  This was an old hack to deal with that.
194
195 config SYSCALL_STRING_SAVING
196         bool "Syscall string saving"
197         default n
198         help
199                 Kmallocs a small buffer for each syscall and attaches it to the
200                 kthread, which can be viewed when debugging semaphores.  Individual
201                 syscalls can save info in this buffer.
202
203 config BLOCK_EXTRAS
204         bool "Block Extra Data"
205         default y
206         help
207                 Extends blocks to have a list of other memory blocks.  Useful for
208                 networking performance.  This is only an option while we debug the
209                 implementation.  Say y.  If you have networking bugs, try turning this
210                 off, and if that helps, tell someone.
211
212 config BETTER_BACKTRACE
213         bool "Better backtraces, less optimizations"
214         default n
215         help
216                 The kernel uses the frame pointer and call stacks for backtraces.
217                 Tail-call optimizations remove some of this information.  Say 'Y' here
218                 to have better backtraces, at the expense of performance.
219
220 endmenu
221
222 menu "Misc/Old Options"
223
224 config ARSC_SERVER
225         bool "Asynchronous remote syscalls"
226         default n
227         help
228                 Code to run a syscall-server on a core.  A process can submit syscalls
229                 and get the results asynchronously.  Hasn't been used in years.  Say
230                 'n' unless you want to play around.
231
232 # SPARC auto-selects this
233 config APPSERVER
234         bool "Appserver"
235         default n
236         help
237                 Old school I/O was through a remote machine.  Not sure if anyone uses
238                 this anymore.
239
240 config SERIAL_IO
241         bool "Serial IO"
242         default n
243         help
244                 Like the appserver, serial I/O was an old attempt to process I/O on a
245                 remote machine across the serial port.
246
247 config SINGLE_CORE
248         bool "Single core"
249         default n
250         help
251                 Have the kernel boot only a single core.  Can be useful for debugging,
252                 but hasn't been used in years.
253
254 config BSD_ON_CORE0
255         bool "BSD on core 0"
256         default n
257         help
258                 This was an old joke.  Say 'n', since we can't simply #include <bsd>.
259
260 endmenu
261
262 source "kern/lib/Kconfig"
263
264 source "kern/src/ktest/Kconfig"