From 976133e4f53de66653eb2d71f5dd7ab534ba8f5e Mon Sep 17 00:00:00 2001
From: Mike Hibler <mike@flux.utah.edu>
Date: Thu, 24 Jun 2004 06:24:21 +0000
Subject: [PATCH] Improve the client-side install.  With these changes, it
 should now be possible to:

	gmake client
	sudo gmake client-install

on a FBSD4, FBSD5, RHL7.3, and RHL9.0 client node.

There are still some dependencies that are not explicit and which would
prevent a build/install from working on a "clean" OS.  Two that I know of are:
you must install our version of the elvin libraries and you must install boost.
---
 GNUmakefile.in                     | 11 ++++-
 configure                          |  5 +-
 configure.in                       |  7 +--
 event/GNUmakefile.in               | 12 +----
 event/delay-agent/GNUmakefile.in   |  3 +-
 event/example/GNUmakefile.in       |  4 ++
 event/lib/GNUmakefile.in           | 25 ++++++++--
 event/link-agent/GNUmakefile.in    |  6 +--
 event/linktest/GNUmakefile.in      | 32 ++++++-------
 event/nsetrafgen/GNUmakefile.in    |  9 +++-
 event/program-agent/GNUmakefile.in |  6 +--
 event/proxy/GNUmakefile.in         |  3 +-
 event/sched/GNUmakefile.in         |  6 ++-
 event/stated/GNUmakefile.in        |  6 ++-
 event/tbgen/GNUmakefile.in         |  8 ++--
 event/trafgen/GNUmakefile.in       |  5 +-
 lib/libtb/GNUmakefile.in           |  1 +
 os/GNUmakefile.in                  | 13 +++++-
 os/dijkstra/GNUmakefile.in         |  3 +-
 os/genhostsfile/GNUmakefile.in     |  5 +-
 os/growdisk/GNUmakefile.in         |  3 +-
 os/imagezip/GNUmakefile.in         |  3 +-
 os/syncd/GNUmakefile.in            | 15 +++---
 sensors/GNUmakefile.in             |  7 ++-
 sensors/slothd/GNUmakefile.in      |  2 +-
 tmcd/GNUmakefile.in                | 17 +++++--
 tmcd/common/GNUmakefile.in         |  2 +-
 tmcd/freebsd/GNUmakefile.in        |  2 +-
 tmcd/freebsd/prepare               | 19 ++++++++
 tmcd/freebsd5/GNUmakefile.in       | 23 +++++++++-
 tmcd/linux/GNUmakefile.in          | 10 +++-
 tmcd/linux/prepare                 |  2 +-
 tmcd/linux9/GNUmakefile.in         | 74 ++++++++++++++++++++++++++++++
 tmcd/linux9/supfile.in             |  4 ++
 tmcd/openbsd/GNUmakefile.in        |  4 +-
 tmcd/plab/GNUmakefile.in           |  2 +-
 tmcd/ron/GNUmakefile.in            |  3 +-
 37 files changed, 274 insertions(+), 88 deletions(-)
 create mode 100644 tmcd/linux9/GNUmakefile.in
 create mode 100644 tmcd/linux9/supfile.in

diff --git a/GNUmakefile.in b/GNUmakefile.in
index a31f2786d0..1ee1d96b7a 100644
--- a/GNUmakefile.in
+++ b/GNUmakefile.in
@@ -91,8 +91,17 @@ tipserv-install:
 	@$(MAKE) -C capture tipserv-install
 	@$(MAKE) -C tbsetup tipserv-install
 
-client-install:
+client-mkdirs:
+	-mkdir -p $(DESTDIR)$(CLIENT_BINDIR)
+
+client:
 	@$(MAKE) -C lib/libtb client
+	@$(MAKE) -C event client
+	@$(MAKE) -C os client
+	@$(MAKE) -C sensors client
+	@$(MAKE) -C tmcd client
+
+client-install: client client-mkdirs
 	@$(MAKE) -C event client-install
 	@$(MAKE) -C os client-install
 	@$(MAKE) -C sensors client-install
diff --git a/configure b/configure
index 74cd298755..74eb457018 100755
--- a/configure
+++ b/configure
@@ -1462,8 +1462,9 @@ outfiles="$outfiles Makeconf GNUmakefile \
 	tmcd/freebsd/supfile tmcd/freebsd/sethostname \
 	tmcd/linux/GNUmakefile tmcd/linux/supfile tmcd/linux/pump.conf \
 	tmcd/linux/sethostname tmcd/linux/sethostname.dhclient \
-	tmcd/freebsd5/GNUmakefile tmcd/openbsd/GNUmakefile \
-	tmcd/ron/GNUmakefile tmcd/plab/GNUmakefile \
+	tmcd/linux9/GNUmakefile tmcd/linux9/supfile \
+	tmcd/freebsd5/GNUmakefile tmcd/freebsd5/supfile \
+	tmcd/openbsd/GNUmakefile tmcd/ron/GNUmakefile tmcd/plab/GNUmakefile \
 	utils/GNUmakefile utils/vlandiff utils/vlansync utils/delay_config \
 	utils/sshtb utils/create_image utils/node_admin utils/webcreateimage \
 	utils/firstuser utils/export_tables utils/eventping \
diff --git a/configure.in b/configure.in
index 5ed407f681..ad134a9588 100755
--- a/configure.in
+++ b/configure.in
@@ -441,7 +441,7 @@ outfiles="$outfiles Makeconf GNUmakefile \
 	os/GNUmakefile os/split-image.sh os/imagezip/GNUmakefile \
 	os/imagezip/ffs/GNUmakefile os/imagezip/extfs/GNUmakefile \
 	os/frisbee.redux/GNUmakefile os/growdisk/GNUmakefile \
-        os/syncd/GNUmakefile  os/dijkstra/GNUmakefile \
+        os/syncd/GNUmakefile os/dijkstra/GNUmakefile \
 	os/genhostsfile/GNUmakefile \
 	pxe/GNUmakefile pxe/bootinfo.restart \
 	security/GNUmakefile security/paperbag security/lastlog_daemon \
@@ -507,8 +507,9 @@ outfiles="$outfiles Makeconf GNUmakefile \
 	tmcd/freebsd/supfile tmcd/freebsd/sethostname \
 	tmcd/linux/GNUmakefile tmcd/linux/supfile tmcd/linux/pump.conf \
 	tmcd/linux/sethostname tmcd/linux/sethostname.dhclient \
