0e33efe4e4
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
72 lines
1.2 KiB
C
72 lines
1.2 KiB
C
/*
|
|
BLAKE2 reference source code package - optimized C implementations
|
|
|
|
Written in 2012 by Samuel Neves <sneves@dei.uc.pt>
|
|
|
|
To the extent possible under law, the author(s) have dedicated all copyright
|
|
and related and 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 <http://creativecommons.org/publicdomain/zero/1.0/>.
|
|
*/
|
|
#pragma once
|
|
#ifndef __BLAKE2_CONFIG_H__
|
|
#define __BLAKE2_CONFIG_H__
|
|
|
|
#if defined(__SSE2__)
|
|
#define HAVE_SSE2
|
|
#endif
|
|
|
|
#if defined(__SSSE3__)
|
|
#define HAVE_SSSE3
|
|
#endif
|
|
|
|
#if defined(__SSE4_1__)
|
|
#define HAVE_SSE4_1
|
|
#endif
|
|
|
|
#if defined(__AVX__)
|
|
#define HAVE_AVX
|
|
#endif
|
|
|
|
#if defined(__XOP__)
|
|
#define HAVE_XOP
|
|
#endif
|
|
|
|
|
|
#ifdef HAVE_AVX2
|
|
#ifndef HAVE_AVX
|
|
#define HAVE_AVX
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef HAVE_XOP
|
|
#ifndef HAVE_AVX
|
|
#define HAVE_AVX
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef HAVE_AVX
|
|
#ifndef HAVE_SSE4_1
|
|
#define HAVE_SSE4_1
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef HAVE_SSE41
|
|
#ifndef HAVE_SSSE3
|
|
#define HAVE_SSSE3
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef HAVE_SSSE3
|
|
#define HAVE_SSE2
|
|
#endif
|
|
|
|
#if !defined(HAVE_SSE2)
|
|
#error "This code requires at least SSE2."
|
|
#endif
|
|
|
|
#endif
|
|
|