Import Blake2 algorithms (blake2b, blake2s) from libb2
The upstream repository is on github BLAKE2/libb2. Files landed in
sys/contrib/libb2 are the unmodified upstream files, except for one
difference: secure_zero_memory's contents have been replaced with
explicit_bzero() only because the previous implementation broke powerpc
link. Preferential use of explicit_bzero() is in progress upstream, so
it is anticipated we will be able to drop this diff in the future.
sys/crypto/blake2 contains the source files needed to port libb2 to our
build system, a wrapped (limited) variant of the algorithm to match the API
of our auth_transform softcrypto abstraction, incorporation into the Open
Crypto Framework (OCF) cryptosoft(4) driver, as well as an x86 SSE/AVX
accelerated OCF driver, blake2(4).
Optimized variants of blake2 are compiled for a number of x86 machines
(anything from SSE2 to AVX + XOP). On those machines, FPU context will need
to be explicitly saved before using blake2(4)-provided algorithms directly.
Use via cryptodev / OCF saves FPU state automatically, and use via the
auth_transform softcrypto abstraction does not use FPU.
The intent of the OCF driver is mostly to enable testing in userspace via
/dev/crypto. ATF tests are added with published KAT test vectors to
validate correctness.
Reviewed by: jhb, markj
Obtained from: github BLAKE2/libb2
Differential Revision: https://reviews.freebsd.org/D14662
2018-03-21 16:18:14 +00:00
|
|
|
# $FreeBSD$
|
|
|
|
|
|
|
|
.PATH: ${SRCTOP}/sys/contrib/libb2
|
|
|
|
.PATH: ${SRCTOP}/sys/crypto/blake2
|
|
|
|
.PATH: ${SRCTOP}/sys/opencrypto
|
|
|
|
.PATH: ${SRCTOP}/contrib/llvm/tools/clang/lib/Headers
|
|
|
|
|
|
|
|
KMOD = blake2
|
|
|
|
|
|
|
|
# Vendor sources
|
|
|
|
SRCS += blake2.h
|
|
|
|
SRCS += blake2-impl.h
|
|
|
|
SRCS += blake2-config.h
|
|
|
|
|
|
|
|
SRCS += blake2-dispatch.c
|
|
|
|
SRCS += blake2bp.c
|
|
|
|
SRCS += blake2sp.c
|
|
|
|
|
|
|
|
CFLAGS += -I${SRCTOP}/sys/contrib/libb2
|
|
|
|
CFLAGS += -I${SRCTOP}/sys/crypto/blake2
|
|
|
|
|
|
|
|
# x86 specific optimization headers:
|
|
|
|
SRCS += blake2b-load-sse2.h
|
|
|
|
SRCS += blake2b-load-sse41.h
|
|
|
|
SRCS += blake2b-round.h
|
|
|
|
|
|
|
|
SRCS += blake2s-load-sse2.h
|
|
|
|
SRCS += blake2s-load-sse41.h
|
|
|
|
SRCS += blake2s-load-xop.h
|
|
|
|
SRCS += blake2s-round.h
|
|
|
|
|
|
|
|
# C files to build a dispatched fat implementation on x86
|
|
|
|
SRCS_IN += blake2b-sse2.c
|
|
|
|
SRCS_IN += blake2b-ssse3.c
|
|
|
|
SRCS_IN += blake2b-sse41.c
|
|
|
|
SRCS_IN += blake2b-avx.c
|
|
|
|
SRCS_IN += blake2b-xop.c
|
|
|
|
SRCS_IN += blake2s-sse2.c
|
|
|
|
SRCS_IN += blake2s-ssse3.c
|
|
|
|
SRCS_IN += blake2s-sse41.c
|
|
|
|
SRCS_IN += blake2s-avx.c
|
|
|
|
SRCS_IN += blake2s-xop.c
|
|
|
|
|
|
|
|
OBJS+= ${SRCS_IN:S/.c/.o/g}
|
|
|
|
|
|
|
|
CFLAGS.blake2b-sse2.c += -DSUFFIX=_sse2 -msse2
|
|
|
|
CFLAGS.blake2s-sse2.c += -DSUFFIX=_sse2 -msse2
|
|
|
|
|
|
|
|
CFLAGS.blake2b-ssse3.c += -DSUFFIX=_ssse3 -msse2 -mssse3
|
|
|
|
CFLAGS.blake2s-ssse3.c += -DSUFFIX=_ssse3 -msse2 -mssse3
|
|
|
|
|
|
|
|
CFLAGS.blake2b-sse41.c += -DSUFFIX=_sse41 -msse2 -mssse3 -msse4.1
|
|
|
|
CFLAGS.blake2s-sse41.c += -DSUFFIX=_sse41 -msse2 -mssse3 -msse4.1
|
|
|
|
|
|
|
|
CFLAGS.blake2b-avx.c += -DSUFFIX=_avx -msse2 -mssse3 -msse4.1 -mavx
|
|
|
|
CFLAGS.blake2s-avx.c += -DSUFFIX=_avx -msse2 -mssse3 -msse4.1 -mavx
|
|
|
|
|
|
|
|
CFLAGS.blake2b-xop.c += -DSUFFIX=_xop -msse2 -mssse3 -msse4.1 -mavx -mxop
|
|
|
|
CFLAGS.blake2s-xop.c += -DSUFFIX=_xop -msse2 -mssse3 -msse4.1 -mavx -mxop
|
|
|
|
|
|
|
|
.for src in ${SRCS_IN}
|
|
|
|
${src:S/.c/.o/}: ${src}
|
|
|
|
${CC} -c ${CFLAGS:N-nostdinc} ${CFLAGS.${src}} ${WERROR} ${PROF} \
|
2018-04-21 02:08:56 +00:00
|
|
|
-D_MM_MALLOC_H_INCLUDED -Wno-unused-function ${.IMPSRC}
|
Import Blake2 algorithms (blake2b, blake2s) from libb2
The upstream repository is on github BLAKE2/libb2. Files landed in
sys/contrib/libb2 are the unmodified upstream files, except for one
difference: secure_zero_memory's contents have been replaced with
explicit_bzero() only because the previous implementation broke powerpc
link. Preferential use of explicit_bzero() is in progress upstream, so
it is anticipated we will be able to drop this diff in the future.
sys/crypto/blake2 contains the source files needed to port libb2 to our
build system, a wrapped (limited) variant of the algorithm to match the API
of our auth_transform softcrypto abstraction, incorporation into the Open
Crypto Framework (OCF) cryptosoft(4) driver, as well as an x86 SSE/AVX
accelerated OCF driver, blake2(4).
Optimized variants of blake2 are compiled for a number of x86 machines
(anything from SSE2 to AVX + XOP). On those machines, FPU context will need
to be explicitly saved before using blake2(4)-provided algorithms directly.
Use via cryptodev / OCF saves FPU state automatically, and use via the
auth_transform softcrypto abstraction does not use FPU.
The intent of the OCF driver is mostly to enable testing in userspace via
/dev/crypto. ATF tests are added with published KAT test vectors to
validate correctness.
Reviewed by: jhb, markj
Obtained from: github BLAKE2/libb2
Differential Revision: https://reviews.freebsd.org/D14662
2018-03-21 16:18:14 +00:00
|
|
|
${CTFCONVERT_CMD}
|
|
|
|
|
|
|
|
${src:S/.c/.o/}: intrin.h emmintrin.h tmmintrin.h smmintrin.h immintrin.h \
|
|
|
|
x86intrin.h ${SRCS:M*.h}
|
|
|
|
.endfor
|
|
|
|
|
|
|
|
# FreeBSD-specific sources:
|
|
|
|
SRCS += blake2_kfreebsd.h
|
|
|
|
SRCS += config.h
|
|
|
|
|
|
|
|
SRCS += stddef.h
|
|
|
|
SRCS += stdint.h
|
|
|
|
SRCS += stdio.h
|
|
|
|
SRCS += stdlib.h
|
|
|
|
SRCS += string.h
|
|
|
|
|
|
|
|
SRCS += blake2_cryptodev.c
|
|
|
|
|
2018-03-22 08:32:39 +00:00
|
|
|
SRCS += opt_param.h cryptodev_if.h bus_if.h device_if.h
|
Import Blake2 algorithms (blake2b, blake2s) from libb2
The upstream repository is on github BLAKE2/libb2. Files landed in
sys/contrib/libb2 are the unmodified upstream files, except for one
difference: secure_zero_memory's contents have been replaced with
explicit_bzero() only because the previous implementation broke powerpc
link. Preferential use of explicit_bzero() is in progress upstream, so
it is anticipated we will be able to drop this diff in the future.
sys/crypto/blake2 contains the source files needed to port libb2 to our
build system, a wrapped (limited) variant of the algorithm to match the API
of our auth_transform softcrypto abstraction, incorporation into the Open
Crypto Framework (OCF) cryptosoft(4) driver, as well as an x86 SSE/AVX
accelerated OCF driver, blake2(4).
Optimized variants of blake2 are compiled for a number of x86 machines
(anything from SSE2 to AVX + XOP). On those machines, FPU context will need
to be explicitly saved before using blake2(4)-provided algorithms directly.
Use via cryptodev / OCF saves FPU state automatically, and use via the
auth_transform softcrypto abstraction does not use FPU.
The intent of the OCF driver is mostly to enable testing in userspace via
/dev/crypto. ATF tests are added with published KAT test vectors to
validate correctness.
Reviewed by: jhb, markj
Obtained from: github BLAKE2/libb2
Differential Revision: https://reviews.freebsd.org/D14662
2018-03-21 16:18:14 +00:00
|
|
|
|
|
|
|
WARNS ?= 6
|
|
|
|
|
|
|
|
.include <bsd.kmod.mk>
|
|
|
|
|
2018-04-21 02:08:56 +00:00
|
|
|
CWARNFLAGS.blake2-dispatch.c += -Wno-unused-const-variable
|
2018-05-19 00:04:01 +00:00
|
|
|
CWARNFLAGS.blake2s-ref.c += -Wno-cast-qual -Wno-unused-function
|
2018-04-21 02:08:56 +00:00
|
|
|
CWARNFLAGS += -Wno-cast-qual
|