7f572e958b
Remove sign/verify and required_pkey_type fields of EVP_MD: these are a legacy from when digests were linked to public key types. All signing is now handled by the corresponding EVP_PKEY_METHOD. Only allow supported digest types in RSA EVP_PKEY_METHOD: other algorithms already block unsupported types. Remove now obsolete EVP_dss1() and EVP_ecdsa(). Reviewed-by: Richard Levitte <levitte@openssl.org>
46 lines
833 B
C
46 lines
833 B
C
/* crypto/evp/m_wp.c */
|
|
|
|
#include <stdio.h>
|
|
#include "internal/cryptlib.h"
|
|
|
|
#ifndef OPENSSL_NO_WHIRLPOOL
|
|
|
|
# include <openssl/evp.h>
|
|
# include <openssl/objects.h>
|
|
# include <openssl/x509.h>
|
|
# include <openssl/whrlpool.h>
|
|
|
|
static int init(EVP_MD_CTX *ctx)
|
|
{
|
|
return WHIRLPOOL_Init(ctx->md_data);
|
|
}
|
|
|
|
static int update(EVP_MD_CTX *ctx, const void *data, size_t count)
|
|
{
|
|
return WHIRLPOOL_Update(ctx->md_data, data, count);
|
|
}
|
|
|
|
static int final(EVP_MD_CTX *ctx, unsigned char *md)
|
|
{
|
|
return WHIRLPOOL_Final(md, ctx->md_data);
|
|
}
|
|
|
|
static const EVP_MD whirlpool_md = {
|
|
NID_whirlpool,
|
|
0,
|
|
WHIRLPOOL_DIGEST_LENGTH,
|
|
0,
|
|
init,
|
|
update,
|
|
final,
|
|
NULL,
|
|
NULL,
|
|
WHIRLPOOL_BBLOCK / 8,
|
|
sizeof(EVP_MD *) + sizeof(WHIRLPOOL_CTX),
|
|
};
|
|
|
|
const EVP_MD *EVP_whirlpool(void)
|
|
{
|
|
return (&whirlpool_md);
|
|
}
|
|
#endif
|