source: azure_iot_hub_f767zi/trunk/wolfssl-4.4.0/wolfssl/openssl/dh.h@ 457

Last change on this file since 457 was 457, checked in by coas-nagasima, 4 years ago

ファイルを追加

  • Property svn:eol-style set to native
  • Property svn:mime-type set to text/x-chdr;charset=UTF-8
File size: 4.0 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
30#ifdef __cplusplus
31 extern "C" {
32#endif
33
34#ifndef WOLFSSL_DH_TYPE_DEFINED /* guard on redeclaration */
35typedef struct WOLFSSL_DH WOLFSSL_DH;
36#define WOLFSSL_DH_TYPE_DEFINED
37#endif
38
39typedef WOLFSSL_DH DH;
40
41struct WOLFSSL_DH {
42 WOLFSSL_BIGNUM* p;
43 WOLFSSL_BIGNUM* g;
44 WOLFSSL_BIGNUM* q;
45 WOLFSSL_BIGNUM* pub_key; /* openssh deference g^x */
46 WOLFSSL_BIGNUM* priv_key; /* openssh deference x */
47 void* internal; /* our DH */
48 char inSet; /* internal set from external ? */
49 char exSet; /* external set from internal ? */
50 /*added for lighttpd openssl compatibility, go back and add a getter in
51 * lighttpd src code.
52 */
53 int length;
54};
55
56WOLFSSL_API WOLFSSL_DH *wolfSSL_d2i_DHparams(WOLFSSL_DH **dh,
57 const unsigned char **pp, long length);
58WOLFSSL_API int wolfSSL_i2d_DHparams(const WOLFSSL_DH *dh, unsigned char **out);
59WOLFSSL_API WOLFSSL_DH* wolfSSL_DH_new(void);
60WOLFSSL_API void wolfSSL_DH_free(WOLFSSL_DH*);
61
62WOLFSSL_API int wolfSSL_DH_check(const WOLFSSL_DH *dh, int *codes);
63WOLFSSL_API int wolfSSL_DH_size(WOLFSSL_DH*);
64WOLFSSL_API int wolfSSL_DH_generate_key(WOLFSSL_DH*);
65WOLFSSL_API int wolfSSL_DH_compute_key(unsigned char* key, WOLFSSL_BIGNUM* pub,
66 WOLFSSL_DH*);
67WOLFSSL_API int wolfSSL_DH_LoadDer(WOLFSSL_DH*, const unsigned char*, int sz);
68WOLFSSL_API int wolfSSL_DH_set0_pqg(WOLFSSL_DH*, WOLFSSL_BIGNUM*,
69 WOLFSSL_BIGNUM*, WOLFSSL_BIGNUM*);
70
71#define DH_new wolfSSL_DH_new
72#define DH_free wolfSSL_DH_free
73
74#define d2i_DHparams wolfSSL_d2i_DHparams
75#define i2d_DHparams wolfSSL_i2d_DHparams
76#define DH_check wolfSSL_DH_check
77
78#define DH_size wolfSSL_DH_size
79#define DH_generate_key wolfSSL_DH_generate_key
80#define DH_compute_key wolfSSL_DH_compute_key
81#if defined(OPENSSL_VERSION_NUMBER) && OPENSSL_VERSION_NUMBER >= 0x10100000L
82#define DH_set0_pqg wolfSSL_DH_set0_pqg
83#endif
84#define DH_bits(x) (BN_num_bits(x->p))
85
86#define DH_GENERATOR_2 2
87#define DH_CHECK_P_NOT_PRIME 0x01
88#define DH_CHECK_P_NOT_SAFE_PRIME 0x02
89#define DH_NOT_SUITABLE_GENERATOR 0x08
90
91/* Temporary values for wolfSSL_DH_Check*/
92#define DH_CHECK_INVALID_Q_VALUE 0x10
93#define DH_CHECK_Q_NOT_PRIME 0x11
94/* end temp */
95
96/* for pre 1.1.0 */
97#define get_rfc2409_prime_768 wolfSSL_DH_768_prime
98#define get_rfc2409_prime_1024 wolfSSL_DH_1024_prime
99#define get_rfc3526_prime_1536 wolfSSL_DH_1536_prime
100#define get_rfc3526_prime_2048 wolfSSL_DH_2048_prime
101#define get_rfc3526_prime_3072 wolfSSL_DH_3072_prime
102#define get_rfc3526_prime_4096 wolfSSL_DH_4096_prime
103#define get_rfc3526_prime_6144 wolfSSL_DH_6144_prime
104#define get_rfc3526_prime_8192 wolfSSL_DH_8192_prime
105
106#ifdef __cplusplus
107 } /* extern "C" */
108#endif
109
110#if defined(OPENSSL_ALL) || defined(HAVE_STUNNEL)
111#define DH_generate_parameters wolfSSL_DH_generate_parameters
112#define DH_generate_parameters_ex wolfSSL_DH_generate_parameters_ex
113#endif /* OPENSSL_ALL || HAVE_STUNNEL */
114
115#endif /* WOLFSSL_DH_H_ */
Note: See TracBrowser for help on using the repository browser.