-	tmcd/freebsd5/GNUmakefile tmcd/openbsd/GNUmakefile \
-	tmcd/ron/GNUmakefile tmcd/plab/GNUmakefile \
+	tmcd/linux9/GNUmakefile tmcd/linux9/supfile \
+	tmcd/freebsd5/GNUmakefile tmcd/freebsd5/supfile \
+	tmcd/openbsd/GNUmakefile tmcd/ron/GNUmakefile tmcd/plab/GNUmakefile \
 	utils/GNUmakefile utils/vlandiff utils/vlansync utils/delay_config \
 	utils/sshtb utils/create_image utils/node_admin utils/webcreateimage \
 	utils/firstuser utils/export_tables utils/eventping \
diff --git a/event/GNUmakefile.in b/event/GNUmakefile.in
index b65dec05b6..92615e76d9 100644
--- a/event/GNUmakefile.in
+++ b/event/GNUmakefile.in
@@ -36,16 +36,8 @@ install:
 	@$(MAKE) -C stated install
 	@$(MAKE) -C linktest install
 
-client-install: lib/all.MAKE
-ifeq ($(SYSTEM),FreeBSD)
-	@$(MAKE) -C delay-agent client-install
-endif
-	@$(MAKE) -C link-agent client-install
-	@$(MAKE) -C tbgen client-install
-	@$(MAKE) -C program-agent client-install
-	@$(MAKE) -C trafgen client-install
-	@$(MAKE) -C proxy client-install
-	@$(MAKE) -C linktest client-install
+client:		client-subdirs
+client-install: client client-install-subdirs
 
 control-install: 
 	@$(MAKE) -C lib control-install
diff --git a/event/delay-agent/GNUmakefile.in b/event/delay-agent/GNUmakefile.in
index c76be05581..270f4e9f6d 100644
--- a/event/delay-agent/GNUmakefile.in
+++ b/event/delay-agent/GNUmakefile.in
@@ -32,7 +32,8 @@ delay-agent:	$(OBJS)
 
 $(OBJS):	main.h ../lib/libevent.a
 
-client-install: delay-agent
+client: delay-agent
+client-install: client
 	$(INSTALL_PROGRAM) -s delay-agent $(DESTDIR)$(CLIENT_BINDIR)/delay-agent
 
 clean:
diff --git a/event/example/GNUmakefile.in b/event/example/GNUmakefile.in
index b705dc4a1d..f692c7ddd9 100644
--- a/event/example/GNUmakefile.in
+++ b/event/example/GNUmakefile.in
@@ -34,5 +34,9 @@ $(PROGRAMS):	../lib/libevent.a ../lib/event.h
 
 install:	$(addprefix $(INSTALL_SBINDIR)/, eventdebug.pl)
 
+# not a client thing
+client:
+client-install: client
+
 clean:
 	/bin/rm -f *.o $(PROGRAMS)
diff --git a/event/lib/GNUmakefile.in b/event/lib/GNUmakefile.in
index b684005332..f80760e3a1 100644
--- a/event/lib/GNUmakefile.in
+++ b/event/lib/GNUmakefile.in
@@ -12,10 +12,13 @@ SUBDIR		= event/lib
 include $(OBJDIR)/Makeconf
 
 SYSTEM	       := $(shell uname -s)
-PROGRAMS	= libevent.a
+LIBS		= libevent.a
+SWIGLIBS        =
 ifneq ($(SYSTEM),Linux)
-PROGRAMS       += libevent_r.a event.so _tbevent.so
+LIBS           += libevent_r.a
+SWIGLIBS       += event.so _tbevent.so
 endif
+PROGRAMS	= $(LIBS) $(SWIGLIBS)
 
 all:		$(PROGRAMS)
 
@@ -31,9 +34,14 @@ CFLAGS_NOWARN += `elvin-config --cflags vin4c`
 ifeq ($(SYSTEM),Linux)
 PCORE  = -I/usr/lib/perl5/5.6.1/i386-linux/CORE
 else
+FBSDVERSION    := $(shell uname -v | sed -e 's/FreeBSD \([0-9]\).*/FreeBSD\1/')
+ifeq ($(FBSDVERSION),FreeBSD5)
+PCORE  = -I/usr/local/lib/perl5/5.6.1/mach/CORE
+else
 PCORE  = -I/usr/libdata/perl/5.00503/mach/CORE
 PYCORE = -I/usr/local/include/python2.3
 endif
+endif
 
 OBJS	= event.o util.o
 POBJS	= event_r.o util.o
@@ -102,14 +110,21 @@ install: $(addprefix $(INSTALL_LIBDIR)/, $(LIB_STUFF))
 
 control-install:	install
 
+#
+# Right now we don't bother with the dynamic libs since all of the existing
+# clients are statically linked.  Also, the dynamic libs include the SWIG stubs
+# and that stuff needs work to build on Linux and FBSD5.
+#
+client: $(LIBS)
+client-install: client # client-libinstall
+
 #
 # XXX Fix the python install location.
 #
-client-install:
+client-libinstall:
 	$(INSTALL_PROGRAM) $(SRCDIR)/event.pm $(DESTDIR)$(CLIENT_BINDIR)/event.pm
 	$(INSTALL_PROGRAM) event.so $(DESTDIR)$(CLIENT_BINDIR)/event.so
-	$(INSTALL_PROGRAM) $(SRCDIR)/tbevent.py \
-		$(DESTDIR)$(CLIENT_BINDIR)/tbevent.py
+	$(INSTALL_PROGRAM) $(SRCDIR)/tbevent.py $(DESTDIR)$(CLIENT_BINDIR)/tbevent.py
 	$(INSTALL_PROGRAM) _tbevent.so $(DESTDIR)$(CLIENT_BINDIR)/_tbevent.so
 
 clean:
