v / thirdparty / mbedtls / 3rdparty / everest / library / Hacl_Curve25519_joined.c
50 lines · 43 sloc · 1.47 KB · 1274cdc3447be8e83616e8512872455e8720c2fd
Raw
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#ifndef _BSD_SOURCE
22/* Required to get htole64() from gcc/glibc's endian.h (older systems)
23 * when we compile with -std=c99 */
24#define _BSD_SOURCE
25#endif
26#ifndef _DEFAULT_SOURCE
27/* (modern version of _BSD_SOURCE) */
28#define _DEFAULT_SOURCE
29#endif
30
31#include "common.h"
32
33#if defined(MBEDTLS_ECDH_VARIANT_EVEREST_ENABLED)
34
35#if defined(__SIZEOF_INT128__) && (__SIZEOF_INT128__ == 16)
36#define MBEDTLS_HAVE_INT128
37#endif
38
39#if defined(MBEDTLS_HAVE_INT128)
40#include "Hacl_Curve25519.c"
41#else
42#define KRML_VERIFIED_UINT128
43#include "kremlib/FStar_UInt128_extracted.c"
44#include "legacy/Hacl_Curve25519.c"
45#endif
46
47#include "kremlib/FStar_UInt64_FStar_UInt32_FStar_UInt16_FStar_UInt8.c"
48
49#endif /* defined(MBEDTLS_ECDH_VARIANT_EVEREST_ENABLED) */
50
51