mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-15 04:30:33 +03:00
9f0a21e641
Add the FreeBSD platform code to the OpenZFS repository. As of this commit the source can be compiled and tested on FreeBSD 11 and 12. Subsequent commits are now required to compile on FreeBSD and Linux. Additionally, they must pass the ZFS Test Suite on FreeBSD which is being run by the CI. As of this commit 1230 tests pass on FreeBSD and there are no unexpected failures. Reviewed-by: Sean Eric Fagan <sef@ixsystems.com> Reviewed-by: Jorgen Lundman <lundman@lundman.net> Reviewed-by: Richard Laager <rlaager@wiktel.com> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Co-authored-by: Ryan Moeller <ryan@iXsystems.com> Signed-off-by: Matt Macy <mmacy@FreeBSD.org> Signed-off-by: Ryan Moeller <ryan@iXsystems.com> Closes #898 Closes #8987
201 lines
5.3 KiB
C
201 lines
5.3 KiB
C
/*
|
|
* CDDL HEADER START
|
|
*
|
|
* The contents of this file are subject to the terms of the
|
|
* Common Development and Distribution License (the "License").
|
|
* You may not use this file except in compliance with the License.
|
|
*
|
|
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
|
|
* or http://www.opensolaris.org/os/licensing.
|
|
* See the License for the specific language governing permissions
|
|
* and limitations under the License.
|
|
*
|
|
* When distributing Covered Code, include this CDDL HEADER in each
|
|
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
|
|
* If applicable, add the following below this CDDL HEADER, with the
|
|
* fields enclosed by brackets "[]" replaced with your own identifying
|
|
* information: Portions Copyright [yyyy] [name of copyright owner]
|
|
*
|
|
* CDDL HEADER END
|
|
*/
|
|
/*
|
|
* Copyright 2009 Sun Microsystems, Inc. All rights reserved.
|
|
* Use is subject to license terms.
|
|
*/
|
|
/* Copyright 2013 Saso Kiselkov. All rights reserved. */
|
|
|
|
#ifndef _SYS_SHA2_H
|
|
#define _SYS_SHA2_H
|
|
|
|
#include <sys/types.h> /* for uint_* */
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#define SHA2_HMAC_MIN_KEY_LEN 1 /* SHA2-HMAC min key length in bytes */
|
|
#define SHA2_HMAC_MAX_KEY_LEN INT_MAX /* SHA2-HMAC max key length in bytes */
|
|
|
|
#define SHA256_DIGEST_LENGTH 32 /* SHA256 digest length in bytes */
|
|
#define SHA384_DIGEST_LENGTH 48 /* SHA384 digest length in bytes */
|
|
#define SHA512_DIGEST_LENGTH 64 /* SHA512 digest length in bytes */
|
|
|
|
/* Truncated versions of SHA-512 according to FIPS-180-4, section 5.3.6 */
|
|
#define SHA512_224_DIGEST_LENGTH 28 /* SHA512/224 digest length */
|
|
#define SHA512_256_DIGEST_LENGTH 32 /* SHA512/256 digest length */
|
|
|
|
#define SHA256_HMAC_BLOCK_SIZE 64 /* SHA256-HMAC block size */
|
|
#define SHA512_HMAC_BLOCK_SIZE 128 /* SHA512-HMAC block size */
|
|
|
|
#define SHA256 0
|
|
#define SHA256_HMAC 1
|
|
#define SHA256_HMAC_GEN 2
|
|
#define SHA384 3
|
|
#define SHA384_HMAC 4
|
|
#define SHA384_HMAC_GEN 5
|
|
#define SHA512 6
|
|
#define SHA512_HMAC 7
|
|
#define SHA512_HMAC_GEN 8
|
|
#define SHA512_224 9
|
|
#define SHA512_256 10
|
|
|
|
/*
|
|
* SHA2 context.
|
|
* The contents of this structure are a private interface between the
|
|
* Init/Update/Final calls of the functions defined below.
|
|
* Callers must never attempt to read or write any of the fields
|
|
* in this structure directly.
|
|
*/
|
|
|
|
#include <crypto/sha2/sha256.h>
|
|
#include <crypto/sha2/sha384.h>
|
|
#include <crypto/sha2/sha512.h>
|
|
#include <crypto/sha2/sha512t.h>
|
|
typedef struct {
|
|
uint32_t algotype; /* Algorithm Type */
|
|
union {
|
|
SHA256_CTX SHA256_ctx;
|
|
SHA384_CTX SHA384_ctx;
|
|
SHA512_CTX SHA512_ctx;
|
|
};
|
|
} SHA2_CTX;
|
|
|
|
extern void SHA256Init(SHA256_CTX *);
|
|
|
|
extern void SHA256Update(SHA256_CTX *, const void *, size_t);
|
|
|
|
extern void SHA256Final(void *, SHA256_CTX *);
|
|
|
|
extern void SHA384Init(SHA384_CTX *);
|
|
|
|
extern void SHA384Update(SHA384_CTX *, const void *, size_t);
|
|
|
|
extern void SHA384Final(void *, SHA384_CTX *);
|
|
|
|
extern void SHA512Init(SHA512_CTX *);
|
|
|
|
extern void SHA512Update(SHA512_CTX *, const void *, size_t);
|
|
|
|
extern void SHA512Final(void *, SHA512_CTX *);
|
|
|
|
|
|
static inline void
|
|
SHA2Init(uint64_t mech, SHA2_CTX *c)
|
|
{
|
|
switch (mech) {
|
|
case SHA256:
|
|
SHA256_Init(&c->SHA256_ctx);
|
|
break;
|
|
case SHA384:
|
|
SHA384_Init(&c->SHA384_ctx);
|
|
break;
|
|
case SHA512:
|
|
SHA512_Init(&c->SHA512_ctx);
|
|
break;
|
|
case SHA512_256:
|
|
SHA512_256_Init(&c->SHA512_ctx);
|
|
break;
|
|
default:
|
|
panic("unknown mechanism %lu", mech);
|
|
}
|
|
c->algotype = (uint32_t)mech;
|
|
}
|
|
|
|
static inline void
|
|
SHA2Update(SHA2_CTX *c, const void *p, size_t s)
|
|
{
|
|
switch (c->algotype) {
|
|
case SHA256:
|
|
SHA256_Update(&c->SHA256_ctx, p, s);
|
|
break;
|
|
case SHA384:
|
|
SHA384_Update(&c->SHA384_ctx, p, s);
|
|
break;
|
|
case SHA512:
|
|
SHA512_Update(&c->SHA512_ctx, p, s);
|
|
break;
|
|
case SHA512_256:
|
|
SHA512_256_Update(&c->SHA512_ctx, p, s);
|
|
break;
|
|
default:
|
|
panic("unknown mechanism %d", c->algotype);
|
|
}
|
|
}
|
|
|
|
static inline void
|
|
SHA2Final(void *p, SHA2_CTX *c)
|
|
{
|
|
switch (c->algotype) {
|
|
case SHA256:
|
|
SHA256_Final(p, &c->SHA256_ctx);
|
|
break;
|
|
case SHA384:
|
|
SHA384_Final(p, &c->SHA384_ctx);
|
|
break;
|
|
case SHA512:
|
|
SHA512_Final(p, &c->SHA512_ctx);
|
|
break;
|
|
case SHA512_256:
|
|
SHA512_256_Final(p, &c->SHA512_ctx);
|
|
break;
|
|
default:
|
|
panic("unknown mechanism %d", c->algotype);
|
|
}
|
|
}
|
|
|
|
#ifdef _SHA2_IMPL
|
|
/*
|
|
* The following types/functions are all private to the implementation
|
|
* of the SHA2 functions and must not be used by consumers of the interface
|
|
*/
|
|
|
|
/*
|
|
* List of support mechanisms in this module.
|
|
*
|
|
* It is important to note that in the module, division or modulus calculations
|
|
* are used on the enumerated type to determine which mechanism is being used;
|
|
* therefore, changing the order or additional mechanisms should be done
|
|
* carefully
|
|
*/
|
|
typedef enum sha2_mech_type {
|
|
SHA256_MECH_INFO_TYPE, /* SUN_CKM_SHA256 */
|
|
SHA256_HMAC_MECH_INFO_TYPE, /* SUN_CKM_SHA256_HMAC */
|
|
SHA256_HMAC_GEN_MECH_INFO_TYPE, /* SUN_CKM_SHA256_HMAC_GENERAL */
|
|
SHA384_MECH_INFO_TYPE, /* SUN_CKM_SHA384 */
|
|
SHA384_HMAC_MECH_INFO_TYPE, /* SUN_CKM_SHA384_HMAC */
|
|
SHA384_HMAC_GEN_MECH_INFO_TYPE, /* SUN_CKM_SHA384_HMAC_GENERAL */
|
|
SHA512_MECH_INFO_TYPE, /* SUN_CKM_SHA512 */
|
|
SHA512_HMAC_MECH_INFO_TYPE, /* SUN_CKM_SHA512_HMAC */
|
|
SHA512_HMAC_GEN_MECH_INFO_TYPE, /* SUN_CKM_SHA512_HMAC_GENERAL */
|
|
SHA512_224_MECH_INFO_TYPE, /* SUN_CKM_SHA512_224 */
|
|
SHA512_256_MECH_INFO_TYPE /* SUN_CKM_SHA512_256 */
|
|
} sha2_mech_type_t;
|
|
|
|
#endif /* _SHA2_IMPL */
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* _SYS_SHA2_H */
|