diff --git a/GNUmakefile.in b/GNUmakefile.in index d8edf261a5eb86c4f5744b17fc0e08a7da688a4f..3d367cdec6e0f159f3c35bbfc37c9170db69e484 100644 --- a/GNUmakefile.in +++ b/GNUmakefile.in @@ -298,6 +298,18 @@ frisbee-mfs-nostatic-install: destdircheck frisbee-mfs-nostatic @$(MAKE) -C os frisbee-mfs-install @$(MAKE) -C clientside frisbee-mfs-install +newnode-mfs: mfsoscheck + @$(MAKE) -C clientside newnode-mfs + +newnode-mfs-nostatic: mfsoscheck + @NOSTATIC=1 $(MAKE) -C clientside newnode-mfs + +newnode-mfs-install: destdircheck newnode-mfs client-mkdirs + @$(MAKE) -C clientside newnode-mfs-install + +newnode-mfs-nostatic-install: destdircheck newnode-mfs-nostatic client-mkdirs + @$(MAKE) -C clientside newnode-mfs-install + cdboot: mfsoscheck client @echo "CD/Dongle files built" diff --git a/clientside/GNUmakefile.in b/clientside/GNUmakefile.in index d351f5c4b5706ff3c10e871a7ae079148284ee1a..447332a42024c08b85122c0ebf4f07d689660e94 100644 --- a/clientside/GNUmakefile.in +++ b/clientside/GNUmakefile.in @@ -37,6 +37,8 @@ mfs: mfs-subdirs mfs-install: client-mkdirs mfs-install-subdirs frisbee-mfs: frisbee-mfs-subdirs frisbee-mfs-install: client-mkdirs frisbee-mfs-install-subdirs +newnode-mfs: newnode-mfs-subdirs +newnode-mfs-install: client-mkdirs newnode-mfs-install-subdirs TARBALLDESTDIR = /var/tmp/emulab-client client-tarball: diff --git a/clientside/event/GNUmakefile.in b/clientside/event/GNUmakefile.in index 1b3fa7f236af657afeec19d5032bb4c31b5a1f01..d1652e64b3d8a6051e7cca8cb8fc74fd2b9df336 100644 --- a/clientside/event/GNUmakefile.in +++ b/clientside/event/GNUmakefile.in @@ -51,6 +51,8 @@ mfs: mfs-install: frisbee-mfs: frisbee-mfs-install: +newnode-mfs: +newnode-mfs-install: # How to recursively descend into subdirectories to make general # targets such as `all'. diff --git a/clientside/lib/GNUmakefile.in b/clientside/lib/GNUmakefile.in index cda12ad07016f0072fef57a46e012cf6efb75271..65376f9ab27bdd32bb2d933f1fcccaf2153fa9fa 100644 --- a/clientside/lib/GNUmakefile.in +++ b/clientside/lib/GNUmakefile.in @@ -1,6 +1,6 @@ # # EMULAB-COPYRIGHT -# Copyright (c) 2000-2011 University of Utah and the Flux Group. +# Copyright (c) 2000-2012 University of Utah and the Flux Group. # All rights reserved. # SRCDIR = @srcdir@ @@ -29,6 +29,8 @@ mfs: mfs-install: frisbee-mfs: frisbee-mfs-install: +newnode-mfs: +newnode-mfs-install: # How to recursively descend into subdirectories to make general # targets such as `all'. diff --git a/clientside/os/GNUmakefile.in b/clientside/os/GNUmakefile.in index 8df81fce8e71c20ef2f1e023cc66d89a54f6f3c0..0da73d237dbc749d05890eb26e5a9a10bd76d681 100644 --- a/clientside/os/GNUmakefile.in +++ b/clientside/os/GNUmakefile.in @@ -102,6 +102,9 @@ mfs-install: CLIENT_BINDIR=/usr/local/bin $(MAKE) -e -C growdisk client-install CLIENT_BINDIR=/usr/local/bin $(MAKE) -e -C frisbee.redux client-install +newnode-mfs: mfs +newnode-mfs-install: mfs-install + cdboot-install: mfs-install subdir-distclean: diff --git a/clientside/sensors/GNUmakefile.in b/clientside/sensors/GNUmakefile.in index f7cc47037359d5268b6b2013467d2d5f953b79c6..7c2aa94712cf890ea943a08f066350f56f72a8ca 100644 --- a/clientside/sensors/GNUmakefile.in +++ b/clientside/sensors/GNUmakefile.in @@ -1,6 +1,6 @@ # # EMULAB-COPYRIGHT -# Copyright (c) 2000-2011 University of Utah and the Flux Group. +# Copyright (c) 2000-2012 University of Utah and the Flux Group. # All rights reserved. # SRCDIR = @srcdir@ @@ -36,6 +36,8 @@ mfs: client mfs-install: client-install frisbee-mfs: frisbee-mfs-install: +newnode-mfs: +newnode-mfs-install: # How to recursively descend into subdirectories to make general # targets such as `all'. diff --git a/clientside/tmcc/GNUmakefile.in b/clientside/tmcc/GNUmakefile.in index fe953e7349f3c0aeecf7c7c4216aff0664a256b8..59916a0cd39b0937b61402b839759b4ffa0ae3f9 100644 --- a/clientside/tmcc/GNUmakefile.in +++ b/clientside/tmcc/GNUmakefile.in @@ -156,6 +156,11 @@ frisbee-mfs: client frisbee-mfs-install: frisbee-mfs @$(MAKE) -C $(MDSUBDIR) frisbee-mfs-install +newnode-mfs: client + +newnode-mfs-install: newnode-mfs + @$(MAKE) -C $(MDSUBDIR) newnode-mfs-install + # # XXX argh! assumes FreeBSD inner boss # diff --git a/clientside/tmcc/freebsd6/GNUmakefile.in b/clientside/tmcc/freebsd6/GNUmakefile.in index d3352b5d6225c25e47ddb60c820fcb0802ab3a1c..04e13f56fd1293d75be694978ab5505671903071 100644 --- a/clientside/tmcc/freebsd6/GNUmakefile.in +++ b/clientside/tmcc/freebsd6/GNUmakefile.in @@ -1,6 +1,6 @@ # # EMULAB-COPYRIGHT -# Copyright (c) 2000-2011 University of Utah and the Flux Group. +# Copyright (c) 2000-2012 University of Utah and the Flux Group. # All rights reserved. # @@ -37,6 +37,16 @@ RCDIR = $(DESTDIR)/usr/local/etc/rc.d ISMFS = $(ETCDIR)/ismfs INSTALL = /usr/bin/install -c +destdircheck: + @if [ -z "$(DESTDIR)" ]; then \ + echo "You must define DESTDIR for this target!"; \ + false; \ + fi + @if [ "$(DESTDIR)" = "/" ]; then \ + echo "DESTDIR is '/', really really bad idea!"; \ + false; \ + fi + install client-install: bincheck basefbsd-install etc-install \ sup-install script-install bin-install @@ -103,18 +113,38 @@ script-install: dir-install # * We still use rc.conf.d/dhclient right now # (til we switch to 6.x rc.d files) # -frisbee-mfs-install: +frisbee-mfs-install: destdircheck $(INSTALL) -m 755 -o root -g wheel -d $(DESTDIR)/usr/local/etc (cd ../freebsd5; $(MAKE) all frisbee-mfs-install) rm -f $(SYSETCDIR)/testbed/dhclient rm -f $(DESTDIR)/usr/local/etc/dhclient* ln -s /etc/dhclient* $(DESTDIR)/usr/local/etc/ + @if [ -r $(SRCDIR)/master.passwd ]; then \ + $(INSTALL) -m 600 $(SRCDIR)/master.passwd $(SYSETCDIR); \ + pwd_mkdb -d $(SYSETCDIR) $(SYSETCDIR)/master.passwd; \ + fi + @if [ -r $(SRCDIR)/group ]; then \ + $(INSTALL) -m 644 $(SRCDIR)/group $(SYSETCDIR); \ + fi -mfs-install: +mfs-install: destdircheck (cd ../freebsd5; $(MAKE) all mfs-install) + rm -rf $(JAILDIR) rm -f $(SYSETCDIR)/testbed/dhclient rm -f $(DESTDIR)/usr/local/etc/dhclient* ln -s /etc/dhclient* $(DESTDIR)/usr/local/etc/ + @if [ -r $(SRCDIR)/master.passwd ]; then \ + $(INSTALL) -m 600 $(SRCDIR)/master.passwd $(SYSETCDIR); \ + pwd_mkdb -d $(SYSETCDIR) $(SYSETCDIR)/master.passwd; \ + fi + @if [ -r $(SRCDIR)/group ]; then \ + $(INSTALL) -m 644 $(SRCDIR)/group $(SYSETCDIR); \ + fi + +newnode-mfs-install: mfs-install + (cd ../../../tools/teachswitch; $(MAKE) DESTDIR=$(DESTDIR) client-install) + $(INSTALL) -m 755 $(SRCDIR)/../../../install/newclient $(BINDIR)/newclient + $(INSTALL) -m 755 $(SRCDIR)/mfs-newnode-testbed.sh $(RCDIR)/testbed.sh # # CD/Flash install DOES have the FreeBSD 6 stuff diff --git a/clientside/tmcc/freebsd6/master.passwd b/clientside/tmcc/freebsd6/master.passwd index ee6735265a66a671b1ca5ff2efd4a236818fd8eb..2a7c297bd359c1599b1d897128a1ed5f3402271e 100644 --- a/clientside/tmcc/freebsd6/master.passwd +++ b/clientside/tmcc/freebsd6/master.passwd @@ -1,7 +1,7 @@ # $FreeBSD: src/etc/master.passwd,v 1.40 2005/06/06 20:19:56 brooks Exp $ # -root:kEi.I6fTKyJDg:0:0::0:0:Charlie &:/root:/bin/csh -toor:kEi.I6fTKyJDg:0:0::0:0:Chaplin &:/root:/bin/csh +root:$1$0DKicYf8$PsfF3uhmTrtuaJKH/rxtQ/:0:0::0:0:Charlie &:/root:/bin/csh +toor:*:0:0::0:0:Chaplin &:/root:/bin/csh daemon:*:1:1::0:0:Owner of many system processes:/root:/usr/sbin/nologin operator:*:2:5::0:0:System &:/:/usr/sbin/nologin bin:*:3:7::0:0:Binaries Commands and Source:/:/usr/sbin/nologin diff --git a/clientside/tmcc/freebsd6/mfs-newnode-testbed.sh b/clientside/tmcc/freebsd6/mfs-newnode-testbed.sh new file mode 100755 index 0000000000000000000000000000000000000000..15be66a97a41b9cf038fc2311e27f221c1bb4f10 --- /dev/null +++ b/clientside/tmcc/freebsd6/mfs-newnode-testbed.sh @@ -0,0 +1,42 @@ +#!/bin/sh +# +# Copyright (c) 2000-2004, 2007 University of Utah and the Flux Group. +# All rights reserved. +# This file is part of the Emulab network testbed software. +# +# Emulab is free software, also known as "open source;" you can +# redistribute it and/or modify it under the terms of the GNU Affero +# General Public License as published by the Free Software Foundation, +# either version 3 of the License, or (at your option) any later version. +# +# Emulab is distributed in the hope that it will be useful, but WITHOUT ANY +# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS +# FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for +# more details, which can be found in the file AGPL-COPYING at the root of +# the source tree. +# +# You should have received a copy of the GNU Affero General Public License +# along with this program. If not, see <http://www.gnu.org/licenses/>. +# +# PROVIDE: testbed +# + +. /etc/emulab/paths.sh + +# +# Boottime initialization. +# +case "$1" in +start|faststart) + echo "" + $BINDIR/newclient + ;; +stop) + # Foreground mode. + ;; +*) + echo "Usage: `basename $0` {start|stop}" >&2 + ;; +esac + +exit 0 diff --git a/clientside/tmcc/freebsd7/GNUmakefile.in b/clientside/tmcc/freebsd7/GNUmakefile.in index ef4c545eed76a8d932b85995040171200caec706..e4999f64d7bb8c4e967acf7169446139b223db23 100644 --- a/clientside/tmcc/freebsd7/GNUmakefile.in +++ b/clientside/tmcc/freebsd7/GNUmakefile.in @@ -118,9 +118,12 @@ script-install: dir-install # frisbee-mfs-install: destdircheck (cd ../freebsd5; $(MAKE) all frisbee-mfs-install) + rm -rf $(SYSETCDIR)/rc.conf.d rm -f $(SYSETCDIR)/testbed/dhclient rm -f $(DESTDIR)/usr/local/etc/dhclient* ln -s /etc/dhclient* $(DESTDIR)/usr/local/etc/ + rmdir $(DESTDIR)/usr/local/etc/emulab + $(INSTALL) -m 644 $(SRCDIR)/mfs-frisbee-rc.conf $(SYSETCDIR)/rc.conf @if [ -r $(SRCDIR)/master.passwd ]; then \ $(INSTALL) -m 600 $(SRCDIR)/master.passwd $(SYSETCDIR); \ pwd_mkdb -d $(SYSETCDIR) $(SYSETCDIR)/master.passwd; \ @@ -129,11 +132,15 @@ frisbee-mfs-install: destdircheck $(INSTALL) -m 644 $(SRCDIR)/group $(SYSETCDIR); \ fi -mfs-install: +mfs-install: destdircheck (cd ../freebsd5; $(MAKE) all mfs-install) + rm -rf $(JAILDIR) + rm -rf $(SYSETCDIR)/rc.conf.d + rm -rf $(DESTDIR)/root/.cvsup rm -f $(SYSETCDIR)/testbed/dhclient rm -f $(DESTDIR)/usr/local/etc/dhclient* ln -s /etc/dhclient* $(DESTDIR)/usr/local/etc/ + $(INSTALL) -m 644 $(SRCDIR)/mfs-rc.conf $(SYSETCDIR)/rc.conf @if [ -r $(SRCDIR)/master.passwd ]; then \ $(INSTALL) -m 600 $(SRCDIR)/master.passwd $(SYSETCDIR); \ pwd_mkdb -d $(SYSETCDIR) $(SYSETCDIR)/master.passwd; \ @@ -141,3 +148,8 @@ mfs-install: @if [ -r $(SRCDIR)/group ]; then \ $(INSTALL) -m 644 $(SRCDIR)/group $(SYSETCDIR); \ fi + +newnode-mfs-install: mfs-install + (cd ../../../tools/teachswitch; $(MAKE) DESTDIR=$(DESTDIR) client-install) + $(INSTALL) -m 755 $(SRCDIR)/../../../install/newclient $(BINDIR)/newclient + $(INSTALL) -m 755 $(SRCDIR)/mfs-newnode-testbed.sh $(RCDIR)/testbed.sh diff --git a/clientside/tmcc/freebsd7/mfs-frisbee-rc.conf b/clientside/tmcc/freebsd7/mfs-frisbee-rc.conf new file mode 100644 index 0000000000000000000000000000000000000000..f243389ac5cfea703bac289a94066030db08b19e --- /dev/null +++ b/clientside/tmcc/freebsd7/mfs-frisbee-rc.conf @@ -0,0 +1,49 @@ +# Common to both MFSes +sendmail_enable="NONE" +inetd_enable="NO" +ldconfig_paths="" +ldconfig_paths_aout="" +blanktime="NO" +update_motd="NO" +background_fsck="NO" +rc_info="YES" + +# turn on syslogd for debugging +syslogd_enable="NO" + +autoboot="no" +varmfs="NO" +ip6addrctl_enable="NO" +moused_nondefault_enable="NO" +cleanvar_enable="NO" +clear_tmp_X="NO" +virecover_enable="NO" +newsyslog_enable="NO" +gptboot_enable="NO" + +# Specific to frisbee MFS +cron_enable="NO" +devd_enable="NO" + +# +# FreeBSD has no way to say "DHCP on all available interfaces" without +# spelling out here what all those interfaces are. So here we just say +# to (statically) configure the loopback device. The real network +# interfaces are identified in rc.conf.d/dhclient for use by the +# rc.d/dhclient script. +# +network_interfaces="lo0" + +# +# Argh! dhclient in FreeBSD 5 has a new auto-background "feature", +# it dives into the background after 10 seconds regardless of whether +# it has received a response. This is fubar for us. Unfortunately, +# we cannot just crank this number through the roof because it is based +# on a polling interval which actually has a rational purpose. The timeout +# is actually (2 * polling_interval) where polling_interval is how often +# dhclient rechecks an interface without link. We need to keep this value +# reasonable in the event that we boot up and don't immediately have link +# on the control net. So lets try 15 seconds (30 second auto-background +# timeout) and see how things go. +# +dhclient_flags="-i 15" diff --git a/clientside/tmcc/freebsd7/mfs-newnode-testbed.sh b/clientside/tmcc/freebsd7/mfs-newnode-testbed.sh new file mode 100644 index 0000000000000000000000000000000000000000..be34f385c1d452f034f1d4a3667109a22616f511 --- /dev/null +++ b/clientside/tmcc/freebsd7/mfs-newnode-testbed.sh @@ -0,0 +1,29 @@ +#!/bin/sh +# +# EMULAB-COPYRIGHT +# Copyright (c) 2000-2012 University of Utah and the Flux Group. +# All rights reserved. +# +# PROVIDE: testbed +# REQUIRE: sshd +# + +. /etc/emulab/paths.sh + +# +# Boottime initialization. +# +case "$1" in +start|faststart) + echo "" + $BINDIR/newclient + ;; +stop) + # Foreground mode. + ;; +*) + echo "Usage: `basename $0` {start|stop}" >&2 + ;; +esac + +exit 0 diff --git a/clientside/tmcc/freebsd7/mfs-rc.conf b/clientside/tmcc/freebsd7/mfs-rc.conf new file mode 100644 index 0000000000000000000000000000000000000000..8e6f7c273454154e2086efda1ceca4168231c657 --- /dev/null +++ b/clientside/tmcc/freebsd7/mfs-rc.conf @@ -0,0 +1,52 @@ +# Common to both MFSes +sendmail_enable="NONE" +inetd_enable="NO" +ldconfig_paths="" +ldconfig_paths_aout="" +blanktime="NO" +update_motd="NO" +background_fsck="NO" +rc_info="YES" + +# turn on syslogd for debugging +syslogd_enable="NO" + +autoboot="no" +varmfs="NO" +ip6addrctl_enable="NO" +moused_nondefault_enable="NO" +cleanvar_enable="NO" +clear_tmp_X="NO" +virecover_enable="NO" +newsyslog_enable="NO" +gptboot_enable="NO" + +# Specific to admin MFS +sshd_enable="YES" +cron_enable="YES" +ntpdate_enable="YES" +ntpdate_flags="boss" +nfs_client_enable="YES" + +# +# FreeBSD has no way to say "DHCP on all available interfaces" without +# spelling out here what all those interfaces are. So here we just say +# to (statically) configure the loopback device. The real network +# interfaces are identified in rc.conf.d/dhclient for use by the +# rc.d/dhclient script. +# +network_interfaces="lo0" + +# +# Argh! dhclient in FreeBSD 5 has a new auto-background "feature", +# it dives into the background after 10 seconds regardless of whether +# it has received a response. This is fubar for us. Unfortunately, +# we cannot just crank this number through the roof because it is based +# on a polling interval which actually has a rational purpose. The timeout +# is actually (2 * polling_interval) where polling_interval is how often +# dhclient rechecks an interface without link. We need to keep this value +# reasonable in the event that we boot up and don't immediately have link +# on the control net. So lets try 15 seconds (30 second auto-background +# timeout) and see how things go. +# +dhclient_flags="-i 15" diff --git a/clientside/tools/GNUmakefile.in b/clientside/tools/GNUmakefile.in index bb6b2a015a664eeb49ae23fbcdaab7f2ac658fa3..c24d667530d327436219493c13928dcaf4772901 100644 --- a/clientside/tools/GNUmakefile.in +++ b/clientside/tools/GNUmakefile.in @@ -1,6 +1,6 @@ # # EMULAB-COPYRIGHT -# Copyright (c) 2000-2011 University of Utah and the Flux Group. +# Copyright (c) 2000-2012 University of Utah and the Flux Group. # All rights reserved. # SRCDIR = @srcdir@ @@ -35,6 +35,8 @@ mfs: mfs-install: frisbee-mfs: frisbee-mfs-install: +newnode-mfs: +newnode-mfs-install: # How to recursively descend into subdirectories to make general # targets such as `all'.