[PATCH] libcamera: meson: Fix libyuv detection

Kieran Bingham kieran.bingham at ideasonboard.com
Tue Jan 14 22:19:35 CET 2025


From: Dylan Aïssi <daissi at debian.org>

We already fall back to a subproject to support the libyuv package when
it can not be discovered through the usual dependency() mechanism.

Unfortunately libyuv may be packaged without any corresponding
pkg-config support as can be seen at [0], so further extend the
dependency search by using an explicit cc.find_library() call.

[0] https://packages.debian.org/bookworm/amd64/libyuv-dev/filelist

Signed-off-by: Dylan Aïssi <dylan.aissi at collabora.com>
Signed-off-by: Kieran Bingham <kieran.bingham at ideasonboard.com>
---
 src/meson.build | 11 ++++++++---
 1 file changed, 8 insertions(+), 3 deletions(-)

diff --git a/src/meson.build b/src/meson.build
index 76198e9535db..0a9cdff8e7dc 100644
--- a/src/meson.build
+++ b/src/meson.build
@@ -27,10 +27,15 @@ else
     ipa_sign_module = false
 endif
 
-# libyuv, used by the Android adaptation layer and the virtual pipeline handler.
-# Fallback to a subproject if libyuv isn't found, as it's typically not provided
-# by distributions.
+# libyuv, used by the Android adaptation layer and the virtual pipeline
+# handler. Fallback to a subproject if libyuv isn't found, as it's typically
+# not provided by distributions. Where libyuv is provided by a distribution, it
+# may not always supply a pkg-config implementation, requiring cc.find_library()
+# to search for it.
 libyuv_dep = dependency('libyuv', required : false)
+if not libyuv_dep.found()
+    libyuv_dep = cc.find_library('yuv', required: false)
+endif
 
 if (pipelines.contains('virtual') or get_option('android').allowed()) and \
    not libyuv_dep.found()
-- 
2.47.1



More information about the libcamera-devel mailing list