]>
Commit | Line | Data |
---|---|---|
7bf7a6d0 MTL |
1 | /* |
2 | * Copyright 2007-2016 The OpenSSL Project Authors. All Rights Reserved. | |
3e575651 | 3 | * |
7bf7a6d0 MTL |
4 | * Licensed under the OpenSSL license (the "License"). You may not use |
5 | * this file except in compliance with the License. You can obtain a copy | |
6 | * in the file LICENSE in the source distribution or at | |
7 | * https://www.openssl.org/source/license.html | |
3e575651 SL |
8 | */ |
9 | ||
d3819813 | 10 | #include <openssl/opensslconf.h> |
7bf7a6d0 MTL |
11 | #ifdef OPENSSL_NO_SEED |
12 | NON_EMPTY_TRANSLATION_UNIT | |
13 | #else | |
d3819813 MTL |
14 | # include <openssl/evp.h> |
15 | # include <openssl/err.h> | |
16 | # include <string.h> | |
17 | # include <assert.h> | |
18 | # include <openssl/seed.h> | |
7bf7a6d0 | 19 | # include "internal/evp_int.h" |
3e575651 | 20 | |
d3819813 MTL |
21 | static int seed_init_key(EVP_CIPHER_CTX *ctx, const unsigned char *key, |
22 | const unsigned char *iv, int enc); | |
3e575651 | 23 | |
d3819813 MTL |
24 | typedef struct { |
25 | SEED_KEY_SCHEDULE ks; | |
26 | } EVP_SEED_KEY; | |
3e575651 | 27 | |
d3819813 | 28 | IMPLEMENT_BLOCK_CIPHER(seed, ks, SEED, EVP_SEED_KEY, NID_seed, |
f4173af1 MTL |
29 | 16, 16, 16, 128, EVP_CIPH_FLAG_DEFAULT_ASN1, |
30 | seed_init_key, 0, 0, 0, 0) | |
3e575651 | 31 | |
d3819813 MTL |
32 | static int seed_init_key(EVP_CIPHER_CTX *ctx, const unsigned char *key, |
33 | const unsigned char *iv, int enc) | |
34 | { | |
7bf7a6d0 | 35 | SEED_set_key(key, &EVP_C_DATA(EVP_SEED_KEY,ctx)->ks); |
d3819813 | 36 | return 1; |
3e575651 | 37 | } |
3e575651 | 38 | |
d3819813 | 39 | #endif |