diff options
Diffstat (limited to 'distrib/sun3')
-rw-r--r-- | distrib/sun3/common/Make.crunch | 4 | ||||
-rw-r--r-- | distrib/sun3/common/Make.static | 11 | ||||
-rw-r--r-- | distrib/sun3/common/install.sh | 524 | ||||
-rw-r--r-- | distrib/sun3/common/mini_bin.list | 5 | ||||
-rw-r--r-- | distrib/sun3/common/mini_sbin.list | 3 | ||||
-rw-r--r-- | distrib/sun3/common/mini_usr.conf | 22 | ||||
-rw-r--r-- | distrib/sun3/common/mini_usr.list | 17 | ||||
-rw-r--r-- | distrib/sun3/common/mini_xx.list | 27 | ||||
-rw-r--r-- | distrib/sun3/common/mini_xx.mk | 37 | ||||
-rw-r--r-- | distrib/sun3/common/miniroot.list | 17 | ||||
-rw-r--r-- | distrib/sun3/common/miniroot.tree | 19 | ||||
-rw-r--r-- | distrib/sun3/common/mr.profile | 26 | ||||
-rw-r--r-- | distrib/sun3/common/rd.welcome | 7 | ||||
-rw-r--r-- | distrib/sun3/common/rd_bin.conf | 15 | ||||
-rw-r--r-- | distrib/sun3/miniroot/Makefile | 56 | ||||
-rw-r--r-- | distrib/sun3/ramdisk/Makefile | 31 |
16 files changed, 558 insertions, 263 deletions
diff --git a/distrib/sun3/common/Make.crunch b/distrib/sun3/common/Make.crunch index b89e7576c2c..ffbe2f1b0ed 100644 --- a/distrib/sun3/common/Make.crunch +++ b/distrib/sun3/common/Make.crunch @@ -1,4 +1,4 @@ -# $NetBSD: Make.crunch,v 1.2 1995/10/13 16:38:20 gwr Exp $ +# $NetBSD: Make.crunch,v 1.3 1995/11/21 21:18:48 gwr Exp $ # # This is included by subdirectories building a crunched binary. # Assume the following are already defined: TOP, CBIN @@ -16,5 +16,5 @@ ${CBIN}: ${CBIN}.mk ${CBIN}.cache ${CBIN}.c strip ${CBIN} ${CBIN}.mk ${CBIN}.cache ${CBIN}.c: ${CRUNCHCONF} - crunchgen ${CRUNCHCONF} + crunchgen -D ${BSDSRCDIR} -L ${DESTDIR}/usr/lib ${CRUNCHCONF} diff --git a/distrib/sun3/common/Make.static b/distrib/sun3/common/Make.static new file mode 100644 index 00000000000..afab996c833 --- /dev/null +++ b/distrib/sun3/common/Make.static @@ -0,0 +1,11 @@ +# +# $NetBSD: Make.static,v 1.1 1995/11/21 21:18:51 gwr Exp $ +# +# This is logically appended to some other makefile, i.e. +# using: make -f Makefile -f $(OUTDIR)/Make.static ... +STRIP_CMD=strip + +${OUTDIR}/${PROG} : ${OBJS} ${LIBC} ${DPADD} + ${CC} -static ${LDFLAGS} -o ${OUTDIR}/${PROG} ${OBJS} ${LDADD} + ${STRIP_CMD} ${OUTDIR}/${PROG} + diff --git a/distrib/sun3/common/install.sh b/distrib/sun3/common/install.sh index 80233095657..3677653d777 100644 --- a/distrib/sun3/common/install.sh +++ b/distrib/sun3/common/install.sh @@ -1,5 +1,5 @@ #!/bin/sh -# $NetBSD: install.sh,v 1.2.2.1 1995/11/02 00:07:25 gwr Exp $ +# $NetBSD: install.sh,v 1.4 1995/11/21 21:18:53 gwr Exp $ # # Copyright (c) 1995 Jason R. Thorpe. # All rights reserved. @@ -35,17 +35,14 @@ # In a perfect world, this would be a nice C program, with a reasonable # user interface. -VERSION=1.0A +VERSION=1.1 +export VERSION # XXX needed in subshell ROOTDISK="" # filled in below -FILESYSTEMS="/tmp/filesystems" # used thoughout +FILESYSTEMS="/tmp/.filesystems" # used thoughout FQDN="" # domain name trap "umount /tmp > /dev/null 2>&1" 0 -# -# Functions... -# - getresp() { read resp if [ "X$resp" = "X" ]; then @@ -53,23 +50,169 @@ getresp() { fi } +isin() { +# test the first argument against the remaining ones, return succes on a match + _a=$1; shift + while [ $# != 0 ]; do + if [ "$_a" = "$1" ]; then return 0; fi + shift + done + return 1 +} + +rmel() { +# remove first argument from list formed by the remaining arguments + _a=$1; shift + while [ $# != 0 ]; do + if [ "$_a" != "$1" ]; then + echo "$1"; + fi + shift + done +} + +twiddle() { +# spin the propeller so we don't get bored + while : ; do + sleep 1; echo -n "/"; + sleep 1; echo -n "-"; + sleep 1; echo -n "\\"; + sleep 1; echo -n "|"; + done > /dev/tty & echo $! +} + +# +# machine dependent section +# + +can_read_dev() { + dd if=/dev/$1 of=/dev/null count=1 > /dev/null 2>&1 +} + +# List of all disks supported by the miniroot: +ALLDISKS="sd0 sd2 xd0 xd1 xy0 xy1" +md_get_diskdevs() { + # return available disk devices + for dev in $ALLDISKS + do + can_read_dev r${dev}c && echo $dev + done +} + +md_get_cddevs() { + # return available CD-ROM devices + for dev in cd0 cd1 + do + can_read_dev r${dev}c && echo $dev + done +} + +md_get_ifdevs() { + # return available network interfaces + for dev in le0 ie0 ie1 + do + (ifconfig $dev >/dev/null 2>&1) && echo $dev + done +} + +md_installboot() { + # $1 is the root disk + echo -n "Installing boot block..." + cd /usr/mdec + cp -p ./ufsboot /mnt/ufsboot + sync ; sleep 1 ; sync + ./installboot /mnt/ufsboot bootxx /dev/r${1}a + echo "done." +} + +md_checkfordisklabel() { + # $1 is the disk to check + disklabel $1 > /dev/null 2> /tmp/checkfordisklabel + if grep "no disk label" /tmp/checkfordisklabel; then + rval="1" + elif grep "disk label corrupted" /tmp/checkfordisklabel; then + rval="2" + else + rval="0" + fi + + rm -f /tmp/checkfordisklabel +} + +md_labeldisk() { + # $1 is the disk to label + disklabel -e $1 +} + +# Note, while they might not seem machine-dependent, the +# welcome banner and the punt message may contain information +# and/or instructions specific to the type of machine. +md_welcome_banner() { +echo " +Welcome to the NetBSD/sun3 ${VERSION} installation program. +" ; cat << \__welcome_banner_1 + +This program is designed to help you install NetBSD on your system in a +simple and rational way. You'll be asked several questions, and it will +be useful to have the installation notes and a calculator at hand. + +As with anything which modifies your disk's contents, this program can +cause SIGNIFICANT data loss, and you are advised to make sure all your +disks are backed up before beginning the installation process. + +Default answers are displyed in brackets after the questions. +You can hit Control-C at any time to quit, but if you do so at a +prompt, you may have to hit return. Also, quitting in the middle of +installation may leave your system in an inconsistent state. + +__welcome_banner_1 +} + +md_not_going_to_install() { +cat << \__not_going_to_install_1 + +OK, then. Enter 'halt' or 'reboot' at the prompt, +or proceed with manual installation commands. + +__not_going_to_install_1 +} + +md_congrats() { +cat << \__congratulations_1 + +CONGRATULATIONS! You have successfully installed NetBSD! To boot the +installed system, enter 'reboot' at the command prompt. + +__congratulations_1 +} + +# Note: I don't use the MFS hack. Just remount root instead. +md_remount() { + # Make sure root was remounted (creates /etc/fstab) + if [ ! -f /etc/fstab ] + then + # This is normally done by .profile + sh /.remount + fi +} + +# end of machine dependent section + getrootdisk() { cat << \__getrootdisk_1 -The installation program needs to know which disk to consider -the root disk. Note the unit number may be different than -the unit number you used in the standalone installation -program. +The installation program needs to know which disk will be +the root disk of the system about to be installed. Available disks are: __getrootdisk_1 - dmesg | grep "^rd" | grep "slave" - dmesg | grep "^sd" | grep "slave" + _DKDEVS=`md_get_diskdevs` + echo "$_DKDEVS" echo "" echo -n "Which disk is the root disk? " getresp "" - if dmesg | grep "^$resp " | grep "slave" > /dev/null ; then + if isin $resp $_DKDEVS ; then ROOTDISK="$resp" else echo "" @@ -78,39 +221,23 @@ __getrootdisk_1 fi } -checkfordisklabel() { - disklabel -r $1 > /dev/null 2> /tmp/checkfordisklabel - if grep "no disk label" /tmp/checkfordisklabel; then - rval="1" - elif grep "disk label corrupted" /tmp/checkfordisklabel; then - rval="2" - else - rval="0" - fi - - rm -f /tmp/checkfordisklabel -} - labelmoredisks() { cat << \__labelmoredisks_1 You may label the following disks: __labelmoredisks_1 - dmesg | grep "^rd" | grep "slave" | grep -v "${ROOTDISK} " - dmesg | grep "^sd" | grep "slave" | grep -v "${ROOTDISK} " + echo "$_DKDEVS" echo "" echo -n "Label which disk? [done] " getresp "done" case "$resp" in - done) + "done") ;; *) - if dmesg | grep "^$resp " | grep "slave" \ - > /dev/null ; then - # XXX CODE ME - echo "Yup, it exists." + if echo "$_DKDEVS" | grep "^$resp" > /dev/null ; then + md_labeldisk $resp else echo "" echo "The disk $resp does not exist." @@ -123,19 +250,13 @@ addhostent() { # $1 - IP address # $2 - symbolic name - # Create an entry in the hosts table. If no host table - # exists, create one. If the IP address already exists, - # replace it's entry. - if [ ! -f /tmp/hosts ]; then - echo "127.0.0.1 localhost" > /tmp/hosts - fi + # Create an entry in the hosts table. + # If the IP address already exists, replace it. + grep -v "^$1 " /etc/hosts > /tmp/hosts + echo "$1 $2 $2.$FQDN" >> /tmp/hosts - if grep "^$1 " /tmp/hosts > /dev/null; then - grep -v "^$1 " /tmp/hosts > /tmp/hosts.new - mv /tmp/hosts.new /tmp/hosts - fi - - echo "$1 $2 $2.$FQDN" >> /tmp/hosts + # Use it now. + cp /tmp/hosts /etc/hosts } addifconfig() { @@ -157,7 +278,8 @@ You may configure the following network interfaces: __configurenetwork_1 - dmesg | grep "^le" | grep "ipl" + _IFS=`md_get_ifdevs` + echo $_IFS echo "" echo -n "Configure which interface? [done] " getresp "done" @@ -166,10 +288,12 @@ __configurenetwork_1 ;; *) - if dmesg | grep "^$resp " | grep "^le" | grep "ipl" \ - > /dev/null ; then + if isin $resp $_IFS ; then _interface_name=$resp + # Keep in the list in case it's misconfigured + # and the user want's to re-do it. + # Get IP address resp="" # force one iteration while [ "X${resp}" = X"" ]; do @@ -181,7 +305,7 @@ __configurenetwork_1 # Get symbolic name resp="" # force one iteration while [ "X${resp}" = X"" ]; do - echo -n "Symbolic name? " + echo -n "Symbolic (host) name? " getresp "" _interface_symname=$resp done @@ -283,7 +407,7 @@ __install_ftp_2 fi _ftp_file=`echo ${resp} | awk '{print $1}'` - echo "get ${_ftp_file} |\"tar -zxvpf -\"" >> \ + echo "get ${_ftp_file} |\"tar --unlink -zxvpf -\"" >> \ /tmp/ftp-script.sh done @@ -314,7 +438,7 @@ install_common_nfs_cdrom() { fi # Extract file - cat $_common_filename | (cd /mnt; tar -zxvpf -) + cat $_common_filename | (cd /mnt; tar --unlink -zxvpf -) echo "Extraction complete." } @@ -322,11 +446,12 @@ install_cdrom() { # Get the cdrom device info cat << \__install_cdrom_1 -The following SCSI disk or disk-like devices are installed on your system; -please select the CD-ROM device containing the installation media: +The following CD-ROM devices are installed on your system; please select +the CD-ROM device containing the installation media: __install_cdrom_1 - dmesg | grep "^sd" | grep "rev" + _CDDEVS=`md_get_cddevs` + echo "$_CDDEVS" echo "" echo -n "Which is the CD-ROM with the installation media? [abort] " getresp "abort" @@ -337,8 +462,7 @@ __install_cdrom_1 ;; *) - if dmesg | grep "^$resp " | grep "slave" \ - > /dev/null ; then + if isin $resp $_CDDEVS ; then _cdrom_drive=$resp else echo "" @@ -534,14 +658,14 @@ __install_tape_2 1) ( cd /mnt - dd if=$TAPE | tar -zxvpf - + dd if=$TAPE | tar --unlink -zxvpf - ) ;; 2) ( cd /mnt - tar -zxvpf $TAPE + dd if=$TAPE | tar --unlink -xvpf - ) ;; @@ -554,37 +678,38 @@ __install_tape_2 echo "Extraction complete." } +get_timezone() { +cat << \__get_timezone_1 + +Select a time zone: + +__get_timezone_1 + ls /mnt/usr/share/zoneinfo # XXX + echo "" + if [ X"$TZ" = "X" ]; then + TZ=`ls -l /etc/timezone 2>/dev/null | awk -F/ '{print $NF}'` + fi + echo -n "What timezone are you in [$TZ]? " + getresp "$TZ" + case "$resp" in + "") + echo "Timezone defaults to GMT" + TZ="GMT" + ;; + *) + TZ="$resp" + ;; + esac + export TZ +} + # # End of functions. # Begin working # -echo "" -echo "Welcome to the NetBSD ${VERSION} installation program." -cat << \__welcome_banner_1 - -This program is designed to help you put NetBSD on your hard disk, -in a simple and rational way. You'll be asked several questions, -and it would probably be useful to have your disk's hardware -manual, the installation notes, and a calculator handy. - -In particular, you will need to know some reasonably detailed -information about your disk's geometry. This program can determine -some limited information about certain specific types of HP-IB disks. -If you have SCSI disks, however, prior knowledge of disk geometry -is absolutely essential. - -As with anything which modifies your hard disk's contents, this -program can cause SIGNIFICANT data loss, and you are advised -to make sure your hard drive is backed up before beginning the -installation process. - -Default answers are displyed in brackets after the questions. -You can hit Control-C at any time to quit, but if you do so at a -prompt, you may have to hit return. Also, quitting in the middle of -installation may leave your system in an inconsistent state. - -__welcome_banner_1 +# Good {morning,afternoon,evening,night}. +md_welcome_banner echo -n "Proceed with installation? [n] " getresp "n" case "$resp" in @@ -592,27 +717,13 @@ case "$resp" in echo "Cool! Let's get to it..." ;; *) - cat << \__welcome_banner_2 - -OK, then. Enter 'halt' at the prompt to halt the machine. Once the -machine has halted, power-cycle the system to load new boot code. - -__welcome_banner_2 + md_not_going_to_install exit ;; esac -# Make sure root was remounted (creates /etc/fstab) -if [ ! -f /etc/fstab ] -then - echo "Need to remount root read/write first." - exit 1 -fi - -# Install the shadowed disktab file; lets us write to it for temporary -# purposes without mounting the miniroot read-write. -# XXX: I just go ahead and remount root. -gwr -# XXX: cp /etc/disktab.shadow /tmp/disktab.shadow +# Make our root read/write (or at least parts of it). +md_remount while [ "X${ROOTDISK}" = "X" ]; do getrootdisk @@ -620,13 +731,13 @@ done # Make sure there's a disklabel there. If there isn't, puke after # disklabel prints the error message. -checkfordisklabel ${ROOTDISK} -case $rval in +md_checkfordisklabel ${ROOTDISK} +case "$resp" in 1) cat << \__disklabel_not_present_1 FATAL ERROR: There is no disklabel present on the root disk! You must -label the disk with SYS_INST before continuing. +label the disk using the RAMDISK kernel before continuing. __disklabel_not_present_1 exit @@ -636,7 +747,7 @@ __disklabel_not_present_1 cat << \__disklabel_corrupted_1 FATAL ERROR: The disklabel on the root disk is corrupted! You must -re-label the disk with SYS_INST before continuing. +re-label the disk using the RAMDISK kernel before continuing. __disklabel_corrupted_1 exit @@ -660,7 +771,6 @@ echo -n "Do you wish to edit the root disklabel? [y] " getresp "y" case "$resp" in y*|Y*) - disklabel -W ${ROOTDISK} disklabel -e ${ROOTDISK} ;; @@ -674,6 +784,7 @@ You will now be given the opportunity to place disklabels on any additional disks on your system. __disklabel_notice_2 +_DKDEVS=`rmel ${ROOTDISK} ${_DKDEVS}` resp="X" # force at least one iteration while [ "X$resp" != X"done" ]; do labelmoredisks @@ -686,7 +797,7 @@ cat << \__get_filesystems_1 You will now have the opportunity to enter filesystem information. You will be prompted for device name and mount point (full path, -including the prepending '/' character). +including the leading '/' character). Note that these do not have to be in any particular order. You will be given the opportunity to edit the resulting 'fstab' file before @@ -750,14 +861,19 @@ case "$resp" in esac # Loop though the file, place filesystems on each device. -echo "Creating filesystems..." -( - while read line; do - _device_name=`echo $line | awk '{print $1}'` - newfs /dev/r${_device_name} - echo "" - done -) < ${FILESYSTEMS} +while read dev mnt +do + echo -n "Create filesystem on $dev? [y] " + getresp "n" < /dev/tty + case "$resp" in + y*|Y*) + newfs /dev/r${dev} + ;; + *) + echo "skipped $dev" + ;; + esac +done < ${FILESYSTEMS} # Get network configuration information, and store it for placement in the # root filesystem later. @@ -804,10 +920,30 @@ case "$resp" in fi fi + echo -n "Enter IP address of primary nameserver: [none] " + getresp "none" + if [ "X${resp}" != X"none" ]; then + echo "domain $FQDN" > /tmp/resolv.conf + echo "nameserver $resp" >> /tmp/resolv.conf + echo "search $FQDN" >> /tmp/resolv.conf + + echo -n "Would you like to use the nameserver now? [y] " + getresp "y" + case "$resp" in + y*|Y*) + cp /tmp/resolv.conf \ + /etc/resolv.conf + ;; + + *) + ;; + esac + fi + echo "" echo "The host table is as follows:" echo "" - cat /tmp/hosts + cat /etc/hosts echo "" echo "You may want to edit the host table in the event that" echo "you need to mount an NFS server." @@ -815,7 +951,7 @@ case "$resp" in getresp "n" case "$resp" in y*|Y*) - vi /tmp/hosts + vi /etc/hosts ;; *) @@ -885,38 +1021,36 @@ case "$resp" in ;; esac -# Now that the 'real' fstab is configured, we munge it into a 'shadow' -# fstab which we'll use for mounting and unmounting all of the target -# filesystems relative to /mnt. Mount all filesystems. +# Now that the 'real' fstab is configured, create a temporary fstab +# which we'll use for mounting and unmounting all of the target +# filesystems relative to /mnt. Save the original (our root). +[ -f /etc/fstab.save ] || cp /etc/fstab /etc/fstab.save +cp /etc/fstab.save /etc/fstab awk '{ if ($2 == "/") printf("%s /mnt %s %s %s %s\n", $1, $3, $4, $5, $6) else printf("%s /mnt%s %s %s %s %s\n", $1, $2, $3, $4, $5, $6) -}' < /tmp/fstab > /tmp/fstab.shadow +}' < /tmp/fstab >> /etc/fstab echo "" # Must mount filesystems manually, one at a time, so we can make sure the # mount points exist. ( - while read line; do - _dev=`echo $line | awk '{print $1}'` - _mp=`echo $line | awk '{print $2}'` - _fstype=`echo $line | awk '{print $3}'` - _opt=`echo $line | awk '{print $4}'` - + while read _dev _mp _fstype _opt junk + do # If not the root filesystem, make sure the mount # point is present. - if [ "X{$_mp}" != X"/mnt" ]; then + if [ "X${_mp}" != X"/mnt" ]; then mkdir -p $_mp fi # Mount the filesystem. If the mount fails, exit # with an error condition to tell the outer - # later to bail. + # layer to bail. if ! mount -v -t $_fstype -o $_opt $_dev $_mp ; then - # error message displated by mount + # error message displayed by mount exit 1 fi done @@ -935,37 +1069,71 @@ fi # Ask the user which media to load the distribution from. cat << \__install_sets_1 -It is now time to extract the installation sets onto the hard disk. -Make sure The sets are either on a local device (i.e. tape, CD-ROM) or on a -network server. +It is now time to extract the installation sets onto the disk. +Make sure The sets are either on a local device (i.e. tape, CD-ROM) +or on a network server. __install_sets_1 -resp="" # force at least one iteration -while [ "X${resp}" = X"" ]; do - echo -n "Install from (f)tp, (t)ape, (C)D-ROM, or (N)FS? [f] " - getresp "f" +if [ -f /base.tar.gz ]; then + echo -n "Install from sets in the current root filesystem? [y] " + getresp "y" case "$resp" in - f*|F*) - install_ftp + y*|Y*) + for _f in /*.tar.gz; do + echo -n "Install $_f ? [y]" + getresp "y" + case "$resp" in + y*|Y*) + cat $_f | (cd /mnt; tar --unlink -zxvpf -) + _yup="TRUE" + ;; + *) + ;; + esac + echo "Extraction complete." + done ;; - - t*|T*) - install_tape + *) + _yup="FALSE" ;; + esac +else + _yup="FALSE" +fi - c*|C*) - install_cdrom - ;; +# Go on prodding for alternate locations +resp="" # force at least one iteration +while [ "X${resp}" = X"" ]; do + # If _yup is not FALSE, it means that we extracted sets above. + # If that's the case, bypass the menu the first time. + if [ X"$_yup" = X"FALSE" ]; then + echo -n "Install from (f)tp, (t)ape, (C)D-ROM, or (N)FS? [f] " + getresp "f" + case "$resp" in + f*|F*) + install_ftp + ;; - n*|N*) - install_nfs - ;; + t*|T*) + install_tape + ;; - *) - echo "Invalid response: $resp" - resp="" - ;; - esac + c*|C*) + install_cdrom + ;; + + n*|N*) + install_nfs + ;; + + *) + echo "Invalid response: $resp" + resp="" + ;; + esac + else + _yup="FALSE" # So we'll ask next time + fi # Give the user the opportunity to extract more sets. They don't # necessarily have to come from the same media. @@ -983,43 +1151,55 @@ while [ "X${resp}" = X"" ]; do esac done +# Get timezone info +get_timezone + # Copy in configuration information and make devices in target root. ( cd /tmp - for file in fstab hostname.* hosts myname mygate; do + cp /etc/hosts hosts + for file in fstab hostname.* hosts myname mygate resolv.conf; do if [ -f $file ]; then - echo "Copying $file..." + echo -n "Copying $file..." cp $file /mnt/etc/$file + echo "done." fi done + echo -n "Installing timezone link..." + rm -f /mnt/etc/localtime + ln -s /usr/share/zoneinfo/$TZ /mnt/etc/localtime + echo "done." + echo -n "Making devices..." + pid=`twiddle` cd /mnt/dev sh MAKEDEV all + kill $pid echo "done." - echo "Copying kernel..." + echo -n "Copying kernel..." cp /netbsd /mnt/netbsd + echo "done." + + md_installboot ${ROOTDISK} ) # Unmount all filesystems and check their integrity. -umount -a -echo "Checking filesystem integrity..." -fsck -pf +echo -n "Syncing disks..." +pid=`twiddle` +sync; sleep 4; sync; sleep 2; sync; sleep 2 +kill $pid +echo "done." -# Install boot code on target disk. -echo "Installing boot block..." -disklabel -W ${ROOTDISK} -disklabel -B ${ROOTDISK} +echo "Unmounting filesystems..." +umount -va -cat << \__congratulations_1 - -CONGRATULATIONS! You have successfully installed NetBSD on your hard disk! -To boot the installed system, enter halt at the command prompt. Once the -system has halted, power-cycle the machine in order to load new boot code. -Make sure you boot from the disk. +echo "Checking filesystem integrity..." +fsck -pf -__congratulations_1 +# Pat on the back. +md_congrats # ALL DONE! -exit +exit 0 diff --git a/distrib/sun3/common/mini_bin.list b/distrib/sun3/common/mini_bin.list index 0d10ae1d43b..a234f07665d 100644 --- a/distrib/sun3/common/mini_bin.list +++ b/distrib/sun3/common/mini_bin.list @@ -1,5 +1,5 @@ # -# $NetBSD: mini_bin.list,v 1.1.1.1 1995/10/08 23:07:48 gwr Exp $ +# $NetBSD: mini_bin.list,v 1.2 1995/11/21 21:18:56 gwr Exp $ # # miniroot files from /bin: @@ -10,13 +10,13 @@ COPY ${DESTDIR}/bin/cat bin COPY ${DESTDIR}/bin/chmod bin COPY ${DESTDIR}/bin/cp bin -# COPY ${DESTDIR}/bin/csh bin COPY ${DESTDIR}/bin/date bin COPY ${DESTDIR}/bin/dd bin COPY ${DESTDIR}/bin/df bin COPY ${DESTDIR}/bin/echo bin COPY ${DESTDIR}/bin/ed bin COPY ${DESTDIR}/bin/expr bin +COPY ${DESTDIR}/bin/hostname bin COPY ${DESTDIR}/bin/kill bin COPY ${DESTDIR}/bin/ln bin COPY ${DESTDIR}/bin/ls bin @@ -31,6 +31,7 @@ COPY ${DESTDIR}/bin/rm bin COPY ${DESTDIR}/bin/rmdir bin COPY ${DESTDIR}/bin/sh bin +COPY ${DESTDIR}/bin/sleep bin COPY ${DESTDIR}/bin/stty bin COPY ${DESTDIR}/bin/sync bin diff --git a/distrib/sun3/common/mini_sbin.list b/distrib/sun3/common/mini_sbin.list index 9325fa7ef0a..53b768169ab 100644 --- a/distrib/sun3/common/mini_sbin.list +++ b/distrib/sun3/common/mini_sbin.list @@ -1,5 +1,5 @@ # -# $NetBSD: mini_sbin.list,v 1.1.1.1 1995/10/08 23:07:50 gwr Exp $ +# $NetBSD: mini_sbin.list,v 1.2 1995/11/21 21:18:57 gwr Exp $ # # XXX - Need these? ping, @@ -21,6 +21,7 @@ COPY ${DESTDIR}/sbin/mount_cd9660 sbin COPY ${DESTDIR}/sbin/mount_ffs sbin LINK sbin/mount_ffs sbin/mount_ufs +COPY ${DESTDIR}/sbin/mount_kernfs sbin COPY ${DESTDIR}/sbin/mount_nfs sbin COPY ${DESTDIR}/sbin/newfs sbin COPY ${DESTDIR}/sbin/ping sbin diff --git a/distrib/sun3/common/mini_usr.conf b/distrib/sun3/common/mini_usr.conf index 46223f0608c..330de168a4e 100644 --- a/distrib/sun3/common/mini_usr.conf +++ b/distrib/sun3/common/mini_usr.conf @@ -1,5 +1,5 @@ # -# $NetBSD: mini_usr.conf,v 1.1.1.1 1995/10/08 23:07:50 gwr Exp $ +# $NetBSD: mini_usr.conf,v 1.2 1995/11/21 21:18:59 gwr Exp $ # # common/mini_usr.conf # @@ -9,17 +9,19 @@ # A few related ones are thrown in to save space: # chgrp, rcp # +# Many others were kept separate, somewhat arbitrarily, +# but mostly things that are somewhat large, or that are +# normally used separately, or have weird make rules... -srcdirs /usr/src/bin /usr/src/sbin /usr/src/usr.bin /usr/src/usr.sbin +srcdirs bin +progs rcp -progs chown chroot cksum cmp eeprom ftp more printf -progs rcp rsh sed strings tftp tip update +srcdirs usr.sbin +progs bad144 chown chroot eeprom rdate update -ln chown chgrp +srcdirs usr.bin +progs basename chflags cksum cmp cut ftp +progs rsh sed strings tftp -# These are linked -static so they are not needed here. -# srcdirs /usr/src/gnu/usr.bin -# progs gzip, tar -# ln gzip gzcat gunzip +ln chown chgrp -libs -ltermcap diff --git a/distrib/sun3/common/mini_usr.list b/distrib/sun3/common/mini_usr.list index 268a18569bf..a05b8a6fadb 100644 --- a/distrib/sun3/common/mini_usr.list +++ b/distrib/sun3/common/mini_usr.list @@ -1,5 +1,5 @@ # -# $NetBSD: mini_usr.list,v 1.1.1.1 1995/10/08 23:07:46 gwr Exp $ +# $NetBSD: mini_usr.list,v 1.2 1995/11/21 21:19:00 gwr Exp $ # # copy the crunched binary, link to it, and kill it @@ -12,31 +12,26 @@ LINK mini_usr bin/rcp # usr/sbin: +LINK mini_usr usr/sbin/bad144 LINK mini_usr usr/sbin/chown LINK mini_usr usr/sbin/chroot LINK mini_usr usr/sbin/eeprom +LINK mini_usr usr/sbin/rdate LINK mini_usr usr/sbin/update # usr/bin: +LINK mini_usr usr/bin/basename +LINK mini_usr usr/bin/chflags LINK mini_usr usr/bin/chgrp LINK mini_usr usr/bin/cksum LINK mini_usr usr/bin/cmp +LINK mini_usr usr/bin/cut LINK mini_usr usr/bin/ftp -LINK mini_usr usr/bin/more -LINK mini_usr usr/bin/printf LINK mini_usr usr/bin/rsh LINK mini_usr usr/bin/sed LINK mini_usr usr/bin/strings LINK mini_usr usr/bin/tftp -LINK mini_usr usr/bin/tip SPECIAL rm mini_usr -# These are linked statically, so just copy from ${DESTDIR}: - -COPY ${DESTDIR}/usr/bin/tar usr/bin -COPY ${DESTDIR}/usr/bin/gzip usr/bin -LINK usr/bin/gzip usr/bin/gunzip -LINK usr/bin/gzip usr/bin/gzcat - diff --git a/distrib/sun3/common/mini_xx.list b/distrib/sun3/common/mini_xx.list new file mode 100644 index 00000000000..1b00ab69307 --- /dev/null +++ b/distrib/sun3/common/mini_xx.list @@ -0,0 +1,27 @@ +# +# $NetBSD: mini_xx.list,v 1.1 1995/11/21 21:19:01 gwr Exp $ +# Build -static versions of some programs. +# + +# These were re-linked with -static locally: + +COPY ${OBJDIR}/awk usr/bin + +COPY ${OBJDIR}/grep usr/bin +LINK usr/bin/grep usr/bin/egrep +LINK usr/bin/grep usr/bin/fgrep + +COPY ${OBJDIR}/more usr/bin + +COPY ${OBJDIR}/tip usr/bin + +COPY ${OBJDIR}/vi usr/bin + +# These are normally -static so just copy: + +COPY ${DESTDIR}/usr/bin/tar usr/bin + +COPY ${DESTDIR}/usr/bin/gzip usr/bin +LINK usr/bin/gzip usr/bin/gunzip +LINK usr/bin/gzip usr/bin/gzcat + diff --git a/distrib/sun3/common/mini_xx.mk b/distrib/sun3/common/mini_xx.mk new file mode 100644 index 00000000000..d3d2b12c739 --- /dev/null +++ b/distrib/sun3/common/mini_xx.mk @@ -0,0 +1,37 @@ +# +# $NetBSD: mini_xx.mk,v 1.1 1995/11/21 21:19:04 gwr Exp $ +# Hacks for re-linking some programs -static +# + +MINI_XX = awk grep more tip vi +mini_xx : ${MINI_XX} + +clean_xx: + -rm -f mini_xx ${MINI_XX} + +awk : FORCE + cd ${BSDSRCDIR}/gnu/usr.bin/gawk ;\ + $(MAKE) -f Makefile -f ${TOP}/common/Make.static \ + OUTDIR=${.CURDIR} ${.CURDIR}/awk + +grep : FORCE + cd ${BSDSRCDIR}/gnu/usr.bin/grep ;\ + $(MAKE) -f Makefile -f ${TOP}/common/Make.static \ + OUTDIR=${.CURDIR} ${.CURDIR}/grep + +more : FORCE + cd ${BSDSRCDIR}/usr.bin/more ;\ + $(MAKE) -f Makefile -f ${TOP}/common/Make.static \ + OUTDIR=${.CURDIR} ${.CURDIR}/more + +tip : FORCE + cd ${BSDSRCDIR}/usr.bin/tip ;\ + $(MAKE) -f Makefile -f ${TOP}/common/Make.static \ + OUTDIR=${.CURDIR} ${.CURDIR}/tip + +vi : FORCE + cd ${BSDSRCDIR}/usr.bin/vi/common ;\ + $(MAKE) -f Makefile -f ${TOP}/common/Make.static \ + OUTDIR=${.CURDIR} ${.CURDIR}/vi + +FORCE: diff --git a/distrib/sun3/common/miniroot.list b/distrib/sun3/common/miniroot.list index 008b928a31f..31648f8c2ca 100644 --- a/distrib/sun3/common/miniroot.list +++ b/distrib/sun3/common/miniroot.list @@ -1,16 +1,21 @@ -# $NetBSD: miniroot.list,v 1.1.1.1 1995/10/08 23:07:48 gwr Exp $ +# $NetBSD: miniroot.list,v 1.2 1995/11/21 21:19:05 gwr Exp $ + +# These are scripts: +COPY ${DESTDIR}/usr/bin/false bin +COPY ${DESTDIR}/usr/bin/true bin # From usr/mdec: COPY ${DESTDIR}/usr/mdec/bootxx usr/mdec COPY ${DESTDIR}/usr/mdec/installboot usr/mdec COPY ${DESTDIR}/usr/mdec/netboot usr/mdec +COPY ${DESTDIR}/usr/mdec/tapeboot usr/mdec COPY ${DESTDIR}/usr/mdec/ufsboot usr/mdec LINK usr/mdec/ufsboot ufsboot -# XXX - How to do installboot? # various files that we need in /etc for the install COPY ${DESTDIR}/etc/disktab etc COPY ${DESTDIR}/etc/group etc +COPY ${DESTDIR}/etc/hosts etc COPY ${DESTDIR}/etc/master.passwd etc COPY ${DESTDIR}/etc/passwd etc COPY ${DESTDIR}/etc/protocols etc @@ -24,15 +29,9 @@ SPECIAL cd dev; sh MAKEDEV std rd0 sd0 sd2 st0 SPECIAL /bin/rm dev/MAKEDEV SPECIAL mkfifo dev/pipe -# and the common installation tools -COPY ${TOPDIR}/common/dot.cmnutils .cmnutils - -# the disktab explanation file (XXX need this?) -# COPY ${TOPDIR}/common/mr.disktab etc/disktab.preinstall - # and the miniroot installation tools -COPY ${TOPDIR}/common/mr.instutils .instutils COPY ${TOPDIR}/common/mr.profile .profile +COPY ${TOPDIR}/common/mr.remount .remount COPY ${TOPDIR}/common/mr.termcap usr/share/misc/termcap # and the "install" command diff --git a/distrib/sun3/common/miniroot.tree b/distrib/sun3/common/miniroot.tree index 9e66a282636..cedeac867ab 100644 --- a/distrib/sun3/common/miniroot.tree +++ b/distrib/sun3/common/miniroot.tree @@ -1,5 +1,5 @@ # -# $NetBSD: miniroot.tree,v 1.1.1.1 1995/10/08 23:07:47 gwr Exp $ +# $NetBSD: miniroot.tree,v 1.2 1995/11/21 21:19:07 gwr Exp $ # /set type=dir uname=root gname=wheel mode=0755 @@ -72,3 +72,20 @@ misc # ./usr .. + +# ./var +var + +# ./var/tmp +tmp mode=01777 + +# ./var/tmp/vi.recover +vi.recover mode=01777 +# ./var/tmp/vi.recover +.. + +# ./var/tmp +.. + +# ./var +.. diff --git a/distrib/sun3/common/mr.profile b/distrib/sun3/common/mr.profile index 8aa3bafd9cc..52b23f6a79c 100644 --- a/distrib/sun3/common/mr.profile +++ b/distrib/sun3/common/mr.profile @@ -1,6 +1,7 @@ # -# $NetBSD: mr.profile,v 1.1.1.1 1995/10/08 23:07:47 gwr Exp $ +# $NetBSD: mr.profile,v 1.2 1995/11/21 21:19:08 gwr Exp $ # +# Copyright (c) 1995 Jason R. Thorpe # Copyright (c) 1994 Christopher G. Demetriou # All rights reserved. # @@ -35,18 +36,23 @@ export PATH TERM=ansi export TERM +umask 022 + # set up some sane defaults -echo 'erase ^?, werase ^H, kill ^U, intr ^C' -stty newcrt werase '^H' intr '^C' kill '^U' erase '^?' -echo '' +echo intr '^C' kill '^U' erase '^?' werase '^W' newcrt +stty intr '^C' kill '^U' erase '^?' werase '^W' newcrt -# start running update, so that installed software is written as it goes. +# run update, so that installed software is written as it goes. update -# pull in the function definitions that people will use from the shell prompt. -. /.cmnutils -. /.instutils +# get the terminal type? +# (nah, ansi is good enough) + +# remount root +sh /.remount # run the installation script. -umask 022 -install +echo 'To install NetBSD, enter the command: install' +echo 'Otherwise, enter the command: halt' +# /install XXX - Not yet... + diff --git a/distrib/sun3/common/rd.welcome b/distrib/sun3/common/rd.welcome index b0600385aa5..9c1cf8fa3b2 100644 --- a/distrib/sun3/common/rd.welcome +++ b/distrib/sun3/common/rd.welcome @@ -12,13 +12,12 @@ the source of the miniroot image to be on any of these: The easiest is loading from tape, which is done as follows: mt -f /dev/nrst0 rewind - mt -f /dev/nrst0 fsf 1 - dd bs=16k if=/dev/nrst0 of=/dev/rsd0b + mt -f /dev/nrst0 fsf 2 + dd bs=32k if=/dev/nrst0 of=/dev/rsd0b (For help with other methods, please see the install notes.) To reboot using the swap partition, first use "halt", then at the PROM monitor prompt use a command like: - b sd(0,0,1)netbsd -s - ^-- 1 selects the swap partition + b sd(,,1) -s To view this message again, type: cat /.welcome diff --git a/distrib/sun3/common/rd_bin.conf b/distrib/sun3/common/rd_bin.conf index fa40e778c99..1c86ed05741 100644 --- a/distrib/sun3/common/rd_bin.conf +++ b/distrib/sun3/common/rd_bin.conf @@ -1,5 +1,5 @@ # -# $NetBSD: rd_bin.conf,v 1.1.1.1 1995/10/08 23:07:47 gwr Exp $ +# $NetBSD: rd_bin.conf,v 1.2 1995/11/21 21:19:10 gwr Exp $ # # common/rd_bin.conf - unified binary for the ramdisk. # @@ -46,8 +46,7 @@ # Here are all the programs, ordered by source location: # Special programs used to save space... -#srcdirs /usr/src/distrib/utils -srcdirs ../../utils +srcdirs distrib/utils progs init_s ssh tls ln init_s init oinit ln ssh sh @@ -59,7 +58,7 @@ progs x_dd x_ifconfig ln x_dd dd ln x_ifconfig ifconfig -srcdirs /usr/src/sbin +srcdirs sbin progs edlabel mknod mount progs mount_cd9660 mount_ffs mount_nfs progs reboot umount @@ -68,15 +67,15 @@ ln mount_nfs nfs ln mount_cd9660 cd9660 ln reboot halt -srcdirs /usr/src/bin +srcdirs bin progs cat echo ln mkdir mt mv pwd sync -srcdirs /usr/src/usr.bin +srcdirs usr.bin progs rsh tftp -# srcdirs /usr/src/usr.sbin +# srcdirs usr.sbin -# srcdirs /usr/src/gnu/usr.bin +# srcdirs gnu/usr.bin # progs cpio, gzip, tar # ln gzip gzcat gunzip diff --git a/distrib/sun3/miniroot/Makefile b/distrib/sun3/miniroot/Makefile index b3defc8ae66..9e22b7ca78c 100644 --- a/distrib/sun3/miniroot/Makefile +++ b/distrib/sun3/miniroot/Makefile @@ -1,4 +1,4 @@ -# $NetBSD: Makefile,v 1.2 1995/10/13 16:46:47 gwr Exp $ +# $NetBSD: Makefile,v 1.3 1995/11/21 21:19:12 gwr Exp $ TOP= ${.CURDIR}/.. @@ -13,45 +13,57 @@ TREE= ${TOP}/common/${IMAGE}.tree LISTS= ${TOP}/common/mini_sbin.list \ ${TOP}/common/mini_bin.list \ ${TOP}/common/${CBIN}.list \ + ${TOP}/common/mini_xx.list \ ${TOP}/common/${IMAGE}.list -MOUNT_POINT= /mnt -DISKTYPE= miniroot -BDEV= /dev/sd2b -CDEV= /dev/rsd2b - KERNEL=${SRCSYSDIR}/arch/sun3/compile/GENERIC/netbsd -# These are all the parameters for the miniroot: (6MB) -NBLKS= 12288 -# old format, minfree, opt, b/i trks, sects, cpg +MOUNT_POINT= /mnt +#BDEV= /dev/sd2b +#CDEV= /dev/rsd2b +BDEV= /dev/sd0d +CDEV= /dev/rsd0d + +# These are all the parameters for the miniroot: (8MB) +DISKTYPE= miniroot +NBLKS= 16384 +# old format, minfree, opt, b/i trks, sects, cpg NEWFSARGS= -O -m 0 -o space -i 8192 -t 8 -u 32 -c 16 -${IMAGE}.fs: ${CBIN} do_mount do_files do_bootxx do_kernel do_umount - dd if=${CDEV} of=$@ bs=64b count=`expr ${NBLKS} / 64` +CLEANFILES= ${IMAGE}.gz -# Only do these for the miniroot, not the ramdisk. -do_bootxx: +${IMAGE}.gz: ${TREE} ${LISTS} ${CBIN} mini_xx + -newfs ${NEWFSARGS} -s ${NBLKS} ${CDEV} ${DISKTYPE} + mount ${BDEV} ${MOUNT_POINT} + mtree -def ${TREE} -p ${MOUNT_POINT}/ -u + TOPDIR=${TOP} CURDIR=${.CURDIR} \ + OBJDIR=${.OBJDIR} TARGDIR=${MOUNT_POINT} \ + sh ${TOP}/common/RunList.sh ${LISTS} sync ; sleep 1 ; sync cd ${MOUNT_POINT} ;\ usr/mdec/installboot -v ufsboot usr/mdec/bootxx ${CDEV} - -# Copy the generic kernel -do_kernel: - cp -p ${KERNEL} ${MOUNT_POINT}/netbsd + cp ${KERNEL} ${MOUNT_POINT}/netbsd + sync + @echo "" + @df -i ${MOUNT_POINT} + @echo "" + -umount ${MOUNT_POINT} + dd if=${CDEV} bs=16b count=`expr ${NBLKS} / 16` |\ + gzip > ${IMAGE}.tmp + -mv -f ${IMAGE}.tmp ${IMAGE}.gz # Do not delete this if I change my mind and kill make... -.PRECIOUS: ${IMAGE}.fs - -# Rules used making ${IMAGE}.fs (do_*) -.include "${TOP}/common/Make.fsimage" +.PRECIOUS: ${IMAGE}.gz # Rules for making ${CBIN} ... .include "${TOP}/common/Make.crunch" -clean cleandir: +clean cleandir: clean_xx -rm -f a.out core *.core *.o -rm -f ${CLEANFILES} # Standard rules needed by the above... .include <bsd.obj.mk> + +# Hacks for re-linking some program -static +.include "${TOP}/common/mini_xx.mk" diff --git a/distrib/sun3/ramdisk/Makefile b/distrib/sun3/ramdisk/Makefile index 0a7294833bb..278e1c30042 100644 --- a/distrib/sun3/ramdisk/Makefile +++ b/distrib/sun3/ramdisk/Makefile @@ -1,4 +1,4 @@ -# $NetBSD: Makefile,v 1.2 1995/10/13 16:51:30 gwr Exp $ +# $NetBSD: Makefile,v 1.3 1995/11/21 21:19:14 gwr Exp $ TOP= ${.CURDIR}/.. @@ -13,19 +13,19 @@ TREE= ${TOP}/common/${IMAGE}.tree LISTS= ${TOP}/common/${CBIN}.list \ ${TOP}/common/${IMAGE}.list +KERNEL=${SRCSYSDIR}/arch/sun3/compile/RAMDISK/netbsd + MOUNT_POINT= /mnt -DISKTYPE= rdroot BDEV= /dev/rd0 -CDEV?= /dev/rd0 - -KERNEL=${SRCSYSDIR}/arch/sun3/compile/RAMDISK/netbsd +CDEV= /dev/rd0 # These are all the parameters for the root fs: (256K) +DISKTYPE= rdroot NBLKS= 512 -# args: old fmt, minfree, opt, b/i trks, sects, cpg +# old format, minfree, opt, b/i trks, sects, cpg NEWFSARGS= -O -m 0 -o space -i 2048 -t 2 -u 16 -c 16 -CLEANFILES= netbsd-rd rdsetroot +CLEANFILES= netbsd-rd rdsetroot ${IMAGE}.fs netbsd-rd : rdsetroot ${IMAGE}.fs cp ${KERNEL} netbsd-tmp @@ -35,18 +35,27 @@ netbsd-rd : rdsetroot ${IMAGE}.fs rdsetroot: ${TOP}/common/rdsetroot.c $(CC) -o $@ -DDEBUG ${TOP}/common/rdsetroot.c -${IMAGE}.fs: ${CBIN} do_mount do_files do_umount +${IMAGE}.fs: ${TREE} ${LISTS} ${CBIN} + -newfs ${NEWFSARGS} -s ${NBLKS} ${CDEV} ${DISKTYPE} + mount ${BDEV} ${MOUNT_POINT} + mtree -def ${TREE} -p ${MOUNT_POINT}/ -u + TOPDIR=${TOP} CURDIR=${.CURDIR} \ + OBJDIR=${.OBJDIR} TARGDIR=${MOUNT_POINT} \ + sh ${TOP}/common/RunList.sh ${LISTS} + sync + @echo "" + @df -i ${MOUNT_POINT} + @echo "" + -umount ${MOUNT_POINT} dd if=${CDEV} of=$@ count=${NBLKS} # Do not delete this if I change my mind and kill make... .PRECIOUS: ${IMAGE}.fs -# Rules used making ${IMAGE}.fs (do_*) -.include "${TOP}/common/Make.fsimage" - # Rules for making ${CBIN} ... .include "${TOP}/common/Make.crunch" +# This is listed in rd_bin.conf but is built here. ${CBIN} : libhack.o # Use stubs to eliminate some large stuff from libc |