]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - sys/modules/crypto/Makefile
Rename skein_block_asm.s to .S and assemble using Clang IAS
[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 .endif
39 SRCS    += siphash.c
40 SRCS    += gmac.c gfmult.c
41 SRCS    += blake2b-ref.c
42 SRCS    += blake2s-ref.c
43 SRCS    += blake2-sw.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
49 SRCS    += chacha.c
50 SRCS    += chacha-sw.c
51
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}
60 SRCS    += verify.c
61 CFLAGS.verify.c                 += -I${LIBSODIUM_INC}/sodium -I${LIBSODIUM_COMPAT}
62 SRCS    += randombytes.c
63 CFLAGS.randombytes.c            += -I${LIBSODIUM_INC} -I${LIBSODIUM_COMPAT}
64 SRCS    += utils.c
65 CFLAGS.utils.c                  += -I${LIBSODIUM_INC} -I${LIBSODIUM_COMPAT}
66
67 SRCS    += opt_param.h cryptodev_if.h bus_if.h device_if.h
68 SRCS    += opt_compat.h
69 SRCS    += opt_ddb.h
70 SRCS    += cbc_mac.c
71 SRCS    += xform_cbc_mac.c
72
73 .include <bsd.kmod.mk>