blob: fff3b613026612612c7ca278b4822b8a8b8d04d6 [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)
Eric Anholta107e5b2009-10-08 16:59:17 -070022AC_INIT([libdrm], 2.4.15, [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
Adam Jackson07d23f92005-07-10 22:42:42 +000035
Eric Anholt6df7b072008-06-12 23:22:26 -070036PKG_CHECK_MODULES(PTHREADSTUBS, pthread-stubs)
37AC_SUBST(PTHREADSTUBS_CFLAGS)
38AC_SUBST(PTHREADSTUBS_LIBS)
39
Adam Jackson5a5478d2005-07-13 00:13:12 +000040pkgconfigdir=${libdir}/pkgconfig
Adam Jackson07d23f92005-07-10 22:42:42 +000041AC_SUBST(pkgconfigdir)
Dave Airlie9101a022008-08-24 16:54:43 +100042AC_ARG_ENABLE(udev, AS_HELP_STRING([--enable-udev],
43 [Enable support for using udev instead of mknod (default: disabled)]),
44 [UDEV=$enableval], [UDEV=no])
Adam Jackson07d23f92005-07-10 22:42:42 +000045
Chris Wilsonab3300c2009-10-03 22:56:04 +010046AC_ARG_ENABLE(intel,
47 AS_HELP_STRING([--disable-intel],
Chris Wilsonfc8f6be2009-10-12 23:58:47 +010048 [Enable support for intel's KMS API (default: auto)]),
49 [INTEL=$enableval], [INTEL=auto])
Chris Wilsonab3300c2009-10-03 22:56:04 +010050
Ben Skeggs7e5c5122009-02-11 14:18:03 +100051AC_ARG_ENABLE(nouveau-experimental-api,
52 AS_HELP_STRING([--enable-nouveau-experimental-api],
53 [Enable support for nouveau's experimental API (default: disabled)]),
54 [NOUVEAU=$enableval], [NOUVEAU=no])
Eric Anholtc4857422008-06-03 10:20:49 -070055
Dave Airlie2fa2db12009-06-17 17:47:42 +100056AC_ARG_ENABLE(radeon-experimental-api,
57 AS_HELP_STRING([--enable-radeon-experimental-api],
58 [Enable support for radeon's KMS API (default: disabled)]),
59 [RADEON=$enableval], [RADEON=no])
60
Eric Anholtc4857422008-06-03 10:20:49 -070061dnl ===========================================================================
62dnl check compiler flags
63AC_DEFUN([LIBDRM_CC_TRY_FLAG], [
64 AC_MSG_CHECKING([whether $CC supports $1])
65
66 libdrm_save_CFLAGS="$CFLAGS"
67 CFLAGS="$CFLAGS $1"
68
69 AC_COMPILE_IFELSE([ ], [libdrm_cc_flag=yes], [libdrm_cc_flag=no])
70 CFLAGS="$libdrm_save_CFLAGS"
71
72 if test "x$libdrm_cc_flag" = "xyes"; then
73 ifelse([$2], , :, [$2])
74 else
75 ifelse([$3], , :, [$3])
76 fi
77 AC_MSG_RESULT([$libdrm_cc_flag])
78])
79
Jesse Barnesbadc6342009-01-07 11:47:52 -080080dnl We use clock_gettime to check for timeouts in drmWaitVBlank
81
82AC_CHECK_FUNCS([clock_gettime], [CLOCK_LIB=],
83 [AC_CHECK_LIB([rt], [clock_gettime], [CLOCK_LIB=-lrt],
84 [AC_MSG_ERROR([Couldn't find clock_gettime])])])
85AC_SUBST([CLOCK_LIB])
86
Eric Anholtc4857422008-06-03 10:20:49 -070087dnl Use lots of warning flags with with gcc and compatible compilers
88
89dnl Note: if you change the following variable, the cache is automatically
90dnl skipped and all flags rechecked. So there's no need to do anything
91dnl else. If for any reason you need to force a recheck, just change
92dnl MAYBE_WARN in an ignorable way (like adding whitespace)
93
94MAYBE_WARN="-Wall -Wextra \
95-Wsign-compare -Werror-implicit-function-declaration \
96-Wpointer-arith -Wwrite-strings -Wstrict-prototypes \
97-Wmissing-prototypes -Wmissing-declarations -Wnested-externs \
98-Wpacked -Wswitch-enum -Wmissing-format-attribute \
99-Wstrict-aliasing=2 -Winit-self -Wunsafe-loop-optimizations \
100-Wdeclaration-after-statement -Wold-style-definition \
101-Wno-missing-field-initializers -Wno-unused-parameter \
102-Wno-attributes -Wno-long-long -Winline"
103
104# invalidate cached value if MAYBE_WARN has changed
105if test "x$libdrm_cv_warn_maybe" != "x$MAYBE_WARN"; then
106 unset libdrm_cv_warn_cflags
107fi
108AC_CACHE_CHECK([for supported warning flags], libdrm_cv_warn_cflags, [
109 echo
110 WARN_CFLAGS=""
111
112 # Some warning options are not supported by all versions of
113 # gcc, so test all desired options against the current
114 # compiler.
115 #
116 # Note that there are some order dependencies
117 # here. Specifically, an option that disables a warning will
118 # have no net effect if a later option then enables that
119 # warnings, (perhaps implicitly). So we put some grouped
120 # options (-Wall and -Wextra) up front and the -Wno options
121 # last.
122
123 for W in $MAYBE_WARN; do
124 LIBDRM_CC_TRY_FLAG([$W], [WARN_CFLAGS="$WARN_CFLAGS $W"])
125 done
126
127 libdrm_cv_warn_cflags=$WARN_CFLAGS
128 libdrm_cv_warn_maybe=$MAYBE_WARN
129
130 AC_MSG_CHECKING([which warning flags were supported])])
131WARN_CFLAGS="$libdrm_cv_warn_cflags"
132
Dave Airlie9101a022008-08-24 16:54:43 +1000133if test "x$UDEV" = xyes; then
134 AC_DEFINE(UDEV, 1, [Have UDEV support])
135fi
136
Pekka Paalanen4a0d19e2009-02-22 12:40:47 +0200137AM_CONDITIONAL(HAVE_NOUVEAU, [test "x$NOUVEAU" = xyes])
Ben Skeggs7e5c5122009-02-11 14:18:03 +1000138
Dave Airlie2fa2db12009-06-17 17:47:42 +1000139AM_CONDITIONAL(HAVE_RADEON, [test "x$RADEON" = xyes])
140
Kristian Høgsberg7a389aa2009-02-03 15:03:41 -0500141PKG_CHECK_MODULES(CAIRO, cairo, [HAVE_CAIRO=yes], [HAVE_CAIRO=no])
142if test "x$HAVE_CAIRO" = xyes; then
143 AC_DEFINE(HAVE_CAIRO, 1, [Have cairo support])
144fi
145AM_CONDITIONAL(HAVE_CAIRO, [test "x$HAVE_CAIRO" = xyes])
146
Kristian Høgsberge9d61162009-04-06 17:13:01 -0400147# For enumerating devices in test case
148PKG_CHECK_MODULES(LIBUDEV, libudev, [HAVE_LIBUDEV=yes], [HAVE_LIBUDEV=no])
149if test "x$HAVE_LIBUDEV" = xyes; then
150 AC_DEFINE(HAVE_LIBUDEV, 1, [Have libudev support])
151fi
152AM_CONDITIONAL(HAVE_LIBUDEV, [test "x$HAVE_LIBUDEV" = xyes])
153
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100154if test "x$INTEL" != "xno"; then
Chris Wilsonab3300c2009-10-03 22:56:04 +0100155 # Check for atomic intrinsics
156 AC_CACHE_CHECK([for native atomic primitives], drm_cv_atomic_primitives,
157 [
158 drm_cv_atomic_primitives="none"
159
160 AC_TRY_LINK([
161 int atomic_add(int i) { return __sync_fetch_and_add (&i, 1); }
162 int atomic_cmpxchg(int i, int j, int k) { return __sync_val_compare_and_swap (&i, j, k); }
163 ], [],
164 drm_cv_atomic_primitives="Intel"
165 )
Chris Wilson901bacd2009-10-13 15:13:00 +0100166
167 if test "x$drm_cv_atomic_primitives" = "xnone"; then
168 AC_CHECK_HEADER([atomic_ops.h], drm_cv_atomic_primitives="libatomic-ops")
169 fi
170
Chris Wilsonab3300c2009-10-03 22:56:04 +0100171 ])
172 if test "x$drm_cv_atomic_primitives" = xIntel; then
173 AC_DEFINE(HAVE_INTEL_ATOMIC_PRIMITIVES, 1,
174 [Enable if your compiler supports the Intel __sync_* atomic primitives])
175 fi
Chris Wilson901bacd2009-10-13 15:13:00 +0100176 if test "x$drm_cv_atomic_primitives" = "xlibatomic-ops"; then
177 AC_DEFINE(HAVE_LIB_ATOMIC_OPS, 1, [Enable if you have libatomic-ops-dev installed])
178 fi
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100179
180 if test "x$drm_cv_atomic_primitives" = "xnone"; then
181 if test "x$INTEL" != "xauto"; then
Chris Wilson901bacd2009-10-13 15:13:00 +0100182 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])
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100183 else
184 INTEL=no
185 fi
186 fi
Chris Wilson04495ee2009-10-02 04:39:22 +0100187fi
188
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100189AM_CONDITIONAL(HAVE_INTEL, [test "x$INTEL" != "xno"])
190
Kristian Høgsberga9968032009-11-17 09:23:52 -0500191AC_ARG_WITH([kernel-source],
192 [AS_HELP_STRING([--with-kernel-source],
193 [specify path to linux kernel source])],
194 [kernel_source="$with_kernel_source"])
195AC_SUBST(kernel_source)
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100196
Eric Anholtc4857422008-06-03 10:20:49 -0700197AC_SUBST(WARN_CFLAGS)
Eric Anholtd7cf2982007-07-19 04:59:59 -0700198AC_OUTPUT([
199 Makefile
Kristian Høgsberg4f57abf2009-11-17 11:14:54 -0500200 intel/Makefile
201 intel/libdrm_intel.pc
202 radeon/Makefile
203 radeon/libdrm_radeon.pc
204 nouveau/Makefile
205 nouveau/libdrm_nouveau.pc
Eric Anholtd7cf2982007-07-19 04:59:59 -0700206 tests/Makefile
Eric Anholt06ab2f62008-12-17 10:41:21 -0800207 tests/modeprint/Makefile
208 tests/modetest/Makefile
Kristian Høgsberg4f070d52009-11-20 19:42:59 -0500209 include/Makefile
210 include/drm/Makefile
Julien Cristau89cc98c2009-10-31 02:25:44 +0100211 libdrm.pc])
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500212
213echo ""
214echo "$PACKAGE_STRING will be compiled with:"
215echo ""
216echo " Intel api yes"
217echo " Radeon api $RADEON"
218echo " Nouveau API $NOUVEAU"
219echo ""