1*5d5fbe79SDavid van Moolenbroek /* 2*5d5fbe79SDavid van Moolenbroek * pppcrypt.c - PPP/DES linkage for MS-CHAP and EAP SRP-SHA1 3*5d5fbe79SDavid van Moolenbroek * 4*5d5fbe79SDavid van Moolenbroek * Extracted from chap_ms.c by James Carlson. 5*5d5fbe79SDavid van Moolenbroek * 6*5d5fbe79SDavid van Moolenbroek * Copyright (c) 1995 Eric Rosenquist. All rights reserved. 7*5d5fbe79SDavid van Moolenbroek * 8*5d5fbe79SDavid van Moolenbroek * Redistribution and use in source and binary forms, with or without 9*5d5fbe79SDavid van Moolenbroek * modification, are permitted provided that the following conditions 10*5d5fbe79SDavid van Moolenbroek * are met: 11*5d5fbe79SDavid van Moolenbroek * 12*5d5fbe79SDavid van Moolenbroek * 1. Redistributions of source code must retain the above copyright 13*5d5fbe79SDavid van Moolenbroek * notice, this list of conditions and the following disclaimer. 14*5d5fbe79SDavid van Moolenbroek * 15*5d5fbe79SDavid van Moolenbroek * 2. Redistributions in binary form must reproduce the above copyright 16*5d5fbe79SDavid van Moolenbroek * notice, this list of conditions and the following disclaimer in 17*5d5fbe79SDavid van Moolenbroek * the documentation and/or other materials provided with the 18*5d5fbe79SDavid van Moolenbroek * distribution. 19*5d5fbe79SDavid van Moolenbroek * 20*5d5fbe79SDavid van Moolenbroek * 3. The name(s) of the authors of this software must not be used to 21*5d5fbe79SDavid van Moolenbroek * endorse or promote products derived from this software without 22*5d5fbe79SDavid van Moolenbroek * prior written permission. 23*5d5fbe79SDavid van Moolenbroek * 24*5d5fbe79SDavid van Moolenbroek * THE AUTHORS OF THIS SOFTWARE DISCLAIM ALL WARRANTIES WITH REGARD TO 25*5d5fbe79SDavid van Moolenbroek * THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY 26*5d5fbe79SDavid van Moolenbroek * AND FITNESS, IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY 27*5d5fbe79SDavid van Moolenbroek * SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 28*5d5fbe79SDavid van Moolenbroek * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN 29*5d5fbe79SDavid van Moolenbroek * AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING 30*5d5fbe79SDavid van Moolenbroek * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 31*5d5fbe79SDavid van Moolenbroek */ 32*5d5fbe79SDavid van Moolenbroek 33*5d5fbe79SDavid van Moolenbroek #include "netif/ppp/ppp_opts.h" 34*5d5fbe79SDavid van Moolenbroek #if PPP_SUPPORT /* don't build if not configured for use in lwipopts.h */ 35*5d5fbe79SDavid van Moolenbroek 36*5d5fbe79SDavid van Moolenbroek /* This header file is included in all PPP modules needing hashes and/or ciphers */ 37*5d5fbe79SDavid van Moolenbroek 38*5d5fbe79SDavid van Moolenbroek #ifndef PPPCRYPT_H 39*5d5fbe79SDavid van Moolenbroek #define PPPCRYPT_H 40*5d5fbe79SDavid van Moolenbroek 41*5d5fbe79SDavid van Moolenbroek /* 42*5d5fbe79SDavid van Moolenbroek * If included PolarSSL copy is not used, user is expected to include 43*5d5fbe79SDavid van Moolenbroek * external libraries in arch/cc.h (which is included by lwip/arch.h). 44*5d5fbe79SDavid van Moolenbroek */ 45*5d5fbe79SDavid van Moolenbroek #include "lwip/arch.h" 46*5d5fbe79SDavid van Moolenbroek 47*5d5fbe79SDavid van Moolenbroek /* 48*5d5fbe79SDavid van Moolenbroek * Map hashes and ciphers functions to PolarSSL 49*5d5fbe79SDavid van Moolenbroek */ 50*5d5fbe79SDavid van Moolenbroek #if !LWIP_USE_EXTERNAL_MBEDTLS 51*5d5fbe79SDavid van Moolenbroek 52*5d5fbe79SDavid van Moolenbroek #include "netif/ppp/polarssl/md4.h" 53*5d5fbe79SDavid van Moolenbroek #define lwip_md4_context md4_context 54*5d5fbe79SDavid van Moolenbroek #define lwip_md4_init(context) 55*5d5fbe79SDavid van Moolenbroek #define lwip_md4_starts md4_starts 56*5d5fbe79SDavid van Moolenbroek #define lwip_md4_update md4_update 57*5d5fbe79SDavid van Moolenbroek #define lwip_md4_finish md4_finish 58*5d5fbe79SDavid van Moolenbroek #define lwip_md4_free(context) 59*5d5fbe79SDavid van Moolenbroek 60*5d5fbe79SDavid van Moolenbroek #include "netif/ppp/polarssl/md5.h" 61*5d5fbe79SDavid van Moolenbroek #define lwip_md5_context md5_context 62*5d5fbe79SDavid van Moolenbroek #define lwip_md5_init(context) 63*5d5fbe79SDavid van Moolenbroek #define lwip_md5_starts md5_starts 64*5d5fbe79SDavid van Moolenbroek #define lwip_md5_update md5_update 65*5d5fbe79SDavid van Moolenbroek #define lwip_md5_finish md5_finish 66*5d5fbe79SDavid van Moolenbroek #define lwip_md5_free(context) 67*5d5fbe79SDavid van Moolenbroek 68*5d5fbe79SDavid van Moolenbroek #include "netif/ppp/polarssl/sha1.h" 69*5d5fbe79SDavid van Moolenbroek #define lwip_sha1_context sha1_context 70*5d5fbe79SDavid van Moolenbroek #define lwip_sha1_init(context) 71*5d5fbe79SDavid van Moolenbroek #define lwip_sha1_starts sha1_starts 72*5d5fbe79SDavid van Moolenbroek #define lwip_sha1_update sha1_update 73*5d5fbe79SDavid van Moolenbroek #define lwip_sha1_finish sha1_finish 74*5d5fbe79SDavid van Moolenbroek #define lwip_sha1_free(context) 75*5d5fbe79SDavid van Moolenbroek 76*5d5fbe79SDavid van Moolenbroek #include "netif/ppp/polarssl/des.h" 77*5d5fbe79SDavid van Moolenbroek #define lwip_des_context des_context 78*5d5fbe79SDavid van Moolenbroek #define lwip_des_init(context) 79*5d5fbe79SDavid van Moolenbroek #define lwip_des_setkey_enc des_setkey_enc 80*5d5fbe79SDavid van Moolenbroek #define lwip_des_crypt_ecb des_crypt_ecb 81*5d5fbe79SDavid van Moolenbroek #define lwip_des_free(context) 82*5d5fbe79SDavid van Moolenbroek 83*5d5fbe79SDavid van Moolenbroek #include "netif/ppp/polarssl/arc4.h" 84*5d5fbe79SDavid van Moolenbroek #define lwip_arc4_context arc4_context 85*5d5fbe79SDavid van Moolenbroek #define lwip_arc4_init(context) 86*5d5fbe79SDavid van Moolenbroek #define lwip_arc4_setup arc4_setup 87*5d5fbe79SDavid van Moolenbroek #define lwip_arc4_crypt arc4_crypt 88*5d5fbe79SDavid van Moolenbroek #define lwip_arc4_free(context) 89*5d5fbe79SDavid van Moolenbroek 90*5d5fbe79SDavid van Moolenbroek #endif /* !LWIP_USE_EXTERNAL_MBEDTLS */ 91*5d5fbe79SDavid van Moolenbroek 92*5d5fbe79SDavid van Moolenbroek /* 93*5d5fbe79SDavid van Moolenbroek * Map hashes and ciphers functions to mbed TLS 94*5d5fbe79SDavid van Moolenbroek */ 95*5d5fbe79SDavid van Moolenbroek #if LWIP_USE_EXTERNAL_MBEDTLS 96*5d5fbe79SDavid van Moolenbroek 97*5d5fbe79SDavid van Moolenbroek #define lwip_md4_context mbedtls_md4_context 98*5d5fbe79SDavid van Moolenbroek #define lwip_md4_init mbedtls_md4_init 99*5d5fbe79SDavid van Moolenbroek #define lwip_md4_starts mbedtls_md4_starts 100*5d5fbe79SDavid van Moolenbroek #define lwip_md4_update mbedtls_md4_update 101*5d5fbe79SDavid van Moolenbroek #define lwip_md4_finish mbedtls_md4_finish 102*5d5fbe79SDavid van Moolenbroek #define lwip_md4_free mbedtls_md4_free 103*5d5fbe79SDavid van Moolenbroek 104*5d5fbe79SDavid van Moolenbroek #define lwip_md5_context mbedtls_md5_context 105*5d5fbe79SDavid van Moolenbroek #define lwip_md5_init mbedtls_md5_init 106*5d5fbe79SDavid van Moolenbroek #define lwip_md5_starts mbedtls_md5_starts 107*5d5fbe79SDavid van Moolenbroek #define lwip_md5_update mbedtls_md5_update 108*5d5fbe79SDavid van Moolenbroek #define lwip_md5_finish mbedtls_md5_finish 109*5d5fbe79SDavid van Moolenbroek #define lwip_md5_free mbedtls_md5_free 110*5d5fbe79SDavid van Moolenbroek 111*5d5fbe79SDavid van Moolenbroek #define lwip_sha1_context mbedtls_sha1_context 112*5d5fbe79SDavid van Moolenbroek #define lwip_sha1_init mbedtls_sha1_init 113*5d5fbe79SDavid van Moolenbroek #define lwip_sha1_starts mbedtls_sha1_starts 114*5d5fbe79SDavid van Moolenbroek #define lwip_sha1_update mbedtls_sha1_update 115*5d5fbe79SDavid van Moolenbroek #define lwip_sha1_finish mbedtls_sha1_finish 116*5d5fbe79SDavid van Moolenbroek #define lwip_sha1_free mbedtls_sha1_free 117*5d5fbe79SDavid van Moolenbroek 118*5d5fbe79SDavid van Moolenbroek #define lwip_des_context mbedtls_des_context 119*5d5fbe79SDavid van Moolenbroek #define lwip_des_init mbedtls_des_init 120*5d5fbe79SDavid van Moolenbroek #define lwip_des_setkey_enc mbedtls_des_setkey_enc 121*5d5fbe79SDavid van Moolenbroek #define lwip_des_crypt_ecb mbedtls_des_crypt_ecb 122*5d5fbe79SDavid van Moolenbroek #define lwip_des_free mbedtls_des_free 123*5d5fbe79SDavid van Moolenbroek 124*5d5fbe79SDavid van Moolenbroek #define lwip_arc4_context mbedtls_arc4_context 125*5d5fbe79SDavid van Moolenbroek #define lwip_arc4_init mbedtls_arc4_init 126*5d5fbe79SDavid van Moolenbroek #define lwip_arc4_setup mbedtls_arc4_setup 127*5d5fbe79SDavid van Moolenbroek #define lwip_arc4_crypt(context, buffer, length) mbedtls_arc4_crypt(context, length, buffer, buffer) 128*5d5fbe79SDavid van Moolenbroek #define lwip_arc4_free mbedtls_arc4_free 129*5d5fbe79SDavid van Moolenbroek 130*5d5fbe79SDavid van Moolenbroek #endif /* LWIP_USE_EXTERNAL_MBEDTLS */ 131*5d5fbe79SDavid van Moolenbroek 132*5d5fbe79SDavid van Moolenbroek void pppcrypt_56_to_64_bit_key(u_char *key, u_char *des_key); 133*5d5fbe79SDavid van Moolenbroek 134*5d5fbe79SDavid van Moolenbroek #endif /* PPPCRYPT_H */ 135*5d5fbe79SDavid van Moolenbroek 136*5d5fbe79SDavid van Moolenbroek #endif /* PPP_SUPPORT */ 137