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 #ifndef OPENSSL_HEADER_DES_INTERNAL_H 58*8fb009dcSAndroid Build Coastguard Worker #define OPENSSL_HEADER_DES_INTERNAL_H 59*8fb009dcSAndroid Build Coastguard Worker 60*8fb009dcSAndroid Build Coastguard Worker #include <openssl/base.h> 61*8fb009dcSAndroid Build Coastguard Worker #include <openssl/des.h> 62*8fb009dcSAndroid Build Coastguard Worker 63*8fb009dcSAndroid Build Coastguard Worker #include "../internal.h" 64*8fb009dcSAndroid Build Coastguard Worker 65*8fb009dcSAndroid Build Coastguard Worker #if defined(__cplusplus) 66*8fb009dcSAndroid Build Coastguard Worker extern "C" { 67*8fb009dcSAndroid Build Coastguard Worker #endif 68*8fb009dcSAndroid Build Coastguard Worker 69*8fb009dcSAndroid Build Coastguard Worker 70*8fb009dcSAndroid Build Coastguard Worker // TODO(davidben): Ideally these macros would be replaced with 71*8fb009dcSAndroid Build Coastguard Worker // |CRYPTO_load_u32_le| and |CRYPTO_store_u32_le|. 72*8fb009dcSAndroid Build Coastguard Worker 73*8fb009dcSAndroid Build Coastguard Worker #define c2l(c, l) \ 74*8fb009dcSAndroid Build Coastguard Worker do { \ 75*8fb009dcSAndroid Build Coastguard Worker (l) = ((uint32_t)(*((c)++))); \ 76*8fb009dcSAndroid Build Coastguard Worker (l) |= ((uint32_t)(*((c)++))) << 8L; \ 77*8fb009dcSAndroid Build Coastguard Worker (l) |= ((uint32_t)(*((c)++))) << 16L; \ 78*8fb009dcSAndroid Build Coastguard Worker (l) |= ((uint32_t)(*((c)++))) << 24L; \ 79*8fb009dcSAndroid Build Coastguard Worker } while (0) 80*8fb009dcSAndroid Build Coastguard Worker 81*8fb009dcSAndroid Build Coastguard Worker #define l2c(l, c) \ 82*8fb009dcSAndroid Build Coastguard Worker do { \ 83*8fb009dcSAndroid Build Coastguard Worker *((c)++) = (unsigned char)(((l)) & 0xff); \ 84*8fb009dcSAndroid Build Coastguard Worker *((c)++) = (unsigned char)(((l) >> 8L) & 0xff); \ 85*8fb009dcSAndroid Build Coastguard Worker *((c)++) = (unsigned char)(((l) >> 16L) & 0xff); \ 86*8fb009dcSAndroid Build Coastguard Worker *((c)++) = (unsigned char)(((l) >> 24L) & 0xff); \ 87*8fb009dcSAndroid Build Coastguard Worker } while (0) 88*8fb009dcSAndroid Build Coastguard Worker 89*8fb009dcSAndroid Build Coastguard Worker // NOTE - c is not incremented as per c2l 90*8fb009dcSAndroid Build Coastguard Worker #define c2ln(c, l1, l2, n) \ 91*8fb009dcSAndroid Build Coastguard Worker do { \ 92*8fb009dcSAndroid Build Coastguard Worker (c) += (n); \ 93*8fb009dcSAndroid Build Coastguard Worker (l1) = (l2) = 0; \ 94*8fb009dcSAndroid Build Coastguard Worker switch (n) { \ 95*8fb009dcSAndroid Build Coastguard Worker case 8: \ 96*8fb009dcSAndroid Build Coastguard Worker (l2) = ((uint32_t)(*(--(c)))) << 24L; \ 97*8fb009dcSAndroid Build Coastguard Worker OPENSSL_FALLTHROUGH; \ 98*8fb009dcSAndroid Build Coastguard Worker case 7: \ 99*8fb009dcSAndroid Build Coastguard Worker (l2) |= ((uint32_t)(*(--(c)))) << 16L; \ 100*8fb009dcSAndroid Build Coastguard Worker OPENSSL_FALLTHROUGH; \ 101*8fb009dcSAndroid Build Coastguard Worker case 6: \ 102*8fb009dcSAndroid Build Coastguard Worker (l2) |= ((uint32_t)(*(--(c)))) << 8L; \ 103*8fb009dcSAndroid Build Coastguard Worker OPENSSL_FALLTHROUGH; \ 104*8fb009dcSAndroid Build Coastguard Worker case 5: \ 105*8fb009dcSAndroid Build Coastguard Worker (l2) |= ((uint32_t)(*(--(c)))); \ 106*8fb009dcSAndroid Build Coastguard Worker OPENSSL_FALLTHROUGH; \ 107*8fb009dcSAndroid Build Coastguard Worker case 4: \ 108*8fb009dcSAndroid Build Coastguard Worker (l1) = ((uint32_t)(*(--(c)))) << 24L; \ 109*8fb009dcSAndroid Build Coastguard Worker OPENSSL_FALLTHROUGH; \ 110*8fb009dcSAndroid Build Coastguard Worker case 3: \ 111*8fb009dcSAndroid Build Coastguard Worker (l1) |= ((uint32_t)(*(--(c)))) << 16L; \ 112*8fb009dcSAndroid Build Coastguard Worker OPENSSL_FALLTHROUGH; \ 113*8fb009dcSAndroid Build Coastguard Worker case 2: \ 114*8fb009dcSAndroid Build Coastguard Worker (l1) |= ((uint32_t)(*(--(c)))) << 8L; \ 115*8fb009dcSAndroid Build Coastguard Worker OPENSSL_FALLTHROUGH; \ 116*8fb009dcSAndroid Build Coastguard Worker case 1: \ 117*8fb009dcSAndroid Build Coastguard Worker (l1) |= ((uint32_t)(*(--(c)))); \ 118*8fb009dcSAndroid Build Coastguard Worker } \ 119*8fb009dcSAndroid Build Coastguard Worker } while (0) 120*8fb009dcSAndroid Build Coastguard Worker 121*8fb009dcSAndroid Build Coastguard Worker // NOTE - c is not incremented as per l2c 122*8fb009dcSAndroid Build Coastguard Worker #define l2cn(l1, l2, c, n) \ 123*8fb009dcSAndroid Build Coastguard Worker do { \ 124*8fb009dcSAndroid Build Coastguard Worker (c) += (n); \ 125*8fb009dcSAndroid Build Coastguard Worker switch (n) { \ 126*8fb009dcSAndroid Build Coastguard Worker case 8: \ 127*8fb009dcSAndroid Build Coastguard Worker *(--(c)) = (unsigned char)(((l2) >> 24L) & 0xff); \ 128*8fb009dcSAndroid Build Coastguard Worker OPENSSL_FALLTHROUGH; \ 129*8fb009dcSAndroid Build Coastguard Worker case 7: \ 130*8fb009dcSAndroid Build Coastguard Worker *(--(c)) = (unsigned char)(((l2) >> 16L) & 0xff); \ 131*8fb009dcSAndroid Build Coastguard Worker OPENSSL_FALLTHROUGH; \ 132*8fb009dcSAndroid Build Coastguard Worker case 6: \ 133*8fb009dcSAndroid Build Coastguard Worker *(--(c)) = (unsigned char)(((l2) >> 8L) & 0xff); \ 134*8fb009dcSAndroid Build Coastguard Worker OPENSSL_FALLTHROUGH; \ 135*8fb009dcSAndroid Build Coastguard Worker case 5: \ 136*8fb009dcSAndroid Build Coastguard Worker *(--(c)) = (unsigned char)(((l2)) & 0xff); \ 137*8fb009dcSAndroid Build Coastguard Worker OPENSSL_FALLTHROUGH; \ 138*8fb009dcSAndroid Build Coastguard Worker case 4: \ 139*8fb009dcSAndroid Build Coastguard Worker *(--(c)) = (unsigned char)(((l1) >> 24L) & 0xff); \ 140*8fb009dcSAndroid Build Coastguard Worker OPENSSL_FALLTHROUGH; \ 141*8fb009dcSAndroid Build Coastguard Worker case 3: \ 142*8fb009dcSAndroid Build Coastguard Worker *(--(c)) = (unsigned char)(((l1) >> 16L) & 0xff); \ 143*8fb009dcSAndroid Build Coastguard Worker OPENSSL_FALLTHROUGH; \ 144*8fb009dcSAndroid Build Coastguard Worker case 2: \ 145*8fb009dcSAndroid Build Coastguard Worker *(--(c)) = (unsigned char)(((l1) >> 8L) & 0xff); \ 146*8fb009dcSAndroid Build Coastguard Worker OPENSSL_FALLTHROUGH; \ 147*8fb009dcSAndroid Build Coastguard Worker case 1: \ 148*8fb009dcSAndroid Build Coastguard Worker *(--(c)) = (unsigned char)(((l1)) & 0xff); \ 149*8fb009dcSAndroid Build Coastguard Worker } \ 150*8fb009dcSAndroid Build Coastguard Worker } while (0) 151*8fb009dcSAndroid Build Coastguard Worker 152*8fb009dcSAndroid Build Coastguard Worker 153*8fb009dcSAndroid Build Coastguard Worker // Correctly-typed versions of DES functions. 154*8fb009dcSAndroid Build Coastguard Worker // 155*8fb009dcSAndroid Build Coastguard Worker // See https://crbug.com/boringssl/683. 156*8fb009dcSAndroid Build Coastguard Worker 157*8fb009dcSAndroid Build Coastguard Worker void DES_set_key_ex(const uint8_t key[8], DES_key_schedule *schedule); 158*8fb009dcSAndroid Build Coastguard Worker void DES_ecb_encrypt_ex(const uint8_t in[8], uint8_t out[8], 159*8fb009dcSAndroid Build Coastguard Worker const DES_key_schedule *schedule, int is_encrypt); 160*8fb009dcSAndroid Build Coastguard Worker void DES_ncbc_encrypt_ex(const uint8_t *in, uint8_t *out, size_t len, 161*8fb009dcSAndroid Build Coastguard Worker const DES_key_schedule *schedule, uint8_t ivec[8], 162*8fb009dcSAndroid Build Coastguard Worker int enc); 163*8fb009dcSAndroid Build Coastguard Worker void DES_ecb3_encrypt_ex(const uint8_t input[8], uint8_t output[8], 164*8fb009dcSAndroid Build Coastguard Worker const DES_key_schedule *ks1, 165*8fb009dcSAndroid Build Coastguard Worker const DES_key_schedule *ks2, 166*8fb009dcSAndroid Build Coastguard Worker const DES_key_schedule *ks3, int enc); 167*8fb009dcSAndroid Build Coastguard Worker void DES_ede3_cbc_encrypt_ex(const uint8_t *in, uint8_t *out, size_t len, 168*8fb009dcSAndroid Build Coastguard Worker const DES_key_schedule *ks1, 169*8fb009dcSAndroid Build Coastguard Worker const DES_key_schedule *ks2, 170*8fb009dcSAndroid Build Coastguard Worker const DES_key_schedule *ks3, uint8_t ivec[8], 171*8fb009dcSAndroid Build Coastguard Worker int enc); 172*8fb009dcSAndroid Build Coastguard Worker 173*8fb009dcSAndroid Build Coastguard Worker 174*8fb009dcSAndroid Build Coastguard Worker // Private functions. 175*8fb009dcSAndroid Build Coastguard Worker // 176*8fb009dcSAndroid Build Coastguard Worker // These functions are only exported for use in |decrepit|. 177*8fb009dcSAndroid Build Coastguard Worker 178*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void DES_decrypt3(uint32_t data[2], const DES_key_schedule *ks1, 179*8fb009dcSAndroid Build Coastguard Worker const DES_key_schedule *ks2, 180*8fb009dcSAndroid Build Coastguard Worker const DES_key_schedule *ks3); 181*8fb009dcSAndroid Build Coastguard Worker 182*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void DES_encrypt3(uint32_t data[2], const DES_key_schedule *ks1, 183*8fb009dcSAndroid Build Coastguard Worker const DES_key_schedule *ks2, 184*8fb009dcSAndroid Build Coastguard Worker const DES_key_schedule *ks3); 185*8fb009dcSAndroid Build Coastguard Worker 186*8fb009dcSAndroid Build Coastguard Worker 187*8fb009dcSAndroid Build Coastguard Worker #if defined(__cplusplus) 188*8fb009dcSAndroid Build Coastguard Worker } // extern C 189*8fb009dcSAndroid Build Coastguard Worker #endif 190*8fb009dcSAndroid Build Coastguard Worker 191*8fb009dcSAndroid Build Coastguard Worker #endif // OPENSSL_HEADER_DES_INTERNAL_H 192