blob: 1447785bbf45fe45b632eaff16f7ea2feed091df [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 Anholtcc9b7512011-10-28 13:14:44 -070023 [2.4.27],
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
Chris Wilson9d776032011-06-04 12:47:19 +010054PKG_CHECK_MODULES(PCIACCESS, [pciaccess >= 0.10])
55AC_SUBST(PCIACCESS_CFLAGS)
56AC_SUBST(PCIACCESS_LIBS)
57
Adam Jackson5a5478d2005-07-13 00:13:12 +000058pkgconfigdir=${libdir}/pkgconfig
Adam Jackson07d23f92005-07-10 22:42:42 +000059AC_SUBST(pkgconfigdir)
Javier Jardónfd3ed342011-02-09 13:28:20 +000060AC_ARG_ENABLE([udev],
61 [AS_HELP_STRING([--enable-udev],
62 [Enable support for using udev instead of mknod (default: disabled)])],
63 [UDEV=$enableval], [UDEV=no])
Adam Jackson07d23f92005-07-10 22:42:42 +000064
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +010065AC_ARG_ENABLE(libkms,
Jakob Bornecrantz97003c52010-02-18 13:27:29 +010066 AS_HELP_STRING([--disable-libkms],
Alan Coopersmith3c7ae8a2010-04-16 10:12:37 -070067 [Disable KMS mm abstraction library (default: auto)]),
68 [LIBKMS=$enableval], [LIBKMS=auto])
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +010069
Chris Wilsonab3300c2009-10-03 22:56:04 +010070AC_ARG_ENABLE(intel,
71 AS_HELP_STRING([--disable-intel],
Chris Wilsonfc8f6be2009-10-12 23:58:47 +010072 [Enable support for intel's KMS API (default: auto)]),
73 [INTEL=$enableval], [INTEL=auto])
Chris Wilsonab3300c2009-10-03 22:56:04 +010074
Dave Airlie520c6582010-02-02 10:58:50 +100075AC_ARG_ENABLE(radeon,
76 AS_HELP_STRING([--disable-radeon],
Pauli Nieminen966c9902009-08-29 12:08:57 +030077 [Enable support for radeon's KMS API (default: auto)]),
78 [RADEON=$enableval], [RADEON=auto])
Dave Airlie520c6582010-02-02 10:58:50 +100079
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +010080AC_ARG_ENABLE(vmwgfx-experimental-api,
81 AS_HELP_STRING([--enable-vmwgfx-experimental-api],
82 [Install vmwgfx's experimental kernel API header (default: disabled)]),
83 [VMWGFX=$enableval], [VMWGFX=no])
84
Ben Skeggs7e5c5122009-02-11 14:18:03 +100085AC_ARG_ENABLE(nouveau-experimental-api,
86 AS_HELP_STRING([--enable-nouveau-experimental-api],
87 [Enable support for nouveau's experimental API (default: disabled)]),
88 [NOUVEAU=$enableval], [NOUVEAU=no])
Eric Anholtc4857422008-06-03 10:20:49 -070089
Dave Airlie2fa2db12009-06-17 17:47:42 +100090
Eric Anholtc4857422008-06-03 10:20:49 -070091dnl ===========================================================================
92dnl check compiler flags
93AC_DEFUN([LIBDRM_CC_TRY_FLAG], [
94 AC_MSG_CHECKING([whether $CC supports $1])
95
96 libdrm_save_CFLAGS="$CFLAGS"
97 CFLAGS="$CFLAGS $1"
98
99 AC_COMPILE_IFELSE([ ], [libdrm_cc_flag=yes], [libdrm_cc_flag=no])
100 CFLAGS="$libdrm_save_CFLAGS"
101
102 if test "x$libdrm_cc_flag" = "xyes"; then
103 ifelse([$2], , :, [$2])
104 else
105 ifelse([$3], , :, [$3])
106 fi
107 AC_MSG_RESULT([$libdrm_cc_flag])
108])
109
Jesse Barnesbadc6342009-01-07 11:47:52 -0800110dnl We use clock_gettime to check for timeouts in drmWaitVBlank
111
112AC_CHECK_FUNCS([clock_gettime], [CLOCK_LIB=],
113 [AC_CHECK_LIB([rt], [clock_gettime], [CLOCK_LIB=-lrt],
114 [AC_MSG_ERROR([Couldn't find clock_gettime])])])
115AC_SUBST([CLOCK_LIB])
116
Eric Anholtc4857422008-06-03 10:20:49 -0700117dnl Use lots of warning flags with with gcc and compatible compilers
118
119dnl Note: if you change the following variable, the cache is automatically
120dnl skipped and all flags rechecked. So there's no need to do anything
121dnl else. If for any reason you need to force a recheck, just change
122dnl MAYBE_WARN in an ignorable way (like adding whitespace)
123
124MAYBE_WARN="-Wall -Wextra \
125-Wsign-compare -Werror-implicit-function-declaration \
126-Wpointer-arith -Wwrite-strings -Wstrict-prototypes \
127-Wmissing-prototypes -Wmissing-declarations -Wnested-externs \
128-Wpacked -Wswitch-enum -Wmissing-format-attribute \
129-Wstrict-aliasing=2 -Winit-self -Wunsafe-loop-optimizations \
130-Wdeclaration-after-statement -Wold-style-definition \
131-Wno-missing-field-initializers -Wno-unused-parameter \
132-Wno-attributes -Wno-long-long -Winline"
133
134# invalidate cached value if MAYBE_WARN has changed
135if test "x$libdrm_cv_warn_maybe" != "x$MAYBE_WARN"; then
136 unset libdrm_cv_warn_cflags
137fi
138AC_CACHE_CHECK([for supported warning flags], libdrm_cv_warn_cflags, [
139 echo
140 WARN_CFLAGS=""
141
142 # Some warning options are not supported by all versions of
143 # gcc, so test all desired options against the current
144 # compiler.
145 #
146 # Note that there are some order dependencies
147 # here. Specifically, an option that disables a warning will
148 # have no net effect if a later option then enables that
149 # warnings, (perhaps implicitly). So we put some grouped
150 # options (-Wall and -Wextra) up front and the -Wno options
151 # last.
152
153 for W in $MAYBE_WARN; do
154 LIBDRM_CC_TRY_FLAG([$W], [WARN_CFLAGS="$WARN_CFLAGS $W"])
155 done
156
157 libdrm_cv_warn_cflags=$WARN_CFLAGS
158 libdrm_cv_warn_maybe=$MAYBE_WARN
159
160 AC_MSG_CHECKING([which warning flags were supported])])
161WARN_CFLAGS="$libdrm_cv_warn_cflags"
162
Dave Airlie9101a022008-08-24 16:54:43 +1000163if test "x$UDEV" = xyes; then
164 AC_DEFINE(UDEV, 1, [Have UDEV support])
165fi
166
Alan Coopersmith3c7ae8a2010-04-16 10:12:37 -0700167AC_CANONICAL_HOST
168if test "x$LIBKMS" = xauto ; then
169 case $host_os in
170 linux*) LIBKMS="yes" ;;
171 *) LIBKMS="no" ;;
172 esac
173fi
174
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100175AM_CONDITIONAL(HAVE_LIBKMS, [test "x$LIBKMS" = xyes])
176
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100177AM_CONDITIONAL(HAVE_VMWGFX, [test "x$VMWGFX" = xyes])
Jakob Bornecrantz5dbc1b32010-01-05 20:55:02 +0100178if test "x$VMWGFX" = xyes; then
179 AC_DEFINE(HAVE_VMWGFX, 1, [Have vmwgfx kernel headers])
180fi
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100181
Pekka Paalanen4a0d19e2009-02-22 12:40:47 +0200182AM_CONDITIONAL(HAVE_NOUVEAU, [test "x$NOUVEAU" = xyes])
Marcin Kościelnickiafd74ec2010-02-27 15:04:37 +0000183if test "x$NOUVEAU" = xyes; then
184 AC_DEFINE(HAVE_NOUVEAU, 1, [Have nouveau (nvidia) support])
185fi
Ben Skeggs7e5c5122009-02-11 14:18:03 +1000186
Kristian Høgsberg7a389aa2009-02-03 15:03:41 -0500187PKG_CHECK_MODULES(CAIRO, cairo, [HAVE_CAIRO=yes], [HAVE_CAIRO=no])
188if test "x$HAVE_CAIRO" = xyes; then
189 AC_DEFINE(HAVE_CAIRO, 1, [Have cairo support])
190fi
191AM_CONDITIONAL(HAVE_CAIRO, [test "x$HAVE_CAIRO" = xyes])
192
Kristian Høgsberge9d61162009-04-06 17:13:01 -0400193# For enumerating devices in test case
194PKG_CHECK_MODULES(LIBUDEV, libudev, [HAVE_LIBUDEV=yes], [HAVE_LIBUDEV=no])
195if test "x$HAVE_LIBUDEV" = xyes; then
196 AC_DEFINE(HAVE_LIBUDEV, 1, [Have libudev support])
197fi
198AM_CONDITIONAL(HAVE_LIBUDEV, [test "x$HAVE_LIBUDEV" = xyes])
199
Pauli Nieminen966c9902009-08-29 12:08:57 +0300200if test "x$INTEL" != "xno" -o "x$RADEON" != "xno"; then
Chris Wilsonab3300c2009-10-03 22:56:04 +0100201 # Check for atomic intrinsics
202 AC_CACHE_CHECK([for native atomic primitives], drm_cv_atomic_primitives,
203 [
204 drm_cv_atomic_primitives="none"
205
Javier Jardónfd3ed342011-02-09 13:28:20 +0000206 AC_LINK_IFELSE([AC_LANG_PROGRAM([[
Chris Wilsonab3300c2009-10-03 22:56:04 +0100207 int atomic_add(int i) { return __sync_fetch_and_add (&i, 1); }
208 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 +0000209 ]],[[]])],
210 [drm_cv_atomic_primitives="Intel"],[])
Chris Wilson901bacd2009-10-13 15:13:00 +0100211
212 if test "x$drm_cv_atomic_primitives" = "xnone"; then
213 AC_CHECK_HEADER([atomic_ops.h], drm_cv_atomic_primitives="libatomic-ops")
214 fi
215
Alan Coopersmithb1ce1e62010-01-16 19:28:50 -0800216 # atomic functions defined in <atomic.h> & libc on Solaris
217 if test "x$drm_cv_atomic_primitives" = "xnone"; then
218 AC_CHECK_FUNC([atomic_cas_uint],
219 drm_cv_atomic_primitives="Solaris")
220 fi
221
Chris Wilsonab3300c2009-10-03 22:56:04 +0100222 ])
223 if test "x$drm_cv_atomic_primitives" = xIntel; then
Pauli Nieminen21105bc2010-03-10 13:35:59 +0200224 AC_DEFINE(HAVE_LIBDRM_ATOMIC_PRIMITIVES, 1,
Chris Wilsonab3300c2009-10-03 22:56:04 +0100225 [Enable if your compiler supports the Intel __sync_* atomic primitives])
226 fi
Chris Wilson901bacd2009-10-13 15:13:00 +0100227 if test "x$drm_cv_atomic_primitives" = "xlibatomic-ops"; then
228 AC_DEFINE(HAVE_LIB_ATOMIC_OPS, 1, [Enable if you have libatomic-ops-dev installed])
229 fi
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100230
231 if test "x$drm_cv_atomic_primitives" = "xnone"; then
Pauli Nieminen966c9902009-08-29 12:08:57 +0300232 if test "x$INTEL" != "xauto"; then
Pauli Nieminen30ce1fd2010-03-17 14:34:53 +0200233 if test "x$INTEL" != "xno"; then
234 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])
235 fi
Pauli Nieminen966c9902009-08-29 12:08:57 +0300236 else
237 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.])
238 INTEL=no
239 fi
240 if test "x$RADEON" != "xauto"; then
Pauli Nieminen30ce1fd2010-03-17 14:34:53 +0200241 if test "x$RADEON" != "xno"; then
242 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])
243 fi
Pauli Nieminen966c9902009-08-29 12:08:57 +0300244 else
245 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.])
246 RADEON=no
247 fi
248
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500249 else
Pauli Nieminen966c9902009-08-29 12:08:57 +0300250 if test "x$INTEL" != "xno"; then
251 INTEL=yes
252 fi
253 if test "x$RADEON" != "xno"; then
254 RADEON=yes
255 fi
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100256 fi
Chris Wilson04495ee2009-10-02 04:39:22 +0100257fi
258
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100259AM_CONDITIONAL(HAVE_INTEL, [test "x$INTEL" != "xno"])
Pauli Nieminendf973702010-03-17 22:41:08 +0200260AM_CONDITIONAL(HAVE_RADEON, [test "x$RADEON" != "xno"])
Benjamin Franzkec75fe3a2011-02-17 10:46:35 +0100261if test "x$RADEON" = xyes; then
262 AC_DEFINE(HAVE_RADEON, 1, [Have radeon support])
263fi
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100264
Kristian Høgsberga9968032009-11-17 09:23:52 -0500265AC_ARG_WITH([kernel-source],
266 [AS_HELP_STRING([--with-kernel-source],
267 [specify path to linux kernel source])],
268 [kernel_source="$with_kernel_source"])
269AC_SUBST(kernel_source)
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100270
Eric Anholtc4857422008-06-03 10:20:49 -0700271AC_SUBST(WARN_CFLAGS)
Javier Jardónfd3ed342011-02-09 13:28:20 +0000272AC_CONFIG_FILES([
Eric Anholtd7cf2982007-07-19 04:59:59 -0700273 Makefile
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100274 libkms/Makefile
275 libkms/libkms.pc
Kristian Høgsberg4f57abf2009-11-17 11:14:54 -0500276 intel/Makefile
277 intel/libdrm_intel.pc
278 radeon/Makefile
279 radeon/libdrm_radeon.pc
280 nouveau/Makefile
281 nouveau/libdrm_nouveau.pc
Eric Anholtd7cf2982007-07-19 04:59:59 -0700282 tests/Makefile
Eric Anholt06ab2f62008-12-17 10:41:21 -0800283 tests/modeprint/Makefile
284 tests/modetest/Makefile
Jakob Bornecrantzd207a382010-01-08 15:34:44 +0000285 tests/kmstest/Makefile
Jerome Glisseca497122011-11-10 16:47:10 -0500286 tests/radeon/Makefile
Jesse Barnesc42d1a12010-04-27 15:43:20 -0400287 tests/vbltest/Makefile
Kristian Høgsberg4f070d52009-11-20 19:42:59 -0500288 include/Makefile
289 include/drm/Makefile
Julien Cristau89cc98c2009-10-31 02:25:44 +0100290 libdrm.pc])
Javier Jardónfd3ed342011-02-09 13:28:20 +0000291AC_OUTPUT
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500292
293echo ""
294echo "$PACKAGE_STRING will be compiled with:"
295echo ""
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100296echo " libkms $LIBKMS"
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500297echo " Intel API $INTEL"
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100298echo " vmwgfx API $VMWGFX"
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500299echo " Radeon API $RADEON"
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500300echo " Nouveau API $NOUVEAU"
301echo ""