1 /*
2  *  Interface to code from Project Everest
3  *
4  *  Copyright 2016-2018 INRIA and Microsoft Corporation
5  *  SPDX-License-Identifier: Apache-2.0
6  *
7  *  Licensed under the Apache License, Version 2.0 (the "License"); you may
8  *  not use this file except in compliance with the License.
9  *  You may obtain a copy of the License at
10  *
11  *  http://www.apache.org/licenses/LICENSE-2.0
12  *
13  *  Unless required by applicable law or agreed to in writing, software
14  *  distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
15  *  WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  *  See the License for the specific language governing permissions and
17  *  limitations under the License.
18  *
19  *  This file is part of mbed TLS (https://tls.mbed.org)
20  */
21 
22 #include "common.h"
23 
24 #if defined(MBEDTLS_ECDH_VARIANT_EVEREST_ENABLED)
25 
26 #if defined(__SIZEOF_INT128__) && (__SIZEOF_INT128__ == 16)
27 #define MBEDTLS_HAVE_INT128
28 #endif
29 
30 #if defined(MBEDTLS_HAVE_INT128)
31 #include "Hacl_Curve25519.c"
32 #else
33 #define KRML_VERIFIED_UINT128
34 #include "kremlib/FStar_UInt128_extracted.c"
35 #include "legacy/Hacl_Curve25519.c"
36 #endif
37 
38 #include "kremlib/FStar_UInt64_FStar_UInt32_FStar_UInt16_FStar_UInt8.c"
39 
40 #endif /* defined(MBEDTLS_ECDH_VARIANT_EVEREST_ENABLED) */
41 
42