xref: /aosp_15_r20/external/boringssl/src/decrepit/des/cfb64ede.c (revision 8fb009dc861624b67b6cdb62ea21f0f22d0c584b)
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