# 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
#
CC ?= gcc -std=c99
CFLAGS ?= -pedantic -Wall -Wextra
.PHONY: all clean
VEC = chacha20 hchacha20 xchacha20 ietf_chacha20 \
aead_ietf aead_8439 \
poly1305 blake2b sha512 sha512_hmac sha512_hkdf argon2 \
edDSA edDSA_pk ed_25519 ed_25519_pk ed_25519_check \
ed_25519ph \
x25519 x25519_pk elligator_inv elligator_dir
VEC2 = $(patsubst %, %.all.vec, $(VEC))
HEADERS = $(patsubst %, %.h.vec , $(VEC))
VECTORS = ../vectors.h
all: $(VECTORS)
clean:
rm -f *.out *.vec *.o
rm -f $(VECTORS)
elligator_inv.vec: elligator-inverse.py elligator.py elligator_scalarmult.py
./$< >$@
elligator_dir.vec: elligator-direct.py elligator.py
./$< >$@
sha512_hkdf.vec: sha512_hkdf.py
./$< >$@
%.vec: %.out
./$< > $@
utils.o: utils.c utils.h
$(CC) $(CFLAGS) -c $< -o $@
%.o: %.c ../utils.h ../externals/ed25519-donna/ed25519.h
$(CC) $(CFLAGS) -c $< \
-I .. \
-I ../externals/ed25519-donna \
-I ../../src \
-I ../../src/optional \
$$(pkg-config --cflags libsodium)
%.out: %.o ed25519.o utils.o
$(CC) $(CFLAGS) -o $@ $^ \
$$(pkg-config --libs libsodium)
ed25519.o: ../externals/ed25519-donna/ed25519.c \
$(wildcard ../externals/ed25519-donna/*.h)
$(CC) $(CFLAGS) -c $< \
-I ../../src \
-I ../../src/optional \
$$(pkg-config --cflags libsodium) \
-DED25519_CUSTOMHASH \
-DED25519_TEST \
-DED25519_NO_INLINE_ASM \
-DED25519_FORCE_32BIT
vector_to_header.out: vector_to_header.c
$(CC) $(CFLAGS) $< -o $@
chacha20.all.vec : chacha20.vec vectors/chacha20
poly1305.all.vec : poly1305.vec vectors/poly1305
x25519.all.vec : x25519.vec vectors/x25519
x25519_pk.all.vec : x25519_pk.vec
hchacha20.all.vec : hchacha20.vec
xchacha20.all.vec : xchacha20.vec
ietf_chacha20.all.vec : ietf_chacha20.vec
aead_ietf.all.vec : aead_ietf.vec
aead_8439.all.vec : aead_8439.vec
blake2b.all.vec : blake2b.vec vectors/blake2b
sha512.all.vec : sha512.vec
sha512_hmac.all.vec : sha512_hmac.vec vectors/sha512_hmac
sha512_hkdf.all.vec : sha512_hkdf.vec
argon2.all.vec : argon2.vec vectors/argon2
edDSA.all.vec : edDSA.vec
edDSA_pk.all.vec : edDSA_pk.vec
ed_25519.all.vec : ed_25519.vec
ed_25519_pk.all.vec : ed_25519_pk.vec
ed_25519_check.all.vec: vectors/ed_25519_check
ed_25519ph.all.vec : vectors/ed_25519ph
elligator_dir.all.vec : elligator_dir.vec vectors/elligator_dir
elligator_inv.all.vec : elligator_inv.vec vectors/elligator_inv
$(VEC2):
mkdir -p $(@D)
cat $^ > $@
%.h.vec: %.all.vec vector_to_header.out
./vector_to_header.out $(patsubst %.all.vec,%,$<) < $< > $@
prelude.h.vec:
@echo "creating prelude.h.vec"
@echo "// Generated with hard coded official vectors, and" > $@
@echo "// random vectors with libsodium and ed25519-donna." >> $@
@echo "// Download Monocypher's git repository to regenerate." >> $@
@echo "#include " >> $@
@echo "#include " >> $@
@echo "" >> $@
$(VECTORS): prelude.h.vec $(HEADERS)
cat $^ > $@