summaryrefslogtreecommitdiffstats
path: root/engines
diff options
context:
space:
mode:
authorDr. Stephen Henson <steve@openssl.org>2010-11-18 22:56:42 +0000
committerDr. Stephen Henson <steve@openssl.org>2010-11-18 22:56:42 +0000
commit3c96907f2b9462045a15929e8692a0482775c757 (patch)
treea0e0d3a533b44db2991fe44a2f4fd1ea043afee7 /engines
parent2d96a30dc71c7328ac7da3326068e7e0ff103979 (diff)
PR: 2374
Submitted by: Guenter <lists@gknw.net> Reviewed by: steve Don't compile capi ENGINE on mingw32
Diffstat (limited to 'engines')
-rw-r--r--engines/e_capi.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/engines/e_capi.c b/engines/e_capi.c
index e2a7cb58b0..5871491fd6 100644
--- a/engines/e_capi.c
+++ b/engines/e_capi.c
@@ -76,10 +76,16 @@
* CertGetCertificateContextProperty. CERT_KEY_PROV_INFO_PROP_ID is
* one of possible values you can pass to function in question. By
* checking if it's defined we can see if wincrypt.h and accompanying
- * crypt32.lib are in shape. Yes, it's rather "weak" test and if
- * compilation fails, then re-configure with -DOPENSSL_NO_CAPIENG.
+ * crypt32.lib are in shape. The native MingW32 headers up to and
+ * including __W32API_VERSION 3.14 lack of struct DSSPUBKEY and the
+ * defines CERT_STORE_PROV_SYSTEM_A and CERT_STORE_READONLY_FLAG,
+ * so we check for these too and avoid compiling.
+ * Yes, it's rather "weak" test and if compilation fails,
+ * then re-configure with -DOPENSSL_NO_CAPIENG.
*/
-#ifdef CERT_KEY_PROV_INFO_PROP_ID
+#if defined(CERT_KEY_PROV_INFO_PROP_ID) && \
+ defined(CERT_STORE_PROV_SYSTEM_A) && \
+ defined(CERT_STORE_READONLY_FLAG)
# define __COMPILE_CAPIENG
#endif /* CERT_KEY_PROV_INFO_PROP_ID */
#endif /* OPENSSL_NO_CAPIENG */