Remove building with NOCRYPTO option
[minix3.git] / minix / man / man8 / config.8
blob3988c8ea921c9dffcce148d2277fcb8a59301275
1 .TH CONFIG 8
2 .SH NAME
3 config \- configuring MINIX 3 tasks and servers
4 .SH DESCRIPTION
5 .de SP
6 .if t .sp 0.4
7 .if n .sp
8 ..
9 MINIX 3 has a number of configuration files containing parameters that can
10 be changed to enable or disable a device driver, to change the number of
11 times a resource can be used, or to tune the performance of the system.
12 We will name the file that contains the parameter, the name of the
13 parameter, and the values it can be set to.  Some comments are prefixed by
14 "8086" for MINIX 3 running in 16-bit real mode, "286" for 16-bit protected
15 mode, and "386" for 32-bit protected mode.
16 Configuration file names can be
17 .RI < file.h >
18 for a file in
19 .BR /usr/include/ ,
20 or a simple file name for a file in
21 .BR /usr/src/ .
22 .PP
23 There may be several definitions for a parameter with only one that is
24 active.  Which one this is is easy to find if you know that
25 .B "(\s-2CPU\s+2\ ==\ \s-2INTEL\s+2)"
26 is true, and
27 .SB _WORD_SIZE
28 equals
29 .B 2
30 in 16-bit mode, and
31 .B 4
32 in 32-bit mode.
33 .PP
34 .ti 2m
35 .RB < minix/config.h >
36 .br
37 This is the main configuration file for the MINIX 3.  It contains lots of
38 boolean variables to enable or disable drivers and a number of parameters
39 that specify the sizes of system data structures:
40 .TP
41 .SB NR_PROCS
42 The number of slots in the process table, and thus the maximum number of
43 processes that can be run concurrently.  Should be increased from the
44 default
45 .B 32
46 if networking is enabled (add
47 .B 8
48 for deamons), and if more users are using the system (add
49 .B 4
50 for each active session).  There are a lot of
51 loops in the kernel scanning the process table, so setting
52 .SB NR_PROCS
53 too high will slow things down a little bit, so don't overdo it.
54 .TP
55 .SB NR_BUFS
56 The number of disk buffers in the file system server.  It is used to keep
57 frequently used disk blocks in memory.
58 .BR 8086 " & " 286 :
59 The default is
60 .BR 40 ,
61 and that's about as high as it can be set.
62 .BR 386 :
63 The default is
64 .BR 80 ,
65 which is best increased to
66 .B 1024
67 if you can spare the memory.  More will help, but the effect won't be as
68 pronounced as
69 .B 1024
70 is more than enough to contain the working set of one active user.
71 .TP
72 .SB NR_CTRLRS
73 Number of tasks used for disk or tape controllers.  By default 2, maximum 4.
74 You need a controller task for each device class to be handled through a
75 .BI /dev/c n "*"
76 set of devices.
77 .TP
78 .SB ENABLE_CACHE2
79 If set to 1 allows the RAM disk to be used as a second level file system
80 cache.  Any block that is evicted from the normal cache is both written to
81 disk (if dirty), and copied to the second level cache.  If it is needed
82 again then the block is reloaded from the RAM disk if it is still there.
83 .BR 8086 :
84 Forget it, you don't have any memory for it.
85 .BR 286 :
86 Turn it on and set the boot environment variable
87 .B ramsize
89 .B 512
90 if you have the memory.  That's enough to contain the working set of
91 one active user, and is also the maximum FS can handle.
92 .BR 386 :
93 The installation scripts sets
94 .B ramsize
96 .B 1024
97 if there is enough memory.  Your first point of call is to compile a
98 new kernel with
99 .SB ENABLE_CACHE2
100 off,
101 .SB NR_BUFS
102 set to a large value, and
103 .B ramsize
104 set back to zero.  A normal block cache works much better than a two level
105 arrangement.
107 .SB ENABLE_AT_WINI
108 Enables the AT or IDE disk driver.  (The IDE interface grew out of the old
109 AT disk interface.)  Any run of the mill PC needs this driver.  You need to
110 assign a driver like this one to a controller task using one of the
111 .BI c n
112 boot variables.  See
113 .BR boot (8).
115 .SB ENABLE_BIOS_WINI
116 Enables the BIOS disk driver.  The BIOS driver uses the system BIOS to read
117 or write disk blocks.
118 .BR 8086 :
119 The preferred disk driver for XT class machines.
120 .BR 286 " & " 386 :
121 Use a native driver if possible to avoid switching back to real mode to make
122 BIOS calls.  Especially on the 286 this is a painful affair.
124 .SB ENABLE_ESDI_WINI
125 Enables the ESDI disk driver.  Some PS/2 models have this disk.
127 .SB ENABLE_XT_WINI
128 Enables the XT disk driver.  Useful for early IBM/AT machines that have XT
129 disks.  In real mode it is best to use the BIOS driver.
131 .SB ENABLE_AHA1540_SCSI
132 Enables the Adaptec 1540 series SCSI driver.
134 .SB ENABLE_DOSFILE
135 Enable the "DOS file as disk" driver that is used when MINIX 3 is run from
136 MS-DOS to access a large file as a disk.
138 .SB ENABLE_FATFILE
139 Enable the "FAT file as disk" driver that interprets a FAT file system
140 to find a large file to use as a disk.  This driver combined with a fast
141 native MINIX 3 disk driver is a better choice then the previous driver.  (And
142 it works when MINIX 3 is not started from MS-DOS.)  This is the last driver
143 that needs to be assigned to a controller task.
145 .SB ENABLE_SB16
146 Enable the Soundblaster-16 audio driver.
148 .SB ENABLE_PRINTER
149 Enable the Printer driver.
151 .SB DMA_SECTORS
152 The size of the DMA buffer for drivers that use DMA or other drivers that
153 can only do I/O to a single chunk of memory.  (BIOS, ESDI, XT, DOSFILE.)
154 Choose a number between
155 .B 1
157 .B 128
158 for the sector size of this buffer.  The memory cost is twice this amount,
159 because of trouble getting it aligned in memory properly.  A value of
160 .B 16
161 is the minimum to work well, choose
162 .B 64
163 if you have enough memory.
165 .SB NR_CONSOLES
166 Number of virtual consoles.  By default
167 .BR 2 ,
168 so you can have two login sessions that can be switched to by ALT-F1,
169 ALT-F2 or ALT-left/rightarrow.  If you have an EGA screen then you can
170 specify up to
171 .B 4
172 virtual consoles, for VGA you can have
173 .BR 8 .
174 It is best to choose one less to leave some video memory to keep text
175 scrolling fast.  You really should read
176 .BR console (4)
177 on this.  Note also the
178 .B console
179 boot variable, you can use it to put more characters on the screen, at
180 the cost of video memory.
182 .SB NR_PTYS
183 Number of pseudo terminals supported, by default
184 .BR 0 ,
185 which disables the driver.  Pseudo terminals are used for incoming network
186 logins by telnet or rlogin.  One pty is needed per session.
188 .SB NR_RS_LINES
189 Number of RS-232 lines supported.  By default
190 .B 2
191 for a normal kernel, but
192 .B 0
193 for a tiny kernel used for XT installation.  You can save a bit of memory by
194 setting this parameter to zero if you don't need serial lines.
196 .ti 2m
197 .BR fs/const.h
199 This file contains most of the parameters used by the file system code.
200 Most of these cannot be changed, with the exception of these four:
202 .SB NR_FILPS
203 Maximum number of open file descriptors for all processes combined.  A "File
204 table overflow" error might indicate that this number must be increased.
206 .SB NR_INODES
207 Maximum number of in-use files for all processes combined.  Like above a
208 "File table overflow" error may also indicate that this number should be
209 increased.  In cases like these one usually doubles both parameters.  (If
210 one table runs out then the other one is likely to run out also anyway.)
212 .SB NR_SUPERS
213 Number of file systems that can be mounted.  Again a "file table overflow"
214 error is given if this table is full, but it will be produced by the
215 .B mount
216 command, so you know what's wrong in this case.
218 .SB NR_LOCKS
219 Number of active file locks by
220 .BR fcntl (2).
221 These locks are often used by programs that update a shared file, like mail
222 programs do with mail boxes.  A "no locks available" error indicates that
223 this table has run out.
224 .SH "SEE ALSO"
225 .BR controller (4),
226 .BR usage (8),
227 .BR boot (8),
228 .BR MAKEDEV (8).
229 .SH NOTES
230 Associated with drivers there are device files to access the devices
231 controlled by the drivers that may have to be created.  Let's simplify this
232 sentence:  Type
233 .BR "ls /dev" ,
234 note that there are only
235 .B c0*
237 .B c1*
238 devices, and only for two disks each.  Some devices, like the audio devices,
239 are not even present.  So if you enable a driver, or increase some limits, you
240 also need to use
241 .BR MAKEDEV (8)
243 .B /dev
244 to allow programs to talk to the drivers.
245 .SH AUTHOR
246 Kees J. Bot (kjb@cs.vu.nl)