diff --git a/event/link-agent/GNUmakefile.in b/event/link-agent/GNUmakefile.in
index 67af9f2754..6ae9d48da6 100644
--- a/event/link-agent/GNUmakefile.in
+++ b/event/link-agent/GNUmakefile.in
@@ -42,9 +42,9 @@ $(PROGRAMS):	../lib/libevent.a ../lib/event.h
 
 install:
 
-client-install: link-agent
-	$(INSTALL_PROGRAM) link-agent \
-			$(DESTDIR)$(CLIENT_BINDIR)/link-agent
+client: $(PROGRAMS)
+client-install: client
+	$(INSTALL_PROGRAM) -s link-agent $(DESTDIR)$(CLIENT_BINDIR)/link-agent
 
 clean:
 	/bin/rm -f *.o $(PROGRAMS)
diff --git a/event/linktest/GNUmakefile.in b/event/linktest/GNUmakefile.in
index 908e1d768e..d277f780de 100644
--- a/event/linktest/GNUmakefile.in
+++ b/event/linktest/GNUmakefile.in
@@ -61,15 +61,15 @@ $(LIBTBDIR)/%.o:
 $(LIBEVENTDIR)/%.a:
 	@$(MAKE) -C $(LIBEVENTDIR) $(@F)
 
-binaries: $(LOCAL_BINDIR)/$(DAEMON) $(LOCAL_BINDIR)/$(LTEVENT) 
-
 $(LOCAL_BINDIR):
 	-mkdir -p $(LOCAL_BINDIR)
 
-$(LOCAL_BINDIR)/$(DAEMON):	$(LOCAL_BINDIR) $(DAEMON_OBJS) $(LIBTB_OBJS)
+binaries: $(LOCAL_BINDIR) $(LOCAL_BINDIR)/$(DAEMON) $(LOCAL_BINDIR)/$(LTEVENT) 
+
+$(LOCAL_BINDIR)/$(DAEMON):	$(DAEMON_OBJS) $(LIBTB_OBJS)
 	$(CC) $(LDFLAGS) $(DAEMON_OBJS) $(LIBTB_OBJS) $(LIBS) -o $@
 
-$(LOCAL_BINDIR)/$(LTEVENT):	$(LOCAL_BINDIR) $(LTEVENT_OBJS) $(LIBTB_OBJS)
+$(LOCAL_BINDIR)/$(LTEVENT):	$(LTEVENT_OBJS) $(LIBTB_OBJS)
 	$(CC) $(LDFLAGS) $(LTEVENT_OBJS) $(LIBTB_OBJS) $(LIBS) -o $@
 
 $(DAEMON_OBJS):	linktest.h ../lib/libevent.a ../lib/event.h
@@ -85,23 +85,17 @@ install:
 
 control-install:	install
 
-client-install: all
-	$(INSTALL_PROGRAM) -s $(LOCAL_BINDIR)/$(DAEMON) \
-			$(DESTDIR)$(CLIENT_BINDIR)/$(DAEMON)
-	$(INSTALL_PROGRAM) -s $(LOCAL_BINDIR)/$(LTEVENT) \
-			$(DESTDIR)$(CLIENT_BINDIR)/$(LTEVENT)
-	$(INSTALL_PROGRAM) $(SCRIPT) \
-			$(DESTDIR)$(CLIENT_BINDIR)/$(SCRIPT)
-	$(INSTALL_PROGRAM) $(SCRIPT_RUN) \
-			$(DESTDIR)$(CLIENT_BINDIR)/$(SCRIPT_RUN)
-	$(INSTALL_PROGRAM) $(SRCDIR)/$(SCRIPT_TBCOMPAT) \
-			$(DESTDIR)$(CLIENT_BINDIR)/$(SCRIPT_TBCOMPAT)
-	$(INSTALL_PROGRAM) $(NSTOIRDIR)/$(SCRIPT_NSTB_COMPAT) \
-			$(DESTDIR)$(CLIENT_BINDIR)/$(SCRIPT_NSTB_COMPAT)
+client: all
+client-install: client
+	$(INSTALL_PROGRAM) -s $(LOCAL_BINDIR)/$(DAEMON) $(DESTDIR)$(CLIENT_BINDIR)/$(DAEMON)
+	$(INSTALL_PROGRAM) -s $(LOCAL_BINDIR)/$(LTEVENT) $(DESTDIR)$(CLIENT_BINDIR)/$(LTEVENT)
+	$(INSTALL_PROGRAM) $(SCRIPT) $(DESTDIR)$(CLIENT_BINDIR)/$(SCRIPT)
+	$(INSTALL_PROGRAM) $(SCRIPT_RUN) $(DESTDIR)$(CLIENT_BINDIR)/$(SCRIPT_RUN)
+	$(INSTALL_PROGRAM) $(SRCDIR)/$(SCRIPT_TBCOMPAT) $(DESTDIR)$(CLIENT_BINDIR)/$(SCRIPT_TBCOMPAT)
+	$(INSTALL_PROGRAM) $(NSTOIRDIR)/$(SCRIPT_NSTB_COMPAT) $(DESTDIR)$(CLIENT_BINDIR)/$(SCRIPT_NSTB_COMPAT)
 
 lt-install:
-	$(INSTALL_PROGRAM) $(SCRIPT) \
-            $(DESTDIR)$(CLIENT_BINDIR)/$(SCRIPT)
+	$(INSTALL_PROGRAM) $(SCRIPT) $(DESTDIR)$(CLIENT_BINDIR)/$(SCRIPT)
 
 clean:
 	rm -f *.o $(TESTS)
diff --git a/event/nsetrafgen/GNUmakefile.in b/event/nsetrafgen/GNUmakefile.in
index 43d58bba50..4d1cb8da4d 100644
--- a/event/nsetrafgen/GNUmakefile.in
+++ b/event/nsetrafgen/GNUmakefile.in
@@ -50,7 +50,14 @@ sup-install:
 	-mkdir -p $(INSTALL_SUPDIR)/usr/local/bin/
 	-cp $(INSTALL_NSE) $(INSTALL_SUPDIR)/usr/local/bin
 
-client-install:
+# XXX requires Shashi-magic right now
+tmpmsg:
+	@echo "WARNING: do 'make real-<target>' if you really mean it"
+client: tmpmsg
+client-install: client
+
+real-client: all
+real-client-install:
 	cp -p $(INSTALL_FILES) $(DESTDIR)$(CLIENT_BINDIR)
 	if [ -x $(INSTALL_NSE) ]; then \
 	    $(INSTALL) -m 755 -o root -g wheel -d $(DESTDIR)/usr/local/bin; \
