#!/bin/rc # cpu server start up date > /env/boottime # mount points mntgen -s slashn && chmod 666 /srv/slashn # name translation, cs sets /dev/sysname ndb/cs sysname=`{cat /dev/sysname} # parallelism for mk NPROC = `{wc -l /dev/sysname } prompt=($sysname^'# ' ' ') # cpu-specific startup if(test -e /cfg/$sysname/cpurc) . /cfg/$sysname/cpurc # start up internet if we don't already have an address if(! grep u /net/ipselftab | grep -sv 127.0.0.1) ip/ipconfig if(! grep -s 127.0.0.1 /net/ipselftab) ip/ipconfig loopback /dev/null 127.1 # if we're not a server, start a dns resolver if(! test -e /srv/dns) ndb/dns -r # If you are on an auth server, start these before listening: # # auth/keyfs -wp -m /mnt/keys /adm/keys >/dev/null >[2=1] auth/cron >>/sys/log/cron >[2=1] & # keep other bootes processes from creating capabilities rm -f '#ยค/caphash' # also rename some files on an auth server: # # if(! test -e /rc/bin/service.auth/tcp567){ # mv /rc/bin/service.auth/authsrv.il566 /rc/bin/service.auth/il566 # mv /rc/bin/service.auth/authsrv.tcp567 /rc/bin/service.auth/tcp567 # mv /rc/bin/service/il566 /rc/bin/service/_il566 # mv /rc/bin/service/tcp567 /rc/bin/service/_tcp567 # } # start listeners if it hasn't already been done (dicey check) if(! netstat -n | grep -s 'tcp.*Listen.* (7|9|21|113|565|17007|17009|17010) .*') aux/listen -q tcp if(! ps|grep -s timesync) { aux/timesync -n pool.ntp.org if (test -e '#r/rtc') @ { sleep 10 # let timesync correct the time field 1 /dev/time >'#r/rtc' # fix hw clock } & } # cpu-specific late startup if(test -e /cfg/$sysname/cpustart) . /cfg/$sysname/cpustart # mode of /proc/*/ctl is inherited across rfork, and sets modes on # other /proc files, such as note, so let listen be killed. #dontkill '^(ipconfig|factotum|mntgen|venti|fossil|cs|dns|reboot)$' #aux/listen1 -t -v tcp!*!1522 /bin/rc -m /rc/lib/rcmain -i & echo 'key proto=p9sk1 dom=harvey user=harvey !password=harvey' >/mnt/factotum/ctl aux/listen1 -t tcp!*!6666 /bin/cpu -R & # echo `{date} $sysname >>/sys/log/boot exit ''