spot-the-bug/stream-ciphers/monocypher-3.1.1/makefile

236 lines
9.4 KiB
Makefile
Raw Permalink Normal View History

2020-09-25 05:58:08 +00:00
# This file is dual-licensed. Choose whichever licence you want from
# the two licences listed below.
#
# The first licence is a regular 2-clause BSD licence. The second licence
# is the CC-0 from Creative Commons. It is intended to release Monocypher
# to the public domain. The BSD licence serves as a fallback option.
#
# SPDX-License-Identifier: BSD-2-Clause OR CC0-1.0
#
# ------------------------------------------------------------------------
#
# Copyright (c) 2017-2019, Loup Vaillant
# Copyright (c) 2017, 2019, Fabio Scotoni
# All rights reserved.
#
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are
# met:
#
# 1. Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
#
# 2. Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the
# distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
# HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#
# ------------------------------------------------------------------------
#
# Written in 2017-2019 by Loup Vaillant and Fabio Scotoni
#
# To the extent possible under law, the author(s) have dedicated all copyright
# and related neighboring rights to this software to the public domain
# worldwide. This software is distributed without any warranty.
#
# You should have received a copy of the CC0 Public Domain Dedication along
# with this software. If not, see
# <https://creativecommons.org/publicdomain/zero/1.0/>
CC=gcc -std=gnu99 # speed tests don't work with -std=cxx, they need the POSIX extensions
CFLAGS= -pedantic -Wall -Wextra -O3 -march=native
DESTDIR=
PREFIX=usr/local
LIBDIR=$(PREFIX)/lib
INCLUDEDIR=$(PREFIX)/include
PKGCONFIGDIR=$(LIBDIR)/pkgconfig
MANDIR=$(PREFIX)/share/man/man3
SONAME=libmonocypher.so.3
VERSION=3.1.1
ifdef USE_ED25519
LINK_ED25519=lib/monocypher-ed25519.o
INSTALL_ED25519=cp src/optional/monocypher-ed25519.h $(DESTDIR)/$(INCLUDEDIR)
endif
.PHONY: all library static-library dynamic-library \
install install-doc pkg-config-libhydrogen \
check test ctgrind \
speed speed-sodium speed-tweetnacl speed-hydrogen speed-c25519 \
clean uninstall \
dist
all : library
install: library src/monocypher.h monocypher.pc install-doc
mkdir -p $(DESTDIR)/$(INCLUDEDIR)
mkdir -p $(DESTDIR)/$(LIBDIR)
mkdir -p $(DESTDIR)/$(PKGCONFIGDIR)
cp -P lib/libmonocypher.a lib/libmonocypher.so* $(DESTDIR)/$(LIBDIR)
cp src/monocypher.h $(DESTDIR)/$(INCLUDEDIR)
$(INSTALL_ED25519)
sed "s|PREFIX|$(PREFIX)|" monocypher.pc \
> $(DESTDIR)/$(PKGCONFIGDIR)/monocypher.pc
install-doc:
mkdir -p $(DESTDIR)/$(MANDIR)
cp -PR doc/man/man3/*.3monocypher $(DESTDIR)/$(MANDIR)
ifdef USE_ED25519
cp -PR doc/man/man3/optional/*.3monocypher $(DESTDIR)/$(MANDIR)
endif
pkg-config-libhydrogen:
mkdir -p $(DESTDIR)/$(PKGCONFIGDIR)
sed "s|PREFIX|$(PREFIX)|" tests/speed/libhydrogen.pc \
> $(DESTDIR)/$(PKGCONFIGDIR)/libhydrogen.pc
library: static-library dynamic-library
static-library : lib/libmonocypher.a
dynamic-library: lib/libmonocypher.so lib/$(SONAME)
clean:
rm -rf lib/
rm -f *.out
uninstall:
rm -f $(DESTDIR)/$(LIBDIR)/libmonocypher.a
rm -f $(DESTDIR)/$(LIBDIR)/libmonocypher.so*
rm -f $(DESTDIR)/$(INCLUDEDIR)/monocypher.h
rm -f $(DESTDIR)/$(INCLUDEDIR)/monocypher-ed25519.h
rm -f $(DESTDIR)/$(PKGCONFIGDIR)/monocypher.pc
rm -f $(DESTDIR)/$(MANDIR)/*.3monocypher
check: test
test : test.out
test-legacy : test-legacy.out
speed : speed.out
speed-sodium : speed-sodium.out
speed-tweetnacl: speed-tweetnacl.out
speed-hydrogen : speed-hydrogen.out
speed-c25519 : speed-c25519.out
test test-legacy speed speed-sodium speed-tweetnacl speed-hydrogen speed-c25519:
./$<
ctgrind: ctgrind.out
valgrind ./ctgrind.out
# Monocypher libraries
lib/libmonocypher.a: lib/monocypher.o $(LINK_ED25519)
ar cr $@ $^
lib/libmonocypher.so: lib/$(SONAME)
@mkdir -p $(@D)
ln -sf `basename $<` $@
lib/$(SONAME): lib/monocypher.o $(LINK_ED25519)
@mkdir -p $(@D)
$(CC) $(CFLAGS) $(LDFLAGS) -shared -Wl,-soname,$(SONAME) -o $@ $^
lib/monocypher-ed25519.o: src/optional/monocypher-ed25519.c \
src/optional/monocypher-ed25519.h
lib/chacha20.o : src/deprecated/chacha20.c src/deprecated/chacha20.h
lib/aead-incr.o : src/deprecated/aead-incr.c src/deprecated/aead-incr.h
lib/monocypher.o: src/monocypher.c src/monocypher.h
lib/monocypher.o lib/monocypher-ed25519.o lib/chacha20.o lib/aead-incr.o:
@mkdir -p $(@D)
$(CC) $(CFLAGS) -I src -I src/optional -fPIC -c -o $@ $<
# Test & speed libraries
TEST_COMMON = tests/utils.h src/monocypher.h src/optional/monocypher-ed25519.h
TEST_LEGACY = $(TEST_COMMON) src/deprecated/chacha20.h src/deprecated/aead-incr.h
SPEED = tests/speed
lib/utils.o :tests/utils.c
lib/test.o :tests/test.c $(TEST_COMMON) tests/vectors.h
lib/test-legacy.o :tests/test-legacy.c $(TEST_LEGACY) tests/vectors.h
lib/ctgrind.o :tests/ctgrind.c $(TEST_COMMON)
lib/speed.o :$(SPEED)/speed.c $(TEST_COMMON) $(SPEED)/speed.h
lib/speed-tweetnacl.o:$(SPEED)/speed-tweetnacl.c $(TEST_COMMON) $(SPEED)/speed.h
lib/utils.o lib/test.o lib/test-legacy.o lib/speed.o:
@mkdir -p $(@D)
$(CC) $(CFLAGS) \
-I src -I src/optional -I tests \
-fPIC -c -o $@ $<
lib/ctgrind.o: # suppress optimisations to maximise findings
@mkdir -p $(@D)
$(CC) $(CFLAGS) -O0 \
-I src -I src/optional -I tests \
-fPIC -c -o $@ $<
lib/speed-tweetnacl.o:
@mkdir -p $(@D)
$(CC) $(CFLAGS) \
-I src -I src/optional -I tests -I tests/externals/tweetnacl \
-fPIC -c -o $@ $<
lib/speed-sodium.o:$(SPEED)/speed-sodium.c $(TEST_COMMON) $(SPEED)/speed.h
@mkdir -p $(@D)
$(CC) $(CFLAGS) \
-I src -I src/optional -I tests \
`pkg-config --cflags libsodium` \
-fPIC -c -o $@ $<
lib/speed-hydrogen.o:$(SPEED)/speed-hydrogen.c $(TEST_COMMON) $(SPEED)/speed.h
@mkdir -p $(@D)
$(CC) $(CFLAGS) \
-I src -I src/optional -I tests \
`pkg-config --cflags libhydrogen` \
-fPIC -c -o $@ $<
C25519= c25519 edsign ed25519 morph25519 fprime f25519 sha512
C25519_H= $(patsubst %, tests/externals/c25519/%.h, $(C25519))
C25519_OBJECTS= $(patsubst %, lib/c25519/%.o, $(C25519))
lib/c25519/c25519.o : tests/externals/c25519/c25519.c $(C25519_H)
lib/c25519/ed25519.o : tests/externals/c25519/ed25519.c $(C25519_H)
lib/c25519/edsign.o : tests/externals/c25519/edsign.c $(C25519_H)
lib/c25519/f25519.o : tests/externals/c25519/f25519.c $(C25519_H)
lib/c25519/fprime.o : tests/externals/c25519/fprime.c $(C25519_H)
lib/c25519/morph25519.o: tests/externals/c25519/morph25519.c $(C25519_H)
lib/c25519/sha512.o : tests/externals/c25519/sha512.c $(C25519_H)
$(C25519_OBJECTS):
@mkdir -p $(@D)
$(CC) $(CFLAGS) -I tests/externals/c25519/ -c -o $@ $<
lib/speed-c25519.o:$(SPEED)/speed-c25519.c \
$(SPEED)/speed.h \
$(TEST_COMMON) \
$(C25519_HEADERS)
@mkdir -p $(@D)
$(CC) $(CFLAGS) -I tests -I tests/externals/c25519 -c -o $@ $<
# test & speed executables
TEST_OBJ= lib/utils.o lib/monocypher.o
test.out : lib/test.o $(TEST_OBJ) lib/monocypher-ed25519.o
test-legacy.out: lib/test-legacy.o $(TEST_OBJ) lib/chacha20.o lib/aead-incr.o
ctgrind.out : lib/ctgrind.o $(TEST_OBJ) lib/monocypher-ed25519.o
speed.out : lib/speed.o $(TEST_OBJ) lib/monocypher-ed25519.o
test.out test-legacy.out speed.out:
$(CC) $(CFLAGS) -I src -I src/optional -o $@ $^
ctgrind.out:
$(CC) $(CFLAGS) -O0 -I src -I src/optional -o $@ $^
speed-sodium.out: lib/speed-sodium.o lib/utils.o
$(CC) $(CFLAGS) -o $@ $^ \
`pkg-config --cflags libsodium` \
`pkg-config --libs libsodium`
speed-hydrogen.out: lib/speed-hydrogen.o lib/utils.o
$(CC) $(CFLAGS) -o $@ $^ \
`pkg-config --cflags libhydrogen` \
`pkg-config --libs libhydrogen`
lib/tweetnacl.o: tests/externals/tweetnacl/tweetnacl.c \
tests/externals/tweetnacl/tweetnacl.h
$(CC) $(CFLAGS) -c -o $@ $<
speed-tweetnacl.out: lib/speed-tweetnacl.o lib/tweetnacl.o lib/utils.o
speed-c25519.out : lib/speed-c25519.o $(C25519_OBJECTS) lib/utils.o
speed-tweetnacl.out speed-c25519.out:
$(CC) $(CFLAGS) -o $@ $^