diff --git a/event/program-agent/GNUmakefile.in b/event/program-agent/GNUmakefile.in
index 7f9ed4dfc1..9a67343a16 100644
--- a/event/program-agent/GNUmakefile.in
+++ b/event/program-agent/GNUmakefile.in
@@ -42,9 +42,9 @@ $(PROGRAMS):	../lib/libevent.a ../lib/event.h
 
 install:
 
-client-install: program-agent
-	$(INSTALL_PROGRAM) -s program-agent \
-			$(DESTDIR)$(CLIENT_BINDIR)/program-agent
+client: $(PROGRAMS)
+client-install: client
+	$(INSTALL_PROGRAM) -s program-agent $(DESTDIR)$(CLIENT_BINDIR)/program-agent
 
 clean:
 	/bin/rm -f *.o $(PROGRAMS)
diff --git a/event/proxy/GNUmakefile.in b/event/proxy/GNUmakefile.in
index 22ffbd56df..19bb310331 100644
--- a/event/proxy/GNUmakefile.in
+++ b/event/proxy/GNUmakefile.in
@@ -77,7 +77,8 @@ proxytest:	proxytest.o $(LIBTBDIR)/log.o
 
 $(PROGRAMS):	../lib/libevent.a ../lib/event.h
 
-client-install: evproxy
+client: evproxy
+client-install: client
 	$(INSTALL_PROGRAM) -s evproxy $(DESTDIR)$(CLIENT_BINDIR)/evproxy
 
 clean:
diff --git a/event/sched/GNUmakefile.in b/event/sched/GNUmakefile.in
index ad386b270d..c7a37c5d58 100644
--- a/event/sched/GNUmakefile.in
+++ b/event/sched/GNUmakefile.in
@@ -1,6 +1,6 @@
 #
 # EMULAB-COPYRIGHT
-# Copyright (c) 2000-2002 University of Utah and the Flux Group.
+# Copyright (c) 2000-2002, 2004 University of Utah and the Flux Group.
 # All rights reserved.
 #
 
@@ -42,5 +42,9 @@ $(OBJS):	event-sched.h ../lib/libevent.a
 
 install:	$(addprefix $(INSTALL_SBINDIR)/, event-sched)
 
+# not a client thing
+client:
+client-install: client
+
 clean:
 	/bin/rm -f *.o event-sched
diff --git a/event/stated/GNUmakefile.in b/event/stated/GNUmakefile.in
index c77972a89a..216bc9912c 100644
--- a/event/stated/GNUmakefile.in
+++ b/event/stated/GNUmakefile.in
@@ -1,6 +1,6 @@
 #
 # EMULAB-COPYRIGHT
-# Copyright (c) 2000-2003 University of Utah and the Flux Group.
+# Copyright (c) 2000-2004 University of Utah and the Flux Group.
 # All rights reserved.
 #
 
@@ -22,3 +22,7 @@ include $(TESTBED_SRCDIR)/GNUmakerules
 install:	 all \
 	$(addprefix $(INSTALL_SBINDIR)/, $(SBIN_STUFF)) \
 	$(addprefix $(INSTALL_LIBDIR)/,  $(LIB_STUFF)) 
+
+# not a client thing
+client:
+client-install: client
diff --git a/event/tbgen/GNUmakefile.in b/event/tbgen/GNUmakefile.in
index 0435e3a539..b962e4583b 100644
--- a/event/tbgen/GNUmakefile.in
+++ b/event/tbgen/GNUmakefile.in
@@ -18,7 +18,6 @@ endif
 include $(OBJDIR)/Makeconf
 
 all:	$(PROGRAMS)
-client: tevc
 
 include $(TESTBED_SRCDIR)/GNUmakerules
 
@@ -50,9 +49,9 @@ endif
 LIBS     += -ldl
 endif
 
+# Link against some of the object files from libtb, instead of the
+# whole library, since the latter cannot be built on clients (without mysql)
 tevc:	tevc.o $(LIBTBDIR)/log.o $(LIBTBDIR)/tbdefs.o
-	# Link against some of the object files from libtb, instead of the
-	# whole library, since the latter cannot be built on ops
 	$(CC) $(LDFLAGS) -static -o $@ tevc.o $(LIBTBDIR)/log.o \
 		$(LIBTBDIR)/tbdefs.o $(LIBS)
 
@@ -68,7 +67,8 @@ install:	$(INSTALL_SBINDIR)/tevd \
 
 control-install:	$(INSTALL_BINDIR)/tevc
 
-client-install: tevc
+client: tevc
+client-install: client
 	$(INSTALL_PROGRAM) -s tevc $(DESTDIR)$(CLIENT_BINDIR)/tevc
 
 clean:
diff --git a/event/trafgen/GNUmakefile.in b/event/trafgen/GNUmakefile.in
index eccd6c0cd2..077ed9f337 100644
--- a/event/trafgen/GNUmakefile.in
+++ b/event/trafgen/GNUmakefile.in
@@ -52,7 +52,7 @@ SYSTEM	       := $(shell uname -s)
 ifeq ($(SYSTEM),FreeBSD)
 # FreeBSD
 CFLAGS	 += -DFREEBSD
-YCFLAGS	 += -I. -DUSEEVENTS -DFREEBSD
+YCFLAGS	 += -I. -I$(TGSRCDIR) -DUSEEVENTS -DFREEBSD
 LIBS	 += -ll -lcompat
 endif
 
@@ -86,7 +86,8 @@ $(PROGRAMS):	../lib/libevent.a ../lib/event.h
 
 install:
 
-client-install: trafgen
+client: $(PROGRAMS)
+client-install: client
 	$(INSTALL_PROGRAM) -s trafgen $(DESTDIR)$(CLIENT_BINDIR)/trafgen
 
 clean:
diff --git a/lib/libtb/GNUmakefile.in b/lib/libtb/GNUmakefile.in
index cbe5ada620..4288beed0e 100644
--- a/lib/libtb/GNUmakefile.in
+++ b/lib/libtb/GNUmakefile.in
@@ -15,6 +15,7 @@ all:	libtb.a
 
 client:	libtb-nodb.a
 	mv libtb-nodb.a libtb.a
