]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - sys/modules/crypto/Makefile
contrib/tzdata: import tzdata 2020f
[FreeBSD/FreeBSD.git] / sys / modules / crypto / Makefile
1 # $FreeBSD$
2
3 LIBSODIUM=${SRCTOP}/sys/contrib/libsodium/src/libsodium
4
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
20
21 KMOD    = crypto
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
38 # 20201002 Add explict Makefile dependency for reenabled assembly optimized
39 # version. SKEIN_USE_ASM determines which routines should come from the assembly
40 # vs C versions, and skein_block needs to be rebuilt if it changes.
41 skein_block.o: Makefile
42 .endif
43 SRCS    += siphash.c
44 SRCS    += gmac.c gfmult.c
45 SRCS    += blake2b-ref.c
46 SRCS    += blake2s-ref.c
47 SRCS    += blake2-sw.c
48 CFLAGS.blake2b-ref.c    += -I${SRCTOP}/sys/crypto/blake2 -DSUFFIX=_ref
49 CFLAGS.blake2s-ref.c    += -I${SRCTOP}/sys/crypto/blake2 -DSUFFIX=_ref
50 CFLAGS.blake2-sw.c      += -I${SRCTOP}/sys/crypto/blake2
51 CWARNFLAGS.blake2b-ref.c        += -Wno-cast-qual -Wno-unused-function
52 CWARNFLAGS.blake2s-ref.c        += -Wno-cast-qual -Wno-unused-function
53 SRCS    += chacha.c
54 SRCS    += chacha-sw.c
55
56 LIBSODIUM_INC=${LIBSODIUM}/include
57 LIBSODIUM_COMPAT=${SRCTOP}/sys/crypto/libsodium
58 SRCS    += xform_poly1305.c
59 CFLAGS.xform_poly1305.c         += -I${LIBSODIUM_INC} -I${LIBSODIUM_COMPAT}
60 SRCS    += onetimeauth_poly1305.c
61 CFLAGS.onetimeauth_poly1305.c   += -I${LIBSODIUM_INC}/sodium -I${LIBSODIUM_COMPAT}
62 SRCS    += poly1305_donna.c
63 CFLAGS.poly1305_donna.c         += -I${LIBSODIUM_INC}/sodium -I${LIBSODIUM_COMPAT}
64 SRCS    += verify.c
65 CFLAGS.verify.c                 += -I${LIBSODIUM_INC}/sodium -I${LIBSODIUM_COMPAT}
66 SRCS    += randombytes.c
67 CFLAGS.randombytes.c            += -I${LIBSODIUM_INC} -I${LIBSODIUM_COMPAT}
68 SRCS    += utils.c
69 CFLAGS.utils.c                  += -I${LIBSODIUM_INC} -I${LIBSODIUM_COMPAT}
70
71 SRCS    += opt_param.h cryptodev_if.h bus_if.h device_if.h
72 SRCS    += opt_compat.h
73 SRCS    += opt_ddb.h
74 SRCS    += cbc_mac.c
75 SRCS    += xform_cbc_mac.c
76
77 .include <bsd.kmod.mk>