blob: 23ccedfa6653aee5263f762c76ce632e28bee48f [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
Ian Romanicka953b322009-07-06 13:23:46 -070021AC_PREREQ(2.60)
Chris Wilson760c01a2010-12-10 12:10:46 +000022AC_INIT([libdrm], 2.4.23, [dri-devel@lists.sourceforge.net], libdrm)
Dave Airlie80179df2009-07-10 02:38:13 +100023AC_USE_SYSTEM_EXTENSIONS
Adam Jackson07d23f92005-07-10 22:42:42 +000024AC_CONFIG_SRCDIR([Makefile.am])
25AM_INIT_AUTOMAKE([dist-bzip2])
26
Kristian Høgsberg4f57abf2009-11-17 11:14:54 -050027AM_CONFIG_HEADER([config.h])
Adam Jackson07d23f92005-07-10 22:42:42 +000028
Adam Jackson56b07332006-06-27 21:04:50 +000029AC_DISABLE_STATIC
Adam Jackson07d23f92005-07-10 22:42:42 +000030AC_PROG_LIBTOOL
31AC_PROG_CC
32
33AC_HEADER_STDC
Thomas Hellstromeacedf42006-10-02 15:06:35 +020034AC_SYS_LARGEFILE
Alan Coopersmithfe7b93f2009-12-16 15:03:58 -080035AC_FUNC_ALLOCA
Adam Jackson07d23f92005-07-10 22:42:42 +000036
Eric Anholt607e2282010-05-25 20:13:37 -070037# Enable quiet compiles on automake 1.11.
38m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
39
Eric Anholt6df7b072008-06-12 23:22:26 -070040PKG_CHECK_MODULES(PTHREADSTUBS, pthread-stubs)
41AC_SUBST(PTHREADSTUBS_CFLAGS)
42AC_SUBST(PTHREADSTUBS_LIBS)
43
Adam Jackson5a5478d2005-07-13 00:13:12 +000044pkgconfigdir=${libdir}/pkgconfig
Adam Jackson07d23f92005-07-10 22:42:42 +000045AC_SUBST(pkgconfigdir)
Dave Airlie9101a022008-08-24 16:54:43 +100046AC_ARG_ENABLE(udev, AS_HELP_STRING([--enable-udev],
47 [Enable support for using udev instead of mknod (default: disabled)]),
48 [UDEV=$enableval], [UDEV=no])
Adam Jackson07d23f92005-07-10 22:42:42 +000049
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +010050AC_ARG_ENABLE(libkms,
Jakob Bornecrantz97003c52010-02-18 13:27:29 +010051 AS_HELP_STRING([--disable-libkms],
Alan Coopersmith3c7ae8a2010-04-16 10:12:37 -070052 [Disable KMS mm abstraction library (default: auto)]),
53 [LIBKMS=$enableval], [LIBKMS=auto])
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +010054
Chris Wilsonab3300c2009-10-03 22:56:04 +010055AC_ARG_ENABLE(intel,
56 AS_HELP_STRING([--disable-intel],
Chris Wilsonfc8f6be2009-10-12 23:58:47 +010057 [Enable support for intel's KMS API (default: auto)]),
58 [INTEL=$enableval], [INTEL=auto])
Chris Wilsonab3300c2009-10-03 22:56:04 +010059
Dave Airlie520c6582010-02-02 10:58:50 +100060AC_ARG_ENABLE(radeon,
61 AS_HELP_STRING([--disable-radeon],
Pauli Nieminen966c9902009-08-29 12:08:57 +030062 [Enable support for radeon's KMS API (default: auto)]),
63 [RADEON=$enableval], [RADEON=auto])
Dave Airlie520c6582010-02-02 10:58:50 +100064
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +010065AC_ARG_ENABLE(vmwgfx-experimental-api,
66 AS_HELP_STRING([--enable-vmwgfx-experimental-api],
67 [Install vmwgfx's experimental kernel API header (default: disabled)]),
68 [VMWGFX=$enableval], [VMWGFX=no])
69
Ben Skeggs7e5c5122009-02-11 14:18:03 +100070AC_ARG_ENABLE(nouveau-experimental-api,
71 AS_HELP_STRING([--enable-nouveau-experimental-api],
72 [Enable support for nouveau's experimental API (default: disabled)]),
73 [NOUVEAU=$enableval], [NOUVEAU=no])
Eric Anholtc4857422008-06-03 10:20:49 -070074
Dave Airlie2fa2db12009-06-17 17:47:42 +100075
Eric Anholtc4857422008-06-03 10:20:49 -070076dnl ===========================================================================
77dnl check compiler flags
78AC_DEFUN([LIBDRM_CC_TRY_FLAG], [
79 AC_MSG_CHECKING([whether $CC supports $1])
80
81 libdrm_save_CFLAGS="$CFLAGS"
82 CFLAGS="$CFLAGS $1"
83
84 AC_COMPILE_IFELSE([ ], [libdrm_cc_flag=yes], [libdrm_cc_flag=no])
85 CFLAGS="$libdrm_save_CFLAGS"
86
87 if test "x$libdrm_cc_flag" = "xyes"; then
88 ifelse([$2], , :, [$2])
89 else
90 ifelse([$3], , :, [$3])
91 fi
92 AC_MSG_RESULT([$libdrm_cc_flag])
93])
94
Jesse Barnesbadc6342009-01-07 11:47:52 -080095dnl We use clock_gettime to check for timeouts in drmWaitVBlank
96
97AC_CHECK_FUNCS([clock_gettime], [CLOCK_LIB=],
98 [AC_CHECK_LIB([rt], [clock_gettime], [CLOCK_LIB=-lrt],
99 [AC_MSG_ERROR([Couldn't find clock_gettime])])])
100AC_SUBST([CLOCK_LIB])
101
Eric Anholtc4857422008-06-03 10:20:49 -0700102dnl Use lots of warning flags with with gcc and compatible compilers
103
104dnl Note: if you change the following variable, the cache is automatically
105dnl skipped and all flags rechecked. So there's no need to do anything
106dnl else. If for any reason you need to force a recheck, just change
107dnl MAYBE_WARN in an ignorable way (like adding whitespace)
108
109MAYBE_WARN="-Wall -Wextra \
110-Wsign-compare -Werror-implicit-function-declaration \
111-Wpointer-arith -Wwrite-strings -Wstrict-prototypes \
112-Wmissing-prototypes -Wmissing-declarations -Wnested-externs \
113-Wpacked -Wswitch-enum -Wmissing-format-attribute \
114-Wstrict-aliasing=2 -Winit-self -Wunsafe-loop-optimizations \
115-Wdeclaration-after-statement -Wold-style-definition \
116-Wno-missing-field-initializers -Wno-unused-parameter \
117-Wno-attributes -Wno-long-long -Winline"
118
119# invalidate cached value if MAYBE_WARN has changed
120if test "x$libdrm_cv_warn_maybe" != "x$MAYBE_WARN"; then
121 unset libdrm_cv_warn_cflags
122fi
123AC_CACHE_CHECK([for supported warning flags], libdrm_cv_warn_cflags, [
124 echo
125 WARN_CFLAGS=""
126
127 # Some warning options are not supported by all versions of
128 # gcc, so test all desired options against the current
129 # compiler.
130 #
131 # Note that there are some order dependencies
132 # here. Specifically, an option that disables a warning will
133 # have no net effect if a later option then enables that
134 # warnings, (perhaps implicitly). So we put some grouped
135 # options (-Wall and -Wextra) up front and the -Wno options
136 # last.
137
138 for W in $MAYBE_WARN; do
139 LIBDRM_CC_TRY_FLAG([$W], [WARN_CFLAGS="$WARN_CFLAGS $W"])
140 done
141
142 libdrm_cv_warn_cflags=$WARN_CFLAGS
143 libdrm_cv_warn_maybe=$MAYBE_WARN
144
145 AC_MSG_CHECKING([which warning flags were supported])])
146WARN_CFLAGS="$libdrm_cv_warn_cflags"
147
Dave Airlie9101a022008-08-24 16:54:43 +1000148if test "x$UDEV" = xyes; then
149 AC_DEFINE(UDEV, 1, [Have UDEV support])
150fi
151
Alan Coopersmith3c7ae8a2010-04-16 10:12:37 -0700152AC_CANONICAL_HOST
153if test "x$LIBKMS" = xauto ; then
154 case $host_os in
155 linux*) LIBKMS="yes" ;;
156 *) LIBKMS="no" ;;
157 esac
158fi
159
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100160AM_CONDITIONAL(HAVE_LIBKMS, [test "x$LIBKMS" = xyes])
161
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100162AM_CONDITIONAL(HAVE_VMWGFX, [test "x$VMWGFX" = xyes])
Jakob Bornecrantz5dbc1b32010-01-05 20:55:02 +0100163if test "x$VMWGFX" = xyes; then
164 AC_DEFINE(HAVE_VMWGFX, 1, [Have vmwgfx kernel headers])
165fi
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100166
Pekka Paalanen4a0d19e2009-02-22 12:40:47 +0200167AM_CONDITIONAL(HAVE_NOUVEAU, [test "x$NOUVEAU" = xyes])
Marcin Kościelnickiafd74ec2010-02-27 15:04:37 +0000168if test "x$NOUVEAU" = xyes; then
169 AC_DEFINE(HAVE_NOUVEAU, 1, [Have nouveau (nvidia) support])
170fi
Ben Skeggs7e5c5122009-02-11 14:18:03 +1000171
Kristian Høgsberg7a389aa2009-02-03 15:03:41 -0500172PKG_CHECK_MODULES(CAIRO, cairo, [HAVE_CAIRO=yes], [HAVE_CAIRO=no])
173if test "x$HAVE_CAIRO" = xyes; then
174 AC_DEFINE(HAVE_CAIRO, 1, [Have cairo support])
175fi
176AM_CONDITIONAL(HAVE_CAIRO, [test "x$HAVE_CAIRO" = xyes])
177
Kristian Høgsberge9d61162009-04-06 17:13:01 -0400178# For enumerating devices in test case
179PKG_CHECK_MODULES(LIBUDEV, libudev, [HAVE_LIBUDEV=yes], [HAVE_LIBUDEV=no])
180if test "x$HAVE_LIBUDEV" = xyes; then
181 AC_DEFINE(HAVE_LIBUDEV, 1, [Have libudev support])
182fi
183AM_CONDITIONAL(HAVE_LIBUDEV, [test "x$HAVE_LIBUDEV" = xyes])
184
Pauli Nieminen966c9902009-08-29 12:08:57 +0300185if test "x$INTEL" != "xno" -o "x$RADEON" != "xno"; then
Chris Wilsonab3300c2009-10-03 22:56:04 +0100186 # Check for atomic intrinsics
187 AC_CACHE_CHECK([for native atomic primitives], drm_cv_atomic_primitives,
188 [
189 drm_cv_atomic_primitives="none"
190
191 AC_TRY_LINK([
192 int atomic_add(int i) { return __sync_fetch_and_add (&i, 1); }
193 int atomic_cmpxchg(int i, int j, int k) { return __sync_val_compare_and_swap (&i, j, k); }
194 ], [],
195 drm_cv_atomic_primitives="Intel"
196 )
Chris Wilson901bacd2009-10-13 15:13:00 +0100197
198 if test "x$drm_cv_atomic_primitives" = "xnone"; then
199 AC_CHECK_HEADER([atomic_ops.h], drm_cv_atomic_primitives="libatomic-ops")
200 fi
201
Alan Coopersmithb1ce1e62010-01-16 19:28:50 -0800202 # atomic functions defined in <atomic.h> & libc on Solaris
203 if test "x$drm_cv_atomic_primitives" = "xnone"; then
204 AC_CHECK_FUNC([atomic_cas_uint],
205 drm_cv_atomic_primitives="Solaris")
206 fi
207
Chris Wilsonab3300c2009-10-03 22:56:04 +0100208 ])
209 if test "x$drm_cv_atomic_primitives" = xIntel; then
Pauli Nieminen21105bc2010-03-10 13:35:59 +0200210 AC_DEFINE(HAVE_LIBDRM_ATOMIC_PRIMITIVES, 1,
Chris Wilsonab3300c2009-10-03 22:56:04 +0100211 [Enable if your compiler supports the Intel __sync_* atomic primitives])
212 fi
Chris Wilson901bacd2009-10-13 15:13:00 +0100213 if 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])
215 fi
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100216
217 if test "x$drm_cv_atomic_primitives" = "xnone"; then
Pauli Nieminen966c9902009-08-29 12:08:57 +0300218 if test "x$INTEL" != "xauto"; then
Pauli Nieminen30ce1fd2010-03-17 14:34:53 +0200219 if test "x$INTEL" != "xno"; then
220 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])
221 fi
Pauli Nieminen966c9902009-08-29 12:08:57 +0300222 else
223 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.])
224 INTEL=no
225 fi
226 if test "x$RADEON" != "xauto"; then
Pauli Nieminen30ce1fd2010-03-17 14:34:53 +0200227 if test "x$RADEON" != "xno"; then
228 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])
229 fi
Pauli Nieminen966c9902009-08-29 12:08:57 +0300230 else
231 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.])
232 RADEON=no
233 fi
234
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500235 else
Pauli Nieminen966c9902009-08-29 12:08:57 +0300236 if test "x$INTEL" != "xno"; then
237 INTEL=yes
238 fi
239 if test "x$RADEON" != "xno"; then
240 RADEON=yes
241 fi
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100242 fi
Chris Wilson04495ee2009-10-02 04:39:22 +0100243fi
244
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100245AM_CONDITIONAL(HAVE_INTEL, [test "x$INTEL" != "xno"])
Pauli Nieminendf973702010-03-17 22:41:08 +0200246AM_CONDITIONAL(HAVE_RADEON, [test "x$RADEON" != "xno"])
Benjamin Franzkec75fe3a2011-02-17 10:46:35 +0100247if test "x$RADEON" = xyes; then
248 AC_DEFINE(HAVE_RADEON, 1, [Have radeon support])
249fi
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100250
Kristian Høgsberga9968032009-11-17 09:23:52 -0500251AC_ARG_WITH([kernel-source],
252 [AS_HELP_STRING([--with-kernel-source],
253 [specify path to linux kernel source])],
254 [kernel_source="$with_kernel_source"])
255AC_SUBST(kernel_source)
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100256
Eric Anholtc4857422008-06-03 10:20:49 -0700257AC_SUBST(WARN_CFLAGS)
Eric Anholtd7cf2982007-07-19 04:59:59 -0700258AC_OUTPUT([
259 Makefile
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100260 libkms/Makefile
261 libkms/libkms.pc
Kristian Høgsberg4f57abf2009-11-17 11:14:54 -0500262 intel/Makefile
263 intel/libdrm_intel.pc
264 radeon/Makefile
265 radeon/libdrm_radeon.pc
266 nouveau/Makefile
267 nouveau/libdrm_nouveau.pc
Eric Anholtd7cf2982007-07-19 04:59:59 -0700268 tests/Makefile
Eric Anholt06ab2f62008-12-17 10:41:21 -0800269 tests/modeprint/Makefile
270 tests/modetest/Makefile
Jakob Bornecrantzd207a382010-01-08 15:34:44 +0000271 tests/kmstest/Makefile
Jesse Barnesc42d1a12010-04-27 15:43:20 -0400272 tests/vbltest/Makefile
Kristian Høgsberg4f070d52009-11-20 19:42:59 -0500273 include/Makefile
274 include/drm/Makefile
Julien Cristau89cc98c2009-10-31 02:25:44 +0100275 libdrm.pc])
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500276
277echo ""
278echo "$PACKAGE_STRING will be compiled with:"
279echo ""
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100280echo " libkms $LIBKMS"
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500281echo " Intel API $INTEL"
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100282echo " vmwgfx API $VMWGFX"
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500283echo " Radeon API $RADEON"
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500284echo " Nouveau API $NOUVEAU"
285echo ""