+client-install: client
 
 include $(TESTBED_SRCDIR)/GNUmakerules
 
diff --git a/os/GNUmakefile.in b/os/GNUmakefile.in
index 9420f91d4c..05adeebc91 100644
--- a/os/GNUmakefile.in
+++ b/os/GNUmakefile.in
@@ -27,16 +27,25 @@ install: $(INSTALL_SBINDIR)/split-image.sh
 control-install: 
 	@$(MAKE) -C imagezip install
 
-client-install: 
+client:
+ifneq ($(SYSTEM),Linux)
+	$(MAKE) -C imagezip client
+	$(MAKE) -C growdisk client
+endif
+	$(MAKE) -C syncd client
+	$(MAKE) -C dijkstra client
+	$(MAKE) -C genhostsfile client
+
+client-install: client
 	$(INSTALL) -m 755 -o root -g wheel -d $(LBINDIR)
 	$(INSTALL_PROGRAM) $(SRCDIR)/install-tarfile $(LBINDIR)/install-tarfile
 	$(INSTALL_PROGRAM) $(SRCDIR)/install-rpm $(LBINDIR)/install-rpm
 ifneq ($(SYSTEM),Linux)
 	$(INSTALL_PROGRAM) $(SRCDIR)/create-image $(LBINDIR)/create-image
 	$(MAKE) -C imagezip client-install
+	$(MAKE) -C growdisk client-install
 endif
 	$(MAKE) -C syncd client-install
-	$(MAKE) -C growdisk client-install
 	$(MAKE) -C dijkstra client-install
 	$(MAKE) -C genhostsfile client-install
 
diff --git a/os/dijkstra/GNUmakefile.in b/os/dijkstra/GNUmakefile.in
index 1421136225..4d85ff349a 100644
--- a/os/dijkstra/GNUmakefile.in
+++ b/os/dijkstra/GNUmakefile.in
@@ -22,7 +22,8 @@ dijkstra:	dijkstra.o bitmath.o Compressor.o IpTree.o SingleSource.o \
                 Compressor.h lib.h
 	$(CXX) $(CXXFLAGS) -static dijkstra.o bitmath.o Compressor.o IpTree.o SingleSource.o $(LIBS) -o dijkstra
 
-client-install: dijkstra
+client: all
+client-install: client
 	$(INSTALL_PROGRAM) dijkstra $(DESTDIR)$(CLIENT_BINDIR)/dijkstra
 
 clean:
diff --git a/os/genhostsfile/GNUmakefile.in b/os/genhostsfile/GNUmakefile.in
index 0124f0b7e0..239ff46ea1 100644
--- a/os/genhostsfile/GNUmakefile.in
+++ b/os/genhostsfile/GNUmakefile.in
@@ -25,8 +25,9 @@ wgraph.o:	wgraph.cc wgraph.h
 
 install:	$(INSTALL_LIBEXECDIR)/genhostsfile
 
-client-install: genhostsfile
-	$(INSTALL_PROGRAM) genhostsfile $(DESTDIR)$(CLIENT_BINDIR)/genhostsfile
+client: genhostsfile
+client-install: client
+	$(INSTALL_PROGRAM) -s genhostsfile $(DESTDIR)$(CLIENT_BINDIR)/genhostsfile
 
 clean:
 	rm -f *.o genhostsfile genfromtopo genfromdb
diff --git a/os/growdisk/GNUmakefile.in b/os/growdisk/GNUmakefile.in
index f1b88d8766..af01692fcd 100644
--- a/os/growdisk/GNUmakefile.in
+++ b/os/growdisk/GNUmakefile.in
@@ -24,7 +24,8 @@ growdisk: growdisk.o
 
 install:
 
-client-install: growdisk
+client: all
+client-install: client
 	$(INSTALL_PROGRAM) growdisk $(DESTDIR)$(CLIENT_BINDIR)
 
 clean:
diff --git a/os/imagezip/GNUmakefile.in b/os/imagezip/GNUmakefile.in
index a418114fe8..8baa0a60f4 100644
--- a/os/imagezip/GNUmakefile.in
+++ b/os/imagezip/GNUmakefile.in
@@ -112,7 +112,8 @@ version.c: imagezip.c imageunzip.c imagedump.c
 
 install: $(INSTALL_BINDIR)/imagezip $(INSTALL_BINDIR)/imageunzip $(INSTALL_BINDIR)/imagedump
 
-client-install: all
+client: all
+client-install: client
 	$(INSTALL) -m 755 -o root -g wheel -d $(DESTDIR)/usr/local/bin
 	$(INSTALL_PROGRAM) imagezip $(DESTDIR)/usr/local/bin/imagezip
 	$(INSTALL_PROGRAM) imageunzip $(DESTDIR)/usr/local/bin/imageunzip
diff --git a/os/syncd/GNUmakefile.in b/os/syncd/GNUmakefile.in
index 24a793097f..9a2aadb7dd 100644
--- a/os/syncd/GNUmakefile.in
+++ b/os/syncd/GNUmakefile.in
@@ -28,16 +28,13 @@ emulab-sync:	emulab-sync.o version.o decls.h
 version.c: emulab-syncd.c 
 	echo >$@ "char build_info[] = \"Built `date +%d-%b-%Y` by `id -nu`@`hostname | sed 's/\..*//'`:`pwd`\";"
 
-client-install: emulab-syncd emulab-sync
-	$(INSTALL_PROGRAM) -s emulab-syncd \
-		$(DESTDIR)$(CLIENT_BINDIR)/emulab-syncd
-	$(INSTALL_PROGRAM) -s emulab-sync \
-		$(DESTDIR)$(CLIENT_BINDIR)/emulab-sync
+client: all
+client-install: client
+	$(INSTALL_PROGRAM) -s emulab-syncd $(DESTDIR)$(CLIENT_BINDIR)/emulab-syncd
+	$(INSTALL_PROGRAM) -s emulab-sync $(DESTDIR)$(CLIENT_BINDIR)/emulab-sync
 	$(INSTALL) -m 755 -o root -g wheel -d $(DESTDIR)$(CLIENT_MANDIR)/man1
