--- a/src/lib-dcrypt/dcrypt-openssl.c
+++ b/src/lib-dcrypt/dcrypt-openssl.c
@@ -17,10 +17,12 @@
 #include <openssl/bio.h>
 #include <openssl/pem.h>
 #include <openssl/x509.h>
-#include <openssl/engine.h>
 #include <openssl/hmac.h>
 #include <openssl/objects.h>
 #include <openssl/bn.h>
+#ifndef OPENSSL_NO_ENGINE
+#include <openssl/engine.h>
+#endif
 #include "dcrypt.h"
 #include "dcrypt-private.h"
 
@@ -179,11 +181,13 @@ static bool dcrypt_openssl_error(const c
 static bool dcrypt_openssl_initialize(const struct dcrypt_settings *set,
 				      const char **error_r)
 {
+#ifndef OPENSSL_NO_ENGINE
 	if (set->crypto_device != NULL && set->crypto_device[0] != '\0') {
 		if (dovecot_openssl_common_global_set_engine(
 			set->crypto_device, error_r) <= 0)
 			return FALSE;
 	}
+#endif
 	return TRUE;
 }
 
--- a/src/lib-ssl-iostream/dovecot-openssl-common.c
+++ b/src/lib-ssl-iostream/dovecot-openssl-common.c
@@ -5,11 +5,14 @@
 #include "dovecot-openssl-common.h"
 
 #include <openssl/ssl.h>
-#include <openssl/engine.h>
 #include <openssl/rand.h>
+#ifndef OPENSSL_NO_ENGINE
+#include <openssl/engine.h>
 
-static int openssl_init_refcount = 0;
 static ENGINE *dovecot_openssl_engine;
+#endif
+
+static int openssl_init_refcount = 0;
 
 #ifdef HAVE_SSL_NEW_MEM_FUNCS
 static void *dovecot_openssl_malloc(size_t size, const char *u0 ATTR_UNUSED, int u1 ATTR_UNUSED)
@@ -77,10 +80,12 @@ bool dovecot_openssl_common_global_unref
 	if (--openssl_init_refcount > 0)
 		return TRUE;
 
+#ifndef OPENSSL_NO_ENGINE
 	if (dovecot_openssl_engine != NULL) {
 		ENGINE_finish(dovecot_openssl_engine);
 		dovecot_openssl_engine = NULL;
 	}
+#endif
 #if OPENSSL_VERSION_NUMBER < 0x10100000L
 	/* OBJ_cleanup() is called automatically by EVP_cleanup() in
 	   newer versions. Doesn't hurt to call it anyway. */
@@ -88,7 +93,9 @@ bool dovecot_openssl_common_global_unref
 #ifdef HAVE_SSL_COMP_FREE_COMPRESSION_METHODS
 	SSL_COMP_free_compression_methods();
 #endif
+#ifndef OPENSSL_NO_ENGINE
 	ENGINE_cleanup();
+#endif
 	EVP_cleanup();
 	CRYPTO_cleanup_all_ex_data();
 #ifdef HAVE_OPENSSL_AUTO_THREAD_DEINIT
@@ -111,6 +118,7 @@ bool dovecot_openssl_common_global_unref
 int dovecot_openssl_common_global_set_engine(const char *engine,
 					     const char **error_r)
 {
+#ifndef OPENSSL_NO_ENGINE
 	if (dovecot_openssl_engine != NULL)
 		return 1;
 
@@ -132,5 +140,6 @@ int dovecot_openssl_common_global_set_en
 		dovecot_openssl_engine = NULL;
 		return -1;
 	}
+#endif
 	return 1;
 }