mirror of https://github.com/ARMmbed/mbed-os.git
				
				
				
			
		
			
				
	
	
		
			141 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			C
		
	
	
			
		
		
	
	
			141 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			C
		
	
	
/*
 | 
						|
 * pppcrypt.c - PPP/DES linkage for MS-CHAP and EAP SRP-SHA1
 | 
						|
 *
 | 
						|
 * Extracted from chap_ms.c by James Carlson.
 | 
						|
 *
 | 
						|
 * Copyright (c) 1995 Eric Rosenquist.  All rights reserved.
 | 
						|
 *
 | 
						|
 * Redistribution and use in source and binary forms, with or without
 | 
						|
 * modification, are permitted provided that the following conditions
 | 
						|
 * are met:
 | 
						|
 *
 | 
						|
 * 1. Redistributions of source code must retain the above copyright
 | 
						|
 *    notice, this list of conditions and the following disclaimer.
 | 
						|
 *
 | 
						|
 * 2. Redistributions in binary form must reproduce the above copyright
 | 
						|
 *    notice, this list of conditions and the following disclaimer in
 | 
						|
 *    the documentation and/or other materials provided with the
 | 
						|
 *    distribution.
 | 
						|
 *
 | 
						|
 * 3. The name(s) of the authors of this software must not be used to
 | 
						|
 *    endorse or promote products derived from this software without
 | 
						|
 *    prior written permission.
 | 
						|
 *
 | 
						|
 * THE AUTHORS OF THIS SOFTWARE DISCLAIM ALL WARRANTIES WITH REGARD TO
 | 
						|
 * THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
 | 
						|
 * AND FITNESS, IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY
 | 
						|
 * SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 | 
						|
 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN
 | 
						|
 * AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
 | 
						|
 * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 | 
						|
 */
 | 
						|
 | 
						|
#include "ppp_opts.h"
 | 
						|
#if PPP_SUPPORT /* don't build if not configured for use in ppp_opts.h */
 | 
						|
 | 
						|
/* This header file is included in all PPP modules needing hashes and/or ciphers */
 | 
						|
 | 
						|
#ifndef PPPCRYPT_H
 | 
						|
#define	PPPCRYPT_H
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
extern "C" {
 | 
						|
#endif
 | 
						|
 | 
						|
/*
 | 
						|
 * Map hashes and ciphers functions to PolarSSL
 | 
						|
 */
 | 
						|
#if !PPP_USE_EXTERNAL_MBEDTLS
 | 
						|
 | 
						|
#include "polarssl/md4.h"
 | 
						|
#define MD4_context md4_context
 | 
						|
#define MD4_init(context)
 | 
						|
#define MD4_starts md4_starts
 | 
						|
#define MD4_update md4_update
 | 
						|
#define MD4_finish md4_finish
 | 
						|
#define MD4_free(context)
 | 
						|
 | 
						|
#include "polarssl/md5.h"
 | 
						|
#define MD5_context md5_context
 | 
						|
#define MD5_init(context)
 | 
						|
#define MD5_starts md5_starts
 | 
						|
#define MD5_update md5_update
 | 
						|
#define MD5_finish md5_finish
 | 
						|
#define MD5_free(context)
 | 
						|
 | 
						|
#include "polarssl/sha1.h"
 | 
						|
#define SHA1_context sha1_context
 | 
						|
#define SHA1_init(context)
 | 
						|
#define SHA1_starts sha1_starts
 | 
						|
#define SHA1_update sha1_update
 | 
						|
#define SHA1_finish sha1_finish
 | 
						|
#define SHA1_free(context)
 | 
						|
 | 
						|
#include "polarssl/des.h"
 | 
						|
#define Des_context des_context
 | 
						|
#define Des_init(context)
 | 
						|
#define Des_setkey_enc des_setkey_enc
 | 
						|
#define Des_crypt_ecb des_crypt_ecb
 | 
						|
#define Des_free(context)
 | 
						|
 | 
						|
#include "polarssl/arc4.h"
 | 
						|
#define ARC4_context arc4_context
 | 
						|
#define ARC4_init(context)
 | 
						|
#define ARC4_setup arc4_setup
 | 
						|
#define ARC4_crypt arc4_crypt
 | 
						|
#define ARC4_free(context)
 | 
						|
 | 
						|
#endif /* !PPP_USE_EXTERNAL_MBEDTLS */
 | 
						|
 | 
						|
/*
 | 
						|
 * Map hashes and ciphers functions to mbed TLS
 | 
						|
 */
 | 
						|
#if PPP_USE_EXTERNAL_MBEDTLS
 | 
						|
 | 
						|
#include "mbedtls/md5.h"
 | 
						|
 | 
						|
#define MD4_context mbedtls_md4_context
 | 
						|
#define MD4_init mbedtls_md4_init
 | 
						|
#define MD4_starts mbedtls_md4_starts
 | 
						|
#define MD4_update mbedtls_md4_update
 | 
						|
#define MD4_finish mbedtls_md4_finish
 | 
						|
#define MD4_free mbedtls_md4_free
 | 
						|
 | 
						|
#define MD5_context mbedtls_md5_context
 | 
						|
#define MD5_init mbedtls_md5_init
 | 
						|
#define MD5_starts mbedtls_md5_starts
 | 
						|
#define MD5_update mbedtls_md5_update
 | 
						|
#define MD5_finish mbedtls_md5_finish
 | 
						|
#define MD5_free mbedtls_md5_free
 | 
						|
 | 
						|
#define SHA1_context mbedtls_sha1_context
 | 
						|
#define SHA1_init mbedtls_sha1_init
 | 
						|
#define SHA1_starts mbedtls_sha1_starts
 | 
						|
#define SHA1_update mbedtls_sha1_update
 | 
						|
#define SHA1_finish mbedtls_sha1_finish
 | 
						|
#define SHA1_free mbedtls_sha1_free
 | 
						|
 | 
						|
#define Des_context mbedtls_des_context
 | 
						|
#define Des_init mbedtls_des_init
 | 
						|
#define Des_setkey_enc mbedtls_des_setkey_enc
 | 
						|
#define Des_crypt_ecb mbedtls_des_crypt_ecb
 | 
						|
#define Des_free mbedtls_des_free
 | 
						|
 | 
						|
#define ARC4_context mbedtls_arc4_context
 | 
						|
#define ARC4_init mbedtls_arc4_init
 | 
						|
#define ARC4_setup mbedtls_arc4_setup
 | 
						|
#define ARC4_crypt(context, buffer, length) mbedtls_arc4_crypt(context, length, buffer, buffer)
 | 
						|
#define ARC4_free mbedtls_arc4_free
 | 
						|
 | 
						|
#endif /* PPP_USE_EXTERNAL_MBEDTLS */
 | 
						|
 | 
						|
void pppcrypt_56_to_64_bit_key(u_char *key, u_char *des_key);
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
}
 | 
						|
#endif
 | 
						|
 | 
						|
#endif /* PPPCRYPT_H */
 | 
						|
 | 
						|
#endif /* PPP_SUPPORT */
 |