-	$(INSTALL_PROGRAM) $(SRCDIR)/emulab-syncd.1 \
-		$(DESTDIR)$(CLIENT_MANDIR)/man1/emulab-syncd.1
-	$(INSTALL_PROGRAM) $(SRCDIR)/emulab-sync.1 \
-		$(DESTDIR)$(CLIENT_MANDIR)/man1/emulab-sync.1
+	$(INSTALL_PROGRAM) $(SRCDIR)/emulab-syncd.1 $(DESTDIR)$(CLIENT_MANDIR)/man1/emulab-syncd.1
+	$(INSTALL_PROGRAM) $(SRCDIR)/emulab-sync.1 $(DESTDIR)$(CLIENT_MANDIR)/man1/emulab-sync.1
 
 check:
 	sh $(SRCDIR)/syncd_test.sh
diff --git a/sensors/GNUmakefile.in b/sensors/GNUmakefile.in
index b3e3e248d4..7105b671bb 100644
--- a/sensors/GNUmakefile.in
+++ b/sensors/GNUmakefile.in
@@ -4,7 +4,7 @@
 SRCDIR		= @srcdir@
 TESTBED_SRCDIR	= @top_srcdir@
 OBJDIR		= ..
-SUBDIR		= lib
+SUBDIR		= sensors
 
 include $(OBJDIR)/Makeconf
 
@@ -20,7 +20,10 @@ slothd:
 install: 
 	@$(MAKE) -C slothd install
 
-client-install:
+client:
+	@$(MAKE) -C slothd client
+
+client-install: client
 	@$(MAKE) -C slothd client-install
 
 clean:		subdir-clean
diff --git a/sensors/slothd/GNUmakefile.in b/sensors/slothd/GNUmakefile.in
index be557b48af..0d3d7f6d0c 100644
--- a/sensors/slothd/GNUmakefile.in
+++ b/sensors/slothd/GNUmakefile.in
@@ -52,7 +52,7 @@ version.c: slothd.c slothd.h sdcollectd.c sdcollectd.h
 	echo >$@ "char build_info[] = \"Built `date +%d-%b-%Y` by `id -nu`@`hostname | sed 's/\..*//'`:`pwd`\";"
 
 client: slothd
-	-mkdir $(SLOTHD_DIR)
+	-mkdir -p $(SLOTHD_DIR)
 	$(CP) slothd $(SLOTHD_DIR)/slothd
 
 install: $(addprefix $(INSTALL_SBINDIR)/, $(SBIN_SCRIPTS) sdcollectd)
diff --git a/tmcd/GNUmakefile.in b/tmcd/GNUmakefile.in
index 37534c724a..e30b78ccc6 100644
--- a/tmcd/GNUmakefile.in
+++ b/tmcd/GNUmakefile.in
@@ -11,8 +11,9 @@ SYSTEM	       := $(shell uname -s)
 
 include $(OBJDIR)/Makeconf
 
-all:	server client
-client: tmcc tmcc-nossl findif
+all:	server fullclient client
+fullclient: tmcc
+client: tmcc-nossl findif
 server: tmcd tmcd.restart
 
 include $(TESTBED_SRCDIR)/GNUmakerules
@@ -29,17 +30,27 @@ SSLFLAGS = -DWITHSSL
 TMLIBS	+= -lssl -lcrypto
 SSLOBJ   = ssl.o
 ifeq ($(SYSTEM),Linux)
+RHLVERSION    := $(shell cat /etc/redhat-release | sed -e 's/Red Hat Linux release \([0-9]\).*/Linux\1/')
 NEEDKERB := $(shell nm /usr/lib/libssl.a | grep -q krb; echo $$?)
 ifeq ($(NEEDKERB),0)
  CFLAGS   += `/usr/kerberos/bin/krb5-config --cflags`
  TMLIBS   += `/usr/kerberos/bin/krb5-config --libs krb5`
 endif
 TMLIBS  += -ldl
+ifeq ($(RHLVERSION),Linux9)
+MDSUBDIR  = linux9
+else
 MDSUBDIR  = linux
 endif
+endif
 ifeq ($(SYSTEM),FreeBSD)
+FBSDVERSION    := $(shell uname -v | sed -e 's/FreeBSD \([0-9]\).*/FreeBSD\1/')
+ifeq ($(FBSDVERSION),FreeBSD5)
+MDSUBDIR  = freebsd5
+else
 MDSUBDIR  = freebsd
 endif
+endif
 
 ifeq ($(EVENTSYS),1)
 	TMCDCFLAGS = `elvin-config --cflags vin4c` \
@@ -79,7 +90,7 @@ install:	$(INSTALL_SBINDIR)/tmcd \
 		$(INSTALL_SBINDIR)/tmcd.restart
 
 
-client-install: tmcc-nossl findif
+client-install: client
 	@$(MAKE) -C $(MDSUBDIR) install
 
 $(INSTALL_BINDIR)/tmcd/%: %
diff --git a/tmcd/common/GNUmakefile.in b/tmcd/common/GNUmakefile.in
index bb7776bed4..f71d892770 100644
--- a/tmcd/common/GNUmakefile.in
+++ b/tmcd/common/GNUmakefile.in
@@ -32,7 +32,7 @@ TBBINDIR	= $(DESTDIR)/usr/testbed/bin
 TBLIBDIR	= $(DESTDIR)/usr/testbed/lib
 INSTALL		= /usr/bin/install -c
 
-install:
+install client-install:
 	@echo "You should probably not run this install directly!"
 	@echo "If you do, be sure to install from the system specific "
 	@echo "directory afterwards."
diff --git a/tmcd/freebsd/GNUmakefile.in b/tmcd/freebsd/GNUmakefile.in
index 9454e48cd9..208a1b143b 100644
--- a/tmcd/freebsd/GNUmakefile.in
+++ b/tmcd/freebsd/GNUmakefile.in
@@ -41,7 +41,7 @@ INSTALL		= /usr/bin/install -c
 injail: $(SRCDIR)/jail/injail.c
 	$(CC) $(CFLAGS) -O2 -o injail $<
 
