X-Git-Url: http://wagner.pp.ru/gitweb/?a=blobdiff_plain;f=gost_md2012.c;h=7afbed947b7b6bb0082781e9d18434722df93943;hb=b397f22eb42d3a6439452e486b657a6a936c6163;hp=08f3724fb3bc510e396d86f4a6dba7c3282ef309;hpb=7ed0037f1e9192a42f4b244221d3bddccc10be63;p=openssl-gost%2Fengine.git diff --git a/gost_md2012.c b/gost_md2012.c index 08f3724..7afbed9 100644 --- a/gost_md2012.c +++ b/gost_md2012.c @@ -19,9 +19,14 @@ static int gost_digest_update(EVP_MD_CTX *ctx, const void *data, static int gost_digest_final(EVP_MD_CTX *ctx, unsigned char *md); static int gost_digest_copy(EVP_MD_CTX *to, const EVP_MD_CTX *from); static int gost_digest_cleanup(EVP_MD_CTX *ctx); +static int gost_digest_ctrl_256(EVP_MD_CTX *ctx, int type, int arg, void *ptr); +static int gost_digest_ctrl_512(EVP_MD_CTX *ctx, int type, int arg, void *ptr); + +const char micalg_256[] = "gostr3411-2012-256"; +const char micalg_512[] = "gostr3411-2012-512"; EVP_MD digest_gost2012_512 = { - NID_id_GostR3411_2012_512, + NID_undef /* NID_md_gost12_512 */, NID_undef, 64, /* digest size */ EVP_MD_FLAG_PKEY_METHOD_SIGNATURE, @@ -35,11 +40,11 @@ EVP_MD digest_gost2012_512 = { {NID_undef, NID_undef, 0, 0, 0}, 64, /* block size */ sizeof(gost2012_hash_ctx), - NULL + gost_digest_ctrl_512, }; EVP_MD digest_gost2012_256 = { - NID_id_GostR3411_2012_256, + NID_undef /*NID_md_gost12_256*/, NID_undef, 32, /* digest size */ EVP_MD_FLAG_PKEY_METHOD_SIGNATURE, @@ -53,7 +58,7 @@ EVP_MD digest_gost2012_256 = { {NID_undef, NID_undef, 0, 0, 0}, 64, /* block size */ sizeof(gost2012_hash_ctx), - NULL + gost_digest_ctrl_256 }; static int gost_digest_init512(EVP_MD_CTX *ctx) @@ -95,3 +100,43 @@ static int gost_digest_cleanup(EVP_MD_CTX *ctx) return 1; } + +static int gost_digest_ctrl_256(EVP_MD_CTX *ctx, int type, int arg, void *ptr) + { + switch (type) + { + case EVP_MD_CTRL_MICALG: + { + *((char **)ptr) = OPENSSL_malloc(strlen(micalg_256)+1); + if (*((char **)ptr) != NULL) + { + strcpy(*((char **)ptr), micalg_256); + return 1; + } + return 0; + } + default: + return 0; + } + } + +static int gost_digest_ctrl_512(EVP_MD_CTX *ctx, int type, int arg, void *ptr) + { + switch (type) + { + case EVP_MD_CTRL_MICALG: + { + *((char **)ptr) = OPENSSL_malloc(strlen(micalg_512)+1); + if (*((char **)ptr) != NULL) + { + strcpy(*((char **)ptr), micalg_512); + return 1; + } + return 0; + } + return 1; + default: + return 0; + } + } +