003 File Manager
Current Path:
/usr/src/crypto/openssl/crypto/evp
usr
/
src
/
crypto
/
openssl
/
crypto
/
evp
/
📁
..
📄
bio_b64.c
(15.83 KB)
📄
bio_enc.c
(11.28 KB)
📄
bio_md.c
(4.96 KB)
📄
bio_ok.c
(15.88 KB)
📄
build.info
(1.04 KB)
📄
c_allc.c
(9.3 KB)
📄
c_alld.c
(1.78 KB)
📄
cmeth_lib.c
(4.56 KB)
📄
digest.c
(8.79 KB)
📄
e_aes.c
(142.86 KB)
📄
e_aes_cbc_hmac_sha1.c
(31.25 KB)
📄
e_aes_cbc_hmac_sha256.c
(31.07 KB)
📄
e_aria.c
(25.76 KB)
📄
e_bf.c
(1.16 KB)
📄
e_camellia.c
(13.64 KB)
📄
e_cast.c
(1.22 KB)
📄
e_chacha20_poly1305.c
(20.61 KB)
📄
e_des.c
(8.13 KB)
📄
e_des3.c
(14.19 KB)
📄
e_idea.c
(2.11 KB)
📄
e_null.c
(1.26 KB)
📄
e_old.c
(2.39 KB)
📄
e_rc2.c
(4.99 KB)
📄
e_rc4.c
(1.86 KB)
📄
e_rc4_hmac_md5.c
(7.7 KB)
📄
e_rc5.c
(2.21 KB)
📄
e_seed.c
(1.13 KB)
📄
e_sm4.c
(3.07 KB)
📄
e_xcbc_d.c
(2.38 KB)
📄
encode.c
(13.63 KB)
📄
evp_cnf.c
(1.65 KB)
📄
evp_enc.c
(20.93 KB)
📄
evp_err.c
(15.14 KB)
📄
evp_key.c
(4.08 KB)
📄
evp_lib.c
(11.76 KB)
📄
evp_local.h
(2.58 KB)
📄
evp_pbe.c
(7.52 KB)
📄
evp_pkey.c
(4 KB)
📄
m_md2.c
(1.14 KB)
📄
m_md4.c
(1.14 KB)
📄
m_md5.c
(1.14 KB)
📄
m_md5_sha1.c
(3.2 KB)
📄
m_mdc2.c
(1.15 KB)
📄
m_null.c
(918 B)
📄
m_ripemd.c
(1.21 KB)
📄
m_sha1.c
(5.95 KB)
📄
m_sha3.c
(13.38 KB)
📄
m_sigver.c
(7 KB)
📄
m_wp.c
(1.17 KB)
📄
names.c
(4.74 KB)
📄
p5_crpt.c
(3.13 KB)
📄
p5_crpt2.c
(7.81 KB)
📄
p_dec.c
(980 B)
📄
p_enc.c
(984 B)
📄
p_lib.c
(16.59 KB)
📄
p_open.c
(1.77 KB)
📄
p_seal.c
(1.73 KB)
📄
p_sign.c
(1.7 KB)
📄
p_verify.c
(1.59 KB)
📄
pbe_scrypt.c
(7.38 KB)
📄
pmeth_fn.c
(9.59 KB)
📄
pmeth_gn.c
(6.01 KB)
📄
pmeth_lib.c
(27.12 KB)
Editing: e_idea.c
/* * Copyright 1995-2016 The OpenSSL Project Authors. All Rights Reserved. * * Licensed under the OpenSSL license (the "License"). You may not use * this file except in compliance with the License. You can obtain a copy * in the file LICENSE in the source distribution or at * https://www.openssl.org/source/license.html */ #include <stdio.h> #include "internal/cryptlib.h" #ifndef OPENSSL_NO_IDEA # include <openssl/evp.h> # include <openssl/objects.h> # include "crypto/evp.h" # include <openssl/idea.h> /* Can't use IMPLEMENT_BLOCK_CIPHER because IDEA_ecb_encrypt is different */ typedef struct { IDEA_KEY_SCHEDULE ks; } EVP_IDEA_KEY; static int idea_init_key(EVP_CIPHER_CTX *ctx, const unsigned char *key, const unsigned char *iv, int enc); /* * NB IDEA_ecb_encrypt doesn't take an 'encrypt' argument so we treat it as a * special case */ static int idea_ecb_cipher(EVP_CIPHER_CTX *ctx, unsigned char *out, const unsigned char *in, size_t inl) { BLOCK_CIPHER_ecb_loop() IDEA_ecb_encrypt(in + i, out + i, &EVP_C_DATA(EVP_IDEA_KEY,ctx)->ks); return 1; } BLOCK_CIPHER_func_cbc(idea, IDEA, EVP_IDEA_KEY, ks) BLOCK_CIPHER_func_ofb(idea, IDEA, 64, EVP_IDEA_KEY, ks) BLOCK_CIPHER_func_cfb(idea, IDEA, 64, EVP_IDEA_KEY, ks) BLOCK_CIPHER_defs(idea, IDEA_KEY_SCHEDULE, NID_idea, 8, 16, 8, 64, 0, idea_init_key, NULL, EVP_CIPHER_set_asn1_iv, EVP_CIPHER_get_asn1_iv, NULL) static int idea_init_key(EVP_CIPHER_CTX *ctx, const unsigned char *key, const unsigned char *iv, int enc) { if (!enc) { if (EVP_CIPHER_CTX_mode(ctx) == EVP_CIPH_OFB_MODE) enc = 1; else if (EVP_CIPHER_CTX_mode(ctx) == EVP_CIPH_CFB_MODE) enc = 1; } if (enc) IDEA_set_encrypt_key(key, &EVP_C_DATA(EVP_IDEA_KEY,ctx)->ks); else { IDEA_KEY_SCHEDULE tmp; IDEA_set_encrypt_key(key, &tmp); IDEA_set_decrypt_key(&tmp, &EVP_C_DATA(EVP_IDEA_KEY,ctx)->ks); OPENSSL_cleanse((unsigned char *)&tmp, sizeof(IDEA_KEY_SCHEDULE)); } return 1; } #endif
Upload File
Create Folder