-install:	common-install etc-install \
+install client-install:	common-install etc-install \
 			sup-install script-install bin-install jail-install
 	@echo "Remember to install the PEM files if necessary"
 
diff --git a/tmcd/freebsd/prepare b/tmcd/freebsd/prepare
index 8e77838384..36e221b283 100755
--- a/tmcd/freebsd/prepare
+++ b/tmcd/freebsd/prepare
@@ -29,6 +29,18 @@ my $SFSUSERS    = "/etc/sfs/sfs_users";
 my $SFSHOSTKEY  = "/etc/sfs/sfs_host_key";
 my $MOUNTINFO	= "/var/db/mounttab";
 
+#
+# Dead wood in $BINDIR
+# If you remove/move a script, list it here so that it goes away when the
+# image is remade.
+#
+my @DEADFILES	= ("rc.agents", "rc.delayagent", "rc.delta", "rc.healthd",
+		   "rc.injail", "rc.ipod", "rc.mfs", "rc.progagent",
+		   "rc.setup", "rc.slothd", "rc.testbed",
+		   "batchcmddone", "bootsetup", "install-tarfile",
+		   "jailsetup", "update_delays");
+
+
 #
 # Turn off line buffering on output
 #
@@ -189,3 +201,10 @@ foreach my $dir (@VARDIRS) {
     }
 }
 
+print "Clearing out old Emulab scripts and binaries in $BINDIR ...\n";
+foreach my $file (@DEADFILES) {
+    if (-f "$BINDIR/$file") {
+	unlink("$BINDIR/$file") or
+	    warn("*** could not remove $BINDIR/$file\n");
+    }
+}
diff --git a/tmcd/freebsd5/GNUmakefile.in b/tmcd/freebsd5/GNUmakefile.in
index 979a1c6a25..83f44705ea 100644
--- a/tmcd/freebsd5/GNUmakefile.in
+++ b/tmcd/freebsd5/GNUmakefile.in
@@ -38,9 +38,27 @@ RCDIR		= $(DESTDIR)/usr/local/etc/rc.d
 ISMFS		= $(ETCDIR)/ismfs
 INSTALL		= /usr/bin/install -c
 
-install:	basefbsd-install etc-install \
+install client-install:	basefbsd-install etc-install \
 			sup-install script-install bin-install # jail-install
 
+destdircheck:
+	@if [ -z "$(DESTDIR)" ]; then \
+	    echo "You must define DESTDIR for this target!"; \
+	    false; \
+	fi
+
+cdboot-install:	destdircheck basefbsdcdboot-install etc-install \
+			script-install bin-install
+	rm -f $(SYSETCDIR)/start_if.*
+	rm -f $(SYSETCDIR)/rc.cdroot $(SYSETCDIR)/fstab.lbs
+	rm -f $(DESTDIR)/boot/loader.rc.lbs
+	$(INSTALL) -m 755 $(SRCDIR)/cdboot/rc.conf $(SYSETCDIR)/rc.conf
+	$(INSTALL) -m 755 $(SRCDIR)/cdboot/rc.cdboot $(BINDIR)/rc/rc.cdboot
+	$(INSTALL) -m 755 $(SRCDIR)/cdboot/cdroot $(SYSETCDIR)/rc.d/cdroot
+	cp $(SRCDIR)/cdboot/fstab $(SYSETCDIR)/fstab
+	cp $(SRCDIR)/cdboot/loader.conf $(DESTDIR)/boot/loader.conf
+	cp $(SRCDIR)/cdboot/.profile $(DESTDIR)/.profile
+
 simple-install:	script-install bin-install # jail-install
 
 dir-install:
@@ -63,6 +81,9 @@ basefbsd-install: dir-install
 	(cd ../freebsd; $(MAKE) all install)
 	rm -f $(SYSETCDIR)/start_if.*
 
+basefbsdcdboot-install: dir-install
+	(cd ../freebsd; $(MAKE) DESTDIR=$(DESTDIR) all cdboot-install)
+
 sup-install:	dir-install supfile
 	$(INSTALL) -m 755 ./supfile $(ETCDIR)/supfile
 
diff --git a/tmcd/linux/GNUmakefile.in b/tmcd/linux/GNUmakefile.in
index f4c7a1c620..57a56e8f11 100644
--- a/tmcd/linux/GNUmakefile.in
+++ b/tmcd/linux/GNUmakefile.in
@@ -37,13 +37,21 @@ RCDIR		= $(SYSETCDIR)/rc.d
 INSTALL		= /usr/bin/install -c 
 COMMON		= $(SRCDIR)/../common
 
-install:	common-install etc-install \
+install client-install:	common-install etc-install \
 			sup-install script-install bin-install
 	@echo "Remember to install the PEM files if necessary"
 
 simple-install:	common-install script-install bin-install
 
 dir-install:
+	$(INSTALL) -m 755 -o root -g wheel -d $(SYSETCDIR)
+	$(INSTALL) -m 755 -o root -g wheel -d $(SYSETCDIR)/sysconfig
+	$(INSTALL) -m 755 -o root -g wheel -d $(SYSETCDIR)/sysconfig/network-scripts
+	$(INSTALL) -m 755 -o root -g wheel -d $(RCDIR)
+	$(INSTALL) -m 755 -o root -g wheel -d $(RCDIR)/init.d
+	$(INSTALL) -m 755 -o root -g wheel -d $(RCDIR)/rc1.d
+	$(INSTALL) -m 755 -o root -g wheel -d $(RCDIR)/rc3.d
+	$(INSTALL) -m 755 -o root -g wheel -d $(RCDIR)/rc6.d
 	$(INSTALL) -m 755 -o root -g wheel -d $(ETCDIR)
 	$(INSTALL) -m 755 -o root -g wheel -d $(BINDIR)
 	$(INSTALL) -m 755 -o root -g wheel -d $(RCDIR)
diff --git a/tmcd/linux/prepare b/tmcd/linux/prepare
index 59ff4e90f2..fc62bd27fd 100755
--- a/tmcd/linux/prepare
+++ b/tmcd/linux/prepare
@@ -13,7 +13,7 @@ require 'ctime.pl';
 #
 my $DUMPDATES   = "/etc/dumpdates";
 my @DBFILES     = ();
