From: Nicolas Boichat Date: Thu, 28 Apr 2016 10:41:39 +0000 (+0800) Subject: mesa: dri: Add shared glapi to LIBADD on Android X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=0cbc90c57cfc;p=mesa.git mesa: dri: Add shared glapi to LIBADD on Android /system/vendor/lib/dri/*_dri.so actually depend on libglapi: without this, loading the so file fails with: cannot locate symbol "__emutls_v._glapi_tls_Context" On non-Android (non-bionic) platform, EGL uses the following workflow, which works fine: dlopen("libglapi.so", RTLD_LAZY | RTLD_GLOBAL); dlopen("dri/_dri.so", RTLD_NOW | RTLD_GLOBAL); However, bionic does not respect the RTLD_GLOBAL flag, and the dri library cannot find symbols in libglapi.so, so we need to link to libglapi.so explicitly. Android.mk already does this. Signed-off-by: Nicolas Boichat Reviewed-by: Emil Velikov [Emil Velikov: s/explicitely/explicitly/] Signed-off-by: Emil Velikov --- diff --git a/src/mesa/drivers/dri/Makefile.am b/src/mesa/drivers/dri/Makefile.am index 08a8e645521..1c6dd08a85d 100644 --- a/src/mesa/drivers/dri/Makefile.am +++ b/src/mesa/drivers/dri/Makefile.am @@ -6,6 +6,13 @@ MEGADRIVERS_DEPS = SUBDIRS+=common +# On Android, we need to explicitly link to libglapi.so. +if HAVE_ANDROID +if HAVE_SHARED_GLAPI +SHARED_GLAPI_LIB = $(top_builddir)/src/mapi/shared-glapi/libglapi.la +endif +endif + if HAVE_I915_DRI SUBDIRS += i915 MEGADRIVERS_DEPS += i915/libi915_dri.la @@ -61,6 +68,7 @@ mesa_dri_drivers_la_LIBADD = \ common/libmegadriver_stub.la \ common/libdricommon.la \ common/libxmlconfig.la \ + $(SHARED_GLAPI_LIB) \ $(MEGADRIVERS_DEPS) \ $(DRI_LIB_DEPS) \ $()