* [Buildroot] [PATCH] rabbitmq-c: openssl/popt sub-options don't work in stat_ic linking
@ 2017-05-14 21:22 Thomas Petazzoni
2017-05-17 8:57 ` Peter Korsgaard
2017-05-17 20:43 ` Peter Korsgaard
0 siblings, 2 replies; 3+ messages in thread
From: Thomas Petazzoni @ 2017-05-14 21:22 UTC (permalink / raw)
To: buildroot
rabbitmq-c currently fails to build in a number of static linking
situations, due to two issues:
- CMake FindOpenSSL module is buggy. Even though it uses pkg-config,
it doesn't use the information returned by pkg-config, and
therefore doesn't know about second order libraries that need be
part of the link for static linking to succeed. Due to this, -lz is
not passed, and therefore rabbitmq-c fails when linking against
libssl/libcrypto. This issue has been reported to upstream CMake at
https://gitlab.kitware.com/cmake/cmake/issues/16885.
- popt might use libintl, but CMake doesn't know about that. For
autotools based packages, we typically work around this by passing
LIBS=, but CMake apparently has no equivalent to LIBS=.
To workaround this, we only use the OpenSSL and Popt optional
dependencies in dynamic linking situations.
Fixes:
http://autobuild.buildroot.net/results/798dbe5e5fd0463bb2066cb115656795144c327f/
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
---
package/rabbitmq-c/rabbitmq-c.mk | 10 ++++++++--
1 file changed, 8 insertions(+), 2 deletions(-)
diff --git a/package/rabbitmq-c/rabbitmq-c.mk b/package/rabbitmq-c/rabbitmq-c.mk
index 1ca35ad..eef09ec 100644
--- a/package/rabbitmq-c/rabbitmq-c.mk
+++ b/package/rabbitmq-c/rabbitmq-c.mk
@@ -21,14 +21,20 @@ else ifeq ($(BR2_SHARED_LIBS),y)
RABBITMQ_C_CONF_OPTS += -DBUILD_SHARED_LIBS=ON -DBUILD_STATIC_LIBS=OFF
endif
-ifeq ($(BR2_PACKAGE_OPENSSL),y)
+# CMake OpenSSL detection is buggy, and doesn't properly use
+# pkg-config, so it fails when statically linking. See
+# https://gitlab.kitware.com/cmake/cmake/issues/16885.
+ifeq ($(BR2_PACKAGE_OPENSSL):$(BR2_STATIC_LIBS),y:)
RABBITMQ_C_CONF_OPTS += -DENABLE_SSL_SUPPORT=ON
RABBITMQ_C_DEPENDENCIES += openssl
else
RABBITMQ_C_CONF_OPTS += -DENABLE_SSL_SUPPORT=OFF
endif
-ifeq ($(BR2_PACKAGE_POPT), y)
+# Popt is sometimes linked against libintl, but CMake doesn't know
+# about that, and there's no way to tell manually CMake to link
+# against an additional library.
+ifeq ($(BR2_PACKAGE_POPT):$(BR2_STATIC_LIBS),y:)
RABBITMQ_C_CONF_OPTS += -DBUILD_TOOLS=ON
RABBITMQ_C_DEPENDENCIES += popt
else
--
2.7.4
^ permalink raw reply related [flat|nested] 3+ messages in thread
* [Buildroot] [PATCH] rabbitmq-c: openssl/popt sub-options don't work in stat_ic linking
2017-05-14 21:22 [Buildroot] [PATCH] rabbitmq-c: openssl/popt sub-options don't work in stat_ic linking Thomas Petazzoni
@ 2017-05-17 8:57 ` Peter Korsgaard
2017-05-17 20:43 ` Peter Korsgaard
1 sibling, 0 replies; 3+ messages in thread
From: Peter Korsgaard @ 2017-05-17 8:57 UTC (permalink / raw)
To: buildroot
>>>>> "Thomas" == Thomas Petazzoni <thomas.petazzoni@free-electrons.com> writes:
> rabbitmq-c currently fails to build in a number of static linking
> situations, due to two issues:
> - CMake FindOpenSSL module is buggy. Even though it uses pkg-config,
> it doesn't use the information returned by pkg-config, and
> therefore doesn't know about second order libraries that need be
> part of the link for static linking to succeed. Due to this, -lz is
> not passed, and therefore rabbitmq-c fails when linking against
> libssl/libcrypto. This issue has been reported to upstream CMake at
> https://gitlab.kitware.com/cmake/cmake/issues/16885.
> - popt might use libintl, but CMake doesn't know about that. For
> autotools based packages, we typically work around this by passing
> LIBS=, but CMake apparently has no equivalent to LIBS=.
> To workaround this, we only use the OpenSSL and Popt optional
> dependencies in dynamic linking situations.
I was hesitating if it wasn't better to just make rabbitmq-c depend on
!static, but OK.
Committed after fixing subject, thanks.
--
Bye, Peter Korsgaard
^ permalink raw reply [flat|nested] 3+ messages in thread
* [Buildroot] [PATCH] rabbitmq-c: openssl/popt sub-options don't work in stat_ic linking
2017-05-14 21:22 [Buildroot] [PATCH] rabbitmq-c: openssl/popt sub-options don't work in stat_ic linking Thomas Petazzoni
2017-05-17 8:57 ` Peter Korsgaard
@ 2017-05-17 20:43 ` Peter Korsgaard
1 sibling, 0 replies; 3+ messages in thread
From: Peter Korsgaard @ 2017-05-17 20:43 UTC (permalink / raw)
To: buildroot
>>>>> "Thomas" == Thomas Petazzoni <thomas.petazzoni@free-electrons.com> writes:
> rabbitmq-c currently fails to build in a number of static linking
> situations, due to two issues:
> - CMake FindOpenSSL module is buggy. Even though it uses pkg-config,
> it doesn't use the information returned by pkg-config, and
> therefore doesn't know about second order libraries that need be
> part of the link for static linking to succeed. Due to this, -lz is
> not passed, and therefore rabbitmq-c fails when linking against
> libssl/libcrypto. This issue has been reported to upstream CMake at
> https://gitlab.kitware.com/cmake/cmake/issues/16885.
> - popt might use libintl, but CMake doesn't know about that. For
> autotools based packages, we typically work around this by passing
> LIBS=, but CMake apparently has no equivalent to LIBS=.
> To workaround this, we only use the OpenSSL and Popt optional
> dependencies in dynamic linking situations.
> Fixes:
> http://autobuild.buildroot.net/results/798dbe5e5fd0463bb2066cb115656795144c327f/
> Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
Committed to 2017.02.x, thanks.
--
Bye, Peter Korsgaard
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2017-05-17 20:43 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-05-14 21:22 [Buildroot] [PATCH] rabbitmq-c: openssl/popt sub-options don't work in stat_ic linking Thomas Petazzoni
2017-05-17 8:57 ` Peter Korsgaard
2017-05-17 20:43 ` Peter Korsgaard
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox