blob: 0eab4ebd34fb55a6d9dd8652c38357b5692b899c [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],
98 [Enable support for freedreno's KMS API (default: enabled)]),
99 [FREEDRENO=$enableval], [FREEDRENO=yes])
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
yzqbd00c5c2014-10-08 14:38:23 +0800111AC_ARG_ENABLE(rockchip-experimental-api,
112 AS_HELP_STRING([--enable-rockchip-experimental-api],
113 [Enable support for rockchip's experimental API (default: disabled)]),
114 [ROCKCHIP=$enableval], [ROCKCHIP=no])
115
Benjamin Gaignard62d88662013-01-30 14:34:00 +0100116AC_ARG_ENABLE(install-test-programs,
117 AS_HELP_STRING([--enable-install-test-programs],
118 [Install test programs (default: no)]),
119 [INSTALL_TESTS=$enableval], [INSTALL_TESTS=no])
120
Eric Anholtc4857422008-06-03 10:20:49 -0700121dnl ===========================================================================
122dnl check compiler flags
123AC_DEFUN([LIBDRM_CC_TRY_FLAG], [
124 AC_MSG_CHECKING([whether $CC supports $1])
125
126 libdrm_save_CFLAGS="$CFLAGS"
127 CFLAGS="$CFLAGS $1"
128
Emil Velikovbf4a7cd2013-09-19 17:21:01 +0100129 AC_COMPILE_IFELSE([AC_LANG_SOURCE([ ])], [libdrm_cc_flag=yes], [libdrm_cc_flag=no])
Eric Anholtc4857422008-06-03 10:20:49 -0700130 CFLAGS="$libdrm_save_CFLAGS"
131
132 if test "x$libdrm_cc_flag" = "xyes"; then
133 ifelse([$2], , :, [$2])
134 else
135 ifelse([$3], , :, [$3])
136 fi
137 AC_MSG_RESULT([$libdrm_cc_flag])
138])
139
Jesse Barnesbadc6342009-01-07 11:47:52 -0800140dnl We use clock_gettime to check for timeouts in drmWaitVBlank
141
142AC_CHECK_FUNCS([clock_gettime], [CLOCK_LIB=],
143 [AC_CHECK_LIB([rt], [clock_gettime], [CLOCK_LIB=-lrt],
144 [AC_MSG_ERROR([Couldn't find clock_gettime])])])
145AC_SUBST([CLOCK_LIB])
146
Eric Anholtccbc4032012-01-03 12:33:37 -0800147AC_CHECK_FUNCS([open_memstream], [HAVE_OPEN_MEMSTREAM=yes])
148
Eric Anholtc4857422008-06-03 10:20:49 -0700149dnl Use lots of warning flags with with gcc and compatible compilers
150
151dnl Note: if you change the following variable, the cache is automatically
152dnl skipped and all flags rechecked. So there's no need to do anything
153dnl else. If for any reason you need to force a recheck, just change
154dnl MAYBE_WARN in an ignorable way (like adding whitespace)
155
156MAYBE_WARN="-Wall -Wextra \
157-Wsign-compare -Werror-implicit-function-declaration \
158-Wpointer-arith -Wwrite-strings -Wstrict-prototypes \
159-Wmissing-prototypes -Wmissing-declarations -Wnested-externs \
160-Wpacked -Wswitch-enum -Wmissing-format-attribute \
Eric Anholt71ebcf42012-08-02 11:25:57 -0700161-Wstrict-aliasing=2 -Winit-self \
Eric Anholtc4857422008-06-03 10:20:49 -0700162-Wdeclaration-after-statement -Wold-style-definition \
163-Wno-missing-field-initializers -Wno-unused-parameter \
164-Wno-attributes -Wno-long-long -Winline"
165
166# invalidate cached value if MAYBE_WARN has changed
167if test "x$libdrm_cv_warn_maybe" != "x$MAYBE_WARN"; then
168 unset libdrm_cv_warn_cflags
169fi
170AC_CACHE_CHECK([for supported warning flags], libdrm_cv_warn_cflags, [
171 echo
172 WARN_CFLAGS=""
173
174 # Some warning options are not supported by all versions of
175 # gcc, so test all desired options against the current
176 # compiler.
177 #
178 # Note that there are some order dependencies
179 # here. Specifically, an option that disables a warning will
180 # have no net effect if a later option then enables that
181 # warnings, (perhaps implicitly). So we put some grouped
182 # options (-Wall and -Wextra) up front and the -Wno options
183 # last.
184
185 for W in $MAYBE_WARN; do
186 LIBDRM_CC_TRY_FLAG([$W], [WARN_CFLAGS="$WARN_CFLAGS $W"])
187 done
188
189 libdrm_cv_warn_cflags=$WARN_CFLAGS
190 libdrm_cv_warn_maybe=$MAYBE_WARN
191
192 AC_MSG_CHECKING([which warning flags were supported])])
193WARN_CFLAGS="$libdrm_cv_warn_cflags"
194
Emil Velikovbe7d2972014-09-07 17:39:46 +0100195# Check for atomic intrinsics
196AC_CACHE_CHECK([for native atomic primitives], drm_cv_atomic_primitives, [
197 drm_cv_atomic_primitives="none"
198
199 AC_LINK_IFELSE([AC_LANG_PROGRAM([[
200 int atomic_add(int i) { return __sync_fetch_and_add (&i, 1); }
201 int atomic_cmpxchg(int i, int j, int k) { return __sync_val_compare_and_swap (&i, j, k); }
202 ]],[[]])], [drm_cv_atomic_primitives="Intel"],[])
203
204 if test "x$drm_cv_atomic_primitives" = "xnone"; then
205 AC_CHECK_HEADER([atomic_ops.h], drm_cv_atomic_primitives="libatomic-ops")
206 fi
207
208 # atomic functions defined in <atomic.h> & libc on Solaris
209 if test "x$drm_cv_atomic_primitives" = "xnone"; then
210 AC_CHECK_FUNC([atomic_cas_uint], drm_cv_atomic_primitives="Solaris")
211 fi
212])
213
214if test "x$drm_cv_atomic_primitives" = xIntel; then
215 AC_DEFINE(HAVE_LIBDRM_ATOMIC_PRIMITIVES, 1,
216 [Enable if your compiler supports the Intel __sync_* atomic primitives])
217fi
218if test "x$drm_cv_atomic_primitives" = "xlibatomic-ops"; then
219 AC_DEFINE(HAVE_LIB_ATOMIC_OPS, 1, [Enable if you have libatomic-ops-dev installed])
220fi
221
222if test "x$INTEL" != "xno" -o "x$RADEON" != "xno" -o "x$NOUVEAU" != "xno"; then
223 if test "x$drm_cv_atomic_primitives" = "xnone"; then
224 if test "x$INTEL" != "xauto"; then
225 if test "x$INTEL" != "xno"; then
226 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])
227 fi
228 else
229 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.])
230 INTEL=no
231 fi
232 if test "x$RADEON" != "xauto"; then
233 if test "x$RADEON" != "xno"; then
234 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])
235 fi
236 else
237 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.])
238 RADEON=no
239 fi
240 if test "x$NOUVEAU" != "xauto"; then
241 if test "x$NOUVEAU" != "xno"; then
242 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])
243 fi
244 else
245 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.])
246 NOUVEAU=no
247 fi
248 else
249 if test "x$INTEL" != "xno"; then
250 case $host_cpu in
251 i?86|x86_64) INTEL=yes ;;
252 *) INTEL=no ;;
253 esac
254 fi
255 if test "x$RADEON" != "xno"; then
256 RADEON=yes
257 fi
258 if test "x$NOUVEAU" != "xno"; then
259 NOUVEAU=yes
260 fi
261 fi
262fi
263
264if test "x$INTEL" != "xno"; then
265 PKG_CHECK_MODULES(PCIACCESS, [pciaccess >= 0.10])
266fi
267AC_SUBST(PCIACCESS_CFLAGS)
268AC_SUBST(PCIACCESS_LIBS)
269
Dave Airlie9101a022008-08-24 16:54:43 +1000270if test "x$UDEV" = xyes; then
271 AC_DEFINE(UDEV, 1, [Have UDEV support])
272fi
273
Alan Coopersmith3c7ae8a2010-04-16 10:12:37 -0700274AC_CANONICAL_HOST
275if test "x$LIBKMS" = xauto ; then
276 case $host_os in
277 linux*) LIBKMS="yes" ;;
Robert Millancbb31f22014-01-23 14:46:05 +0000278 freebsd* | kfreebsd*-gnu)
279 LIBKMS="yes" ;;
François Tigeot1d868692014-02-17 10:07:54 +0100280 dragonfly*) LIBKMS="yes" ;;
Alan Coopersmith3c7ae8a2010-04-16 10:12:37 -0700281 *) LIBKMS="no" ;;
282 esac
283fi
284
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100285AM_CONDITIONAL(HAVE_LIBKMS, [test "x$LIBKMS" = xyes])
286
Emil Velikovbe7d2972014-09-07 17:39:46 +0100287AM_CONDITIONAL(HAVE_INTEL, [test "x$INTEL" = xyes])
Emil Velikovf3fd11b2014-09-07 17:54:39 +0100288if test "x$INTEL" = xyes; then
289 AC_DEFINE(HAVE_INTEL, 1, [Have intel support])
290fi
Emil Velikovbe7d2972014-09-07 17:39:46 +0100291
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100292AM_CONDITIONAL(HAVE_VMWGFX, [test "x$VMWGFX" = xyes])
Jakob Bornecrantz5dbc1b32010-01-05 20:55:02 +0100293if test "x$VMWGFX" = xyes; then
294 AC_DEFINE(HAVE_VMWGFX, 1, [Have vmwgfx kernel headers])
295fi
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100296
Pekka Paalanen4a0d19e2009-02-22 12:40:47 +0200297AM_CONDITIONAL(HAVE_NOUVEAU, [test "x$NOUVEAU" = xyes])
Marcin Kościelnickiafd74ec2010-02-27 15:04:37 +0000298if test "x$NOUVEAU" = xyes; then
299 AC_DEFINE(HAVE_NOUVEAU, 1, [Have nouveau (nvidia) support])
300fi
Ben Skeggs7e5c5122009-02-11 14:18:03 +1000301
Rob Clarkef1b9582012-03-28 14:39:43 -0500302AM_CONDITIONAL(HAVE_OMAP, [test "x$OMAP" = xyes])
303if test "x$OMAP" = xyes; then
304 AC_DEFINE(HAVE_OMAP, 1, [Have OMAP support])
305fi
306
Inki Daee07b6502012-05-04 19:13:14 +0900307AM_CONDITIONAL(HAVE_EXYNOS, [test "x$EXYNOS" = xyes])
308if test "x$EXYNOS" = xyes; then
309 AC_DEFINE(HAVE_EXYNOS, 1, [Have EXYNOS support])
310fi
311
Rob Clark41fc2cc2012-10-07 18:57:31 -0500312AM_CONDITIONAL(HAVE_FREEDRENO, [test "x$FREEDRENO" = xyes])
313if test "x$FREEDRENO" = xyes; then
314 AC_DEFINE(HAVE_FREEDRENO, 1, [Have freedreno support])
315fi
316
Rob Clark28662b72015-01-13 10:53:42 -0500317AM_CONDITIONAL(HAVE_FREEDRENO_KGSL, [test "x$FREEDRENO_KGSL" = xyes])
318if test "x$FREEDRENO_KGSL" = xyes; then
319 AC_DEFINE(HAVE_FREEDRENO_KGSL, 1, [Have freedreno support for KGSL kernel interface])
320fi
321
Emil Velikovbe7d2972014-09-07 17:39:46 +0100322AM_CONDITIONAL(HAVE_RADEON, [test "x$RADEON" = xyes])
323if test "x$RADEON" = xyes; then
324 AC_DEFINE(HAVE_RADEON, 1, [Have radeon support])
325fi
326
Thierry Redingd6a4c2c2012-12-01 10:30:38 +0100327AM_CONDITIONAL(HAVE_TEGRA, [test "x$TEGRA" = xyes])
328if test "x$TEGRA" = xyes; then
329 AC_DEFINE(HAVE_TEGRA, 1, [Have Tegra support])
330fi
331
yzqbd00c5c2014-10-08 14:38:23 +0800332AM_CONDITIONAL(HAVE_ROCKCHIP, [test "x$ROCKCHIP" = xyes])
333if test "x$ROCKCHIP" = xyes; then
334 AC_DEFINE(HAVE_ROCKCHIP, 1, [Have ROCKCHIP support])
335fi
336
Benjamin Gaignard62d88662013-01-30 14:34:00 +0100337AM_CONDITIONAL(HAVE_INSTALL_TESTS, [test "x$INSTALL_TESTS" = xyes])
338if test "x$INSTALL_TESTS" = xyes; then
339 AC_DEFINE(HAVE_INSTALL_TESTS, 1, [Install test programs])
340fi
341
Daniel Stone14db9482012-10-04 01:21:57 +0000342AC_ARG_ENABLE([cairo-tests],
343 [AS_HELP_STRING([--enable-cairo-tests],
344 [Enable support for Cairo rendering in tests (default: auto)])],
345 [CAIRO=$enableval], [CAIRO=auto])
Kristian Høgsberg7a389aa2009-02-03 15:03:41 -0500346PKG_CHECK_MODULES(CAIRO, cairo, [HAVE_CAIRO=yes], [HAVE_CAIRO=no])
Daniel Stone14db9482012-10-04 01:21:57 +0000347AC_MSG_CHECKING([whether to enable Cairo tests])
348if test "x$CAIRO" = xauto; then
349 CAIRO="$HAVE_CAIRO"
Kristian Høgsberg7a389aa2009-02-03 15:03:41 -0500350fi
Daniel Stone14db9482012-10-04 01:21:57 +0000351if test "x$CAIRO" = xyes; then
352 if ! test "x$HAVE_CAIRO" = xyes; then
353 AC_MSG_ERROR([Cairo support required but not present])
354 fi
355 AC_DEFINE(HAVE_CAIRO, 1, [Have Cairo support])
356fi
357AC_MSG_RESULT([$CAIRO])
358AM_CONDITIONAL(HAVE_CAIRO, [test "x$CAIRO" = xyes])
Kristian Høgsberg7a389aa2009-02-03 15:03:41 -0500359
Kristian Høgsberge9d61162009-04-06 17:13:01 -0400360# For enumerating devices in test case
361PKG_CHECK_MODULES(LIBUDEV, libudev, [HAVE_LIBUDEV=yes], [HAVE_LIBUDEV=no])
362if test "x$HAVE_LIBUDEV" = xyes; then
363 AC_DEFINE(HAVE_LIBUDEV, 1, [Have libudev support])
364fi
365AM_CONDITIONAL(HAVE_LIBUDEV, [test "x$HAVE_LIBUDEV" = xyes])
366
David Herrmann08cb5c12013-01-16 19:35:25 +0100367# xsltproc for docbook manpages
368AC_ARG_ENABLE([manpages],
369 AS_HELP_STRING([--disable-manpages], [disable manpages @<:@default=enabled@:>@]),
370 [MANS=$enableval], [MANS=auto])
David Herrmann6b7e45c2012-09-28 23:44:19 +0200371AC_PATH_PROG(XSLTPROC, xsltproc)
David Herrmann08cb5c12013-01-16 19:35:25 +0100372AM_CONDITIONAL([BUILD_MANPAGES], [test "x$XSLTPROC" != "x" -a "x$MANS" != "xno"])
373
374# check for offline man-pages stylesheet
375AC_MSG_CHECKING([for docbook manpages stylesheet])
376MANPAGES_STYLESHEET="http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl"
377AC_PATH_PROGS_FEATURE_CHECK([XSLTPROC_TMP], [xsltproc],
378 AS_IF([`"$ac_path_XSLTPROC_TMP" --nonet "$MANPAGES_STYLESHEET" > /dev/null 2>&1`],
379 [HAVE_MANPAGES_STYLESHEET=yes]))
380if test "x$HAVE_MANPAGES_STYLESHEET" = "xyes"; then
381 AC_SUBST(MANPAGES_STYLESHEET)
382 AC_MSG_RESULT([yes])
383else
384 AC_MSG_RESULT([no])
385fi
386AM_CONDITIONAL([HAVE_MANPAGES_STYLESHEET], [test "x$HAVE_MANPAGES_STYLESHEET" = "xyes"])
David Herrmann6b7e45c2012-09-28 23:44:19 +0200387
Chris Wilsonced219e2012-02-13 00:19:17 +0000388PKG_CHECK_MODULES(VALGRIND, [valgrind], [have_valgrind=yes], [have_valgrind=no])
389if test "x$have_valgrind" = "xyes"; then
390 AC_DEFINE([HAVE_VALGRIND], 1, [Use valgrind intrinsics to suppress false warnings])
391fi
Chris Wilson90b23cc2012-02-09 10:23:10 +0000392
Kristian Høgsberga9968032009-11-17 09:23:52 -0500393AC_ARG_WITH([kernel-source],
394 [AS_HELP_STRING([--with-kernel-source],
395 [specify path to linux kernel source])],
396 [kernel_source="$with_kernel_source"])
397AC_SUBST(kernel_source)
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100398
Thierry Reding5d835792014-02-19 15:56:50 +0100399dnl Add flags for gcc and g++
400if test "x$GCC" = xyes; then
401 # Enable -fvisibility=hidden if using a gcc that supports it
402 save_CFLAGS="$CFLAGS"
403 AC_MSG_CHECKING([whether $CC supports -fvisibility=hidden])
404 VISIBILITY_CFLAGS="-fvisibility=hidden"
405 CFLAGS="$CFLAGS $VISIBILITY_CFLAGS"
406 AC_LINK_IFELSE([AC_LANG_PROGRAM()], AC_MSG_RESULT([yes]),
407 [VISIBILITY_CFLAGS=""; AC_MSG_RESULT([no])]);
408
409 # Restore CFLAGS; VISIBILITY_CFLAGS are added to it where needed.
410 CFLAGS=$save_CFLAGS
411
412 if test "x$VISIBILITY_CFLAGS" != x; then
413 AC_DEFINE(HAVE_VISIBILITY, 1, [Compiler has -fvisibility support])
414 fi
415
416 AC_SUBST([VISIBILITY_CFLAGS])
417fi
418
Eric Anholtc4857422008-06-03 10:20:49 -0700419AC_SUBST(WARN_CFLAGS)
Javier Jardónfd3ed342011-02-09 13:28:20 +0000420AC_CONFIG_FILES([
Eric Anholtd7cf2982007-07-19 04:59:59 -0700421 Makefile
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100422 libkms/Makefile
423 libkms/libkms.pc
Kristian Høgsberg4f57abf2009-11-17 11:14:54 -0500424 intel/Makefile
425 intel/libdrm_intel.pc
426 radeon/Makefile
427 radeon/libdrm_radeon.pc
428 nouveau/Makefile
429 nouveau/libdrm_nouveau.pc
Rob Clarkef1b9582012-03-28 14:39:43 -0500430 omap/Makefile
431 omap/libdrm_omap.pc
Inki Daee07b6502012-05-04 19:13:14 +0900432 exynos/Makefile
433 exynos/libdrm_exynos.pc
Rob Clark41fc2cc2012-10-07 18:57:31 -0500434 freedreno/Makefile
435 freedreno/libdrm_freedreno.pc
Thierry Redingd6a4c2c2012-12-01 10:30:38 +0100436 tegra/Makefile
437 tegra/libdrm_tegra.pc
yzqbd00c5c2014-10-08 14:38:23 +0800438 rockchip/Makefile
439 rockchip/libdrm_rockchip.pc
Eric Anholtd7cf2982007-07-19 04:59:59 -0700440 tests/Makefile
Eric Anholt06ab2f62008-12-17 10:41:21 -0800441 tests/modeprint/Makefile
442 tests/modetest/Makefile
Jakob Bornecrantzd207a382010-01-08 15:34:44 +0000443 tests/kmstest/Makefile
Paulo Zanoni8f66c982012-05-15 18:38:30 -0300444 tests/proptest/Makefile
Jerome Glisseca497122011-11-10 16:47:10 -0500445 tests/radeon/Makefile
Jesse Barnesc42d1a12010-04-27 15:43:20 -0400446 tests/vbltest/Makefile
Inki Daebbf6e3d2013-02-18 21:51:00 +0900447 tests/exynos/Makefile
Thierry Reding93035cf2014-02-19 14:48:31 +0100448 tests/tegra/Makefile
Sean Paulef6e8f22014-12-01 16:02:14 -0800449 tests/planetest/Makefile
Jesse Barnes2426a6a2012-09-06 16:16:50 -0700450 man/Makefile
Julien Cristau89cc98c2009-10-31 02:25:44 +0100451 libdrm.pc])
Javier Jardónfd3ed342011-02-09 13:28:20 +0000452AC_OUTPUT
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500453
454echo ""
455echo "$PACKAGE_STRING will be compiled with:"
456echo ""
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100457echo " libkms $LIBKMS"
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500458echo " Intel API $INTEL"
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100459echo " vmwgfx API $VMWGFX"
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500460echo " Radeon API $RADEON"
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500461echo " Nouveau API $NOUVEAU"
Rob Clarkef1b9582012-03-28 14:39:43 -0500462echo " OMAP API $OMAP"
Inki Daee07b6502012-05-04 19:13:14 +0900463echo " EXYNOS API $EXYNOS"
Rob Clark28662b72015-01-13 10:53:42 -0500464echo " Freedreno API $FREEDRENO (kgsl: $FREEDRENO_KGSL)"
Thierry Redingd6a4c2c2012-12-01 10:30:38 +0100465echo " Tegra API $TEGRA"
yzqbd00c5c2014-10-08 14:38:23 +0800466echo " Rockchip API $ROCKCHIP"
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500467echo ""