&grasshopper_cfb_cipher,
&grasshopper_ofb_cipher,
&grasshopper_ctr_cipher,
+ &magma_ecb_cipher,
+ &grasshopper_mgm_cipher,
&magma_cbc_cipher,
&magma_ctr_cipher,
&magma_ctr_acpkm_cipher,
&magma_ctr_acpkm_omac_cipher,
+ &magma_mgm_cipher,
&grasshopper_ctr_acpkm_cipher,
&grasshopper_ctr_acpkm_omac_cipher,
&magma_kexp15_cipher,
return 1;
}
+static void free_NIDs();
+
static int gost_engine_destroy(ENGINE* e) {
int i;
}
free_cached_groups();
+ free_NIDs();
# ifndef BUILDING_GOST_PROVIDER
ERR_unload_GOST_strings();
* binds it to OpenSSL libraries
*/
+static GOST_NID_JOB *missing_NIDs[] = {
+ &kuznyechik_mgm_NID,
+ &magma_mgm_NID,
+};
+
+static int create_NIDs() {
+ int i;
+ int new_nid = OBJ_new_nid(OSSL_NELEM(missing_NIDs));
+ for (i = 0; i < OSSL_NELEM(missing_NIDs); i++) {
+ GOST_NID_JOB *job = missing_NIDs[i];
+ ASN1_OBJECT *obj =
+ ASN1_OBJECT_create(new_nid + i, NULL, 0, job->sn, job->ln);
+ job->asn1 = obj;
+ if (!obj || OBJ_add_object(obj) == NID_undef) {
+ OPENSSL_free(obj);
+ return 0;
+ }
+ (*missing_NIDs[i]->callback)(new_nid + i);
+ }
+ return 1;
+}
+
+static void free_NIDs() {
+ int i;
+ for (i = 0; i < OSSL_NELEM(missing_NIDs); i++) {
+ ASN1_OBJECT_free(missing_NIDs[i]->asn1);
+ }
+}
+
# ifndef BUILDING_GOST_PROVIDER
static
# endif
fprintf(stderr, "ENGINE_set_name failed\n");
goto end;
}
+ if (!create_NIDs()) {
+ fprintf(stderr, "NID creation failed\n");
+ goto end;
+ }
if (!ENGINE_set_digests(e, gost_digests)) {
fprintf(stderr, "ENGINE_set_digests failed\n");
goto end;