blob: ff2c840127c954e14c66949cef9108e91d173859 [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],
Eric Anholt51c3e7d2012-03-16 16:11:10 -070023 [2.4.32],
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
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +010076AC_ARG_ENABLE(vmwgfx-experimental-api,
77 AS_HELP_STRING([--enable-vmwgfx-experimental-api],
78 [Install vmwgfx's experimental kernel API header (default: disabled)]),
79 [VMWGFX=$enableval], [VMWGFX=no])
80
Ben Skeggs7e5c5122009-02-11 14:18:03 +100081AC_ARG_ENABLE(nouveau-experimental-api,
82 AS_HELP_STRING([--enable-nouveau-experimental-api],
83 [Enable support for nouveau's experimental API (default: disabled)]),
84 [NOUVEAU=$enableval], [NOUVEAU=no])
Eric Anholtc4857422008-06-03 10:20:49 -070085
Dave Airlie2fa2db12009-06-17 17:47:42 +100086
Eric Anholtc4857422008-06-03 10:20:49 -070087dnl ===========================================================================
88dnl check compiler flags
89AC_DEFUN([LIBDRM_CC_TRY_FLAG], [
90 AC_MSG_CHECKING([whether $CC supports $1])
91
92 libdrm_save_CFLAGS="$CFLAGS"
93 CFLAGS="$CFLAGS $1"
94
95 AC_COMPILE_IFELSE([ ], [libdrm_cc_flag=yes], [libdrm_cc_flag=no])
96 CFLAGS="$libdrm_save_CFLAGS"
97
98 if test "x$libdrm_cc_flag" = "xyes"; then
99 ifelse([$2], , :, [$2])
100 else
101 ifelse([$3], , :, [$3])
102 fi
103 AC_MSG_RESULT([$libdrm_cc_flag])
104])
105
Jesse Barnesbadc6342009-01-07 11:47:52 -0800106dnl We use clock_gettime to check for timeouts in drmWaitVBlank
107
108AC_CHECK_FUNCS([clock_gettime], [CLOCK_LIB=],
109 [AC_CHECK_LIB([rt], [clock_gettime], [CLOCK_LIB=-lrt],
110 [AC_MSG_ERROR([Couldn't find clock_gettime])])])
111AC_SUBST([CLOCK_LIB])
112
Eric Anholtccbc4032012-01-03 12:33:37 -0800113AC_CHECK_FUNCS([open_memstream], [HAVE_OPEN_MEMSTREAM=yes])
114
Eric Anholtc4857422008-06-03 10:20:49 -0700115dnl Use lots of warning flags with with gcc and compatible compilers
116
117dnl Note: if you change the following variable, the cache is automatically
118dnl skipped and all flags rechecked. So there's no need to do anything
119dnl else. If for any reason you need to force a recheck, just change
120dnl MAYBE_WARN in an ignorable way (like adding whitespace)
121
122MAYBE_WARN="-Wall -Wextra \
123-Wsign-compare -Werror-implicit-function-declaration \
124-Wpointer-arith -Wwrite-strings -Wstrict-prototypes \
125-Wmissing-prototypes -Wmissing-declarations -Wnested-externs \
126-Wpacked -Wswitch-enum -Wmissing-format-attribute \
127-Wstrict-aliasing=2 -Winit-self -Wunsafe-loop-optimizations \
128-Wdeclaration-after-statement -Wold-style-definition \
129-Wno-missing-field-initializers -Wno-unused-parameter \
130-Wno-attributes -Wno-long-long -Winline"
131
132# invalidate cached value if MAYBE_WARN has changed
133if test "x$libdrm_cv_warn_maybe" != "x$MAYBE_WARN"; then
134 unset libdrm_cv_warn_cflags
135fi
136AC_CACHE_CHECK([for supported warning flags], libdrm_cv_warn_cflags, [
137 echo
138 WARN_CFLAGS=""
139
140 # Some warning options are not supported by all versions of
141 # gcc, so test all desired options against the current
142 # compiler.
143 #
144 # Note that there are some order dependencies
145 # here. Specifically, an option that disables a warning will
146 # have no net effect if a later option then enables that
147 # warnings, (perhaps implicitly). So we put some grouped
148 # options (-Wall and -Wextra) up front and the -Wno options
149 # last.
150
151 for W in $MAYBE_WARN; do
152 LIBDRM_CC_TRY_FLAG([$W], [WARN_CFLAGS="$WARN_CFLAGS $W"])
153 done
154
155 libdrm_cv_warn_cflags=$WARN_CFLAGS
156 libdrm_cv_warn_maybe=$MAYBE_WARN
157
158 AC_MSG_CHECKING([which warning flags were supported])])
159WARN_CFLAGS="$libdrm_cv_warn_cflags"
160
Dave Airlie9101a022008-08-24 16:54:43 +1000161if test "x$UDEV" = xyes; then
162 AC_DEFINE(UDEV, 1, [Have UDEV support])
163fi
164
Alan Coopersmith3c7ae8a2010-04-16 10:12:37 -0700165AC_CANONICAL_HOST
166if test "x$LIBKMS" = xauto ; then
167 case $host_os in
168 linux*) LIBKMS="yes" ;;
169 *) LIBKMS="no" ;;
170 esac
171fi
172
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100173AM_CONDITIONAL(HAVE_LIBKMS, [test "x$LIBKMS" = xyes])
174
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100175AM_CONDITIONAL(HAVE_VMWGFX, [test "x$VMWGFX" = xyes])
Jakob Bornecrantz5dbc1b32010-01-05 20:55:02 +0100176if test "x$VMWGFX" = xyes; then
177 AC_DEFINE(HAVE_VMWGFX, 1, [Have vmwgfx kernel headers])
178fi
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100179
Pekka Paalanen4a0d19e2009-02-22 12:40:47 +0200180AM_CONDITIONAL(HAVE_NOUVEAU, [test "x$NOUVEAU" = xyes])
Marcin Kościelnickiafd74ec2010-02-27 15:04:37 +0000181if test "x$NOUVEAU" = xyes; then
182 AC_DEFINE(HAVE_NOUVEAU, 1, [Have nouveau (nvidia) support])
183fi
Ben Skeggs7e5c5122009-02-11 14:18:03 +1000184
Kristian Høgsberg7a389aa2009-02-03 15:03:41 -0500185PKG_CHECK_MODULES(CAIRO, cairo, [HAVE_CAIRO=yes], [HAVE_CAIRO=no])
186if test "x$HAVE_CAIRO" = xyes; then
187 AC_DEFINE(HAVE_CAIRO, 1, [Have cairo support])
188fi
189AM_CONDITIONAL(HAVE_CAIRO, [test "x$HAVE_CAIRO" = xyes])
190
Kristian Høgsberge9d61162009-04-06 17:13:01 -0400191# For enumerating devices in test case
192PKG_CHECK_MODULES(LIBUDEV, libudev, [HAVE_LIBUDEV=yes], [HAVE_LIBUDEV=no])
193if test "x$HAVE_LIBUDEV" = xyes; then
194 AC_DEFINE(HAVE_LIBUDEV, 1, [Have libudev support])
195fi
196AM_CONDITIONAL(HAVE_LIBUDEV, [test "x$HAVE_LIBUDEV" = xyes])
197
Pauli Nieminen966c9902009-08-29 12:08:57 +0300198if test "x$INTEL" != "xno" -o "x$RADEON" != "xno"; then
Chris Wilsonab3300c2009-10-03 22:56:04 +0100199 # Check for atomic intrinsics
200 AC_CACHE_CHECK([for native atomic primitives], drm_cv_atomic_primitives,
201 [
202 drm_cv_atomic_primitives="none"
203
Javier Jardónfd3ed342011-02-09 13:28:20 +0000204 AC_LINK_IFELSE([AC_LANG_PROGRAM([[
Chris Wilsonab3300c2009-10-03 22:56:04 +0100205 int atomic_add(int i) { return __sync_fetch_and_add (&i, 1); }
206 int atomic_cmpxchg(int i, int j, int k) { return __sync_val_compare_and_swap (&i, j, k); }
Javier Jardónfd3ed342011-02-09 13:28:20 +0000207 ]],[[]])],
208 [drm_cv_atomic_primitives="Intel"],[])
Chris Wilson901bacd2009-10-13 15:13:00 +0100209
210 if test "x$drm_cv_atomic_primitives" = "xnone"; then
211 AC_CHECK_HEADER([atomic_ops.h], drm_cv_atomic_primitives="libatomic-ops")
212 fi
213
Alan Coopersmithb1ce1e62010-01-16 19:28:50 -0800214 # atomic functions defined in <atomic.h> & libc on Solaris
215 if test "x$drm_cv_atomic_primitives" = "xnone"; then
216 AC_CHECK_FUNC([atomic_cas_uint],
217 drm_cv_atomic_primitives="Solaris")
218 fi
219
Chris Wilsonab3300c2009-10-03 22:56:04 +0100220 ])
221 if test "x$drm_cv_atomic_primitives" = xIntel; then
Pauli Nieminen21105bc2010-03-10 13:35:59 +0200222 AC_DEFINE(HAVE_LIBDRM_ATOMIC_PRIMITIVES, 1,
Chris Wilsonab3300c2009-10-03 22:56:04 +0100223 [Enable if your compiler supports the Intel __sync_* atomic primitives])
224 fi
Chris Wilson901bacd2009-10-13 15:13:00 +0100225 if test "x$drm_cv_atomic_primitives" = "xlibatomic-ops"; then
226 AC_DEFINE(HAVE_LIB_ATOMIC_OPS, 1, [Enable if you have libatomic-ops-dev installed])
227 fi
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100228
229 if test "x$drm_cv_atomic_primitives" = "xnone"; then
Pauli Nieminen966c9902009-08-29 12:08:57 +0300230 if test "x$INTEL" != "xauto"; then
Pauli Nieminen30ce1fd2010-03-17 14:34:53 +0200231 if test "x$INTEL" != "xno"; then
232 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])
233 fi
Pauli Nieminen966c9902009-08-29 12:08:57 +0300234 else
235 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.])
236 INTEL=no
237 fi
238 if test "x$RADEON" != "xauto"; then
Pauli Nieminen30ce1fd2010-03-17 14:34:53 +0200239 if test "x$RADEON" != "xno"; then
240 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 support by passing --disable-radeon to ./configure])
241 fi
Pauli Nieminen966c9902009-08-29 12:08:57 +0300242 else
243 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.])
244 RADEON=no
245 fi
246
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500247 else
Pauli Nieminen966c9902009-08-29 12:08:57 +0300248 if test "x$INTEL" != "xno"; then
Paul Berry82c69382012-01-31 14:44:14 -0800249 case $host_cpu in
250 i?86|x86_64) INTEL=yes ;;
Jeremy Huddlestonefd6e812012-01-30 15:20:04 -0800251 *) INTEL=no ;;
252 esac
Pauli Nieminen966c9902009-08-29 12:08:57 +0300253 fi
254 if test "x$RADEON" != "xno"; then
255 RADEON=yes
256 fi
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100257 fi
Chris Wilson04495ee2009-10-02 04:39:22 +0100258fi
259
Matt Turnerbe30d352012-03-01 12:19:59 -0500260if test "x$INTEL" != "xno"; then
261 PKG_CHECK_MODULES(PCIACCESS, [pciaccess >= 0.10])
262fi
263AC_SUBST(PCIACCESS_CFLAGS)
264AC_SUBST(PCIACCESS_LIBS)
265
Chris Wilsonced219e2012-02-13 00:19:17 +0000266PKG_CHECK_MODULES(VALGRIND, [valgrind], [have_valgrind=yes], [have_valgrind=no])
267if test "x$have_valgrind" = "xyes"; then
268 AC_DEFINE([HAVE_VALGRIND], 1, [Use valgrind intrinsics to suppress false warnings])
269fi
Chris Wilson90b23cc2012-02-09 10:23:10 +0000270
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100271AM_CONDITIONAL(HAVE_INTEL, [test "x$INTEL" != "xno"])
Pauli Nieminendf973702010-03-17 22:41:08 +0200272AM_CONDITIONAL(HAVE_RADEON, [test "x$RADEON" != "xno"])
Benjamin Franzkec75fe3a2011-02-17 10:46:35 +0100273if test "x$RADEON" = xyes; then
274 AC_DEFINE(HAVE_RADEON, 1, [Have radeon support])
275fi
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100276
Kristian Høgsberga9968032009-11-17 09:23:52 -0500277AC_ARG_WITH([kernel-source],
278 [AS_HELP_STRING([--with-kernel-source],
279 [specify path to linux kernel source])],
280 [kernel_source="$with_kernel_source"])
281AC_SUBST(kernel_source)
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100282
Eric Anholtc4857422008-06-03 10:20:49 -0700283AC_SUBST(WARN_CFLAGS)
Javier Jardónfd3ed342011-02-09 13:28:20 +0000284AC_CONFIG_FILES([
Eric Anholtd7cf2982007-07-19 04:59:59 -0700285 Makefile
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100286 libkms/Makefile
287 libkms/libkms.pc
Kristian Høgsberg4f57abf2009-11-17 11:14:54 -0500288 intel/Makefile
289 intel/libdrm_intel.pc
290 radeon/Makefile
291 radeon/libdrm_radeon.pc
292 nouveau/Makefile
293 nouveau/libdrm_nouveau.pc
Eric Anholtd7cf2982007-07-19 04:59:59 -0700294 tests/Makefile
Eric Anholt06ab2f62008-12-17 10:41:21 -0800295 tests/modeprint/Makefile
296 tests/modetest/Makefile
Jakob Bornecrantzd207a382010-01-08 15:34:44 +0000297 tests/kmstest/Makefile
Jerome Glisseca497122011-11-10 16:47:10 -0500298 tests/radeon/Makefile
Jesse Barnesc42d1a12010-04-27 15:43:20 -0400299 tests/vbltest/Makefile
Kristian Høgsberg4f070d52009-11-20 19:42:59 -0500300 include/Makefile
301 include/drm/Makefile
Julien Cristau89cc98c2009-10-31 02:25:44 +0100302 libdrm.pc])
Javier Jardónfd3ed342011-02-09 13:28:20 +0000303AC_OUTPUT
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500304
305echo ""
306echo "$PACKAGE_STRING will be compiled with:"
307echo ""
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100308echo " libkms $LIBKMS"
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500309echo " Intel API $INTEL"
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100310echo " vmwgfx API $VMWGFX"
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500311echo " Radeon API $RADEON"
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500312echo " Nouveau API $NOUVEAU"
313echo ""