1 1.1 christos /* 2 1.1 christos * Copyright 2019-2020 The OpenSSL Project Authors. All Rights Reserved. 3 1.1 christos * 4 1.1 christos * Licensed under the Apache License 2.0 (the "License"). You may not use 5 1.1 christos * this file except in compliance with the License. You can obtain a copy 6 1.1 christos * in the file LICENSE in the source distribution or at 7 1.1 christos * https://www.openssl.org/source/license.html 8 1.1 christos */ 9 1.1 christos 10 1.1 christos /* 11 1.1 christos * IDEA low level APIs are deprecated for public use, but still ok for internal 12 1.1 christos * use where we're using them to implement the higher level EVP interface, as is 13 1.1 christos * the case here. 14 1.1 christos */ 15 1.1 christos #include "internal/deprecated.h" 16 1.1 christos 17 1.1 christos /* Dispatch functions for Idea cipher modes ecb, cbc, ofb, cfb */ 18 1.1 christos 19 1.1 christos #include "cipher_idea.h" 20 1.1 christos #include "prov/implementations.h" 21 1.1 christos #include "prov/providercommon.h" 22 1.1 christos 23 1.1 christos static OSSL_FUNC_cipher_freectx_fn idea_freectx; 24 1.1 christos static OSSL_FUNC_cipher_dupctx_fn idea_dupctx; 25 1.1 christos 26 1.1 christos static void idea_freectx(void *vctx) 27 1.1 christos { 28 1.1 christos PROV_IDEA_CTX *ctx = (PROV_IDEA_CTX *)vctx; 29 1.1 christos 30 1.1 christos ossl_cipher_generic_reset_ctx((PROV_CIPHER_CTX *)vctx); 31 1.1 christos OPENSSL_clear_free(ctx, sizeof(*ctx)); 32 1.1 christos } 33 1.1 christos 34 1.1 christos static void *idea_dupctx(void *ctx) 35 1.1 christos { 36 1.1 christos PROV_IDEA_CTX *in = (PROV_IDEA_CTX *)ctx; 37 1.1 christos PROV_IDEA_CTX *ret; 38 1.1 christos 39 1.1 christos if (!ossl_prov_is_running()) 40 1.1 christos return NULL; 41 1.1 christos 42 1.1 christos ret = OPENSSL_malloc(sizeof(*ret)); 43 1.1 christos if (ret == NULL) { 44 1.1 christos ERR_raise(ERR_LIB_PROV, ERR_R_MALLOC_FAILURE); 45 1.1 christos return NULL; 46 1.1 christos } 47 1.1 christos *ret = *in; 48 1.1 christos 49 1.1 christos return ret; 50 1.1 christos } 51 1.1 christos 52 1.1 christos /* ossl_idea128ecb_functions */ 53 1.1 christos IMPLEMENT_generic_cipher(idea, IDEA, ecb, ECB, 0, 128, 64, 0, block) 54 1.1 christos /* ossl_idea128cbc_functions */ 55 1.1 christos IMPLEMENT_generic_cipher(idea, IDEA, cbc, CBC, 0, 128, 64, 64, block) 56 1.1 christos /* ossl_idea128ofb64_functions */ 57 1.1 christos IMPLEMENT_generic_cipher(idea, IDEA, ofb64, OFB, 0, 128, 8, 64, stream) 58 1.1 christos /* ossl_idea128cfb64_functions */ 59 1.1 christos IMPLEMENT_generic_cipher(idea, IDEA, cfb64, CFB, 0, 128, 8, 64, stream) 60