X-Git-Url: http://git.sameswireless.fr/l2tpns.git/blobdiff_plain/c239d4b22829335fda98b66ce045a3f624436eeb..a109954b2c321e4ac88557abf9fbbce27329dae5:/Makefile?ds=inline diff --git a/Makefile b/Makefile index 04bf448..015aa63 100644 --- a/Makefile +++ b/Makefile @@ -1,14 +1,14 @@ -PREFIX= -bindir = $(PREFIX)/usr/sbin -etcdir = $(PREFIX)/etc/l2tpns -libdir = $(PREFIX)/usr/lib/l2tpns +DESTDIR = +bindir = $(DESTDIR)/usr/sbin +etcdir = $(DESTDIR)/etc/l2tpns +libdir = $(DESTDIR)/usr/lib/l2tpns CC = gcc -DEFINES= -DBGP -DRINGBUFFER -DSTAT_CALLS -DSTATISTICS -OPTIM=-g -O3 -funroll-loops -fomit-frame-pointer -finline-functions -CFLAGS=-Wall $(OPTIM) $(DEFINES) -LDFLAGS = -LIBS = -lm -ldl -lcli +DEFINES = -DBGP -DRINGBUFFER -DSTAT_CALLS -DSTATISTICS +OPTIM = -g -O3 -funroll-loops -fomit-frame-pointer -finline-functions +CFLAGS = -Wall $(OPTIM) $(DEFINES) +LDFLAGS = -rdynamic +LIBS = -lm INSTALL = /usr/bin/install -c OBJS= md5.o \ @@ -27,18 +27,13 @@ OBJS= md5.o \ tbf.o \ bgp.o \ -PLUGINS=garden.so autothrottle.so autosnoop.so +PLUGINS=garden.so autothrottle.so autosnoop.so stripdomain.so +TARGETS=l2tpns nsctl generateload bounce $(PLUGINS) -all: l2tpns nsctl $(PLUGINS) - -l2tpns: $(OBJS) - $(CC) $(CFLAGS) -o $@ $^ $(LIBS) $(DEFS) - -nsctl: nsctl.o control.o - $(CC) $(CFLAGS) -o $@ $^ $(DEFS) +all: $(TARGETS) clean: - /bin/rm -f *.o *.so l2tpns nsctl + /bin/rm -f *.o *.so $(TARGETS) depend: (sed -n 'p; /^## Dependencies: (autogenerated) ##/q' Makefile && \ @@ -47,32 +42,57 @@ depend: mv Makefile Makefile.bak mv Makefile.tmp Makefile +# install config files only if a startup-config does not exist yet JK 20040713 +# this does not interfere when building rpms or debs and makes +# fast upgrading via make install possible + install: all $(INSTALL) -D -o root -g root -m 0755 l2tpns $(bindir)/l2tpns $(INSTALL) -D -o root -g root -m 0755 nsctl $(bindir)/nsctl - $(INSTALL) -D -o root -g root -m 0600 etc/l2tpns.cfg.default $(etcdir)/l2tpns.cfg - $(INSTALL) -D -o root -g root -m 0644 etc/ip_pool.default $(etcdir)/l2tpns.ip_pool - $(INSTALL) -D -o root -g root -m 0600 etc/users.default $(etcdir)/l2tpns.users - for PLUGIN in $(PLUGINS); do \ - $(INSTALL) -D -o root -g root -m 0755 $(PLUGIN) $(libdir)/$(PLUGIN); \ + @if [ -f $(etcdir)/startup-config ]; then \ + echo '***' Installing default config files in $(etcdir) as .defaults; \ + $(INSTALL) -D -o root -g root -m 0600 etc/startup-config.default $(etcdir)/startup-config.default; \ + $(INSTALL) -D -o root -g root -m 0644 etc/ip_pool.default $(etcdir)/ip_pool.default; \ + $(INSTALL) -D -o root -g root -m 0600 etc/users.default $(etcdir)/users.default; \ + else \ + echo '***' Installing default config files in $(etcdir) - remember to adjust them; \ + $(INSTALL) -D -o root -g root -m 0600 etc/startup-config.default $(etcdir)/startup-config; \ + $(INSTALL) -D -o root -g root -m 0644 etc/ip_pool.default $(etcdir)/l2tpns.ip_pool; \ + $(INSTALL) -D -o root -g root -m 0600 etc/users.default $(etcdir)/l2tpns.users; \ + fi + + for plugin in $(PLUGINS); do \ + $(INSTALL) -D -o root -g root -m 0755 $$plugin $(libdir)/$$plugin; \ done if [ ! -e /dev/net/tun ]; then \ mkdir /dev/net; \ mknod /dev/net/tun c 10 200; \ fi +l2tpns: $(OBJS) + $(CC) $(CFLAGS) -o $@ $^ $(LDFLAGS) $(LIBS) -lcli -ldl + +nsctl: nsctl.o control.o + $(CC) $(CFLAGS) -o $@ $^ $(LDFLAGS) $(LIBS) + +generateload: test/generateload.o + $(CC) $(CFLAGS) -o $@ $^ $(LDFLAGS) $(LIBS) + +bounce: test/bounce.o + $(CC) $(CFLAGS) -o $@ $^ $(LDFLAGS) $(LIBS) + %.o: %.c $(CC) -c $(CFLAGS) -o $@ $< %.so: %.c - $(CC) -fPIC -shared $(CFLAGS) -o $@ $< $(LDFLAGS) $(LIBS) $(LIBPATH) + $(CC) -fPIC -shared $(CFLAGS) -o $@ $< $(LDFLAGS) $(LIBS) .PHONY: all clean depend ## Dependencies: (autogenerated) ## md5.o: md5.c md5.h icmp.o: icmp.c l2tpns.h config.h -cli.o: cli.c l2tpns.h config.h util.h cluster.h tbf.h bgp.h +cli.o: cli.c l2tpns.h config.h util.h cluster.h tbf.h ll.h bgp.h l2tpns.o: l2tpns.c md5.h l2tpns.h config.h cluster.h plugin.h ll.h \ constants.h control.h util.h tbf.h bgp.h ppp.o: ppp.c l2tpns.h config.h constants.h plugin.h util.h tbf.h \ @@ -85,7 +105,7 @@ constants.o: constants.c constants.h ll.o: ll.c ll.h control.o: control.c control.h util.o: util.c l2tpns.h config.h -tbf.o: tbf.c l2tpns.h config.h tbf.h +tbf.o: tbf.c l2tpns.h config.h util.h tbf.h bgp.o: bgp.c l2tpns.h config.h bgp.h util.h garden.so: garden.c l2tpns.h config.h plugin.h control.h autothrottle.so: autothrottle.c l2tpns.h config.h plugin.h control.h