diff mbox series

[1/1] package/strongswan: fix wolfssl build

Message ID 20220818213936.442912-1-fontaine.fabrice@gmail.com
State Accepted
Headers show
Series [1/1] package/strongswan: fix wolfssl build | expand

Commit Message

Fabrice Fontaine Aug. 18, 2022, 9:39 p.m. UTC
Fix the following build failure with BR2_PACKAGE_WOLFSSL_ALL raised
since bump to version 5.9.0 in commit
da912a3d2abe2eb2b338c03ec56c7e39a4d640f9:

In file included from ../../../../src/libstrongswan/utils/utils.h:59,
                 from ../../../../src/libstrongswan/library.h:101,
                 from wolfssl_common.h:29,
                 from wolfssl_aead.c:23:
wolfssl_aead.c:90:16: error: conflicting types for 'encrypt'; have '_Bool(union <anonymous>,  chunk_t,  chunk_t,  chunk_t,  chunk_t *)'
   90 | METHOD(aead_t, encrypt, bool,
      |                ^~~~~~~
../../../../src/libstrongswan/utils/utils/object.h:99:20: note: in definition of macro 'METHOD'
   99 |         static ret name(union {iface *_public; this;} \
      |                    ^~~~
In file included from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/wc_port.h:573,
                 from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/types.h:35,
                 from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/logging.h:33,
                 from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/ssl.h:35,
                 from wolfssl_common.h:64,
                 from wolfssl_aead.c:23:
/home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/unistd.h:149:6: note: previous declaration of 'encrypt' with type 'void(char *, int)'
  149 | void encrypt(char *, int);
      |      ^~~~~~~

Fixes:
 - http://autobuild.buildroot.org/results/02f080c2f6d8272cb8cc1de66e058d66fb7499bc

Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com>
---
 ...gswan-plugins-wolfssl-rename-encrypt.patch | 150 ++++++++++++++++++
 1 file changed, 150 insertions(+)
 create mode 100644 package/strongswan/0001-src-libstrongswan-plugins-wolfssl-rename-encrypt.patch

Comments

Yann E. MORIN Aug. 20, 2022, 8:23 a.m. UTC | #1
Fabrice, All,

On 2022-08-18 23:39 +0200, Fabrice Fontaine spake thusly:
> Fix the following build failure with BR2_PACKAGE_WOLFSSL_ALL raised
> since bump to version 5.9.0 in commit
> da912a3d2abe2eb2b338c03ec56c7e39a4d640f9:
> 
> In file included from ../../../../src/libstrongswan/utils/utils.h:59,
>                  from ../../../../src/libstrongswan/library.h:101,
>                  from wolfssl_common.h:29,
>                  from wolfssl_aead.c:23:
> wolfssl_aead.c:90:16: error: conflicting types for 'encrypt'; have '_Bool(union <anonymous>,  chunk_t,  chunk_t,  chunk_t,  chunk_t *)'
>    90 | METHOD(aead_t, encrypt, bool,
>       |                ^~~~~~~
> ../../../../src/libstrongswan/utils/utils/object.h:99:20: note: in definition of macro 'METHOD'
>    99 |         static ret name(union {iface *_public; this;} \
>       |                    ^~~~
> In file included from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/wc_port.h:573,
>                  from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/types.h:35,
>                  from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/logging.h:33,
>                  from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/ssl.h:35,
>                  from wolfssl_common.h:64,
>                  from wolfssl_aead.c:23:
> /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/unistd.h:149:6: note: previous declaration of 'encrypt' with type 'void(char *, int)'
>   149 | void encrypt(char *, int);
>       |      ^~~~~~~
> 
> Fixes:
>  - http://autobuild.buildroot.org/results/02f080c2f6d8272cb8cc1de66e058d66fb7499bc
> 
> Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com>

Applied to master, thanks.

Regards,
Yann E. MORIN.

> ---
>  ...gswan-plugins-wolfssl-rename-encrypt.patch | 150 ++++++++++++++++++
>  1 file changed, 150 insertions(+)
>  create mode 100644 package/strongswan/0001-src-libstrongswan-plugins-wolfssl-rename-encrypt.patch
> 
> diff --git a/package/strongswan/0001-src-libstrongswan-plugins-wolfssl-rename-encrypt.patch b/package/strongswan/0001-src-libstrongswan-plugins-wolfssl-rename-encrypt.patch
> new file mode 100644
> index 0000000000..7b47b3278b
> --- /dev/null
> +++ b/package/strongswan/0001-src-libstrongswan-plugins-wolfssl-rename-encrypt.patch
> @@ -0,0 +1,150 @@
> +From 5900426a710eaa65a27784687775e331bcb0489b Mon Sep 17 00:00:00 2001
> +From: Fabrice Fontaine <fontaine.fabrice@gmail.com>
> +Date: Mon, 8 Aug 2022 09:52:19 +0200
> +Subject: [PATCH] wolfssl: Rename `encrypt` methods to avoid conflicts with
> + system headers
> +
> +Rename `encrypt` methods to avoid the following build failure when wolfSSL
> +is built with --enable-opensslextra:
> +
> +In file included from ../../../../src/libstrongswan/utils/utils.h:59,
> +                 from ../../../../src/libstrongswan/library.h:101,
> +                 from wolfssl_common.h:29,
> +                 from wolfssl_aead.c:23:
> +wolfssl_aead.c:90:16: error: conflicting types for 'encrypt'; have '_Bool(union <anonymous>,  chunk_t,  chunk_t,  chunk_t,  chunk_t *)'
> +   90 | METHOD(aead_t, encrypt, bool,
> +      |                ^~~~~~~
> +../../../../src/libstrongswan/utils/utils/object.h:99:20: note: in definition of macro 'METHOD'
> +   99 |         static ret name(union {iface *_public; this;} \
> +      |                    ^~~~
> +In file included from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/wc_port.h:573,
> +                 from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/types.h:35,
> +                 from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/logging.h:33,
> +                 from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/ssl.h:35,
> +                 from wolfssl_common.h:64,
> +                 from wolfssl_aead.c:23:
> +/home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/unistd.h:149:6: note: previous declaration of 'encrypt' with type 'void(char *, int)'
> +  149 | void encrypt(char *, int);
> +      |      ^~~~~~~
> +
> +Closes strongswan/strongswan#1201
> +[Retrieved from:
> +https://github.com/strongswan/strongswan/commit/5900426a710eaa65a27784687775e331bcb0489b]
> +---
> + src/libstrongswan/plugins/wolfssl/wolfssl_aead.c           | 4 ++--
> + src/libstrongswan/plugins/wolfssl/wolfssl_crypter.c        | 4 ++--
> + src/libstrongswan/plugins/wolfssl/wolfssl_ec_public_key.c  | 4 ++--
> + src/libstrongswan/plugins/wolfssl/wolfssl_ed_public_key.c  | 4 ++--
> + src/libstrongswan/plugins/wolfssl/wolfssl_rsa_public_key.c | 4 ++--
> + 5 files changed, 10 insertions(+), 10 deletions(-)
> +
> +diff --git a/src/libstrongswan/plugins/wolfssl/wolfssl_aead.c b/src/libstrongswan/plugins/wolfssl/wolfssl_aead.c
> +index 2ea7c94cd65..44f054916cf 100644
> +--- a/src/libstrongswan/plugins/wolfssl/wolfssl_aead.c
> ++++ b/src/libstrongswan/plugins/wolfssl/wolfssl_aead.c
> +@@ -87,7 +87,7 @@ struct private_aead_t {
> + 	encryption_algorithm_t alg;
> + };
> + 
> +-METHOD(aead_t, encrypt, bool,
> ++METHOD(aead_t, encrypt_, bool,
> + 	private_aead_t *this, chunk_t plain, chunk_t assoc, chunk_t iv,
> + 	chunk_t *encrypted)
> + {
> +@@ -323,7 +323,7 @@ aead_t *wolfssl_aead_create(encryption_algorithm_t algo,
> + 
> + 	INIT(this,
> + 		.public = {
> +-			.encrypt = _encrypt,
> ++			.encrypt = _encrypt_,
> + 			.decrypt = _decrypt,
> + 			.get_block_size = _get_block_size,
> + 			.get_icv_size = _get_icv_size,
> +diff --git a/src/libstrongswan/plugins/wolfssl/wolfssl_crypter.c b/src/libstrongswan/plugins/wolfssl/wolfssl_crypter.c
> +index cffe7ba2375..085a912404c 100644
> +--- a/src/libstrongswan/plugins/wolfssl/wolfssl_crypter.c
> ++++ b/src/libstrongswan/plugins/wolfssl/wolfssl_crypter.c
> +@@ -230,7 +230,7 @@ METHOD(crypter_t, decrypt, bool,
> + 	return success;
> + }
> + 
> +-METHOD(crypter_t, encrypt, bool,
> ++METHOD(crypter_t, encrypt_, bool,
> + 	private_wolfssl_crypter_t *this, chunk_t data, chunk_t iv, chunk_t *dst)
> + {
> + 	u_char *out;
> +@@ -578,7 +578,7 @@ wolfssl_crypter_t *wolfssl_crypter_create(encryption_algorithm_t algo,
> + 	INIT(this,
> + 		.public = {
> + 			.crypter = {
> +-				.encrypt = _encrypt,
> ++				.encrypt = _encrypt_,
> + 				.decrypt = _decrypt,
> + 				.get_block_size = _get_block_size,
> + 				.get_iv_size = _get_iv_size,
> +diff --git a/src/libstrongswan/plugins/wolfssl/wolfssl_ec_public_key.c b/src/libstrongswan/plugins/wolfssl/wolfssl_ec_public_key.c
> +index d8a1ededb06..110543762f2 100644
> +--- a/src/libstrongswan/plugins/wolfssl/wolfssl_ec_public_key.c
> ++++ b/src/libstrongswan/plugins/wolfssl/wolfssl_ec_public_key.c
> +@@ -193,7 +193,7 @@ METHOD(public_key_t, verify, bool,
> + 	}
> + }
> + 
> +-METHOD(public_key_t, encrypt, bool,
> ++METHOD(public_key_t, encrypt_, bool,
> + 	private_wolfssl_ec_public_key_t *this, encryption_scheme_t scheme,
> + 	void *params, chunk_t crypto, chunk_t *plain)
> + {
> +@@ -324,7 +324,7 @@ static private_wolfssl_ec_public_key_t *create_empty()
> + 			.key = {
> + 				.get_type = _get_type,
> + 				.verify = _verify,
> +-				.encrypt = _encrypt,
> ++				.encrypt = _encrypt_,
> + 				.get_keysize = _get_keysize,
> + 				.equals = public_key_equals,
> + 				.get_fingerprint = _get_fingerprint,
> +diff --git a/src/libstrongswan/plugins/wolfssl/wolfssl_ed_public_key.c b/src/libstrongswan/plugins/wolfssl/wolfssl_ed_public_key.c
> +index f423d8d5691..ea0fb3dfc77 100644
> +--- a/src/libstrongswan/plugins/wolfssl/wolfssl_ed_public_key.c
> ++++ b/src/libstrongswan/plugins/wolfssl/wolfssl_ed_public_key.c
> +@@ -111,7 +111,7 @@ METHOD(public_key_t, verify, bool,
> + 	return ret == 0 && res == 1;
> + }
> + 
> +-METHOD(public_key_t, encrypt, bool,
> ++METHOD(public_key_t, encrypt_, bool,
> + 	private_public_key_t *this, encryption_scheme_t scheme,
> + 	void *params, chunk_t crypto, chunk_t *plain)
> + {
> +@@ -368,7 +368,7 @@ static private_public_key_t *create_empty(key_type_t type)
> + 		.public = {
> + 			.get_type = _get_type,
> + 			.verify = _verify,
> +-			.encrypt = _encrypt,
> ++			.encrypt = _encrypt_,
> + 			.get_keysize = _get_keysize,
> + 			.equals = public_key_equals,
> + 			.get_fingerprint = _get_fingerprint,
> +diff --git a/src/libstrongswan/plugins/wolfssl/wolfssl_rsa_public_key.c b/src/libstrongswan/plugins/wolfssl/wolfssl_rsa_public_key.c
> +index 72df115fe90..da8899c2d8c 100644
> +--- a/src/libstrongswan/plugins/wolfssl/wolfssl_rsa_public_key.c
> ++++ b/src/libstrongswan/plugins/wolfssl/wolfssl_rsa_public_key.c
> +@@ -216,7 +216,7 @@ METHOD(public_key_t, verify, bool,
> + 	}
> + }
> + 
> +-METHOD(public_key_t, encrypt, bool,
> ++METHOD(public_key_t, encrypt_, bool,
> + 	private_wolfssl_rsa_public_key_t *this, encryption_scheme_t scheme,
> + 	void *params, chunk_t plain, chunk_t *crypto)
> + {
> +@@ -440,7 +440,7 @@ static private_wolfssl_rsa_public_key_t *create_empty()
> + 			.key = {
> + 				.get_type = _get_type,
> + 				.verify = _verify,
> +-				.encrypt = _encrypt,
> ++				.encrypt = _encrypt_,
> + 				.equals = public_key_equals,
> + 				.get_keysize = _get_keysize,
> + 				.get_fingerprint = _get_fingerprint,
> -- 
> 2.35.1
> 
> _______________________________________________
> buildroot mailing list
> buildroot@buildroot.org
> https://lists.buildroot.org/mailman/listinfo/buildroot
Peter Korsgaard Sept. 17, 2022, 6:50 a.m. UTC | #2
>>>>> "Fabrice" == Fabrice Fontaine <fontaine.fabrice@gmail.com> writes:

 > Fix the following build failure with BR2_PACKAGE_WOLFSSL_ALL raised
 > since bump to version 5.9.0 in commit
 > da912a3d2abe2eb2b338c03ec56c7e39a4d640f9:

 > In file included from ../../../../src/libstrongswan/utils/utils.h:59,
 >                  from ../../../../src/libstrongswan/library.h:101,
 >                  from wolfssl_common.h:29,
 >                  from wolfssl_aead.c:23:
 > wolfssl_aead.c:90:16: error: conflicting types for 'encrypt'; have '_Bool(union <anonymous>,  chunk_t,  chunk_t,  chunk_t,  chunk_t *)'
 >    90 | METHOD(aead_t, encrypt, bool,
 >       |                ^~~~~~~
 > ../../../../src/libstrongswan/utils/utils/object.h:99:20: note: in
 > definition of macro 'METHOD'
 >    99 |         static ret name(union {iface *_public; this;} \
 >       |                    ^~~~
 > In file included from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/wc_port.h:573,
 >                  from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/types.h:35,
 >                  from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/logging.h:33,
 >                  from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/ssl.h:35,
 >                  from wolfssl_common.h:64,
 >                  from wolfssl_aead.c:23:
 > /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/unistd.h:149:6: note: previous declaration of 'encrypt' with type 'void(char *, int)'
 >   149 | void encrypt(char *, int);
 >       |      ^~~~~~~

 > Fixes:
 >  - http://autobuild.buildroot.org/results/02f080c2f6d8272cb8cc1de66e058d66fb7499bc

 > Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com>

Committed to 2022.05.x and 2022.02.x, thanks.
diff mbox series

Patch

diff --git a/package/strongswan/0001-src-libstrongswan-plugins-wolfssl-rename-encrypt.patch b/package/strongswan/0001-src-libstrongswan-plugins-wolfssl-rename-encrypt.patch
new file mode 100644
index 0000000000..7b47b3278b
--- /dev/null
+++ b/package/strongswan/0001-src-libstrongswan-plugins-wolfssl-rename-encrypt.patch
@@ -0,0 +1,150 @@ 
+From 5900426a710eaa65a27784687775e331bcb0489b Mon Sep 17 00:00:00 2001
+From: Fabrice Fontaine <fontaine.fabrice@gmail.com>
+Date: Mon, 8 Aug 2022 09:52:19 +0200
+Subject: [PATCH] wolfssl: Rename `encrypt` methods to avoid conflicts with
+ system headers
+
+Rename `encrypt` methods to avoid the following build failure when wolfSSL
+is built with --enable-opensslextra:
+
+In file included from ../../../../src/libstrongswan/utils/utils.h:59,
+                 from ../../../../src/libstrongswan/library.h:101,
+                 from wolfssl_common.h:29,
+                 from wolfssl_aead.c:23:
+wolfssl_aead.c:90:16: error: conflicting types for 'encrypt'; have '_Bool(union <anonymous>,  chunk_t,  chunk_t,  chunk_t,  chunk_t *)'
+   90 | METHOD(aead_t, encrypt, bool,
+      |                ^~~~~~~
+../../../../src/libstrongswan/utils/utils/object.h:99:20: note: in definition of macro 'METHOD'
+   99 |         static ret name(union {iface *_public; this;} \
+      |                    ^~~~
+In file included from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/wc_port.h:573,
+                 from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/types.h:35,
+                 from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/wolfcrypt/logging.h:33,
+                 from /home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/wolfssl/ssl.h:35,
+                 from wolfssl_common.h:64,
+                 from wolfssl_aead.c:23:
+/home/autobuild/autobuild/instance-5/output-1/host/powerpc64le-buildroot-linux-musl/sysroot/usr/include/unistd.h:149:6: note: previous declaration of 'encrypt' with type 'void(char *, int)'
+  149 | void encrypt(char *, int);
+      |      ^~~~~~~
+
+Closes strongswan/strongswan#1201
+[Retrieved from:
+https://github.com/strongswan/strongswan/commit/5900426a710eaa65a27784687775e331bcb0489b]
+---
+ src/libstrongswan/plugins/wolfssl/wolfssl_aead.c           | 4 ++--
+ src/libstrongswan/plugins/wolfssl/wolfssl_crypter.c        | 4 ++--
+ src/libstrongswan/plugins/wolfssl/wolfssl_ec_public_key.c  | 4 ++--
+ src/libstrongswan/plugins/wolfssl/wolfssl_ed_public_key.c  | 4 ++--
+ src/libstrongswan/plugins/wolfssl/wolfssl_rsa_public_key.c | 4 ++--
+ 5 files changed, 10 insertions(+), 10 deletions(-)
+
+diff --git a/src/libstrongswan/plugins/wolfssl/wolfssl_aead.c b/src/libstrongswan/plugins/wolfssl/wolfssl_aead.c
+index 2ea7c94cd65..44f054916cf 100644
+--- a/src/libstrongswan/plugins/wolfssl/wolfssl_aead.c
++++ b/src/libstrongswan/plugins/wolfssl/wolfssl_aead.c
+@@ -87,7 +87,7 @@ struct private_aead_t {
+ 	encryption_algorithm_t alg;
+ };
+ 
+-METHOD(aead_t, encrypt, bool,
++METHOD(aead_t, encrypt_, bool,
+ 	private_aead_t *this, chunk_t plain, chunk_t assoc, chunk_t iv,
+ 	chunk_t *encrypted)
+ {
+@@ -323,7 +323,7 @@ aead_t *wolfssl_aead_create(encryption_algorithm_t algo,
+ 
+ 	INIT(this,
+ 		.public = {
+-			.encrypt = _encrypt,
++			.encrypt = _encrypt_,
+ 			.decrypt = _decrypt,
+ 			.get_block_size = _get_block_size,
+ 			.get_icv_size = _get_icv_size,
+diff --git a/src/libstrongswan/plugins/wolfssl/wolfssl_crypter.c b/src/libstrongswan/plugins/wolfssl/wolfssl_crypter.c
+index cffe7ba2375..085a912404c 100644
+--- a/src/libstrongswan/plugins/wolfssl/wolfssl_crypter.c
++++ b/src/libstrongswan/plugins/wolfssl/wolfssl_crypter.c
+@@ -230,7 +230,7 @@ METHOD(crypter_t, decrypt, bool,
+ 	return success;
+ }
+ 
+-METHOD(crypter_t, encrypt, bool,
++METHOD(crypter_t, encrypt_, bool,
+ 	private_wolfssl_crypter_t *this, chunk_t data, chunk_t iv, chunk_t *dst)
+ {
+ 	u_char *out;
+@@ -578,7 +578,7 @@ wolfssl_crypter_t *wolfssl_crypter_create(encryption_algorithm_t algo,
+ 	INIT(this,
+ 		.public = {
+ 			.crypter = {
+-				.encrypt = _encrypt,
++				.encrypt = _encrypt_,
+ 				.decrypt = _decrypt,
+ 				.get_block_size = _get_block_size,
+ 				.get_iv_size = _get_iv_size,
+diff --git a/src/libstrongswan/plugins/wolfssl/wolfssl_ec_public_key.c b/src/libstrongswan/plugins/wolfssl/wolfssl_ec_public_key.c
+index d8a1ededb06..110543762f2 100644
+--- a/src/libstrongswan/plugins/wolfssl/wolfssl_ec_public_key.c
++++ b/src/libstrongswan/plugins/wolfssl/wolfssl_ec_public_key.c
+@@ -193,7 +193,7 @@ METHOD(public_key_t, verify, bool,
+ 	}
+ }
+ 
+-METHOD(public_key_t, encrypt, bool,
++METHOD(public_key_t, encrypt_, bool,
+ 	private_wolfssl_ec_public_key_t *this, encryption_scheme_t scheme,
+ 	void *params, chunk_t crypto, chunk_t *plain)
+ {
+@@ -324,7 +324,7 @@ static private_wolfssl_ec_public_key_t *create_empty()
+ 			.key = {
+ 				.get_type = _get_type,
+ 				.verify = _verify,
+-				.encrypt = _encrypt,
++				.encrypt = _encrypt_,
+ 				.get_keysize = _get_keysize,
+ 				.equals = public_key_equals,
+ 				.get_fingerprint = _get_fingerprint,
+diff --git a/src/libstrongswan/plugins/wolfssl/wolfssl_ed_public_key.c b/src/libstrongswan/plugins/wolfssl/wolfssl_ed_public_key.c
+index f423d8d5691..ea0fb3dfc77 100644
+--- a/src/libstrongswan/plugins/wolfssl/wolfssl_ed_public_key.c
++++ b/src/libstrongswan/plugins/wolfssl/wolfssl_ed_public_key.c
+@@ -111,7 +111,7 @@ METHOD(public_key_t, verify, bool,
+ 	return ret == 0 && res == 1;
+ }
+ 
+-METHOD(public_key_t, encrypt, bool,
++METHOD(public_key_t, encrypt_, bool,
+ 	private_public_key_t *this, encryption_scheme_t scheme,
+ 	void *params, chunk_t crypto, chunk_t *plain)
+ {
+@@ -368,7 +368,7 @@ static private_public_key_t *create_empty(key_type_t type)
+ 		.public = {
+ 			.get_type = _get_type,
+ 			.verify = _verify,
+-			.encrypt = _encrypt,
++			.encrypt = _encrypt_,
+ 			.get_keysize = _get_keysize,
+ 			.equals = public_key_equals,
+ 			.get_fingerprint = _get_fingerprint,
+diff --git a/src/libstrongswan/plugins/wolfssl/wolfssl_rsa_public_key.c b/src/libstrongswan/plugins/wolfssl/wolfssl_rsa_public_key.c
+index 72df115fe90..da8899c2d8c 100644
+--- a/src/libstrongswan/plugins/wolfssl/wolfssl_rsa_public_key.c
++++ b/src/libstrongswan/plugins/wolfssl/wolfssl_rsa_public_key.c
+@@ -216,7 +216,7 @@ METHOD(public_key_t, verify, bool,
+ 	}
+ }
+ 
+-METHOD(public_key_t, encrypt, bool,
++METHOD(public_key_t, encrypt_, bool,
+ 	private_wolfssl_rsa_public_key_t *this, encryption_scheme_t scheme,
+ 	void *params, chunk_t plain, chunk_t *crypto)
+ {
+@@ -440,7 +440,7 @@ static private_wolfssl_rsa_public_key_t *create_empty()
+ 			.key = {
+ 				.get_type = _get_type,
+ 				.verify = _verify,
+-				.encrypt = _encrypt,
++				.encrypt = _encrypt_,
+ 				.equals = public_key_equals,
+ 				.get_keysize = _get_keysize,
+ 				.get_fingerprint = _get_fingerprint,