-my @VARDIRS	= ("logs", "db", "jails", "boot", "lock");
+my @VARDIRS	= ("logs", "db", "jails", "boot", "lock", "lib/dhcp");
 my $FSTAB       = "/etc/fstab";
 my $LOGDIR      = "/var/log";
 my $RUNDIR      = "/var/run";
diff --git a/tmcd/linux9/GNUmakefile.in b/tmcd/linux9/GNUmakefile.in
new file mode 100644
index 0000000000..824498ee39
--- /dev/null
+++ b/tmcd/linux9/GNUmakefile.in
@@ -0,0 +1,74 @@
+#
+# EMULAB-COPYRIGHT
+# Copyright (c) 2000-2004 University of Utah and the Flux Group.
+# All rights reserved.
+#
+
+#
+# XXX ONLY RUN THIS INSTALL ON A LINUX TESTBED NODE!
+#
+# Trivial. These things just need to be installed into the right place
+# on a testbed node before cutting an image.
+#
+#
+SRCDIR		= @srcdir@
+TESTBED_SRCDIR	= @top_srcdir@
+OBJDIR		= ../..
+SUBDIR		= tmcd/linux9
+
+include $(OBJDIR)/Makeconf
+
+SCRIPTS		= 
+
+#
+# Force dependencies on the scripts so that they will be rerun through
+# configure if the .in file is changed.
+# 
+all:	supfile ifcfgs
+
+include $(TESTBED_SRCDIR)/GNUmakerules
+
+DESTDIR		=
+SYSETCDIR	= $(DESTDIR)/etc
+ETCDIR		= $(DESTDIR)$(CLIENT_ETCDIR)
+BINDIR		= $(DESTDIR)$(CLIENT_BINDIR)
+VARDIR		= $(DESTDIR)$(CLIENT_VARDIR)
+RCDIR		= $(SYSETCDIR)/rc.d
+INSTALL		= /usr/bin/install -c 
+COMMON		= $(SRCDIR)/../common
+
+install client-install:	baselinux-install common-install etc-install \
+			sup-install script-install bin-install
+	@echo "Remember to install the PEM files if necessary"
+
+simple-install:	common-install script-install bin-install
+
+dir-install:
+
+baselinux-install: dir-install
+	(cd ../linux; $(MAKE) client-install)
+	rm -f $(SYSETCDIR)/pump.conf
+#	rm -f $(SYSETCDIR)/sysconfig/network-scripts/ifcfg-eth?
+
+common-install:	dir-install
+	(cd ../common; $(MAKE) local-install)
+
+sup-install:	dir-install supfile
+	$(INSTALL) -m 755 ./supfile $(ETCDIR)/supfile
+
+bin-install:	dir-install
+
+etc-install:	dir-install sysetc-remove sysetc-install
+
+sysetc-install:	ifcfgs dir-install
+#	$(INSTALL) -m 755 ifcfg-eth[0-9]* $(SYSETCDIR)/sysconfig/network-scripts
+
+sysetc-remove:
+
+script-install:	dir-install $(SCRIPTS)
+
+sfs-install:
+
+# create ifcfg-eth? files
+ifcfgs: $(SRCDIR)/mkifcfgs $(SRCDIR)/ifcfg.template
+#	$(SRCDIR)/mkifcfgs $(SRCDIR)/ifcfg.template
diff --git a/tmcd/linux9/supfile.in b/tmcd/linux9/supfile.in
new file mode 100644
index 0000000000..9745dc1fa7
--- /dev/null
+++ b/tmcd/linux9/supfile.in
@@ -0,0 +1,4 @@
+#
+# Bump as needed
+#
+RHL90-STD  base=@CLIENT_VARDIR@ prefix=/ preserve release=20040319
diff --git a/tmcd/openbsd/GNUmakefile.in b/tmcd/openbsd/GNUmakefile.in
index 83dc43973a..d7521bbbd4 100644
--- a/tmcd/openbsd/GNUmakefile.in
+++ b/tmcd/openbsd/GNUmakefile.in
@@ -1,6 +1,6 @@
 #
 # EMULAB-COPYRIGHT
-# Copyright (c) 2000-2003 University of Utah and the Flux Group.
+# Copyright (c) 2000-2004 University of Utah and the Flux Group.
 # All rights reserved.
 #
 
@@ -33,7 +33,7 @@ RCDIR		= $(DESTDIR)/usr/local/etc/rc.d
 ISMFS		= $(ETCDIR)/ismfs
 INSTALL		= /usr/bin/install -c
 
-install:	common-install etc-install \
+install client-install:	common-install etc-install \
 			sup-install script-install bin-install jail-install
 	@echo "Remember to install the PEM files if necessary"
 
diff --git a/tmcd/plab/GNUmakefile.in b/tmcd/plab/GNUmakefile.in
index 6258078f0e..ef4e0a0319 100644
--- a/tmcd/plab/GNUmakefile.in
+++ b/tmcd/plab/GNUmakefile.in
@@ -97,7 +97,7 @@ tmcc:
 	@echo "prior to building the tarball."
 	@false
 
-install:
+install client-install:
 
 rootball-install: 
 	$(INSTALL_DATA) $(ROOTBALLNAME) $(INSTALL_ETCDIR)/plab
diff --git a/tmcd/ron/GNUmakefile.in b/tmcd/ron/GNUmakefile.in
index 4aedd81620..fd731ce274 100644
--- a/tmcd/ron/GNUmakefile.in
+++ b/tmcd/ron/GNUmakefile.in
@@ -1,6 +1,6 @@
 #
 # EMULAB-COPYRIGHT
-# Copyright (c) 2000-2003 University of Utah and the Flux Group.
+# Copyright (c) 2000-2004 University of Utah and the Flux Group.
 # All rights reserved.
 #
 
@@ -31,6 +31,7 @@ VARDIR		= $(DESTDIR)$(CLIENT_VARDIR)
 RCDIR		= $(DESTDIR)/usr/local/etc/rc.d
 INSTALL		= /usr/bin/install -c
 
+client-install:
 wa-install:	wa-stuff doinstall
 ron-install:	ron-stuff doinstall
 doinstall:	common-install etc-install sysetc-install other-install \
-- 
GitLab