summaryrefslogtreecommitdiff
path: root/src/lib/libcrypto/bf/bf_skey.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib/libcrypto/bf/bf_skey.c')
-rw-r--r--src/lib/libcrypto/bf/bf_skey.c91
1 files changed, 47 insertions, 44 deletions
diff --git a/src/lib/libcrypto/bf/bf_skey.c b/src/lib/libcrypto/bf/bf_skey.c
index 8191d17d8e..8c214f7428 100644
--- a/src/lib/libcrypto/bf/bf_skey.c
+++ b/src/lib/libcrypto/bf/bf_skey.c
@@ -1,25 +1,25 @@
1/* $OpenBSD: bf_skey.c,v 1.12 2014/06/12 15:49:28 deraadt Exp $ */ 1/* $OpenBSD: bf_skey.c,v 1.13 2022/11/11 12:08:29 jsing Exp $ */
2/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) 2/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
3 * All rights reserved. 3 * All rights reserved.
4 * 4 *
5 * This package is an SSL implementation written 5 * This package is an SSL implementation written
6 * by Eric Young (eay@cryptsoft.com). 6 * by Eric Young (eay@cryptsoft.com).
7 * The implementation was written so as to conform with Netscapes SSL. 7 * The implementation was written so as to conform with Netscapes SSL.
8 * 8 *
9 * This library is free for commercial and non-commercial use as long as 9 * This library is free for commercial and non-commercial use as long as
10 * the following conditions are aheared to. The following conditions 10 * the following conditions are aheared to. The following conditions
11 * apply to all code found in this distribution, be it the RC4, RSA, 11 * apply to all code found in this distribution, be it the RC4, RSA,
12 * lhash, DES, etc., code; not just the SSL code. The SSL documentation 12 * lhash, DES, etc., code; not just the SSL code. The SSL documentation
13 * included with this distribution is covered by the same copyright terms 13 * included with this distribution is covered by the same copyright terms
14 * except that the holder is Tim Hudson (tjh@cryptsoft.com). 14 * except that the holder is Tim Hudson (tjh@cryptsoft.com).
15 * 15 *
16 * Copyright remains Eric Young's, and as such any Copyright notices in 16 * Copyright remains Eric Young's, and as such any Copyright notices in
17 * the code are not to be removed. 17 * the code are not to be removed.
18 * If this package is used in a product, Eric Young should be given attribution 18 * If this package is used in a product, Eric Young should be given attribution
19 * as the author of the parts of the library used. 19 * as the author of the parts of the library used.
20 * This can be in the form of a textual message at program startup or 20 * This can be in the form of a textual message at program startup or
21 * in documentation (online or textual) provided with the package. 21 * in documentation (online or textual) provided with the package.
22 * 22 *
23 * Redistribution and use in source and binary forms, with or without 23 * Redistribution and use in source and binary forms, with or without
24 * modification, are permitted provided that the following conditions 24 * modification, are permitted provided that the following conditions
25 * are met: 25 * are met:
@@ -34,10 +34,10 @@
34 * Eric Young (eay@cryptsoft.com)" 34 * Eric Young (eay@cryptsoft.com)"
35 * The word 'cryptographic' can be left out if the rouines from the library 35 * The word 'cryptographic' can be left out if the rouines from the library
36 * being used are not cryptographic related :-). 36 * being used are not cryptographic related :-).
37 * 4. If you include any Windows specific code (or a derivative thereof) from 37 * 4. If you include any Windows specific code (or a derivative thereof) from
38 * the apps directory (application code) you must include an acknowledgement: 38 * the apps directory (application code) you must include an acknowledgement:
39 * "This product includes software written by Tim Hudson (tjh@cryptsoft.com)" 39 * "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
40 * 40 *
41 * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND 41 * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
42 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 42 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
43 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 43 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
@@ -49,7 +49,7 @@
49 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 49 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
50 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 50 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
51 * SUCH DAMAGE. 51 * SUCH DAMAGE.
52 * 52 *
53 * The licence and distribution terms for any publically available version or 53 * The licence and distribution terms for any publically available version or
54 * derivative of this code cannot be changed. i.e. this code cannot simply be 54 * derivative of this code cannot be changed. i.e. this code cannot simply be
55 * copied and put under another distribution licence 55 * copied and put under another distribution licence
@@ -63,55 +63,58 @@
63#include "bf_locl.h" 63#include "bf_locl.h"
64#include "bf_pi.h" 64#include "bf_pi.h"
65 65
66void BF_set_key(BF_KEY *key, int len, const unsigned char *data) 66void
67 { 67BF_set_key(BF_KEY *key, int len, const unsigned char *data)
68{
68 int i; 69 int i;
69 BF_LONG *p,ri,in[2]; 70 BF_LONG *p, ri, in[2];
70 const unsigned char *d,*end; 71 const unsigned char *d, *end;
71 72
72 73
73 memcpy(key,&bf_init,sizeof(BF_KEY)); 74 memcpy(key, &bf_init, sizeof(BF_KEY));
74 p=key->P; 75 p = key->P;
75 76
76 if (len > ((BF_ROUNDS+2)*4)) len=(BF_ROUNDS+2)*4; 77 if (len > ((BF_ROUNDS + 2)*4))
78 len = (BF_ROUNDS + 2)*4;
77 79
78 d=data; 80 d = data;
79 end= &(data[len]); 81 end = &(data[len]);
80 for (i=0; i<(BF_ROUNDS+2); i++) 82 for (i = 0; i < (BF_ROUNDS + 2); i++) {
81 {
82 ri= *(d++); 83 ri= *(d++);
83 if (d >= end) d=data; 84 if (d >= end)
85 d = data;
84 86
85 ri<<=8; 87 ri <<= 8;
86 ri|= *(d++); 88 ri |= *(d++);
87 if (d >= end) d=data; 89 if (d >= end)
90 d = data;
88 91
89 ri<<=8; 92 ri <<= 8;
90 ri|= *(d++); 93 ri |= *(d++);
91 if (d >= end) d=data; 94 if (d >= end)
95 d = data;
92 96
93 ri<<=8; 97 ri <<= 8;
94 ri|= *(d++); 98 ri |= *(d++);
95 if (d >= end) d=data; 99 if (d >= end)
100 d = data;
96 101
97 p[i]^=ri; 102 p[i]^=ri;
98 } 103 }
99 104
100 in[0]=0L; 105 in[0] = 0L;
101 in[1]=0L; 106 in[1] = 0L;
102 for (i=0; i<(BF_ROUNDS+2); i+=2) 107 for (i = 0; i < (BF_ROUNDS + 2); i += 2) {
103 { 108 BF_encrypt(in, key);
104 BF_encrypt(in,key); 109 p[i ] = in[0];
105 p[i ]=in[0]; 110 p[i + 1] = in[1];
106 p[i+1]=in[1]; 111 }
107 }
108 112
109 p=key->S; 113 p = key->S;
110 for (i=0; i<4*256; i+=2) 114 for (i = 0; i < 4*256; i += 2) {
111 { 115 BF_encrypt(in, key);
112 BF_encrypt(in,key); 116 p[i ] = in[0];
113 p[i ]=in[0]; 117 p[i + 1] = in[1];
114 p[i+1]=in[1];
115 }
116 } 118 }
119}
117 120