2 .\" Jordan Hubbard <jkh@FreeBSD.org>. All rights reserved.
4 .\" Redistribution and use in source and binary forms, with or without
5 .\" modification, are permitted provided that the following conditions
7 .\" 1. Redistributions of source code must retain the above copyright
8 .\" notice, this list of conditions and the following disclaimer.
9 .\" 2. Redistributions in binary form must reproduce the above copyright
10 .\" notice, this list of conditions and the following disclaimer in the
11 .\" documentation and/or other materials provided with the distribution.
13 .\" THIS SOFTWARE IS PROVIDED BY Jordan Hubbard AND CONTRIBUTORS ``AS IS'' AND
14 .\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 .\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16 .\" ARE DISCLAIMED. IN NO EVENT SHALL Jordan Hubbard OR CONTRIBUTORS BE LIABLE
17 .\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18 .\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
19 .\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
20 .\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
21 .\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
22 .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32 .Nd system installation and configuration tool
41 utility is used for installing and configuring
44 It is the first utility invoked by the
47 floppy and is also available as
48 .Pa /usr/sbin/sysinstall
51 systems for use in later configuring the system.
55 utility is generally invoked without arguments for the default
56 behavior, where the main installation/configuration menu is presented.
58 On those occasions where it is deemed necessary to invoke a subsystem
59 of sysinstall directly, however, it is also possible to do so by
60 naming the appropriate function entry points on the command line.
61 Since this action is essentially identical to running an installation
62 script, each command-line argument corresponding to a line of script,
63 the reader is encouraged to read the section on scripting for more
64 information on this feature.
68 utility is essentially nothing more than a monolithic C program with
69 the ability to write MBRs and disk labels (through the services
72 library) and install distributions or packages onto new and
76 It also contains some extra intelligence
77 for running as a replacement for
79 when it is invoked by the
81 installation boot procedure.
83 assumes very little in the way of additional utility support and
84 performs most file system operations by calling the relevant syscalls
91 utility currently uses the
93 library to do user interaction with simple ANSI line graphics, color
94 support for which is enabled by either running on a syscons VTY or some
95 other color-capable terminal emulator (newer versions of xterm will support
100 This product is currently at the end of its life cycle and will
101 eventually be replaced.
105 utility may be either driven interactively through its various internal menus
106 or run in batch mode, driven by an external script.
108 be loaded and executed in one of 3 ways:
110 .It Sy "LOAD_CONFIG_FILE"
113 is compiled with LOAD_CONFIG_FILE set in the environment
114 (or in the Makefile) to some value, then that value will
115 be used as the filename to automatically look for and load
118 starts up and with no user interaction required.
119 This option is aimed primarily at large sites who wish to create a
120 single prototype install for multiple machines with largely identical
121 configurations and/or installation options.
125 is run interactively, that is to say in the default manner, it will
126 bring up a main menu which contains a "load config file" option.
127 Selecting this option will prompt for the name of a script file which
128 it then will attempt to load from a DOS or UFS formatted floppy.
129 .It Sy "COMMAND LINE"
130 Each command line argument is treated as a script directive
133 is run in multi-user mode.
134 Execution ends either by explicit request
137 directive), upon reaching the end of the argument list or on error.
141 /usr/sbin/sysinstall _ftpPath=ftp://ziggy/pub/ mediaSetFTP configPackages
146 for FTP installation media (using the server `ziggy') and then
147 bring up the package installation editor, exiting when finished.
150 A script is a list of one or more directives, each directive taking
162 is the assignment of some internal
164 variable, e.g.\& "ftpPass=FuNkYChiKn", and
166 is the name of an internal
168 function, e.g.\& "mediaSetFTP", and
170 is a single-line comment for documentation purposes (ignored by
172 Each directive must be by itself on a single line,
173 functions taking their arguments by examining known variable names.
174 This requires that you be sure to assign the relevant variables before
175 calling a function which requires them.
179 variable can be assigned before each directive: this will cause any error
180 detected while processing the directive itself to be ignored.
183 will automatically reset to the default "unassigned" every time a directive is
186 When and where a function depends on the settings of one or more variables
187 will be noted in the following table:
189 .Sy "Function Glossary" :
191 .Bl -tag -width indent
193 Invoke the Anonymous FTP configuration menu.
198 Select which routing daemon you wish to use, potentially
199 loading any required 3rd-party routing daemons as necessary.
202 .Bl -tag -width indent
204 can be set to the name of the desired routing daemon,
209 otherwise it is prompted for.
212 Configure host as an NFS server.
217 Configure host as a user of the Network Time Protocol.
220 .Bl -tag -width indent
224 that is to say the name of the server to sync from.
227 Configure host to support PC NFS.
230 .Bl -tag -width indent
232 The name of the PCNFSD package to load if necessary (defaults to hard coded
236 Bring up the interactive package management menu.
241 Add users and/or groups to the system.
245 .It diskPartitionEditor
246 Invokes the disk partition (MBR) editor.
249 .Bl -tag -width findx
251 The disk geometry, as a cyls/heads/sectors formatted string.
255 Set to disk partitioning type or size, its value being
257 in order to use only remaining free space for
260 to use the entire disk for
262 but maintain a proper partition
267 partition (first found),
270 .Dq dangerously dedicated
275 blocks of available free space to a new
278 Default: Interactive mode.
282 to signify the installation of a boot manager,
284 to signify installation of a "standard" non-boot MGR DOS
287 to indicate that no change to the boot manager is desired.
290 If set, bring up the interactive disk partition editor.
293 Note: Nothing is actually written to disk by this function, an explicit call to
294 .Ar diskPartitionWrite
295 being required for that to happen.
296 .It diskPartitionWrite
297 Causes any pending MBR changes (typically from the
298 .Ar diskPartitionEditor
299 function) to be written out.
304 Invokes the disk label editor.
305 This is a bit trickier from a script
306 since you need to essentially label everything inside each
308 (type 0xA5) partition created by the
309 .Ar diskPartitionEditor
310 function, and that requires knowing a few rules about how things are
312 When creating a script to automatically allocate disk space
313 and partition it up, it is suggested that you first perform the
314 installation interactively at least once and take careful notes as to
315 what the slice names will be, then and only then hardwiring them into
318 For example, let's say you have a SCSI disk on which you have created a new
320 partition in slice 2 (your DOS partition residing in slice 1).
321 The slice name would be
327 being your DOS primary
329 Now let's further assume that you have 4GB in this
330 partition and you want to sub-partition that space into root, swap,
331 var and usr file systems for
333 Your invocation of the
335 function might involve setting the following variables:
336 .Bl -tag -width findx
337 .It Li "da0s2-1=ufs 2097152 /"
338 A 1GB root file system (all sizes are in 512 byte blocks).
339 .It Li "da0s2-2=swap 1048576 /"
340 A 512MB swap partition.
341 .It Li "da0s2-3=ufs 524288 /var"
342 A 256MB /var file system.
343 .It Li "da0s2-4=ufs 0 /usr 1"
344 With the balance of free space (around 2.25GB) going to the /usr
345 file system and with soft-updates enabled (the argument following
346 the mount point, if non-zero, means to set the soft updates flag).
351 for mounting or erasing existing partitions as well as creating new
353 Using the previous example again, let's say that we also wanted
354 to mount our DOS partition and make sure that an
356 entry is created for it in the new installation.
359 function, we simply add an additional line:
364 This tells the label editor that you want to mount
367 and not to attempt to newfs it (not that
369 would attempt this for a DOS partition in any case, but it could just
370 as easily be an existing UFS partition being named here and the 2nd
371 field is non-optional).
375 variable to request that the disk label editor use an interactive dialog
376 to partition the disk instead of using variables to explicitly layout the
377 disk as described above.
379 Note: No file system data is actually written to disk until an
384 Writes out all pending disklabel information and creates and/or mounts any
385 file systems which have requests pending from the
392 Resets all selected distributions to the empty set (no distributions selected).
397 Allows the selection of a custom distribution set (e.g.\& not just one of the
398 existing "canned" sets) with no user interaction.
401 .Bl -tag -width indent
403 List of distributions to load.
404 Possible distribution values are:
405 .Bl -tag -width indentxx
407 The base binary distribution.
411 A kernel suitable for multiple processor systems.
413 Miscellaneous documentation
417 Manual pages (unformatted)
419 Pre-formatted manual pages
421 Profiled libraries for developers.
423 Dictionary information (for tools like spell).
425 GNU info files and other extra docs.
428 32-bit runtime compatibility libraries.
430 The ports collection.
434 /usr/src/[top level files]
474 X.Org client applications.
480 X.Org protocol and library documentation.
482 X.Org imake distribution.
486 X.Org nested X server.
490 X.Org virtual frame-buffer X server.
492 X.Org miscellaneous font set.
494 X.Org 75DPI font set.
496 X.Org 100DPI font set.
498 X.Org Cyrillic font set.
500 X.Org Type 1 font set.
502 X.Org TrueType font set.
506 Local additions collection.
510 Selects the standard Developer's distribution set.
514 .It distSetXDeveloper
515 Selects the standard X Developer's distribution set.
519 .It distSetKernDeveloper
520 Selects the standard kernel Developer's distribution set.
525 Selects the standard user distribution set.
530 Selects the standard X user's distribution set.
535 Selects the very minimum distribution set.
539 .It distSetEverything
540 Selects the full whack - all available distributions.
545 Interactively select source subcomponents.
550 Interactively select X.Org subcomponents.
555 Install all currently selected distributions (requires that
556 media device also be selected).
561 Install (if necessary) an HTML documentation browser and go to the
562 HTML documentation submenu.
565 .Bl -tag -width indent
567 The name of the browser package to try and install as necessary.
568 Defaults to latest links package.
570 The name of the browser binary itself (if overriding the
576 Commit any and all pending changes to disk.
578 is essentially shorthand for a number of more granular "commit"
584 Start an "express" installation, asking few questions of
590 Start a "standard" installation, the most user-friendly
591 installation type available.
596 Start an upgrade installation.
600 .It installFixitHoloShell
601 Start up the "emergency holographic shell" over on VTY4
603 This will also happen automatically
604 as part of the installation process unless
610 .It installFixitCDROM
611 Go into "fixit" mode, assuming a live file system CDROM
612 currently in the drive.
616 .It installFixitFloppy
617 Go into "fixit" mode, assuming an available fixit floppy
618 disk (user will be prompted for it).
622 .It installFilesystems
623 Do just the file system initialization part of an install.
627 .It installVarDefaults
628 Initialize all variables to their defaults, overriding any
634 Sort of like an #include statement, it allows you to load one
635 configuration file from another.
638 .Bl -tag -width indent
640 The fully qualified pathname of the file to load.
643 If a media device is set, mount it.
648 If a media device is open, close it.
655 CDROM as the installation media.
660 Select a pre-made floppy installation set as the installation media.
665 Select an existing DOS primary partition as the installation media.
666 The first primary partition found is used (e.g.\& C:).
671 Select a tape device as the installation media.
676 Select an FTP site as the installation media.
679 .Bl -tag -width indent
681 The name of the host being installed (non-optional).
683 The domain name of the host being installed (optional).
685 The default router for this host (non-optional).
687 Which host interface to use
694 If set, bring up the interactive network setup form even
695 if all relevant configuration variables are already set (optional).
697 The IP address for the selected host interface (non-optional).
699 The netmask for the selected host interface (non-optional).
701 The fully qualified URL of the FTP site containing the
703 distribution you are interested in, e.g.\&
704 .Ar ftp://ftp.FreeBSD.org/pub/FreeBSD/ .
706 .It mediaSetFTPActive
709 using "active" FTP transfer mode.
714 .It mediaSetFTPPassive
717 using "passive" FTP transfer mode.
731 .Bl -tag -width indent
733 The proxy to use (host:port) (non-optional).
736 Select an existing UFS partition (mounted with the label editor) as
737 the installation media.
740 .Bl -tag -width indent
742 full /path to directory containing the
750 .Bl -tag -width indent
752 The name of the host being installed (non-optional).
754 The domain name of the host being installed (optional).
756 The default router for this host (non-optional).
758 Which host interface to use
765 If set, bring up the interactive network setup form even
766 if all relevant configuration variables are already set (optional).
768 The IP address for the selected host interface (non-optional).
770 The netmask for the selected host interface (non-optional).
772 full hostname:/path specification for directory containing
775 distribution you are interested in.
777 .It mediaSetFTPUserPass
780 .Bl -tag -width indent
782 The username to log in as on the ftp server site.
785 The password to use for this username on the ftp
789 .It mediaSetCPIOVerbosity
792 .Bl -tag -width indent
794 Can be used to set the verbosity of cpio extractions to low, medium or
798 Interactively get the user to specify some type of media.
803 Invoke the interactive options editor.
808 Try to fetch and add a package to the system (requires
809 that a media type be set),
812 .Bl -tag -width indent
814 The name of the package to add, e.g.\& bash-1.14.7 or ncftp-2.4.2.
817 Invoke the interactive group editor.
822 Invoke the interactive user editor.
827 Stop the script, terminate sysinstall and reboot the system.
828 On the sparc64 platform, the system is halted rather than rebooted.
833 Execute an arbitrary command with
837 .Bl -tag -width indent
839 The name of the command to execute.
841 from a boot floppy, very minimal expectations should
842 be made as to what is available until/unless a relatively
843 full system installation has just been done.
846 Configure a network device.
855 .Sh DISTRIBUTION MEDIA
856 The following files can be used to affect the operation of
858 when used during initial system installation.
859 .Bl -tag -width ".Pa packages/INDEX"
861 A text file of properties, listed one per line, that describe the
862 contents of the media in use.
863 The syntax for each line is simply
864 .Dq Ar property No = Ar value .
865 Currently, only the following properties are recognized.
866 .Bl -tag -width ".Va CD_MACHINE_ARCH"
868 This property should be set to the
870 version on the current
873 .Dq Li "CD_VERSION = 5.3" .
874 .It Va CD_MACHINE_ARCH
875 This property should be set to the architecture of the contents on
877 This property is normally only used with
879 products that contain
880 CDs for different architectures, to provide better error messages if
881 users try to install Alpha packages on an i386 machine.
883 .Dq Li "CD_MACHINE_ARCH = alpha" .
885 In a multi-volume collection (such as the
889 file on each disc should contain the full package index for the set.
890 The last field of the
892 file denotes which volume the package
895 property here defines the volume ID of the current disc.
897 .It Pa packages/INDEX
898 The package index file.
899 Each package is listed on a separate line with additional meta-data
900 such as the required dependencies.
901 This index is generated by
906 When multi-volume support is enabled, an additional field should be
907 added to each line indicating which media volume contains the given
911 For information about building a full release of
916 This utility may edit the contents of
921 as necessary to reflect changes in the network configuration.
923 If you have a reasonably complete source tree online, take
925 .Pa /usr/src/usr.sbin/sysinstall/install.cfg
926 for a sample installation script.
933 .An Jordan K. Hubbard Aq jkh@FreeBSD.org
935 Editing slice and partition tables on disks which are currently mounted by
936 the system is not allowed.
937 This is generally only a problem when
939 is run on a system that is already installed.
946 This utility is a prototype which lasted several years past
947 its expiration date and is greatly in need of death.