INSTALL.T
上传用户:datang2001
上传日期:2007-02-01
资源大小:53269k
文件大小:33k
源码类别:

操作系统开发

开发平台:

C/C++

  1. .TH USAGE 8
  2. .SH NAME
  3. usage - installing and using MINIX
  4. .SH DESCRIPTION
  5. .de SP
  6. .if t .sp 0.4
  7. .if n .sp
  8. ..
  9. .de XB " An example in bold print.
  10. .RS
  11. .nf
  12. .ft B
  13. &\$1
  14. .ft R
  15. .fi
  16. .RE
  17. ..
  18. This manual page describes the installation and use of MINIX from a
  19. System Administrators point of view.  It contains an installation guide,
  20. instructions on how to do the initial configuration and some other info.
  21. Please read this document entirely before attempting to install MINIX.
  22. The installation steps are in the proper order, but not all the
  23. information you may need is presented at the right moment.
  24. Other detailed information that may be useful can be found in
  25. .BR boot (8)
  26. and
  27. .BR hier (7).
  28. .SS "1. REQUIREMENTS"
  29. The minimum system MINIX can be installed on comfortably is an IBM PC/AT
  30. or PS/2 with a 286 processor, 640 KB memory, a 720 kb diskette drive, and
  31. 25-30 MB free space on an AT,
  32. .ig
  33. PS/2,
  34. ..
  35. ESDI, or SCSI hard disk (the latter controlled by an Adaptec 1540.)  MINIX
  36. for the 386 (MINIX-386 for short) can be installed on a machine with at
  37. least a 386sx processor, 3 MB memory and at least 25-30 MB of disk space.
  38. .SS "2. MINIX INSTALLATION BACKGROUND"
  39. The objective of the installation is to create a partition on your disk
  40. and to put MINIX into it.  MINIX really requires two partitions however, so
  41. the single "primary" partition is split into two subpartitions.  The
  42. .B a
  43. subpartition will contain the root file system, and the
  44. .B c
  45. subpartition will contain the
  46. .B /usr
  47. file system.  What MS-DOS calls
  48. "drives", i.e C:, D:, E:, MINIX calls "file systems".  MINIX does not use
  49. drive letters, but requires that one file system is made a part of another
  50. file system by "mounting" one on the other.  The "root" file system is
  51. always present and starts with the directory "/", the root of the directory
  52. tree.  The root file system contains a few programs in
  53. .BR /bin ,
  54. device files in
  55. .BR /dev ,
  56. and configuration files in
  57. .BR /etc .
  58. This is just enough to get the system started.  MINIX will soon extend
  59. its directory tree by mounting a file system on the
  60. .B /usr
  61. directory.  What is henceforth known as the /usr file system contains all
  62. MINIX programs in
  63. .BR /usr/bin ,
  64. file system sources in
  65. .BR /usr/src ,
  66. etc, etc.
  67. The s-2ROOTs+2 image contains the complete MINIX root file system, but
  68. s-2USRs+2 contains just a small subset of the /usr file system, with just
  69. enough utilities to install MINIX.  The complete /usr file system is
  70. split up into the s-2USR.TAZs+2, s-2SYS.TAZs+2 and s-2CMD.TAZs+2
  71. archives that are installed later to fill /usr.
  72. .PP
  73. Let's suppose your first hard disk, which has
  74. device name
  75. .BR /dev/hd0 ,
  76. has MS-DOS already present in the first primary partition
  77. .RB ( /dev/hd1 ),
  78. and some free space left after that.  After MINIX is installed in that
  79. free space the disk will look like this:
  80. .PP
  81. .ta +12n
  82. .nf
  83. .in +4n
  84. /dev/hd0 Whole hard disk #0
  85. .in +2n
  86. /dev/hd1 MS-DOS C: drive
  87. /dev/hd2 MINIX primary partition
  88. .in +2n
  89. /dev/hd2a MINIX root partition
  90. /dev/hd2c MINIX /usr partition
  91. .in -8n
  92. .fi
  93. .PP
  94. /dev/hd0 is the sum of a partition table, /dev/hd1 and /dev/hd2.
  95. Likewise is /dev/hd2 the sum of a subpartition table, /dev/hd2a and
  96. /dev/hd2c.  Read the "DEVICES" sections for more information on MINIX
  97. devices.
  98. .SS "3. INSTALLATION"
  99. If you have not already copied MINIX to floppy disks, please read
  100. the README.TXT file in the MINIX directory now.
  101. It tells how to do this.
  102. You should also print out EXAMPLE.TXT and read it in parallel with this
  103. document.  This one tells you what to do; that one shows you what the
  104. screen is supposed to look like at each step, so you can see if everything
  105. is OK.
  106. .PP
  107. You can install MINIX automatically or manually as described the sections
  108. below.  The end result is the same, but manual installation allows
  109. one to deviate from the preconfigured choices.  You may wish to read the
  110. manual pages of the programs used below before you start.  You may especially
  111. want to read
  112. .BR boot (8)
  113. if your machine is different from what the majority buys, because you
  114. may need to set a few boot parameters to configure drivers.  To do this type
  115. .B ESC
  116. to get to the Boot Monitor prompt, set the appropriate variables, use
  117. .B save
  118. to store the settings and
  119. .B menu
  120. to continue where you left off.
  121. .PP
  122. To install the system you need two diskettes: a bootable root diskette and a
  123. diskette full of binaries to use as
  124. .BR /usr .
  125. These diskettes are named
  126. .B s-2ROOTs+2
  127. and
  128. .BR s-2USRs+2 .
  129. These two diskettes may also be combined on a single high density diskette.
  130. In that case the s-2USRs+2 part is on the
  131. .B c
  132. partition.
  133. .PP
  134. Insert the s-2ROOTs+2 diskette, boot the machine and type '=' to the menu.
  135. The MINIX kernel is loaded and takes control when you see the copyright
  136. banner.  After loading the root diskette into the RAM disk you will be asked
  137. to finish the name of the device to mount on
  138. .BR /usr .
  139. Type
  140. .BR fd0c
  141. for a diskette that contains both s-2ROOTs+2 and s-2USRs+2, otherwise
  142. replace s-2ROOTs+2 by s-2USRs+2 and type
  143. .BR fd0 .
  144. Login as
  145. .BR root .
  146. .SS "4. AUTOMATIC INSTALLATION"
  147. Before starting the installation, you must either have a free partition
  148. available or have at least 25-30 MB not in any partition so you can create
  149. a MINIX partition.
  150. Splitting an MS-DOS partition can be done using fips, and is discussed in the
  151. main README.TXT file.
  152. .PP
  153. Type
  154. .B setup
  155. to start the installation script.  First it offers to install a national
  156. keyboard map.  The names should be clear, except for
  157. .BR us-swap ,
  158. which swaps the CTRL and CAPS LOCK keys of a standard US style keyboard
  159. for people who believe that the natural place of CTRL is next to A.
  160. The default suggested between [ and ] is the US standard keyboard.
  161. .PP
  162. The next thing to do is to make a partition, for this you are placed in a
  163. partition table editor named
  164. .BR part .
  165. This partition table editor is very easy to use (in the author's opinion),
  166. but you will probably hate it.  You can move all over the place with the
  167. arrow keys, change values, and make a mess of your partition table real quick.
  168. So if you get into trouble, type 'q' to quit, 'n' to not write the table,
  169. and RETURN to start over.  Use the '?' key to get help.
  170. .PP
  171. With the '+' and '-' keys you can select the disk device to install on,
  172. probably
  173. .BR /dev/hd0 ,
  174. the first hard disk.  Type 'r' to load the partition table of the selected
  175. disk.  Either create one new partition by modifying a partition marked
  176. "None", or reuse an existing partition by changing its type to "MINIX" (hex
  177. code 81).  The FIPS program can be used under MS-DOS to shrink an MS-DOS
  178. partition.  FIPS splits the MS-DOS partition in two, so one of the two can be
  179. used for MINIX.  You have to be absolutely sure which one.  When in doubt,
  180. first use the FDISK program under MS-DOS to delete the extra partition, and
  181. let MINIX part create a new one.  DO NOT use part to shrink an existing
  182. partition!  MINIX needs a partition of at least 25-30 MB, but not larger
  183. than 128 MB (MINIX-86) or 1 GB (MINIX-386).  The system needs
  184. 30 MB in compiled state.
  185. .PP
  186. The script then wants to know the name of the partition you've created, this
  187. name is probably still visible on the screen (hd2, hd6, something like
  188. that.)  The new partition table is reloaded into the disk driver, and the
  189. new MINIX partition is carved up into two subpartitions, a 1440 kb root and
  190. the rest for /usr.
  191. .PP
  192. After making /usr, it is immediately put to use to replace the installation
  193. /usr file system so that you can remove the s-2USRs+2 diskette and insert
  194. the s-2ROOTs+2 diskette (unless they are one and the same).  The root file
  195. system is filled with the contents of the s-2ROOTs+2 diskette and slightly
  196. patched up to work on the hard disk (/etc/fstab.)
  197. .PP
  198. To compute the size of the so-called "second level block cache" you are
  199. asked to specify the RAM size of your machine.  If you have plenty, i.e
  200. 4 MB or more then simply hit RETURN, otherwise enter the size of your system
  201. RAM in kilobytes.
  202. .PP
  203. You can now skip the next section and move to "TESTING", but it may be
  204. instructive to read it anyway.
  205. .SS "5. MANUAL INSTALLATION"
  206. The instructions that follow are at a very low level and require you to be
  207. very careful.  The big advantage is that you know precisely what
  208. tools have been used and how everything works.  The disadvantage is that
  209. you may easily make a mistake that either forces you to start over if you
  210. are lucky, or wipes out the contents of your hard disk if you are not.
  211. Only if you really want to do something different should you use a manual
  212. installation.  Slavishly following the steps shown below will only make
  213. you end up with the same result as an automatic installation.
  214. .PP
  215. Run
  216. .B part
  217. to make partitions to load the system into.  The best thing to do is to make
  218. one large primary partition of type "MINIX" and to carve this partition up
  219. into three subpartitions for root and /usr.  The assumption is that you will
  220. use the second partition on the first hard disk,
  221. .BR /dev/hd2 ,
  222. and that
  223. .B hd2a
  224. is the root subpartition and
  225. .B hd2c
  226. is /usr.  If you want to use the first partition on
  227. the second hard disk for instance, then substitute hd6 and hd6[ac] for the
  228. above.  On a s-2SCSIs+2 disk it will be /dev/sd2 for the second partition
  229. on the disk at target 0.  See the section on devices below, and the manual
  230. pages of
  231. .BR part (8),
  232. .BR hd (4),
  233. and
  234. .BR sd (4).
  235. Start
  236. .B part
  237. and select the whole hard disk device (the "multiple of 5" device) that you
  238. want to install MINIX onto.  In our example it will be
  239. .BR /dev/hd0 .
  240. .PP
  241. Use
  242. .B part
  243. to make a single partition in the primary partition table of type "MINIX",
  244. then hit '>' on this new partition to make a subpartition table.
  245. .PP
  246. For the root subpartition you are advised to use 1440 kb exactly.  You can
  247. make it larger if you want to, but it is advisable never to let the contents
  248. outgrow a floppy.  (The s-2ROOTs+2 diskette is a copy of a root file
  249. system, and will be used to fill your root subpartition.)
  250. .PP
  251. The second subpartition is either empty or a "scratch" partition.  MINIX no
  252. longer uses the
  253. .B b
  254. subpartition for anything useful anymore, but it has become customary to
  255. have root on
  256. .B a
  257. and /usr on
  258. .BR c .
  259. (You are free to ignore this convention, of course.)
  260. .PP
  261. Use the rest of the partition for the /usr
  262. .B c
  263. subpartition.
  264. .PP
  265. When you are done check that /dev/hd2a is active (the * after the partition
  266. number) so you can boot from it later.
  267. .PP
  268. If your disk has bad blocks then don't put the root or scratch subpartition
  269. on top of them.  Make sure the inode tables in the other partitions don't
  270. have bad blocks either.  You can put the subpartitions out of order on the
  271. disk if that helps.  Subpartition tables, other than the main partition
  272. table, are not sorted by the driver.
  273. .PP
  274. After making the partitions you do not have to reboot.  The disk driver
  275. reloads the partition tables on the next access if the disk is not in use.
  276. (Open or mounted.)
  277. .PP
  278. To be able to boot from /dev/hd2a you must place a master bootstrap in
  279. /dev/hd2.  It has been placed there by
  280. .B part
  281. if it told you that it was creating a new partition table, but
  282. .PP
  283. .XB "installboot-m/dev/hd2/usr/mdec/masterboot"
  284. .RE
  285. .PP
  286. will put it there for sure.
  287. .PP
  288. You will start by making a file system for /usr and filling it partially.
  289. This may seem to be out of order, but you can't insert the s-2ROOTs+2
  290. floppy right now.
  291. .PP
  292. .XB "mkfs/dev/hd2c"
  293. .XB "readall-b/dev/hd2c | sh"
  294. .XB "mount/dev/hd2c/mnt"
  295. .XB "cpdir-v/usr/mnt"
  296. .PP
  297. This will create a file system on /dev/hd2c, mount it on /mnt, and copy the
  298. contents of the s-2USRs+2 floppy onto it.  The call to
  299. .B readall
  300. marks bad blocks on the file system as unusable, you can omit this on a
  301. drive known to be spotless (s-2IDEs+2 or s-2SCSIs+2.)
  302. .PP
  303. You can now use the new /usr in place of the s-2USRs+2 floppy:
  304. .PP
  305. .XB "umount/dev/hd2c"
  306. .XB "umount/dev/fd0# fd0c if combined"
  307. .XB "mount/dev/hd2c/usr"
  308. .PP
  309. This little dance has freed up your floppy drive, so please remove the
  310. s-2USRs+2 diskette and replace it by the s-2ROOTs+2 diskette.  Make a
  311. file system for the root with at least 512 inodes (files), and
  312. fill it from the floppy:
  313. .PP
  314. .XB "mkfs-i512/dev/hd2a"
  315. .XB "mount/dev/fd0/fd0"
  316. .XB "mount/dev/hd2a/mnt"
  317. .XB "cpdir-v/fd0/mnt"
  318. .XB "umount/dev/fd0"
  319. .PP
  320. Remove
  321. .B /mnt/etc/issue
  322. to get rid of the "use setup" message that greets you when you boot, and
  323. edit the file
  324. .B /mnt/etc/fstab
  325. to name the devices MINIX has been installed on.  In our example it
  326. should look like this:
  327. .PP
  328. .XB "root=/dev/hd2a"
  329. .XB "usr=/dev/hd2c"
  330. .PP
  331. Unmount the new root:
  332. .PP
  333. .XB "umount/dev/hd2a"
  334. .PP
  335. Make it bootable:
  336. .PP
  337. .XB "installboot-d/dev/hd2a/usr/mdec/bootblockboot"
  338. .PP
  339. The automatic script would now set the
  340. .B rootdev
  341. and
  342. .B ramimagedev
  343. boot variables.  You can do this now using the
  344. .B edparams
  345. command, but it is easier to postpone it until the testing phase.  The
  346. settings should be:
  347. .PP
  348. .XB "rootdev=hd2a"
  349. .XB "ramimagedev=hd2a"
  350. .SS "6. TESTING"
  351. By now a new MINIX system is present on your hard disk.  Time to see if
  352. it works.  Leave the s-2ROOTs+2 diskette in the drive and type
  353. .BR halt .
  354. You are now going to use the power of the Boot Monitor on the diskette to
  355. boot the MINIX partition on the hard disk.  Use the monitor command
  356. .B boot hd2
  357. to boot the primary partition MINIX has been installed in.  (It is "hd2" in
  358. our example.)  For a s-2SCSIs+2 disk you will have to use a 'hd' name too.
  359. The monitor uses the BIOS, so you will have to treat it as a "normal" disk
  360. at this point.
  361. .PP
  362. The hard disk bootstrap is now showing the menu again.  You can type '='
  363. to start MINIX, but you probably want to change the boot parameters.
  364. Hit
  365. .B ESC
  366. once more to get to the command prompt.  The command
  367. .B set
  368. shows what the current parameters are.  Here is an example that shows how
  369. to make a menu to either start MINIX or boot MS-DOS:
  370. .PP
  371. .XB "minix(=,MINIX){boot}"
  372. .XB "dos(d,MS-DOS){boothd1}"
  373. .XB "save"
  374. .PP
  375. MS-DOS is assumed to be in the first partition in the example above (hd1).
  376. When finished type
  377. .B menu
  378. to see if the menu looks right. If so hit '=' to start MINIX. Log in as root.
  379. .SS "7. ADDING PROGRAMS AND SOURCES TO /usr"
  380. The
  381. .B setup
  382. command can also be used to add files from floppy sets to the system.  The
  383. .B s-2USR.TAZs+2
  384. (programs and stuff),
  385. .B s-2SYS.TAZs+2
  386. (system sources), and
  387. .B s-2CMD.TAZs+2
  388. (commands sources)
  389. are all installed relative to the
  390. .B /usr
  391. directory, so the command to use three times is
  392. .PP
  393. .XB setup/usr
  394. .PP
  395. .B Setup
  396. will ask for the size of data on the floppies, which is by default simply
  397. the entire floppy.  You will see some "Cannot make directory" errors
  398. while extracting, as some directories already exist.  Ignore these messages.
  399. You need the
  400. .B s-2USR.TAZs+2
  401. set if you want a working MINIX system,
  402. .B s-2SYS.TAZs+2
  403. if you want recompile the system or study it, and
  404. .B s-2CMD.TAZs+2
  405. if you also want the sources of the commands.  On a disk space
  406. starved machine you could opt to do without the commands sources, as they
  407. are not absolutely necessary to understand MINIX.
  408. .PP
  409. If your machine does not have enough memory to run
  410. .B setup/usr
  411. then type these commands manually:
  412. .PP
  413. .XB "cd/usr"
  414. .XB "vol/dev/fd0 | uncompress | tarxvfp-"
  415. .SS "8. NAMES"
  416. A standalone machine will have to be given a name.  As
  417. .B root
  418. type
  419. .PP
  420. .XB "echofInamefB>/etc/hostname.file"
  421. .PP
  422. to change the host name of your machine to
  423. .IR name .
  424. .SS "9. ACTIVE ON BOOT"
  425. You may want to make the MINIX partition active so that it is automatically
  426. booted.  With MS-DOS
  427. .B fdisk
  428. or MINIX
  429. .BR part ,
  430. mark the primary partition that contains MINIX active.  Using the menu you
  431. made earlier you can boot either MINIX or MS-DOS at a keypress.  You can even
  432. set timeouts.  To boot MINIX automatically after 5 seconds:
  433. .PP
  434. .XB "main(){trap5000minix;menu}"
  435. .PP
  436. See
  437. .BR monitor (8)
  438. for all the details on the monitor.
  439. .PP
  440. If you don't trust this then you can rig up a diskette that boots the MINIX
  441. partition when left in the drive:
  442. .PP
  443. .XB "installboot-m2/dev/fd0/usr/mdec/masterboot"
  444. .PP
  445. The number 2 indicates the hard disk partition that must be booted, you can
  446. use the numbers 1 to 9 for hd1 to hd9.
  447. .SS "10. DEVICES"
  448. A crash course on the MINIX devices in
  449. .BR /dev :
  450. The two hard disks are named
  451. .BR hd0
  452. and
  453. .BR hd5 .
  454. These "multiple of five" devices address the entire hard disk, from the
  455. first to the last byte.  Each disk has four partitions, for disk 0 they are
  456. .BR hd1 ,
  457. .BR hd2 ,
  458. .BR hd3 ,
  459. and
  460. .BR hd4 .
  461. And for disk 1 they are named
  462. .BR hd6 ,
  463. .BR hd7 ,
  464. .BR hd8 ,
  465. and
  466. .BR hd9 .
  467. These partitions may contain file systems,
  468. .B hd1
  469. often contains the MS-DOS "C:" file system.  MINIX can use these partitions
  470. for file systems too, but you can also partition one of these "primary
  471. partitions" into four so-called "subpartitions".  The subpartitions of
  472. .B hd1
  473. are named
  474. .BR hd1a ,
  475. .BR hd1b ,
  476. .BR hd1c ,
  477. and
  478. .BR hd1d .
  479. The other partitions may have four subpartitions that are named in the same
  480. way by adding a letter from
  481. .B a
  482. to
  483. .BR d .
  484. So one disk may have four partitions, and 16 subpartititions total.  SCSI
  485. disks are named in the same way, from
  486. .BR sd0
  487. to
  488. .BR sd39d
  489. for all possible devices for all eight SCSI targets.
  490. The two floppy disks are
  491. .BR fd0
  492. and
  493. .BR fd1 .
  494. Each may have four partitions named
  495. .BR fd0a ,
  496. .BR fd0b ", ..."
  497. .BR fd1d .
  498. The command
  499. .B MAKEDEV
  500. knows how to make devices, and
  501. .B DESCRIBE
  502. can tell you what an unknown device may be, or even what all devices in
  503. .B /dev
  504. may be if called without arguments.  Devices are described fully in
  505. .BR dev (4),
  506. and in the device specific manual pages like
  507. .BR fd (4)
  508. and
  509. .BR hd (4).
  510. .SS "11. EDITORS"
  511. The editors available are
  512. .B elvis
  513. (a
  514. .B vi
  515. clone),
  516. .B elle
  517. (a simple
  518. .B emacs
  519. clone),
  520. and the old MINIX
  521. .B mined
  522. editor.  Of these editors only elvis can recover your file after a system
  523. crash.  Only
  524. .B mined
  525. is available at installation time.  (All you need to know about mined right
  526. now is that CTRL-X gets you out of it.)
  527. .SS "12. INSTALLING ON A SCSI DISK"
  528. Using a disk other than an (IDE)
  529. .B hd
  530. disk complicates things a bit.  The Boot Monitor uses the BIOS, so it names
  531. all disks with
  532. .B hd
  533. names.  So it is
  534. .B boot hd1
  535. to boot partition 1, and
  536. .B "ramimagedev=sd2a"
  537. to tell MINIX its root partition.  If you have both a normal and a SCSI disk
  538. then the disks may be
  539. .B hd0
  540. and
  541. .B hd5
  542. to the Monitor, and
  543. .B hd0
  544. and
  545. .B sd0
  546. to MINIX.
  547. .SS "13. NATIONAL KEYBOARDS"
  548. The directory
  549. .B /usr/lib/keymaps
  550. contains keymap tables for several national keyboards.  If you have a German
  551. keyboard for instance, then
  552. .PP
  553. .XB "loadkeys/usr/lib/keymaps/german.map"
  554. .PP
  555. will load the German key translation table into the keyboard driver.  Copy
  556. the map to
  557. .B /etc/keymap
  558. once MINIX is installed on the hard disk, because having to type a key
  559. sequence like one of these:
  560. .PP
  561. .XB "loadkezs-usr-lib-kezmaps-german.map"
  562. .XB "loqdkeys=usr=lib=key,qps=french.,qp"
  563. .PP
  564. on a reboot gets a bit annoying after a while.  Send corrections and new
  565. keymaps to the person named below.  (Do not send a Dutch keymap, buy
  566. yourself a real keyboard instead.)
  567. .SH SUGGESTIONS
  568. Below are a few useful suggestions.  Some of the information can be of use
  569. in other situations than described here.
  570. .SS "14. VIRTUAL CONSOLES"
  571. Hold down the ALT key and press the left or right arrow key, F1, or F2.
  572. This switches the console between two login sessions.  (Unless you have
  573. an old mono adapter, because virtual consoles sit in video memory, and
  574. a mono adapter only has memory for one.)
  575. .PP
  576. Note that kernel messages, including function key output, only appear on
  577. the first console.  This may be confusing, but it keeps the other consoles
  578. clean.
  579. .SS "15. LOW ON MEMORY"
  580. The normal installation requires that you have enough memory for a large RAM
  581. disk.  You can still install MINIX normally if you either have a high density
  582. diskette drive for a combined root+usr floppy, or you have two floppy drives
  583. of at least 720 kb.  Before booting you have to set the variable
  584. .B rootdev
  585. to the same value as
  586. .BR ramimagedev .
  587. This is slower then a RAM disk, but saves a lot of memory.
  588. .PP
  589. The automatic installation script knows how to handle this new situation.
  590. If you install manually then you have to use
  591. .PP
  592. .XB "cpdir-vx//mnt"
  593. .PP
  594. to copy the root device to disk.  When it is time to fill /usr and you only
  595. have one floppy drive then hit DEL to get out of the installation script and
  596. reboot as described in "TESTING".  You can then finish the installation
  597. manually.
  598. See the XT640K.TXT file for more advice on small machines.
  599. .SS "16. LOW ON MEMORY AND ONLY ONE 720 KB FLOPPY DRIVE"
  600. If you only have one 720 kb floppy drive and your system is low on memory
  601. then you can use the s-2TINYROOTs+2 boot image.  This image contains a
  602. small kernel with only the BIOS disk driver, and a small root file system.
  603. You can use this disk to boot your machine.  Use the normal s-2ROOTs+2 to
  604. install the root file system.  Keep booting your machine with
  605. s-2TINYROOTs+2 until you have compiled a small kernel for your system.
  606. Use the
  607. .B rootdev
  608. boot variable to select the hard disk root file system.  Do
  609. .B not
  610. use s-2TINYROOTs+2 for anything other than booting, always use
  611. s-2ROOTs+2 when mentioned.
  612. .SS "17. FLOPPY DRIVE 1 IS A HIGH DENSITY DRIVE"
  613. If you would like to install from floppy drive 1 then you need to copy at
  614. least one sector from the s-2USRs+2 image onto a diskette for drive 0.
  615. The s-2USRs+2 bootstrap has been rigged to boot the other drive.
  616. .SS "18. INSTALLING ON A SECOND HARD DISK"
  617. MINIX doesn't care if it is installed on the second disk of a system with
  618. two disks.  The only problem is to get it booted.  You can either rig up
  619. a diskette to boot MINIX as shown earlier, or you can use the same trick
  620. on the first disk.  The command
  621. .PP
  622. .XB "installboot-m5/dev/hd0/usr/mdec/masterboot"
  623. .PP
  624. will lock the first disk into booting the second disk.  Note that this
  625. command modifies the disk outside a MINIX partition, overwriting a bit of
  626. code that has likely been put there by MS-DOS fdisk.  First verify that the
  627. Boot Monitor can boot an MS-DOS partition, because then the MINIX master
  628. bootstrap can do it too.
  629. .SS "19. LOTS OF MEMORY ON A 286"
  630. You will have a hard time making MINIX use up 3 MB memory.  Memory you
  631. can spare can be used for a "second level block cache" on the RAM disk.  The
  632. File System uses the second level cache to store copies of disk blocks that
  633. are pushed out of the normal (primary) block cache.  The size of the primary
  634. cache is compiled into the FS server, but the size of the second level cache
  635. can be set with the
  636. .B ramsize
  637. boot variable.  Set it to a number between 0 and 512.  512 kilobytes is
  638. enough to keep most of the compiler cached.
  639. You must have extended memory; expanded memory is not supported.
  640. .SS "20. LOTS OF MEMORY ON A 386+"
  641. Processes can be as big as you would like on a 386, but in practice 4 MB is
  642. plenty for all your processes.
  643. The installation script sets up a second level cache for MINIX-386
  644. of up to 1024 kilobytes.  This is because the default file system cache
  645. is only 80 kb.  Your first point of call is to get rid of the poorly
  646. performing second level cache by setting
  647. .B ENABLE_CACHE2
  648. to 0 and to assign the memory used by it to the
  649. normal block cache by enlarging the appropriate
  650. .B NR_BUFS
  651. and
  652. .B NR_BUF_HASH
  653. constants in <minix/config.h> with as much as you can spare.  (1024 for
  654. NR_BUFS is the minimum to keep
  655. .B "cc -c"
  656. cached.  2048 is then a nice value for NR_BUF_HASH.)
  657. Disable the second level cache, compile a new kernel, reboot and set
  658. .B ramsize
  659. to 0.
  660. .SS "21. LOTS OF DISK SPACE"
  661. The maximum file system size is 1 GB for MINIX-386 and 128 MB for
  662. MINIX-86.  (MINIX-86 can handle larger file systems, but
  663. .B fsck
  664. can't check them.)  Note that a MINIX file system can only contain 65535
  665. inodes (files), so the average file should be 16 kb to completely fill it.
  666. It may be better to make two smaller file systems.  Besides, fsck takes
  667. forever on a large file system.
  668. .SH SYSTEM ADMINISTRATION
  669. The system has been set up with the idea that working as root is a bad thing
  670. to do.  As root you are in no way protected from doing stupid things.  So
  671. don't do development as root, but work as
  672. .BR bin !
  673. Only in exceptional cases do you want to become root.  Being root is fun for
  674. wannabe hackers; administrators know better.
  675. .PP
  676. To make life easier for bin, some programs like
  677. .BR su (1),
  678. .BR install (1)
  679. and
  680. .BR shutdown (8)
  681. treat bin and other members of the operator group as special and allow them
  682. the privileges of root.  (One is an operator if one's
  683. group id is zero.)  Operators should share the shadow password of root by
  684. having
  685. .B ##root
  686. in their password field.  This way they all have one face (password)
  687. to the outside world, forming no greater security risk than root alone.
  688. .PP
  689. The home directory of bin contains one important Makefile.  You can use it
  690. to recompile all the commands and libraries of the system.  Type
  691. .B make
  692. to see the usage message.  If you want to compile just one command then you
  693. can simply type
  694. .B make
  695. to do so.  To put it in its proper place you have to type
  696. .BR "make install" .
  697. Read the Makefiles in the
  698. .B commands
  699. and
  700. .B lib
  701. subdirectories to understand how everything is put together.  If you are
  702. tight on memory then
  703. .B make
  704. may fail to traverse down the source tree and also compile things.  You will
  705. have to type
  706. .B make
  707. in each subdirectory.  You can run make in /usr/src at the end to see if
  708. you've missed something or not.
  709. .PP
  710. The login shell of bin is
  711. .BR ash ,
  712. the BSD shell.  It has been modified to offer simple line editing using the
  713. .BR editline (3)
  714. library.
  715. .B Ash
  716. is rather big, so you may have to change bin's shell back to
  717. .B /bin/sh
  718. with
  719. .BR chsh (1)
  720. if you are low on memory.  Do not change root's shell to ash, and do not
  721. replace /bin/sh by ash.  It may run out of memory at the wrong moment.
  722. .PP
  723. The kernel is not compiled from the master Makefile.  To make a new kernel
  724. you have to step into the
  725. .B tools
  726. directory.  There you can run four different make commands:
  727. .PP
  728. .TP
  729. .B make
  730. This makes all the different kernel parts and combines them in the file
  731. named
  732. .BR image .
  733. .TP
  734. .B make fdboot
  735. As above and then makes a boot floppy that you can use to restart your
  736. system with.  You are prompted for the floppy device name.
  737. .TP
  738. .B make hdboot
  739. First makes the image file and then copies it into the directory
  740. .BR /minix .
  741. If there are already two images in that directory then the newest image will
  742. be removed to make space for this newer image.  It is assumed that the
  743. oldest image is the most stable system image, one that always works, and
  744. that the newest image is experimental.  Check beforehand what
  745. .B /minix
  746. contains before you run
  747. .BR "make hdboot" .
  748. Remove the oldest image if you want another image to become the stable
  749. image.  The Boot Monitor chooses the newest image in
  750. .B /minix
  751. to boot.  You can use the monitor command
  752. .B ls minix
  753. to view the images present, and set the
  754. .B image
  755. variable to the full name of the image you want to use instead if the newest
  756. doesn't work.  The images in
  757. .B /minix
  758. are named using the MINIX release and version numbers with an extra revision
  759. number added to distinguish the images.
  760. .PP
  761. The first new kernel you would like to make is one configured for your
  762. system.  The kernel you are running now contains several hard disk drivers
  763. you don't need, and it does not have a TCP/IP server that you may want to
  764. have.  In <minix/config.h> you can find a number of
  765. .BI ENABLE_ XXX
  766. variables that can be set to
  767. .B 0
  768. to exclude, or
  769. .B 1
  770. to include a particular driver.  Another driver related variable is
  771. .BR DMA_SECTORS .
  772. This variable sets the size of a buffer used by DMA based disk drivers (all
  773. but the floppy, AT/IDE, and Adaptec drivers).  Raise its value to greatly
  774. improve throughput, especially writing.  A value of 16 shows good results.
  775. (The BIOS driver benefits most, because it is a long way to the BIOS from
  776. protected mode, especially from 286 protected mode.)  You can increase
  777. .B NR_CONS
  778. if you want to have more virtual consoles.  Having more consoles costs
  779. little memory, because all the consoles are kept in video memory.  Scrolling
  780. speed of the console will go down if more virtual consoles share the
  781. available memory.  CGA cards have space for 4 consoles, EGA and VGA can
  782. have 8 consoles.  The
  783. .B NR_PTYS
  784. variable sets the number of pseudo-ttys.  You need pseudo-ttys to be able to
  785. login remotely over a network with the
  786. .B rlogin
  787. command.  Each remote login session needs one pseudo-tty.  If you fear that
  788. the system will now run out of processes then increase
  789. .BR NR_PROCS .
  790. Configuring a new kernel is sometimes not enough to enable new devices, you
  791. sometimes need to use the
  792. .B MAKEDEV
  793. command to make new device files in
  794. .BR /dev .
  795. For pseudo-ttys you also have to check if
  796. .B /etc/ttytab
  797. mentiones the new devices.
  798. .PP
  799. New additions to the system can be made in the
  800. .B /usr/local
  801. tree.  An empty directory tree has been set up for you and binaries and
  802. manual pages are already in the search paths.  You can make a new user entry
  803. with the
  804. .B adduser
  805. command.
  806. .PP
  807. The
  808. .B TZ
  809. variable in
  810. .B /etc/profile
  811. tells the time zone offset from the wall clock time to GMT.  You have to
  812. change it for your time zone.  (See
  813. .BR TZ (5).)
  814. .PP
  815. The function keys produce debug dumps, showing various interesting data
  816. about the system.  F1 lists processes and F5 shows ethernet stats, which
  817. may be of use now.  Read
  818. .BR console (4)
  819. to know all the details of the screen and keyboard.
  820. .SS "22. SYSTEM SHUTDOWN"
  821. You can't just turn a MINIX system off.  MINIX must be told to flush the
  822. modified data in the file system cache first.  The following
  823. commands/keystrokes can be used to exit MINIX properly:
  824. .TP
  825. .B shutdown
  826. First alert all users and then all processes of the impending shutdown
  827. then halt or reboot the system in one of various ways.  See
  828. .BR shutdown (8).
  829. .TP
  830. .B reboot / halt
  831. Alert all processes of the system shutdown then reboot or halt.
  832. .TP
  833. .B s-2CTRL-ALT-DELs+2
  834. Halt the system by running
  835. .BR "shutdown -h now" .
  836. .PP
  837. MINIX halts by returning to the Boot Monitor, MINIX reboots by instructing
  838. the monitor to reboot MINIX.  (MINIX is just a subprocess to the monitor.)
  839. Either halt MINIX and use monitor commands to escape MINIX, or use
  840. .B shutdown -R
  841. to reset the system.
  842. .SH FILES
  843. .TP 12
  844. .B /usr/ast
  845. Honorary home directory of Andew S. Tanenbaum.  Doubles as the place where
  846. the default setup for a new user is found.
  847. .SH "SEE ALSO"
  848. .BR monitor (8),
  849. .BR boot (8),
  850. .BR part (8),
  851. .BR mkfs (1),
  852. .BR mount (8),
  853. .BR M (8),
  854. .BR fstab (5),
  855. .BR hier (7),
  856. .BR console (4),
  857. .BR dev (4),
  858. .BR adduser (8),
  859. .BR TZ (5),
  860. .BR mkdist (8),
  861. .BR shutdown (8).
  862. .br
  863. "Operating Systems - Design and Implementation 2/e" by Andrew S. Tanenbaum
  864. and Albert S. Woodhull.
  865. .SH NOTES
  866. The notation
  867. .BI < file .h>
  868. refers to a C language include file in /usr/include.
  869. .PP
  870. .B Root
  871. and
  872. .B bin
  873. do not have the current directory in their program search path to avoid
  874. executing programs left around by malicious people.  This means that to run
  875. .B foo
  876. from the current directory,
  877. .B ./foo
  878. must be typed.
  879. .PP
  880. Some of the commands have changed since earlier MINIX versions.  For instance
  881. .B mkfs
  882. doesn't need a size argument anymore, and
  883. .B vol
  884. automagically determines if it needs to read or write.  Keep this in mind
  885. if you use an older MINIX version to examine the newer system.
  886. .SH BUGS
  887. There are many PS/2 models, all different.  Some will run MINIX, some won't,
  888. some crippled if you lie to MINIX by setting
  889. .B processor
  890. to
  891. .BR 86 .
  892. Almost no PS/2 has a standard disk, so setting
  893. .B hd
  894. to
  895. .B esdi
  896. or
  897. .B bios
  898. will be necessary.
  899. .PP
  900. While testing a full library rebuild of this distribution it sometimes
  901. happened that some things were not put back into the library.  This seems
  902. to be fixed, but we do not understand why the fix fixed the problem.  So
  903. if you see strange "undefined" errors when compiling a program after a
  904. library rebuild then run
  905. .B make install
  906. again in
  907. .B /usr/src/lib/
  908. to try and add the missing pieces.
  909. .PP
  910. Except for the floppy driver, none of the DMA based drivers know about DMA
  911. being limited to a 24 bits address, i.e. the first 16 MB.  So under MINIX-386
  912. you run a slight risk that a
  913. .B tar
  914. or
  915. .B dd
  916. command may use a buffer above 16 MB for reading or writing to a character
  917. device.  This only happens if the low 16 MB is taken by some huge processes,
  918. and you have more than 16 MB, of course.
  919. .SH AUTHOR
  920. Kees J. Bot (kjb@cs.vu.nl)