X-Git-Url: https://git.distorted.org.uk/~mdw/secnet/blobdiff_plain/4ff0a42ff7efe5cc1b36e9c5ff930609b3f56b86..refs/heads/mdw/xdh:/Makefile.in diff --git a/Makefile.in b/Makefile.in index 68b7b7b..ab70bd6 100644 --- a/Makefile.in +++ b/Makefile.in @@ -1,24 +1,26 @@ # Makefile for secnet -# Copyright (C) 1995-2001 Stephen Early - -# This program is free software; you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation; either version 2, or (at your option) -# any later version. - -# This program 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 General Public License for more details. - +# +# This file is part of secnet. +# See README for full list of copyright holders. +# +# secnet is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 3 of the License, or +# (at your option) any later version. +# +# secnet 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 +# General Public License for more details. +# # You should have received a copy of the GNU General Public License -# along with this program; if not, write to the Free Software -# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. +# version 3 along with secnet; if not, see +# https://www.gnu.org/licenses/gpl.html. .PHONY: all clean realclean distclean dist install PACKAGE:=secnet -VERSION:=0.1.18 +VERSION=0.4.5 @SET_MAKE@ @@ -30,55 +32,56 @@ RM:=@RM@ CC:=@CC@ INSTALL:=@INSTALL@ INSTALL_PROGRAM:=@INSTALL_PROGRAM@ +INSTALL_SCRIPT:=@INSTALL_SCRIPT@ +INSTALL_DATA:=@INSTALL_DATA@ + +prefix:=$(DESTDIR)@prefix@ +exec_prefix:=@exec_prefix@ +sbindir:=@sbindir@ +sysconfdir:=$(DESTDIR)@sysconfdir@ +datarootdir:=@datarootdir@ +transform:=@program_transform_name@ +mandir:=@mandir@ CFLAGS:=-Wall @WRITESTRINGS@ @CFLAGS@ -Werror \ - -W -Wno-unused \ + -W -Wno-unused -Wno-unused-parameter \ -Wno-pointer-sign -Wstrict-prototypes -Wmissing-prototypes \ -Wmissing-declarations -Wnested-externs -Wredundant-decls \ -Wpointer-arith -Wformat=2 -Winit-self \ - -Wswitch-enum -Wunused-variable -Wbad-function-cast \ - -Wno-strict-aliasing -fno-strict-aliasing -ALL_CFLAGS:=@DEFS@ -I$(srcdir) -I. $(CFLAGS) -CPPFLAGS:=@CPPFLAGS@ -LDFLAGS:=@LDFLAGS@ -LDLIBS:=@LIBS@ - -prefix:=@prefix@ -exec_prefix:=@exec_prefix@ -sbindir:=@sbindir@ -sysconfdir:=@sysconfdir@ -transform:=@program_transform_name@ + -Wswitch-enum -Wunused-variable -Wunused-function -Wbad-function-cast \ + -Wno-strict-aliasing -fno-strict-aliasing \ + -MMD +ALL_CFLAGS:=@DEFS@ -I$(srcdir) -I. $(CFLAGS) $(EXTRA_CFLAGS) +CPPFLAGS:=@CPPFLAGS@ -DDATAROOTDIR='"$(datarootdir)"' $(EXTRA_CPPFLAGS) +LDFLAGS:=@LDFLAGS@ $(EXTRA_LDFLAGS) +LDLIBS:=@LIBS@ $(EXTRA_LDLIBS) TARGETS:=secnet OBJECTS:=secnet.o util.o conffile.yy.o conffile.tab.o conffile.o modules.o \ - resolver.o random.o udp.o site.o transform.o netlink.o rsa.o dh.o \ - serpent.o md5.o version.o tun.o slip.o sha1.o ipaddr.o log.o \ + resolver.o random.o udp.o site.o transform-cbcmac.o transform-eax.o \ + comm-common.o polypath.o \ + netlink.o rsa.o dh.o xdh.o serpent.o serpentbe.o \ + scaf.o f25519.o x25519.o ed25519.o fgoldi.o x448.o ed448.o \ + md5.o sha512.o keccak1600.o sha3.o \ + tun.o slip.o sha1.o ipaddr.o log.o \ process.o @LIBOBJS@ \ hackypar.o +# version.o is handled specially below and in the link rule for secnet. -DISTDIRS:=debian -DISTFILES:=BUGS COPYING CREDITS INSTALL LICENSE.txt Makefile.in \ - NEWS NOTES README TODO \ - setup.mac uk.org.greenend.secnet.plist README.mac \ - ac_prog_cc_no_writeable_strings.m4 \ - conffile.c conffile.fl conffile.h conffile.y \ - conffile_internal.h \ - config.h.in configure \ - configure.in depend.sh dh.c \ - example.conf \ - install-sh ipaddr.c ipaddr.h ipaddr.py linux log.c \ - magic.h md5.c md5.h \ - make-secnet-sites \ - modules.c netlink.c netlink.h process.c process.h \ - random.c resolver.c rsa.c \ - secnet.c secnet.h serpent.c serpent.h serpentsboxes.h \ - snprintf.c snprintf.h \ - sha1.c site.c slip.c stamp-h.in transform.c tun.c udp.c \ - unaligned.h util.c util.h \ - hackypar.c hackypar.h -DISTSUBDIRS:=debian/copyright debian/changelog debian/control \ - debian/init debian/rules debian/compat debian/default +TEST_OBJECTS:=eax-aes-test.o eax-serpent-test.o eax-serpentbe-test.o \ + eax-test.o aes.o x25519-test.o x448-test.o + +ifeq (version.o,$(MAKECMDGOALS)) +OBJECTS:=version.o +TEST_OBJECTS:= +endif + +STALE_PYTHON_FILES= $(foreach e, py pyc, \ + $(foreach p, /usr /usr/local, \ + $(foreach l, ipaddr, \ + $(DESTDIR)$p/share/secnet/$l.$e \ + ))) %.c: %.y @@ -88,10 +91,10 @@ DISTSUBDIRS:=debian/copyright debian/changelog debian/control \ %.tab.c %.tab.h: %.y bison -d -o $@ $< -%.o: %.c +%.o: %.c conffile.yy.h $(CC) $(CPPFLAGS) $(ALL_CFLAGS) -c $< -o $@ -all: $(TARGETS) +all: $(TARGETS) check # Automatic remaking of configuration files, from autoconf documentation ${srcdir}/configure: configure.in @@ -115,15 +118,10 @@ config.status: configure # End of config file remaking rules # C and header file dependency rules -SOURCES:=$(OBJECTS:.o=.c) -DEPENDS:=$(OBJECTS:.o=.d) - -$(DEPENDS): ${srcdir}/depend.sh +SOURCES:=$(OBJECTS:.o=.c) $(TEST_OBJECTS:.o=.c) +DEPENDS:=$(OBJECTS:.o=.d) $(TEST_OBJECTS:.o=.d) -%.d: %.c - ${srcdir}/depend.sh $(srcdir) $(CPPFLAGS) $(ALL_CFLAGS) $< > $@ - --include $(DEPENDS) +-include *.d # Manual dependencies section conffile.yy.c: conffile.fl conffile.tab.c @@ -131,23 +129,117 @@ conffile.yy.h: conffile.yy.c conffile.tab.c: conffile.y # End of manual dependencies section +conffile.yy.o: ALL_CFLAGS += -Wno-sign-compare + secnet: $(OBJECTS) - $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $(OBJECTS) $(LDLIBS) + $(MAKE) version.o # *.o $(filter-out %.o, $^) + $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $(OBJECTS) version.o $(LDLIBS) +# We (always) regenerate the version, but only if we regenerate the +# binary. (This is necessary as the version string is can depend on +# any of the source files, eg to see whether "+" is needed.) + +ifneq (,$(wildcard .git/HEAD)) +# If we have (eg) committed, relink and thus regenerate the version +# with the new info from git describe. +secnet: Makefile .git/HEAD $(shell sed -n 's#^ref: #.git/#p' .git/HEAD) +secnet: $(wildcard .git/packed-refs) +endif + +CRYPTO_TESTS = keccak1600 sha3 f25519 x25519 ed25519 fgoldi x448 ed448 + +check: eax-aes-test.confirm eax-serpent-test.confirm \ + eax-serpentbe-test.confirm check-ipaddrset \ + msgcode-test.confirm \ + $(foreach c,$(CRYPTO_TESTS),$c-test.confirm) version.c: Makefile echo "#include \"secnet.h\"" >$@.new - echo "char version[]=\"secnet $(VERSION)\";" >>$@.new + @set -ex; if test -e .git && type -p git >/dev/null; then \ + v=$$(git describe --match 'v*'); v=$${v#v}; \ + if ! git diff --quiet HEAD; then v="$$v+"; fi; \ + else \ + v="$(VERSION)"; \ + fi; \ + echo "char version[]=\"secnet $$v\";" >>$@.new mv -f $@.new $@ -install: all +eax-%-test: eax-%-test.o eax-test.o %.o + $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $^ + +eax-%-test.confirm: eax-%-test eax-%-test.vectors + ./$< <$(srcdir)/eax-$*-test.vectors >$@.new + mv -f $@.new $@ + +msgcode-test: msgcode-test.o + $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $^ + +msgcode-test.confirm: msgcode-test + ./msgcode-test + touch $@ + +$(foreach c,$(CRYPTO_TESTS),$c-test): %-test: %-test.o crypto-test.o + $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $^ + +$(foreach c,$(CRYPTO_TESTS),$c-test.confirm): \ + %-test.confirm: %-test %-tests.in + ./$*-test <$(srcdir)/$*-tests.in + touch $@ + +keccak1600-test: keccak1600.o +sha3-test: sha3.o keccak1600.o +f25519-test: f25519.o +x25519-test: x25519.o f25519.o +ed25519-test: sha512.o f25519.o scaf.o ed25519.o +fgoldi-test: fgoldi.o +x448-test: x448.o fgoldi.o +ed448-test: keccak1600.o sha3.o fgoldi.o scaf.o ed448.o + +f25519-test.o: ec-field-test.c + $(CC) $(CPPFLAGS) $(ALL_CFLAGS) -c -DFIELD=f25519 $< -o $@ +fgoldi-test.o: ec-field-test.c + $(CC) $(CPPFLAGS) $(ALL_CFLAGS) -c -DFIELD=fgoldi $< -o $@ +x25519-test.o: xdh-test.c + $(CC) $(CPPFLAGS) $(ALL_CFLAGS) -c -DXDH=x25519 -DFIELD=f25519 $< -o $@ +x448-test.o: xdh-test.c + $(CC) $(CPPFLAGS) $(ALL_CFLAGS) -c -DXDH=x448 -DFIELD=fgoldi $< -o $@ + +check-ipaddrset: ipaddrset-test.py ipaddrset.py ipaddrset-test.expected + $(srcdir)/ipaddrset-test.py >ipaddrset-test.new + diff -u $(srcdir)/ipaddrset-test.expected ipaddrset-test.new + +.PRECIOUS: eax-%-test + +installdirs: $(INSTALL) -d $(prefix)/share/secnet $(sbindir) + $(INSTALL) -d $(mandir)/man8 + $(INSTALL) -d $(datarootdir)/secnet + +install: installdirs + set -e; ok=true; for f in $(STALE_PYTHON_FILES); do \ + if test -e $$f; then \ + echo >&2 "ERROR: $$f still exists "\ + "- try \`make install-force'"; \ + ok=false; \ + fi; \ + done; \ + $$ok $(INSTALL_PROGRAM) secnet $(sbindir)/`echo secnet|sed '$(transform)'` $(INSTALL_PROGRAM) ${srcdir}/make-secnet-sites $(sbindir)/`echo make-secnet-sites|sed '$(transform)'` - $(INSTALL) ${srcdir}/ipaddr.py $(prefix)/share/secnet/ipaddr.py + $(INSTALL_DATA) ${srcdir}/ipaddrset.py $(prefix)/share/secnet/ipaddrset.py + $(INSTALL_SCRIPT) ${srcdir}/polypath-interface-monitor-linux \ + $(datarootdir)/secnet/. + $(INSTALL_DATA) ${srcdir}/secnet.8 $(mandir)/man8/secnet.8 + +install-force: + rm -f $(STALE_PYTHON_FILES) + $(MAKE) install clean: - $(RM) -f *.o *.yy.c *.tab.[ch] $(TARGETS) core version.c - $(RM) -f *.d *~ + $(RM) -f *.o *.yy.[ch] *.tab.[ch] $(TARGETS) core version.c + $(RM) -f *.d *.pyc *~ eax-*-test.confirm eax-*-test + $(RM) -f msgcode-test.confirm msgcode-test + $(RM) -f $(addsuffix -test, $(CRYPTO_TESTS)) + $(RM) -f $(addsuffix -test.confirm, $(CRYPTO_TESTS)) realclean: clean $(RM) -f *~ Makefile config.h *.d \ @@ -156,13 +248,48 @@ realclean: clean distclean: realclean -pfname:=$(PACKAGE)-$(VERSION) -dist: - $(RM) -rf $(pfname) - mkdir $(pfname) - for i in $(DISTDIRS) ; do mkdir $(pfname)/$$i ; done - for i in $(DISTFILES) ; do ln -s ../$(srcdir)/$$i $(pfname)/ ; done - for i in $(DISTSUBDIRS) ; do ln -s ../../$(srcdir)/$$i $(pfname)/$$i ; done - tar hcf ../$(pfname).tar --exclude=CVS --exclude=.cvsignore $(pfname) - gzip -9f ../$(pfname).tar - $(RM) -rf $(pfname) +# Release checklist: +# +# 0. Use this checklist from Makefile.in +# +# 1. Check that the tree has what you want +# +# 2. Update changelog: +# gbp dch --since= +# and then edit debian/changelog. +# +# 3. Update VERSION (in this file, above) and +# finalise debian/changelog (removing ~ from version) and commit. +# +# 4. Build source and binaries: +# dgit -wgf sbuild -A -c stretch +# +# 5. dpkg -i on zealot just to check +# dpkg -i ~ian/things/Fvpn/bpd/secnet_${VERSION}_amd64.deb +# +# 6. run it on chiark +# check we can still ping davenant and chiark +# +# 7. Make git tag and source tarball signature: +# git-tag -u general -m "secnet $VERSION" -s v${VERSION//\~/_} +# gpg -u general --detach-sign ../bpd/secnet_$VERSION.tar.gz +# +# 8. Publish the branch and distriubtion files: +# git-push origin v${VERSION//\~/_} v${VERSION//\~/_}~0:master +# dcmd rsync -v ../bpd/secnet_${VERSION}_multi.changes chiark:/home/ianmdlvl/public-html/secnet/download/ +# +# 9. Sort out html. On chiark as user secnet: +# cd ~secnet/public-html/release/ +# mkdir $VERSION +# cd $VERSION +# ln -s /home/ianmdlvl/public-html/secnet/download/secnet?$VERSION* . +# ln -sfn $VERSION ../current +# +# 10. write and post a release announcement +# cd ../bpd +# dcmd sha256sum secnet_${VERSION}_multi.changes +# ... +# gpg --clearsign ../release-announcement +# rsync -vP ../release-announcement.asc c:mail/d/ +# +# 11. bump changelog version in master, to new version with ~