#!/bin/rc # this file is run if service=cpu date > /env/boottime for(i in m i P S t u '$') bind -a '#'^$i /dev >/dev/null >[2=1] mount -qb /srv/cons /dev # mount points mntgen -s slashn && chmod 666 /srv/slashn mntgen -s slashmnt /mnt && chmod 666 /srv/slashmnt mntgen -s mntexport /mnt/exportfs && chmod 666 /srv/mntexport # move factotum from /mnt to /mnt/factotum mount /srv/factotum /mnt/temp unmount /srv/factotum /mnt bind /mnt/temp/factotum /mnt/factotum unmount /mnt/temp # usb listener nusbrc # name translation, cs sets /dev/sysname ndb/cs sysname=`{cat /dev/sysname} # site-specific startup if(test -e /rc/bin/cpurc.local) . /rc/bin/cpurc.local if (~ $#sysname 0 || ~ $sysname ''){ sysname=cirno # default echo -n $sysname >/dev/sysname } prompt=($sysname^'# ' ' ') # parallelism for mk NPROC=`{wc -l [2]/dev/null || ip/ipconfig -h $sysname } rm -f /env/ether } } if(! test -e /net/dns) ndb/dns -r if(! ps|grep -s timesync){ if(~ $#ntp 0) . <{ndb/ipquery sys $sysname ntp | sed 's, +,\n,g'} if(~ $#ntp 0) ntp=pool.ntp.org aux/timesync -n $ntp sleep 2 } myip=`{cat /net/ipselftab} myip=$myip(13) if(~ $#auth 0){ auth=`{ndb/query sys $sysname auth} . <{ndb/ipquery sys $sysname auth | sed 's, +,\n,g'} } switch($auth){ case `{ echo $sysname; ndb/query sys $sysname dom if(test -r /net/ipselftab){ for(i in `{awk '/u\ *$/{print $1}' /net/ipselftab}){ echo $i; ndb/ipquery ip $i dom; ndb/ipquery ip $i sys } | sed 's,[^ ]+=,,g'}} # cpu+auth server auth/keyfs -wp -m /mnt/keys /adm/keys srv $registry registry mount /srv/registry /mnt/registry gridlisten -q -t /rc/bin/service tcp gridlisten -q -t /rc/bin/service.auth tcp case * # cpu server srv $registry registry mount /srv/registry /mnt/registry gridlisten -q -t /rc/bin/service tcp } if(test -f /dev/apm) aux/apm if(test -e /cfg/$sysname/cpustart) . /cfg/$sysname/cpustart