1e1051a39Sopenharmony_ci/* 2e1051a39Sopenharmony_ci * Copyright 1995-2021 The OpenSSL Project Authors. All Rights Reserved. 3e1051a39Sopenharmony_ci * 4e1051a39Sopenharmony_ci * Licensed under the Apache License 2.0 (the "License"). You may not use 5e1051a39Sopenharmony_ci * this file except in compliance with the License. You can obtain a copy 6e1051a39Sopenharmony_ci * in the file LICENSE in the source distribution or at 7e1051a39Sopenharmony_ci * https://www.openssl.org/source/license.html 8e1051a39Sopenharmony_ci */ 9e1051a39Sopenharmony_ci 10e1051a39Sopenharmony_ci/* 11e1051a39Sopenharmony_ci * IDEA low level APIs are deprecated for public use, but still ok for internal 12e1051a39Sopenharmony_ci * use where we're using them to implement the higher level EVP interface, as is 13e1051a39Sopenharmony_ci * the case here. 14e1051a39Sopenharmony_ci */ 15e1051a39Sopenharmony_ci#include "internal/deprecated.h" 16e1051a39Sopenharmony_ci 17e1051a39Sopenharmony_ci#include <stdio.h> 18e1051a39Sopenharmony_ci#include "internal/cryptlib.h" 19e1051a39Sopenharmony_ci 20e1051a39Sopenharmony_ci#ifndef OPENSSL_NO_IDEA 21e1051a39Sopenharmony_ci# include <openssl/evp.h> 22e1051a39Sopenharmony_ci# include <openssl/objects.h> 23e1051a39Sopenharmony_ci# include "crypto/evp.h" 24e1051a39Sopenharmony_ci# include <openssl/idea.h> 25e1051a39Sopenharmony_ci# include "evp_local.h" 26e1051a39Sopenharmony_ci 27e1051a39Sopenharmony_ci/* Can't use IMPLEMENT_BLOCK_CIPHER because IDEA_ecb_encrypt is different */ 28e1051a39Sopenharmony_ci 29e1051a39Sopenharmony_citypedef struct { 30e1051a39Sopenharmony_ci IDEA_KEY_SCHEDULE ks; 31e1051a39Sopenharmony_ci} EVP_IDEA_KEY; 32e1051a39Sopenharmony_ci 33e1051a39Sopenharmony_cistatic int idea_init_key(EVP_CIPHER_CTX *ctx, const unsigned char *key, 34e1051a39Sopenharmony_ci const unsigned char *iv, int enc); 35e1051a39Sopenharmony_ci 36e1051a39Sopenharmony_ci/* 37e1051a39Sopenharmony_ci * NB IDEA_ecb_encrypt doesn't take an 'encrypt' argument so we treat it as a 38e1051a39Sopenharmony_ci * special case 39e1051a39Sopenharmony_ci */ 40e1051a39Sopenharmony_ci 41e1051a39Sopenharmony_cistatic int idea_ecb_cipher(EVP_CIPHER_CTX *ctx, unsigned char *out, 42e1051a39Sopenharmony_ci const unsigned char *in, size_t inl) 43e1051a39Sopenharmony_ci{ 44e1051a39Sopenharmony_ci BLOCK_CIPHER_ecb_loop() 45e1051a39Sopenharmony_ci IDEA_ecb_encrypt(in + i, out + i, &EVP_C_DATA(EVP_IDEA_KEY,ctx)->ks); 46e1051a39Sopenharmony_ci return 1; 47e1051a39Sopenharmony_ci} 48e1051a39Sopenharmony_ci 49e1051a39Sopenharmony_ciBLOCK_CIPHER_func_cbc(idea, IDEA, EVP_IDEA_KEY, ks) 50e1051a39Sopenharmony_ciBLOCK_CIPHER_func_ofb(idea, IDEA, 64, EVP_IDEA_KEY, ks) 51e1051a39Sopenharmony_ciBLOCK_CIPHER_func_cfb(idea, IDEA, 64, EVP_IDEA_KEY, ks) 52e1051a39Sopenharmony_ci 53e1051a39Sopenharmony_ciBLOCK_CIPHER_defs(idea, IDEA_KEY_SCHEDULE, NID_idea, 8, 16, 8, 64, 54e1051a39Sopenharmony_ci 0, idea_init_key, NULL, 55e1051a39Sopenharmony_ci EVP_CIPHER_set_asn1_iv, EVP_CIPHER_get_asn1_iv, NULL) 56e1051a39Sopenharmony_ci 57e1051a39Sopenharmony_cistatic int idea_init_key(EVP_CIPHER_CTX *ctx, const unsigned char *key, 58e1051a39Sopenharmony_ci const unsigned char *iv, int enc) 59e1051a39Sopenharmony_ci{ 60e1051a39Sopenharmony_ci if (!enc) { 61e1051a39Sopenharmony_ci if (EVP_CIPHER_CTX_get_mode(ctx) == EVP_CIPH_OFB_MODE) 62e1051a39Sopenharmony_ci enc = 1; 63e1051a39Sopenharmony_ci else if (EVP_CIPHER_CTX_get_mode(ctx) == EVP_CIPH_CFB_MODE) 64e1051a39Sopenharmony_ci enc = 1; 65e1051a39Sopenharmony_ci } 66e1051a39Sopenharmony_ci if (enc) 67e1051a39Sopenharmony_ci IDEA_set_encrypt_key(key, &EVP_C_DATA(EVP_IDEA_KEY,ctx)->ks); 68e1051a39Sopenharmony_ci else { 69e1051a39Sopenharmony_ci IDEA_KEY_SCHEDULE tmp; 70e1051a39Sopenharmony_ci 71e1051a39Sopenharmony_ci IDEA_set_encrypt_key(key, &tmp); 72e1051a39Sopenharmony_ci IDEA_set_decrypt_key(&tmp, &EVP_C_DATA(EVP_IDEA_KEY,ctx)->ks); 73e1051a39Sopenharmony_ci OPENSSL_cleanse((unsigned char *)&tmp, sizeof(IDEA_KEY_SCHEDULE)); 74e1051a39Sopenharmony_ci } 75e1051a39Sopenharmony_ci return 1; 76e1051a39Sopenharmony_ci} 77e1051a39Sopenharmony_ci 78e1051a39Sopenharmony_ci#endif 79