summaryrefslogtreecommitdiffstats
path: root/sshkey.h
diff options
context:
space:
mode:
authorDamien Miller <djm@mindrot.org>2014-08-20 03:06:50 +0200
committerDamien Miller <djm@mindrot.org>2014-08-20 03:06:50 +0200
commitf0935698f0461f24d8d1f1107b476ee5fd4db1cb (patch)
treee8b62fc6549faadf9789aec1e163a4fe5f38d52a /sshkey.h
parent - (djm) [Makefile.in] refer to libtest_helper.a by explicit path rather than (diff)
downloadopenssh-f0935698f0461f24d8d1f1107b476ee5fd4db1cb.tar.xz
openssh-f0935698f0461f24d8d1f1107b476ee5fd4db1cb.zip
- (djm) [sshkey.h] Fix compilation when OpenSSL lacks ECC
Diffstat (limited to 'sshkey.h')
-rw-r--r--sshkey.h38
1 files changed, 24 insertions, 14 deletions
diff --git a/sshkey.h b/sshkey.h
index 4127db244..450b30c1f 100644
--- a/sshkey.h
+++ b/sshkey.h
@@ -31,13 +31,19 @@
#ifdef WITH_OPENSSL
#include <openssl/rsa.h>
#include <openssl/dsa.h>
-#include <openssl/ec.h>
-#else /* OPENSSL */
-#define RSA void
-#define DSA void
-#define EC_KEY void
-#define EC_GROUP void
-#define EC_POINT void
+# ifdef OPENSSL_HAS_ECC
+# include <openssl/ec.h>
+# else /* OPENSSL_HAS_ECC */
+# define EC_KEY void
+# define EC_GROUP void
+# define EC_POINT void
+# endif /* OPENSSL_HAS_ECC */
+#else /* WITH_OPENSSL */
+# define RSA void
+# define DSA void
+# define EC_KEY void
+# define EC_GROUP void
+# define EC_POINT void
#endif /* WITH_OPENSSL */
#define SSH_RSA_MINIMUM_MODULUS_SIZE 768
@@ -211,12 +217,16 @@ int ssh_ed25519_verify(const struct sshkey *key,
const u_char *data, size_t datalen, u_int compat);
#endif
-#ifndef WITH_OPENSSL
-#undef RSA
-#undef DSA
-#undef EC_KEY
-#undef EC_GROUP
-#undef EC_POINT
-#endif /* WITH_OPENSSL */
+#if !defined(WITH_OPENSSL)
+# undef RSA
+# undef DSA
+# undef EC_KEY
+# undef EC_GROUP
+# undef EC_POINT
+#elif !defined(OPENSSL_HAS_ECC)
+# undef EC_KEY
+# undef EC_GROUP
+# undef EC_POINT
+#endif
#endif /* SSHKEY_H */