blob: 8422de942fe92e7e478a69a2456519ff8d37bccf [file] [log] [blame]
Adam Jackson07d23f92005-07-10 22:42:42 +00001# Copyright 2005 Adam Jackson.
2#
3# Permission is hereby granted, free of charge, to any person obtaining a
4# copy of this software and associated documentation files (the "Software"),
5# to deal in the Software without restriction, including without limitation
6# on the rights to use, copy, modify, merge, publish, distribute, sub
7# license, and/or sell copies of the Software, and to permit persons to whom
8# the Software is furnished to do so, subject to the following conditions:
9#
10# The above copyright notice and this permission notice (including the next
11# paragraph) shall be included in all copies or substantial portions of the
12# Software.
13#
14# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16# FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL
17# ADAM JACKSON BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
18# IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
19# CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
20
Javier Jardónfd3ed342011-02-09 13:28:20 +000021AC_PREREQ([2.63])
22AC_INIT([libdrm],
Rob Clark7068d982014-09-28 14:53:34 -040023 [2.4.58],
Javier Jardónfd3ed342011-02-09 13:28:20 +000024 [https://bugs.freedesktop.org/enter_bug.cgi?product=DRI],
25 [libdrm])
26
27AC_CONFIG_HEADERS([config.h])
Adam Jackson07d23f92005-07-10 22:42:42 +000028AC_CONFIG_SRCDIR([Makefile.am])
Javier Jardónfd3ed342011-02-09 13:28:20 +000029AC_CONFIG_MACRO_DIR([m4])
30AC_CONFIG_AUX_DIR([build-aux])
Adam Jackson07d23f92005-07-10 22:42:42 +000031
Javier Jardónfd3ed342011-02-09 13:28:20 +000032AM_INIT_AUTOMAKE([1.10 foreign dist-bzip2])
33AM_MAINTAINER_MODE([enable])
Adam Jackson07d23f92005-07-10 22:42:42 +000034
Eric Anholt607e2282010-05-25 20:13:37 -070035# Enable quiet compiles on automake 1.11.
36m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
37
Javier Jardónfd3ed342011-02-09 13:28:20 +000038# Check for programs
39AC_PROG_CC
40
41AC_USE_SYSTEM_EXTENSIONS
42AC_SYS_LARGEFILE
43AC_FUNC_ALLOCA
44
45# Initialize libtool
46LT_PREREQ([2.2])
47LT_INIT([disable-static])
48
49
Eric Anholt6df7b072008-06-12 23:22:26 -070050PKG_CHECK_MODULES(PTHREADSTUBS, pthread-stubs)
51AC_SUBST(PTHREADSTUBS_CFLAGS)
52AC_SUBST(PTHREADSTUBS_LIBS)
53
Adam Jackson5a5478d2005-07-13 00:13:12 +000054pkgconfigdir=${libdir}/pkgconfig
Adam Jackson07d23f92005-07-10 22:42:42 +000055AC_SUBST(pkgconfigdir)
Javier Jardónfd3ed342011-02-09 13:28:20 +000056AC_ARG_ENABLE([udev],
57 [AS_HELP_STRING([--enable-udev],
58 [Enable support for using udev instead of mknod (default: disabled)])],
59 [UDEV=$enableval], [UDEV=no])
Adam Jackson07d23f92005-07-10 22:42:42 +000060
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +010061AC_ARG_ENABLE(libkms,
Jakob Bornecrantz97003c52010-02-18 13:27:29 +010062 AS_HELP_STRING([--disable-libkms],
Alan Coopersmith3c7ae8a2010-04-16 10:12:37 -070063 [Disable KMS mm abstraction library (default: auto)]),
64 [LIBKMS=$enableval], [LIBKMS=auto])
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +010065
Chris Wilsonab3300c2009-10-03 22:56:04 +010066AC_ARG_ENABLE(intel,
67 AS_HELP_STRING([--disable-intel],
Chris Wilsonfc8f6be2009-10-12 23:58:47 +010068 [Enable support for intel's KMS API (default: auto)]),
69 [INTEL=$enableval], [INTEL=auto])
Chris Wilsonab3300c2009-10-03 22:56:04 +010070
Dave Airlie520c6582010-02-02 10:58:50 +100071AC_ARG_ENABLE(radeon,
72 AS_HELP_STRING([--disable-radeon],
Pauli Nieminen966c9902009-08-29 12:08:57 +030073 [Enable support for radeon's KMS API (default: auto)]),
74 [RADEON=$enableval], [RADEON=auto])
Dave Airlie520c6582010-02-02 10:58:50 +100075
Ben Skeggs292da612011-12-09 16:11:06 +100076AC_ARG_ENABLE(nouveau,
77 AS_HELP_STRING([--disable-nouveau],
78 [Enable support for nouveau's KMS API (default: auto)]),
79 [NOUVEAU=$enableval], [NOUVEAU=auto])
80
Jakob Bornecrantz7080bfd2012-08-13 13:35:07 +020081AC_ARG_ENABLE(vmwgfx,
82 AS_HELP_STRING([--disable-vmwgfx],
83 [Enable support for vmwgfx's KMS API (default: yes)]),
84 [VMWGFX=$enableval], [VMWGFX=yes])
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +010085
Rob Clarkef1b9582012-03-28 14:39:43 -050086AC_ARG_ENABLE(omap-experimental-api,
87 AS_HELP_STRING([--enable-omap-experimental-api],
88 [Enable support for OMAP's experimental API (default: disabled)]),
89 [OMAP=$enableval], [OMAP=no])
Dave Airlie2fa2db12009-06-17 17:47:42 +100090
Inki Daee07b6502012-05-04 19:13:14 +090091AC_ARG_ENABLE(exynos-experimental-api,
92 AS_HELP_STRING([--enable-exynos-experimental-api],
93 [Enable support for EXYNOS's experimental API (default: disabled)]),
94 [EXYNOS=$enableval], [EXYNOS=no])
95
Rob Clarka5003c62015-01-13 11:00:09 -050096AC_ARG_ENABLE(freedreno,
97 AS_HELP_STRING([--disable-freedreno],
Maarten Lankhorstd5bfbdc2015-01-21 11:46:04 +010098 [Enable support for freedreno's KMS API (default: enabled on arm)]),
99 [FREEDRENO=$enableval], [FREEDRENO=auto])
Rob Clark41fc2cc2012-10-07 18:57:31 -0500100
Rob Clark28662b72015-01-13 10:53:42 -0500101AC_ARG_ENABLE(freedreno-kgsl,
102 AS_HELP_STRING([--enable-freedreno-kgsl],
103 [Enable support for freedreno's to use downstream android kernel API (default: disabled)]),
104 [FREEDRENO_KGSL=$enableval], [FREEDRENO_KGSL=no])
105
Thierry Redingd6a4c2c2012-12-01 10:30:38 +0100106AC_ARG_ENABLE(tegra-experimental-api,
107 AS_HELP_STRING([--enable-tegra-experimental-api],
108 [Enable support for Tegra's experimental API (default: disabled)]),
109 [TEGRA=$enableval], [TEGRA=no])
110
Benjamin Gaignard62d88662013-01-30 14:34:00 +0100111AC_ARG_ENABLE(install-test-programs,
112 AS_HELP_STRING([--enable-install-test-programs],
113 [Install test programs (default: no)]),
114 [INSTALL_TESTS=$enableval], [INSTALL_TESTS=no])
115
Eric Anholtc4857422008-06-03 10:20:49 -0700116dnl ===========================================================================
117dnl check compiler flags
118AC_DEFUN([LIBDRM_CC_TRY_FLAG], [
119 AC_MSG_CHECKING([whether $CC supports $1])
120
121 libdrm_save_CFLAGS="$CFLAGS"
122 CFLAGS="$CFLAGS $1"
123
Emil Velikovbf4a7cd2013-09-19 17:21:01 +0100124 AC_COMPILE_IFELSE([AC_LANG_SOURCE([ ])], [libdrm_cc_flag=yes], [libdrm_cc_flag=no])
Eric Anholtc4857422008-06-03 10:20:49 -0700125 CFLAGS="$libdrm_save_CFLAGS"
126
127 if test "x$libdrm_cc_flag" = "xyes"; then
128 ifelse([$2], , :, [$2])
129 else
130 ifelse([$3], , :, [$3])
131 fi
132 AC_MSG_RESULT([$libdrm_cc_flag])
133])
134
Jesse Barnesbadc6342009-01-07 11:47:52 -0800135dnl We use clock_gettime to check for timeouts in drmWaitVBlank
136
137AC_CHECK_FUNCS([clock_gettime], [CLOCK_LIB=],
138 [AC_CHECK_LIB([rt], [clock_gettime], [CLOCK_LIB=-lrt],
139 [AC_MSG_ERROR([Couldn't find clock_gettime])])])
140AC_SUBST([CLOCK_LIB])
141
Eric Anholtccbc4032012-01-03 12:33:37 -0800142AC_CHECK_FUNCS([open_memstream], [HAVE_OPEN_MEMSTREAM=yes])
143
Eric Anholtc4857422008-06-03 10:20:49 -0700144dnl Use lots of warning flags with with gcc and compatible compilers
145
146dnl Note: if you change the following variable, the cache is automatically
147dnl skipped and all flags rechecked. So there's no need to do anything
148dnl else. If for any reason you need to force a recheck, just change
149dnl MAYBE_WARN in an ignorable way (like adding whitespace)
150
151MAYBE_WARN="-Wall -Wextra \
152-Wsign-compare -Werror-implicit-function-declaration \
153-Wpointer-arith -Wwrite-strings -Wstrict-prototypes \
154-Wmissing-prototypes -Wmissing-declarations -Wnested-externs \
155-Wpacked -Wswitch-enum -Wmissing-format-attribute \
Eric Anholt71ebcf42012-08-02 11:25:57 -0700156-Wstrict-aliasing=2 -Winit-self \
Eric Anholtc4857422008-06-03 10:20:49 -0700157-Wdeclaration-after-statement -Wold-style-definition \
158-Wno-missing-field-initializers -Wno-unused-parameter \
159-Wno-attributes -Wno-long-long -Winline"
160
161# invalidate cached value if MAYBE_WARN has changed
162if test "x$libdrm_cv_warn_maybe" != "x$MAYBE_WARN"; then
163 unset libdrm_cv_warn_cflags
164fi
165AC_CACHE_CHECK([for supported warning flags], libdrm_cv_warn_cflags, [
166 echo
167 WARN_CFLAGS=""
168
169 # Some warning options are not supported by all versions of
170 # gcc, so test all desired options against the current
171 # compiler.
172 #
173 # Note that there are some order dependencies
174 # here. Specifically, an option that disables a warning will
175 # have no net effect if a later option then enables that
176 # warnings, (perhaps implicitly). So we put some grouped
177 # options (-Wall and -Wextra) up front and the -Wno options
178 # last.
179
180 for W in $MAYBE_WARN; do
181 LIBDRM_CC_TRY_FLAG([$W], [WARN_CFLAGS="$WARN_CFLAGS $W"])
182 done
183
184 libdrm_cv_warn_cflags=$WARN_CFLAGS
185 libdrm_cv_warn_maybe=$MAYBE_WARN
186
187 AC_MSG_CHECKING([which warning flags were supported])])
188WARN_CFLAGS="$libdrm_cv_warn_cflags"
189
Emil Velikovbe7d2972014-09-07 17:39:46 +0100190# Check for atomic intrinsics
191AC_CACHE_CHECK([for native atomic primitives], drm_cv_atomic_primitives, [
192 drm_cv_atomic_primitives="none"
193
194 AC_LINK_IFELSE([AC_LANG_PROGRAM([[
195 int atomic_add(int i) { return __sync_fetch_and_add (&i, 1); }
196 int atomic_cmpxchg(int i, int j, int k) { return __sync_val_compare_and_swap (&i, j, k); }
197 ]],[[]])], [drm_cv_atomic_primitives="Intel"],[])
198
199 if test "x$drm_cv_atomic_primitives" = "xnone"; then
200 AC_CHECK_HEADER([atomic_ops.h], drm_cv_atomic_primitives="libatomic-ops")
201 fi
202
203 # atomic functions defined in <atomic.h> & libc on Solaris
204 if test "x$drm_cv_atomic_primitives" = "xnone"; then
205 AC_CHECK_FUNC([atomic_cas_uint], drm_cv_atomic_primitives="Solaris")
206 fi
207])
208
209if test "x$drm_cv_atomic_primitives" = xIntel; then
210 AC_DEFINE(HAVE_LIBDRM_ATOMIC_PRIMITIVES, 1,
211 [Enable if your compiler supports the Intel __sync_* atomic primitives])
212fi
213if test "x$drm_cv_atomic_primitives" = "xlibatomic-ops"; then
214 AC_DEFINE(HAVE_LIB_ATOMIC_OPS, 1, [Enable if you have libatomic-ops-dev installed])
215fi
216
217if test "x$INTEL" != "xno" -o "x$RADEON" != "xno" -o "x$NOUVEAU" != "xno"; then
218 if test "x$drm_cv_atomic_primitives" = "xnone"; then
219 if test "x$INTEL" != "xauto"; then
220 if test "x$INTEL" != "xno"; then
221 AC_MSG_ERROR([libdrm_intel depends upon atomic operations, which were not found for your compiler/cpu. Try compiling with -march=native, or install the libatomics-op-dev package, or, failing both of those, disable support for Intel GPUs by passing --disable-intel to ./configure])
222 fi
223 else
224 AC_MSG_WARN([Disabling libdrm_intel. It depends on atomic operations, which were not found for your compiler/cpu. Try compiling with -march=native, or install the libatomics-op-dev package.])
225 INTEL=no
226 fi
227 if test "x$RADEON" != "xauto"; then
228 if test "x$RADEON" != "xno"; then
229 AC_MSG_ERROR([libdrm_radeon depends upon atomic operations, which were not found for your compiler/cpu. Try compiling with -march=native, or install the libatomics-op-dev package, or, failing both of those, disable support for Radeon GPUs by passing --disable-radeon to ./configure])
230 fi
231 else
232 AC_MSG_WARN([Disabling libdrm_radeon. It depends on atomic operations, which were not found for your compiler/cpu. Try compiling with -march=native, or install the libatomics-op-dev package.])
233 RADEON=no
234 fi
235 if test "x$NOUVEAU" != "xauto"; then
236 if test "x$NOUVEAU" != "xno"; then
237 AC_MSG_ERROR([libdrm_nouveau depends upon atomic operations, which were not found for your compiler/cpu. Try compiling with -march=native, or install the libatomics-op-dev package, or, failing both of those, disable support for NVIDIA GPUs by passing --disable-nouveau to ./configure])
238 fi
239 else
240 AC_MSG_WARN([Disabling libdrm_nouveau. It depends on atomic operations, which were not found for your compiler/cpu. Try compiling with -march=native, or install the libatomics-op-dev package.])
241 NOUVEAU=no
242 fi
243 else
244 if test "x$INTEL" != "xno"; then
245 case $host_cpu in
246 i?86|x86_64) INTEL=yes ;;
247 *) INTEL=no ;;
248 esac
249 fi
250 if test "x$RADEON" != "xno"; then
251 RADEON=yes
252 fi
253 if test "x$NOUVEAU" != "xno"; then
254 NOUVEAU=yes
255 fi
256 fi
257fi
258
259if test "x$INTEL" != "xno"; then
260 PKG_CHECK_MODULES(PCIACCESS, [pciaccess >= 0.10])
261fi
262AC_SUBST(PCIACCESS_CFLAGS)
263AC_SUBST(PCIACCESS_LIBS)
264
Dave Airlie9101a022008-08-24 16:54:43 +1000265if test "x$UDEV" = xyes; then
266 AC_DEFINE(UDEV, 1, [Have UDEV support])
267fi
268
Alan Coopersmith3c7ae8a2010-04-16 10:12:37 -0700269AC_CANONICAL_HOST
270if test "x$LIBKMS" = xauto ; then
271 case $host_os in
272 linux*) LIBKMS="yes" ;;
Robert Millancbb31f22014-01-23 14:46:05 +0000273 freebsd* | kfreebsd*-gnu)
274 LIBKMS="yes" ;;
François Tigeot1d868692014-02-17 10:07:54 +0100275 dragonfly*) LIBKMS="yes" ;;
Alan Coopersmith3c7ae8a2010-04-16 10:12:37 -0700276 *) LIBKMS="no" ;;
277 esac
278fi
279
Maarten Lankhorstd5bfbdc2015-01-21 11:46:04 +0100280if test "x$FREEDRENO" = xauto ; then
281 case $host_cpu in
282 arm*|aarch64) FREEDRENO="yes" ;;
283 *) FREEDRENO="no" ;;
284 esac
285fi
286
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100287AM_CONDITIONAL(HAVE_LIBKMS, [test "x$LIBKMS" = xyes])
288
Emil Velikovbe7d2972014-09-07 17:39:46 +0100289AM_CONDITIONAL(HAVE_INTEL, [test "x$INTEL" = xyes])
Emil Velikovf3fd11b2014-09-07 17:54:39 +0100290if test "x$INTEL" = xyes; then
291 AC_DEFINE(HAVE_INTEL, 1, [Have intel support])
292fi
Emil Velikovbe7d2972014-09-07 17:39:46 +0100293
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100294AM_CONDITIONAL(HAVE_VMWGFX, [test "x$VMWGFX" = xyes])
Jakob Bornecrantz5dbc1b32010-01-05 20:55:02 +0100295if test "x$VMWGFX" = xyes; then
296 AC_DEFINE(HAVE_VMWGFX, 1, [Have vmwgfx kernel headers])
297fi
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100298
Pekka Paalanen4a0d19e2009-02-22 12:40:47 +0200299AM_CONDITIONAL(HAVE_NOUVEAU, [test "x$NOUVEAU" = xyes])
Marcin Kościelnickiafd74ec2010-02-27 15:04:37 +0000300if test "x$NOUVEAU" = xyes; then
301 AC_DEFINE(HAVE_NOUVEAU, 1, [Have nouveau (nvidia) support])
302fi
Ben Skeggs7e5c5122009-02-11 14:18:03 +1000303
Rob Clarkef1b9582012-03-28 14:39:43 -0500304AM_CONDITIONAL(HAVE_OMAP, [test "x$OMAP" = xyes])
305if test "x$OMAP" = xyes; then
306 AC_DEFINE(HAVE_OMAP, 1, [Have OMAP support])
307fi
308
Inki Daee07b6502012-05-04 19:13:14 +0900309AM_CONDITIONAL(HAVE_EXYNOS, [test "x$EXYNOS" = xyes])
310if test "x$EXYNOS" = xyes; then
311 AC_DEFINE(HAVE_EXYNOS, 1, [Have EXYNOS support])
312fi
313
Rob Clark41fc2cc2012-10-07 18:57:31 -0500314AM_CONDITIONAL(HAVE_FREEDRENO, [test "x$FREEDRENO" = xyes])
315if test "x$FREEDRENO" = xyes; then
316 AC_DEFINE(HAVE_FREEDRENO, 1, [Have freedreno support])
317fi
318
Rob Clark28662b72015-01-13 10:53:42 -0500319AM_CONDITIONAL(HAVE_FREEDRENO_KGSL, [test "x$FREEDRENO_KGSL" = xyes])
320if test "x$FREEDRENO_KGSL" = xyes; then
321 AC_DEFINE(HAVE_FREEDRENO_KGSL, 1, [Have freedreno support for KGSL kernel interface])
322fi
323
Emil Velikovbe7d2972014-09-07 17:39:46 +0100324AM_CONDITIONAL(HAVE_RADEON, [test "x$RADEON" = xyes])
325if test "x$RADEON" = xyes; then
326 AC_DEFINE(HAVE_RADEON, 1, [Have radeon support])
327fi
328
Thierry Redingd6a4c2c2012-12-01 10:30:38 +0100329AM_CONDITIONAL(HAVE_TEGRA, [test "x$TEGRA" = xyes])
330if test "x$TEGRA" = xyes; then
331 AC_DEFINE(HAVE_TEGRA, 1, [Have Tegra support])
332fi
333
Benjamin Gaignard62d88662013-01-30 14:34:00 +0100334AM_CONDITIONAL(HAVE_INSTALL_TESTS, [test "x$INSTALL_TESTS" = xyes])
335if test "x$INSTALL_TESTS" = xyes; then
336 AC_DEFINE(HAVE_INSTALL_TESTS, 1, [Install test programs])
337fi
338
Daniel Stone14db9482012-10-04 01:21:57 +0000339AC_ARG_ENABLE([cairo-tests],
340 [AS_HELP_STRING([--enable-cairo-tests],
341 [Enable support for Cairo rendering in tests (default: auto)])],
342 [CAIRO=$enableval], [CAIRO=auto])
Kristian Høgsberg7a389aa2009-02-03 15:03:41 -0500343PKG_CHECK_MODULES(CAIRO, cairo, [HAVE_CAIRO=yes], [HAVE_CAIRO=no])
Daniel Stone14db9482012-10-04 01:21:57 +0000344AC_MSG_CHECKING([whether to enable Cairo tests])
345if test "x$CAIRO" = xauto; then
346 CAIRO="$HAVE_CAIRO"
Kristian Høgsberg7a389aa2009-02-03 15:03:41 -0500347fi
Daniel Stone14db9482012-10-04 01:21:57 +0000348if test "x$CAIRO" = xyes; then
349 if ! test "x$HAVE_CAIRO" = xyes; then
350 AC_MSG_ERROR([Cairo support required but not present])
351 fi
352 AC_DEFINE(HAVE_CAIRO, 1, [Have Cairo support])
353fi
354AC_MSG_RESULT([$CAIRO])
355AM_CONDITIONAL(HAVE_CAIRO, [test "x$CAIRO" = xyes])
Kristian Høgsberg7a389aa2009-02-03 15:03:41 -0500356
Kristian Høgsberge9d61162009-04-06 17:13:01 -0400357# For enumerating devices in test case
358PKG_CHECK_MODULES(LIBUDEV, libudev, [HAVE_LIBUDEV=yes], [HAVE_LIBUDEV=no])
359if test "x$HAVE_LIBUDEV" = xyes; then
360 AC_DEFINE(HAVE_LIBUDEV, 1, [Have libudev support])
361fi
362AM_CONDITIONAL(HAVE_LIBUDEV, [test "x$HAVE_LIBUDEV" = xyes])
363
David Herrmann08cb5c12013-01-16 19:35:25 +0100364# xsltproc for docbook manpages
365AC_ARG_ENABLE([manpages],
366 AS_HELP_STRING([--disable-manpages], [disable manpages @<:@default=enabled@:>@]),
367 [MANS=$enableval], [MANS=auto])
David Herrmann6b7e45c2012-09-28 23:44:19 +0200368AC_PATH_PROG(XSLTPROC, xsltproc)
David Herrmann08cb5c12013-01-16 19:35:25 +0100369AM_CONDITIONAL([BUILD_MANPAGES], [test "x$XSLTPROC" != "x" -a "x$MANS" != "xno"])
370
371# check for offline man-pages stylesheet
372AC_MSG_CHECKING([for docbook manpages stylesheet])
373MANPAGES_STYLESHEET="http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl"
374AC_PATH_PROGS_FEATURE_CHECK([XSLTPROC_TMP], [xsltproc],
375 AS_IF([`"$ac_path_XSLTPROC_TMP" --nonet "$MANPAGES_STYLESHEET" > /dev/null 2>&1`],
376 [HAVE_MANPAGES_STYLESHEET=yes]))
377if test "x$HAVE_MANPAGES_STYLESHEET" = "xyes"; then
378 AC_SUBST(MANPAGES_STYLESHEET)
379 AC_MSG_RESULT([yes])
380else
381 AC_MSG_RESULT([no])
382fi
383AM_CONDITIONAL([HAVE_MANPAGES_STYLESHEET], [test "x$HAVE_MANPAGES_STYLESHEET" = "xyes"])
David Herrmann6b7e45c2012-09-28 23:44:19 +0200384
Chris Wilsonced219e2012-02-13 00:19:17 +0000385PKG_CHECK_MODULES(VALGRIND, [valgrind], [have_valgrind=yes], [have_valgrind=no])
386if test "x$have_valgrind" = "xyes"; then
387 AC_DEFINE([HAVE_VALGRIND], 1, [Use valgrind intrinsics to suppress false warnings])
388fi
Chris Wilson90b23cc2012-02-09 10:23:10 +0000389
Kristian Høgsberga9968032009-11-17 09:23:52 -0500390AC_ARG_WITH([kernel-source],
391 [AS_HELP_STRING([--with-kernel-source],
392 [specify path to linux kernel source])],
393 [kernel_source="$with_kernel_source"])
394AC_SUBST(kernel_source)
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100395
Thierry Reding5d835792014-02-19 15:56:50 +0100396dnl Add flags for gcc and g++
397if test "x$GCC" = xyes; then
398 # Enable -fvisibility=hidden if using a gcc that supports it
399 save_CFLAGS="$CFLAGS"
400 AC_MSG_CHECKING([whether $CC supports -fvisibility=hidden])
401 VISIBILITY_CFLAGS="-fvisibility=hidden"
402 CFLAGS="$CFLAGS $VISIBILITY_CFLAGS"
403 AC_LINK_IFELSE([AC_LANG_PROGRAM()], AC_MSG_RESULT([yes]),
404 [VISIBILITY_CFLAGS=""; AC_MSG_RESULT([no])]);
405
406 # Restore CFLAGS; VISIBILITY_CFLAGS are added to it where needed.
407 CFLAGS=$save_CFLAGS
408
409 if test "x$VISIBILITY_CFLAGS" != x; then
410 AC_DEFINE(HAVE_VISIBILITY, 1, [Compiler has -fvisibility support])
411 fi
412
413 AC_SUBST([VISIBILITY_CFLAGS])
414fi
415
Eric Anholtc4857422008-06-03 10:20:49 -0700416AC_SUBST(WARN_CFLAGS)
Javier Jardónfd3ed342011-02-09 13:28:20 +0000417AC_CONFIG_FILES([
Eric Anholtd7cf2982007-07-19 04:59:59 -0700418 Makefile
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100419 libkms/Makefile
420 libkms/libkms.pc
Kristian Høgsberg4f57abf2009-11-17 11:14:54 -0500421 intel/Makefile
422 intel/libdrm_intel.pc
423 radeon/Makefile
424 radeon/libdrm_radeon.pc
425 nouveau/Makefile
426 nouveau/libdrm_nouveau.pc
Rob Clarkef1b9582012-03-28 14:39:43 -0500427 omap/Makefile
428 omap/libdrm_omap.pc
Inki Daee07b6502012-05-04 19:13:14 +0900429 exynos/Makefile
430 exynos/libdrm_exynos.pc
Rob Clark41fc2cc2012-10-07 18:57:31 -0500431 freedreno/Makefile
432 freedreno/libdrm_freedreno.pc
Thierry Redingd6a4c2c2012-12-01 10:30:38 +0100433 tegra/Makefile
434 tegra/libdrm_tegra.pc
Eric Anholtd7cf2982007-07-19 04:59:59 -0700435 tests/Makefile
Eric Anholt06ab2f62008-12-17 10:41:21 -0800436 tests/modeprint/Makefile
437 tests/modetest/Makefile
Jakob Bornecrantzd207a382010-01-08 15:34:44 +0000438 tests/kmstest/Makefile
Paulo Zanoni8f66c982012-05-15 18:38:30 -0300439 tests/proptest/Makefile
Jerome Glisseca497122011-11-10 16:47:10 -0500440 tests/radeon/Makefile
Jesse Barnesc42d1a12010-04-27 15:43:20 -0400441 tests/vbltest/Makefile
Inki Daebbf6e3d2013-02-18 21:51:00 +0900442 tests/exynos/Makefile
Thierry Reding93035cf2014-02-19 14:48:31 +0100443 tests/tegra/Makefile
Jesse Barnes2426a6a2012-09-06 16:16:50 -0700444 man/Makefile
Julien Cristau89cc98c2009-10-31 02:25:44 +0100445 libdrm.pc])
Javier Jardónfd3ed342011-02-09 13:28:20 +0000446AC_OUTPUT
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500447
448echo ""
449echo "$PACKAGE_STRING will be compiled with:"
450echo ""
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100451echo " libkms $LIBKMS"
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500452echo " Intel API $INTEL"
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100453echo " vmwgfx API $VMWGFX"
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500454echo " Radeon API $RADEON"
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500455echo " Nouveau API $NOUVEAU"
Rob Clarkef1b9582012-03-28 14:39:43 -0500456echo " OMAP API $OMAP"
Inki Daee07b6502012-05-04 19:13:14 +0900457echo " EXYNOS API $EXYNOS"
Rob Clark28662b72015-01-13 10:53:42 -0500458echo " Freedreno API $FREEDRENO (kgsl: $FREEDRENO_KGSL)"
Thierry Redingd6a4c2c2012-12-01 10:30:38 +0100459echo " Tegra API $TEGRA"
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500460echo ""