1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- /*
- * Copyright 2019-2021 The OpenSSL Project Authors. All Rights Reserved.
- *
- * Licensed under the Apache License 2.0 (the "License"). You may not use
- * this file except in compliance with the License. You can obtain a copy
- * in the file LICENSE in the source distribution or at
- * https://www.openssl.org/source/license.html
- */
- #include "crypto/evp.h"
- #include "prov/blake2.h" /* diverse BLAKE2 macros */
- #include "legacy_meth.h"
- /*
- * Local hack to adapt the BLAKE2 init functions to what the
- * legacy function signatures demand.
- */
- static int blake2s_init(BLAKE2S_CTX *C)
- {
- BLAKE2S_PARAM P;
- ossl_blake2s_param_init(&P);
- return ossl_blake2s_init(C, &P);
- }
- static int blake2b_init(BLAKE2B_CTX *C)
- {
- BLAKE2B_PARAM P;
- ossl_blake2b_param_init(&P);
- return ossl_blake2b_init(C, &P);
- }
- #define blake2s_update ossl_blake2s_update
- #define blake2b_update ossl_blake2b_update
- #define blake2s_final ossl_blake2s_final
- #define blake2b_final ossl_blake2b_final
- IMPLEMENT_LEGACY_EVP_MD_METH_LC(blake2s_int, blake2s)
- IMPLEMENT_LEGACY_EVP_MD_METH_LC(blake2b_int, blake2b)
- static const EVP_MD blake2b_md = {
- NID_blake2b512,
- 0,
- BLAKE2B_DIGEST_LENGTH,
- 0,
- EVP_ORIG_GLOBAL,
- LEGACY_EVP_MD_METH_TABLE(blake2b_int_init, blake2b_int_update,
- blake2b_int_final, NULL, BLAKE2B_BLOCKBYTES),
- };
- const EVP_MD *EVP_blake2b512(void)
- {
- return &blake2b_md;
- }
- static const EVP_MD blake2s_md = {
- NID_blake2s256,
- 0,
- BLAKE2S_DIGEST_LENGTH,
- 0,
- EVP_ORIG_GLOBAL,
- LEGACY_EVP_MD_METH_TABLE(blake2s_int_init, blake2s_int_update,
- blake2s_int_final, NULL, BLAKE2S_BLOCKBYTES),
- };
- const EVP_MD *EVP_blake2s256(void)
- {
- return &blake2s_md;
- }
|