3 LIBSODIUM=${SRCTOP}/sys/contrib/libsodium/src/libsodium
5 .PATH: ${SRCTOP}/sys/opencrypto
6 .PATH: ${SRCTOP}/sys/crypto
7 .PATH: ${SRCTOP}/sys/crypto/camellia
8 .PATH: ${SRCTOP}/sys/crypto/des
9 .PATH: ${SRCTOP}/sys/crypto/rijndael
10 .PATH: ${SRCTOP}/sys/crypto/sha2
11 .PATH: ${SRCTOP}/sys/crypto/siphash
12 .PATH: ${SRCTOP}/sys/crypto/skein
13 .PATH: ${SRCTOP}/sys/crypto/blake2
14 .PATH: ${SRCTOP}/sys/crypto/chacha20
15 .PATH: ${SRCTOP}/sys/contrib/libb2
16 .PATH: ${LIBSODIUM}/crypto_onetimeauth/poly1305
17 .PATH: ${LIBSODIUM}/crypto_onetimeauth/poly1305/donna
18 .PATH: ${LIBSODIUM}/crypto_verify/sodium
19 .PATH: ${SRCTOP}/sys/crypto/libsodium
22 SRCS = crypto.c cryptodev_if.c
23 SRCS += criov.c cryptosoft.c xform.c
24 SRCS += cryptodeflate.c rmd160.c rijndael-alg-fst.c rijndael-api.c rijndael-api-fst.c
25 SRCS += camellia.c camellia-api.c
26 SRCS += des_ecb.c des_enc.c des_setkey.c
27 SRCS += sha1.c sha256c.c sha512c.c
28 SRCS += skein.c skein_block.c
29 # unroll the 256 and 512 loops, half unroll the 1024
30 CFLAGS.skein_block.c += -DSKEIN_LOOP=995
31 .if exists(${MACHINE_ARCH}/skein_block_asm.S)
32 .PATH: ${SRCTOP}/sys/crypto/skein/${MACHINE_ARCH}
33 SRCS += skein_block_asm.S
34 CFLAGS += -DSKEIN_ASM -DSKEIN_USE_ASM=1792 # list of block functions to replace with assembly: 256+512+1024 = 1792
35 ACFLAGS += -DELF -Wa,--noexecstack
36 # Fully unroll all loops in the assembly optimized version
37 ACFLAGS += -DSKEIN_LOOP=0
40 SRCS += gmac.c gfmult.c
44 CFLAGS.blake2b-ref.c += -I${SRCTOP}/sys/crypto/blake2 -DSUFFIX=_ref
45 CFLAGS.blake2s-ref.c += -I${SRCTOP}/sys/crypto/blake2 -DSUFFIX=_ref
46 CFLAGS.blake2-sw.c += -I${SRCTOP}/sys/crypto/blake2
47 CWARNFLAGS.blake2b-ref.c += -Wno-cast-qual -Wno-unused-function
48 CWARNFLAGS.blake2s-ref.c += -Wno-cast-qual -Wno-unused-function
52 LIBSODIUM_INC=${LIBSODIUM}/include
53 LIBSODIUM_COMPAT=${SRCTOP}/sys/crypto/libsodium
54 SRCS += xform_poly1305.c
55 CFLAGS.xform_poly1305.c += -I${LIBSODIUM_INC} -I${LIBSODIUM_COMPAT}
56 SRCS += onetimeauth_poly1305.c
57 CFLAGS.onetimeauth_poly1305.c += -I${LIBSODIUM_INC}/sodium -I${LIBSODIUM_COMPAT}
58 SRCS += poly1305_donna.c
59 CFLAGS.poly1305_donna.c += -I${LIBSODIUM_INC}/sodium -I${LIBSODIUM_COMPAT}
61 CFLAGS.verify.c += -I${LIBSODIUM_INC}/sodium -I${LIBSODIUM_COMPAT}
63 CFLAGS.randombytes.c += -I${LIBSODIUM_INC} -I${LIBSODIUM_COMPAT}
65 CFLAGS.utils.c += -I${LIBSODIUM_INC} -I${LIBSODIUM_COMPAT}
67 SRCS += opt_param.h cryptodev_if.h bus_if.h device_if.h
71 SRCS += xform_cbc_mac.c
73 .include <bsd.kmod.mk>