1*8fb009dcSAndroid Build Coastguard Worker /* Copyright (C) 1995-1998 Eric Young ([email protected])
2*8fb009dcSAndroid Build Coastguard Worker * All rights reserved.
3*8fb009dcSAndroid Build Coastguard Worker *
4*8fb009dcSAndroid Build Coastguard Worker * This package is an SSL implementation written
5*8fb009dcSAndroid Build Coastguard Worker * by Eric Young ([email protected]).
6*8fb009dcSAndroid Build Coastguard Worker * The implementation was written so as to conform with Netscapes SSL.
7*8fb009dcSAndroid Build Coastguard Worker *
8*8fb009dcSAndroid Build Coastguard Worker * This library is free for commercial and non-commercial use as long as
9*8fb009dcSAndroid Build Coastguard Worker * the following conditions are aheared to. The following conditions
10*8fb009dcSAndroid Build Coastguard Worker * apply to all code found in this distribution, be it the RC4, RSA,
11*8fb009dcSAndroid Build Coastguard Worker * lhash, DES, etc., code; not just the SSL code. The SSL documentation
12*8fb009dcSAndroid Build Coastguard Worker * included with this distribution is covered by the same copyright terms
13*8fb009dcSAndroid Build Coastguard Worker * except that the holder is Tim Hudson ([email protected]).
14*8fb009dcSAndroid Build Coastguard Worker *
15*8fb009dcSAndroid Build Coastguard Worker * Copyright remains Eric Young's, and as such any Copyright notices in
16*8fb009dcSAndroid Build Coastguard Worker * the code are not to be removed.
17*8fb009dcSAndroid Build Coastguard Worker * If this package is used in a product, Eric Young should be given attribution
18*8fb009dcSAndroid Build Coastguard Worker * as the author of the parts of the library used.
19*8fb009dcSAndroid Build Coastguard Worker * This can be in the form of a textual message at program startup or
20*8fb009dcSAndroid Build Coastguard Worker * in documentation (online or textual) provided with the package.
21*8fb009dcSAndroid Build Coastguard Worker *
22*8fb009dcSAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without
23*8fb009dcSAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions
24*8fb009dcSAndroid Build Coastguard Worker * are met:
25*8fb009dcSAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the copyright
26*8fb009dcSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer.
27*8fb009dcSAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright
28*8fb009dcSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the
29*8fb009dcSAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution.
30*8fb009dcSAndroid Build Coastguard Worker * 3. All advertising materials mentioning features or use of this software
31*8fb009dcSAndroid Build Coastguard Worker * must display the following acknowledgement:
32*8fb009dcSAndroid Build Coastguard Worker * "This product includes cryptographic software written by
33*8fb009dcSAndroid Build Coastguard Worker * Eric Young ([email protected])"
34*8fb009dcSAndroid Build Coastguard Worker * The word 'cryptographic' can be left out if the rouines from the library
35*8fb009dcSAndroid Build Coastguard Worker * being used are not cryptographic related :-).
36*8fb009dcSAndroid Build Coastguard Worker * 4. If you include any Windows specific code (or a derivative thereof) from
37*8fb009dcSAndroid Build Coastguard Worker * the apps directory (application code) you must include an acknowledgement:
38*8fb009dcSAndroid Build Coastguard Worker * "This product includes software written by Tim Hudson ([email protected])"
39*8fb009dcSAndroid Build Coastguard Worker *
40*8fb009dcSAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
41*8fb009dcSAndroid Build Coastguard Worker * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
42*8fb009dcSAndroid Build Coastguard Worker * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
43*8fb009dcSAndroid Build Coastguard Worker * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
44*8fb009dcSAndroid Build Coastguard Worker * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
45*8fb009dcSAndroid Build Coastguard Worker * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
46*8fb009dcSAndroid Build Coastguard Worker * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
47*8fb009dcSAndroid Build Coastguard Worker * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
48*8fb009dcSAndroid Build Coastguard Worker * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
49*8fb009dcSAndroid Build Coastguard Worker * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
50*8fb009dcSAndroid Build Coastguard Worker * SUCH DAMAGE.
51*8fb009dcSAndroid Build Coastguard Worker *
52*8fb009dcSAndroid Build Coastguard Worker * The licence and distribution terms for any publically available version or
53*8fb009dcSAndroid Build Coastguard Worker * derivative of this code cannot be changed. i.e. this code cannot simply be
54*8fb009dcSAndroid Build Coastguard Worker * copied and put under another distribution licence
55*8fb009dcSAndroid Build Coastguard Worker * [including the GNU Public Licence.] */
56*8fb009dcSAndroid Build Coastguard Worker
57*8fb009dcSAndroid Build Coastguard Worker #include <string.h>
58*8fb009dcSAndroid Build Coastguard Worker
59*8fb009dcSAndroid Build Coastguard Worker #include <openssl/des.h>
60*8fb009dcSAndroid Build Coastguard Worker
61*8fb009dcSAndroid Build Coastguard Worker #include "../../crypto/des/internal.h"
62*8fb009dcSAndroid Build Coastguard Worker #include "../../crypto/internal.h"
63*8fb009dcSAndroid Build Coastguard Worker
64*8fb009dcSAndroid Build Coastguard Worker
65*8fb009dcSAndroid Build Coastguard Worker // The input and output encrypted as though 64bit cfb mode is being used. The
66*8fb009dcSAndroid Build Coastguard Worker // extra state information to record how much of the 64bit block we have used
67*8fb009dcSAndroid Build Coastguard Worker // is contained in *num;
DES_ede3_cfb64_encrypt(const uint8_t * in,uint8_t * out,long length,DES_key_schedule * ks1,DES_key_schedule * ks2,DES_key_schedule * ks3,DES_cblock * ivec,int * num,int enc)68*8fb009dcSAndroid Build Coastguard Worker void DES_ede3_cfb64_encrypt(const uint8_t *in, uint8_t *out,
69*8fb009dcSAndroid Build Coastguard Worker long length, DES_key_schedule *ks1,
70*8fb009dcSAndroid Build Coastguard Worker DES_key_schedule *ks2, DES_key_schedule *ks3,
71*8fb009dcSAndroid Build Coastguard Worker DES_cblock *ivec, int *num, int enc) {
72*8fb009dcSAndroid Build Coastguard Worker uint32_t v0, v1;
73*8fb009dcSAndroid Build Coastguard Worker long l = length;
74*8fb009dcSAndroid Build Coastguard Worker int n = *num;
75*8fb009dcSAndroid Build Coastguard Worker uint32_t ti[2];
76*8fb009dcSAndroid Build Coastguard Worker uint8_t *iv, c, cc;
77*8fb009dcSAndroid Build Coastguard Worker
78*8fb009dcSAndroid Build Coastguard Worker iv = ivec->bytes;
79*8fb009dcSAndroid Build Coastguard Worker if (enc) {
80*8fb009dcSAndroid Build Coastguard Worker while (l--) {
81*8fb009dcSAndroid Build Coastguard Worker if (n == 0) {
82*8fb009dcSAndroid Build Coastguard Worker c2l(iv, v0);
83*8fb009dcSAndroid Build Coastguard Worker c2l(iv, v1);
84*8fb009dcSAndroid Build Coastguard Worker
85*8fb009dcSAndroid Build Coastguard Worker ti[0] = v0;
86*8fb009dcSAndroid Build Coastguard Worker ti[1] = v1;
87*8fb009dcSAndroid Build Coastguard Worker DES_encrypt3(ti, ks1, ks2, ks3);
88*8fb009dcSAndroid Build Coastguard Worker v0 = ti[0];
89*8fb009dcSAndroid Build Coastguard Worker v1 = ti[1];
90*8fb009dcSAndroid Build Coastguard Worker
91*8fb009dcSAndroid Build Coastguard Worker iv = ivec->bytes;
92*8fb009dcSAndroid Build Coastguard Worker l2c(v0, iv);
93*8fb009dcSAndroid Build Coastguard Worker l2c(v1, iv);
94*8fb009dcSAndroid Build Coastguard Worker iv = ivec->bytes;
95*8fb009dcSAndroid Build Coastguard Worker }
96*8fb009dcSAndroid Build Coastguard Worker c = *(in++) ^ iv[n];
97*8fb009dcSAndroid Build Coastguard Worker *(out++) = c;
98*8fb009dcSAndroid Build Coastguard Worker iv[n] = c;
99*8fb009dcSAndroid Build Coastguard Worker n = (n + 1) & 0x07;
100*8fb009dcSAndroid Build Coastguard Worker }
101*8fb009dcSAndroid Build Coastguard Worker } else {
102*8fb009dcSAndroid Build Coastguard Worker while (l--) {
103*8fb009dcSAndroid Build Coastguard Worker if (n == 0) {
104*8fb009dcSAndroid Build Coastguard Worker c2l(iv, v0);
105*8fb009dcSAndroid Build Coastguard Worker c2l(iv, v1);
106*8fb009dcSAndroid Build Coastguard Worker
107*8fb009dcSAndroid Build Coastguard Worker ti[0] = v0;
108*8fb009dcSAndroid Build Coastguard Worker ti[1] = v1;
109*8fb009dcSAndroid Build Coastguard Worker DES_encrypt3(ti, ks1, ks2, ks3);
110*8fb009dcSAndroid Build Coastguard Worker v0 = ti[0];
111*8fb009dcSAndroid Build Coastguard Worker v1 = ti[1];
112*8fb009dcSAndroid Build Coastguard Worker
113*8fb009dcSAndroid Build Coastguard Worker iv = ivec->bytes;
114*8fb009dcSAndroid Build Coastguard Worker l2c(v0, iv);
115*8fb009dcSAndroid Build Coastguard Worker l2c(v1, iv);
116*8fb009dcSAndroid Build Coastguard Worker iv = ivec->bytes;
117*8fb009dcSAndroid Build Coastguard Worker }
118*8fb009dcSAndroid Build Coastguard Worker cc = *(in++);
119*8fb009dcSAndroid Build Coastguard Worker c = iv[n];
120*8fb009dcSAndroid Build Coastguard Worker iv[n] = cc;
121*8fb009dcSAndroid Build Coastguard Worker *(out++) = c ^ cc;
122*8fb009dcSAndroid Build Coastguard Worker n = (n + 1) & 0x07;
123*8fb009dcSAndroid Build Coastguard Worker }
124*8fb009dcSAndroid Build Coastguard Worker }
125*8fb009dcSAndroid Build Coastguard Worker v0 = v1 = ti[0] = ti[1] = c = cc = 0;
126*8fb009dcSAndroid Build Coastguard Worker *num = n;
127*8fb009dcSAndroid Build Coastguard Worker }
128*8fb009dcSAndroid Build Coastguard Worker
129*8fb009dcSAndroid Build Coastguard Worker // This is compatible with the single key CFB-r for DES, even thought that's
130*8fb009dcSAndroid Build Coastguard Worker // not what EVP needs.
131*8fb009dcSAndroid Build Coastguard Worker
DES_ede3_cfb_encrypt(const uint8_t * in,uint8_t * out,int numbits,long length,DES_key_schedule * ks1,DES_key_schedule * ks2,DES_key_schedule * ks3,DES_cblock * ivec,int enc)132*8fb009dcSAndroid Build Coastguard Worker void DES_ede3_cfb_encrypt(const uint8_t *in, uint8_t *out, int numbits,
133*8fb009dcSAndroid Build Coastguard Worker long length, DES_key_schedule *ks1,
134*8fb009dcSAndroid Build Coastguard Worker DES_key_schedule *ks2, DES_key_schedule *ks3,
135*8fb009dcSAndroid Build Coastguard Worker DES_cblock *ivec, int enc) {
136*8fb009dcSAndroid Build Coastguard Worker uint32_t d0, d1, v0, v1;
137*8fb009dcSAndroid Build Coastguard Worker unsigned long l = length, n = ((unsigned int)numbits + 7) / 8;
138*8fb009dcSAndroid Build Coastguard Worker int num = numbits, i;
139*8fb009dcSAndroid Build Coastguard Worker uint32_t ti[2];
140*8fb009dcSAndroid Build Coastguard Worker uint8_t *iv;
141*8fb009dcSAndroid Build Coastguard Worker uint8_t ovec[16];
142*8fb009dcSAndroid Build Coastguard Worker
143*8fb009dcSAndroid Build Coastguard Worker if (num > 64) {
144*8fb009dcSAndroid Build Coastguard Worker return;
145*8fb009dcSAndroid Build Coastguard Worker }
146*8fb009dcSAndroid Build Coastguard Worker
147*8fb009dcSAndroid Build Coastguard Worker iv = ivec->bytes;
148*8fb009dcSAndroid Build Coastguard Worker c2l(iv, v0);
149*8fb009dcSAndroid Build Coastguard Worker c2l(iv, v1);
150*8fb009dcSAndroid Build Coastguard Worker
151*8fb009dcSAndroid Build Coastguard Worker if (enc) {
152*8fb009dcSAndroid Build Coastguard Worker while (l >= n) {
153*8fb009dcSAndroid Build Coastguard Worker l -= n;
154*8fb009dcSAndroid Build Coastguard Worker ti[0] = v0;
155*8fb009dcSAndroid Build Coastguard Worker ti[1] = v1;
156*8fb009dcSAndroid Build Coastguard Worker DES_encrypt3(ti, ks1, ks2, ks3);
157*8fb009dcSAndroid Build Coastguard Worker c2ln(in, d0, d1, n);
158*8fb009dcSAndroid Build Coastguard Worker in += n;
159*8fb009dcSAndroid Build Coastguard Worker d0 ^= ti[0];
160*8fb009dcSAndroid Build Coastguard Worker d1 ^= ti[1];
161*8fb009dcSAndroid Build Coastguard Worker l2cn(d0, d1, out, n);
162*8fb009dcSAndroid Build Coastguard Worker out += n;
163*8fb009dcSAndroid Build Coastguard Worker // 30-08-94 - eay - changed because l>>32 and l<<32 are bad under
164*8fb009dcSAndroid Build Coastguard Worker // gcc :-(
165*8fb009dcSAndroid Build Coastguard Worker if (num == 32) {
166*8fb009dcSAndroid Build Coastguard Worker v0 = v1;
167*8fb009dcSAndroid Build Coastguard Worker v1 = d0;
168*8fb009dcSAndroid Build Coastguard Worker } else if (num == 64) {
169*8fb009dcSAndroid Build Coastguard Worker v0 = d0;
170*8fb009dcSAndroid Build Coastguard Worker v1 = d1;
171*8fb009dcSAndroid Build Coastguard Worker } else {
172*8fb009dcSAndroid Build Coastguard Worker iv = &ovec[0];
173*8fb009dcSAndroid Build Coastguard Worker l2c(v0, iv);
174*8fb009dcSAndroid Build Coastguard Worker l2c(v1, iv);
175*8fb009dcSAndroid Build Coastguard Worker l2c(d0, iv);
176*8fb009dcSAndroid Build Coastguard Worker l2c(d1, iv);
177*8fb009dcSAndroid Build Coastguard Worker // shift ovec left most of the bits...
178*8fb009dcSAndroid Build Coastguard Worker OPENSSL_memmove(ovec, ovec + num / 8, 8 + (num % 8 ? 1 : 0));
179*8fb009dcSAndroid Build Coastguard Worker // now the remaining bits
180*8fb009dcSAndroid Build Coastguard Worker if (num % 8 != 0) {
181*8fb009dcSAndroid Build Coastguard Worker for (i = 0; i < 8; ++i) {
182*8fb009dcSAndroid Build Coastguard Worker ovec[i] <<= num % 8;
183*8fb009dcSAndroid Build Coastguard Worker ovec[i] |= ovec[i + 1] >> (8 - num % 8);
184*8fb009dcSAndroid Build Coastguard Worker }
185*8fb009dcSAndroid Build Coastguard Worker }
186*8fb009dcSAndroid Build Coastguard Worker iv = &ovec[0];
187*8fb009dcSAndroid Build Coastguard Worker c2l(iv, v0);
188*8fb009dcSAndroid Build Coastguard Worker c2l(iv, v1);
189*8fb009dcSAndroid Build Coastguard Worker }
190*8fb009dcSAndroid Build Coastguard Worker }
191*8fb009dcSAndroid Build Coastguard Worker } else {
192*8fb009dcSAndroid Build Coastguard Worker while (l >= n) {
193*8fb009dcSAndroid Build Coastguard Worker l -= n;
194*8fb009dcSAndroid Build Coastguard Worker ti[0] = v0;
195*8fb009dcSAndroid Build Coastguard Worker ti[1] = v1;
196*8fb009dcSAndroid Build Coastguard Worker DES_encrypt3(ti, ks1, ks2, ks3);
197*8fb009dcSAndroid Build Coastguard Worker c2ln(in, d0, d1, n);
198*8fb009dcSAndroid Build Coastguard Worker in += n;
199*8fb009dcSAndroid Build Coastguard Worker // 30-08-94 - eay - changed because l>>32 and l<<32 are bad under
200*8fb009dcSAndroid Build Coastguard Worker // gcc :-(
201*8fb009dcSAndroid Build Coastguard Worker if (num == 32) {
202*8fb009dcSAndroid Build Coastguard Worker v0 = v1;
203*8fb009dcSAndroid Build Coastguard Worker v1 = d0;
204*8fb009dcSAndroid Build Coastguard Worker } else if (num == 64) {
205*8fb009dcSAndroid Build Coastguard Worker v0 = d0;
206*8fb009dcSAndroid Build Coastguard Worker v1 = d1;
207*8fb009dcSAndroid Build Coastguard Worker } else {
208*8fb009dcSAndroid Build Coastguard Worker iv = &ovec[0];
209*8fb009dcSAndroid Build Coastguard Worker l2c(v0, iv);
210*8fb009dcSAndroid Build Coastguard Worker l2c(v1, iv);
211*8fb009dcSAndroid Build Coastguard Worker l2c(d0, iv);
212*8fb009dcSAndroid Build Coastguard Worker l2c(d1, iv);
213*8fb009dcSAndroid Build Coastguard Worker // shift ovec left most of the bits...
214*8fb009dcSAndroid Build Coastguard Worker OPENSSL_memmove(ovec, ovec + num / 8, 8 + (num % 8 ? 1 : 0));
215*8fb009dcSAndroid Build Coastguard Worker // now the remaining bits
216*8fb009dcSAndroid Build Coastguard Worker if (num % 8 != 0) {
217*8fb009dcSAndroid Build Coastguard Worker for (i = 0; i < 8; ++i) {
218*8fb009dcSAndroid Build Coastguard Worker ovec[i] <<= num % 8;
219*8fb009dcSAndroid Build Coastguard Worker ovec[i] |= ovec[i + 1] >> (8 - num % 8);
220*8fb009dcSAndroid Build Coastguard Worker }
221*8fb009dcSAndroid Build Coastguard Worker }
222*8fb009dcSAndroid Build Coastguard Worker iv = &ovec[0];
223*8fb009dcSAndroid Build Coastguard Worker c2l(iv, v0);
224*8fb009dcSAndroid Build Coastguard Worker c2l(iv, v1);
225*8fb009dcSAndroid Build Coastguard Worker }
226*8fb009dcSAndroid Build Coastguard Worker d0 ^= ti[0];
227*8fb009dcSAndroid Build Coastguard Worker d1 ^= ti[1];
228*8fb009dcSAndroid Build Coastguard Worker l2cn(d0, d1, out, n);
229*8fb009dcSAndroid Build Coastguard Worker out += n;
230*8fb009dcSAndroid Build Coastguard Worker }
231*8fb009dcSAndroid Build Coastguard Worker }
232*8fb009dcSAndroid Build Coastguard Worker
233*8fb009dcSAndroid Build Coastguard Worker iv = ivec->bytes;
234*8fb009dcSAndroid Build Coastguard Worker l2c(v0, iv);
235*8fb009dcSAndroid Build Coastguard Worker l2c(v1, iv);
236*8fb009dcSAndroid Build Coastguard Worker v0 = v1 = d0 = d1 = ti[0] = ti[1] = 0;
237*8fb009dcSAndroid Build Coastguard Worker }
238