source: azure_iot_hub_f767zi/trunk/wolfssl-4.7.0/wolfssl/openssl/dh.h

Last change on this file was 464, checked in by coas-nagasima, 3 years ago

WolfSSLとAzure IoT SDKを更新

  • Property svn:eol-style set to native
  • Property svn:mime-type set to text/x-chdr;charset=UTF-8
File size: 4.1 KB
Line 
1/* dh.h
2 *
3 * Copyright (C) 2006-2020 wolfSSL Inc.
4 *
5 * This file is part of wolfSSL.
6 *
7 * wolfSSL is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
11 *
12 * wolfSSL is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335, USA
20 */
21
22/* dh.h for openSSL */
23
24
25#ifndef WOLFSSL_DH_H_
26#define WOLFSSL_DH_H_
27
28#include <wolfssl/openssl/bn.h>
29#include <wolfssl/openssl/opensslv.h>
30
31#ifdef __cplusplus
32 extern "C" {
33#endif
34
35#ifndef WOLFSSL_DH_TYPE_DEFINED /* guard on redeclaration */
36typedef struct WOLFSSL_DH WOLFSSL_DH;
37#define WOLFSSL_DH_TYPE_DEFINED
38#endif
39
40typedef WOLFSSL_DH DH;
41
42struct WOLFSSL_DH {
43 WOLFSSL_BIGNUM* p;
44 WOLFSSL_BIGNUM* g;
45 WOLFSSL_BIGNUM* q;
46 WOLFSSL_BIGNUM* pub_key; /* openssh deference g^x */
47 WOLFSSL_BIGNUM* priv_key; /* openssh deference x */
48 void* internal; /* our DH */
49 char inSet; /* internal set from external ? */
50 char exSet; /* external set from internal ? */
51 /*added for lighttpd openssl compatibility, go back and add a getter in
52 * lighttpd src code.
53 */
54 int length;
55};
56
57WOLFSSL_API WOLFSSL_DH *wolfSSL_d2i_DHparams(WOLFSSL_DH **dh,
58 const unsigned char **pp, long length);
59WOLFSSL_API int wolfSSL_i2d_DHparams(const WOLFSSL_DH *dh, unsigned char **out);
60WOLFSSL_API WOLFSSL_DH* wolfSSL_DH_new(void);
61WOLFSSL_API void wolfSSL_DH_free(WOLFSSL_DH*);
62WOLFSSL_API WOLFSSL_DH* wolfSSL_DH_dup(WOLFSSL_DH* dh);
63
64WOLFSSL_API int wolfSSL_DH_check(const WOLFSSL_DH *dh, int *codes);
65WOLFSSL_API int wolfSSL_DH_size(WOLFSSL_DH*);
66WOLFSSL_API int wolfSSL_DH_generate_key(WOLFSSL_DH*);
67WOLFSSL_API int wolfSSL_DH_compute_key(unsigned char* key, WOLFSSL_BIGNUM* pub,
68 WOLFSSL_DH*);
69WOLFSSL_API int wolfSSL_DH_LoadDer(WOLFSSL_DH*, const unsigned char*, int sz);
70WOLFSSL_API int wolfSSL_DH_set0_pqg(WOLFSSL_DH*, WOLFSSL_BIGNUM*,
71 WOLFSSL_BIGNUM*, WOLFSSL_BIGNUM*);
72
73#define DH_new wolfSSL_DH_new
74#define DH_free wolfSSL_DH_free
75
76#define d2i_DHparams wolfSSL_d2i_DHparams
77#define i2d_DHparams wolfSSL_i2d_DHparams
78#define DH_check wolfSSL_DH_check
79
80#define DH_size wolfSSL_DH_size
81#define DH_generate_key wolfSSL_DH_generate_key
82#define DH_compute_key wolfSSL_DH_compute_key
83#if defined(OPENSSL_VERSION_NUMBER) && OPENSSL_VERSION_NUMBER >= 0x10100000L
84#define DH_set0_pqg wolfSSL_DH_set0_pqg
85#endif
86#define DH_bits(x) (BN_num_bits(x->p))
87
88#define DH_GENERATOR_2 2
89#define DH_CHECK_P_NOT_PRIME 0x01
90#define DH_CHECK_P_NOT_SAFE_PRIME 0x02
91#define DH_NOT_SUITABLE_GENERATOR 0x08
92
93/* Temporary values for wolfSSL_DH_Check*/
94#define DH_CHECK_INVALID_Q_VALUE 0x10
95#define DH_CHECK_Q_NOT_PRIME 0x11
96/* end temp */
97
98/* for pre 1.1.0 */
99#define get_rfc2409_prime_768 wolfSSL_DH_768_prime
100#define get_rfc2409_prime_1024 wolfSSL_DH_1024_prime
101#define get_rfc3526_prime_1536 wolfSSL_DH_1536_prime
102#define get_rfc3526_prime_2048 wolfSSL_DH_2048_prime
103#define get_rfc3526_prime_3072 wolfSSL_DH_3072_prime
104#define get_rfc3526_prime_4096 wolfSSL_DH_4096_prime
105#define get_rfc3526_prime_6144 wolfSSL_DH_6144_prime
106#define get_rfc3526_prime_8192 wolfSSL_DH_8192_prime
107
108#ifdef __cplusplus
109 } /* extern "C" */
110#endif
111
112#if defined(OPENSSL_ALL) || defined(HAVE_STUNNEL)
113#define DH_generate_parameters wolfSSL_DH_generate_parameters
114#define DH_generate_parameters_ex wolfSSL_DH_generate_parameters_ex
115#endif /* OPENSSL_ALL || HAVE_STUNNEL */
116
117#endif /* WOLFSSL_DH_H_ */
Note: See TracBrowser for help on using the repository browser.