blob: d3dc15420b4629a10faffc5cabec5cb153da0085 [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)
Dave Airliefdb33d52009-12-21 15:03:31 +100022AC_INIT([libdrm], 2.4.17, [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
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +010046AC_ARG_ENABLE(libkms,
Jakob Bornecrantzd6059c32010-01-05 20:58:37 +010047 AS_HELP_STRING([--enable-libkms],
48 [Enable KMS mm abstraction library (default: disabled)]),
49 [LIBKMS=$enableval], [LIBKMS=no])
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +010050
Chris Wilsonab3300c2009-10-03 22:56:04 +010051AC_ARG_ENABLE(intel,
52 AS_HELP_STRING([--disable-intel],
Chris Wilsonfc8f6be2009-10-12 23:58:47 +010053 [Enable support for intel's KMS API (default: auto)]),
54 [INTEL=$enableval], [INTEL=auto])
Chris Wilsonab3300c2009-10-03 22:56:04 +010055
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +010056AC_ARG_ENABLE(vmwgfx-experimental-api,
57 AS_HELP_STRING([--enable-vmwgfx-experimental-api],
58 [Install vmwgfx's experimental kernel API header (default: disabled)]),
59 [VMWGFX=$enableval], [VMWGFX=no])
60
Ben Skeggs7e5c5122009-02-11 14:18:03 +100061AC_ARG_ENABLE(nouveau-experimental-api,
62 AS_HELP_STRING([--enable-nouveau-experimental-api],
63 [Enable support for nouveau's experimental API (default: disabled)]),
64 [NOUVEAU=$enableval], [NOUVEAU=no])
Eric Anholtc4857422008-06-03 10:20:49 -070065
Dave Airlie2fa2db12009-06-17 17:47:42 +100066AC_ARG_ENABLE(radeon-experimental-api,
67 AS_HELP_STRING([--enable-radeon-experimental-api],
68 [Enable support for radeon's KMS API (default: disabled)]),
69 [RADEON=$enableval], [RADEON=no])
70
Eric Anholtc4857422008-06-03 10:20:49 -070071dnl ===========================================================================
72dnl check compiler flags
73AC_DEFUN([LIBDRM_CC_TRY_FLAG], [
74 AC_MSG_CHECKING([whether $CC supports $1])
75
76 libdrm_save_CFLAGS="$CFLAGS"
77 CFLAGS="$CFLAGS $1"
78
79 AC_COMPILE_IFELSE([ ], [libdrm_cc_flag=yes], [libdrm_cc_flag=no])
80 CFLAGS="$libdrm_save_CFLAGS"
81
82 if test "x$libdrm_cc_flag" = "xyes"; then
83 ifelse([$2], , :, [$2])
84 else
85 ifelse([$3], , :, [$3])
86 fi
87 AC_MSG_RESULT([$libdrm_cc_flag])
88])
89
Jesse Barnesbadc6342009-01-07 11:47:52 -080090dnl We use clock_gettime to check for timeouts in drmWaitVBlank
91
92AC_CHECK_FUNCS([clock_gettime], [CLOCK_LIB=],
93 [AC_CHECK_LIB([rt], [clock_gettime], [CLOCK_LIB=-lrt],
94 [AC_MSG_ERROR([Couldn't find clock_gettime])])])
95AC_SUBST([CLOCK_LIB])
96
Eric Anholtc4857422008-06-03 10:20:49 -070097dnl Use lots of warning flags with with gcc and compatible compilers
98
99dnl Note: if you change the following variable, the cache is automatically
100dnl skipped and all flags rechecked. So there's no need to do anything
101dnl else. If for any reason you need to force a recheck, just change
102dnl MAYBE_WARN in an ignorable way (like adding whitespace)
103
104MAYBE_WARN="-Wall -Wextra \
105-Wsign-compare -Werror-implicit-function-declaration \
106-Wpointer-arith -Wwrite-strings -Wstrict-prototypes \
107-Wmissing-prototypes -Wmissing-declarations -Wnested-externs \
108-Wpacked -Wswitch-enum -Wmissing-format-attribute \
109-Wstrict-aliasing=2 -Winit-self -Wunsafe-loop-optimizations \
110-Wdeclaration-after-statement -Wold-style-definition \
111-Wno-missing-field-initializers -Wno-unused-parameter \
112-Wno-attributes -Wno-long-long -Winline"
113
114# invalidate cached value if MAYBE_WARN has changed
115if test "x$libdrm_cv_warn_maybe" != "x$MAYBE_WARN"; then
116 unset libdrm_cv_warn_cflags
117fi
118AC_CACHE_CHECK([for supported warning flags], libdrm_cv_warn_cflags, [
119 echo
120 WARN_CFLAGS=""
121
122 # Some warning options are not supported by all versions of
123 # gcc, so test all desired options against the current
124 # compiler.
125 #
126 # Note that there are some order dependencies
127 # here. Specifically, an option that disables a warning will
128 # have no net effect if a later option then enables that
129 # warnings, (perhaps implicitly). So we put some grouped
130 # options (-Wall and -Wextra) up front and the -Wno options
131 # last.
132
133 for W in $MAYBE_WARN; do
134 LIBDRM_CC_TRY_FLAG([$W], [WARN_CFLAGS="$WARN_CFLAGS $W"])
135 done
136
137 libdrm_cv_warn_cflags=$WARN_CFLAGS
138 libdrm_cv_warn_maybe=$MAYBE_WARN
139
140 AC_MSG_CHECKING([which warning flags were supported])])
141WARN_CFLAGS="$libdrm_cv_warn_cflags"
142
Dave Airlie9101a022008-08-24 16:54:43 +1000143if test "x$UDEV" = xyes; then
144 AC_DEFINE(UDEV, 1, [Have UDEV support])
145fi
146
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100147AM_CONDITIONAL(HAVE_LIBKMS, [test "x$LIBKMS" = xyes])
148
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100149AM_CONDITIONAL(HAVE_VMWGFX, [test "x$VMWGFX" = xyes])
Jakob Bornecrantz5dbc1b32010-01-05 20:55:02 +0100150if test "x$VMWGFX" = xyes; then
151 AC_DEFINE(HAVE_VMWGFX, 1, [Have vmwgfx kernel headers])
152fi
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100153
Pekka Paalanen4a0d19e2009-02-22 12:40:47 +0200154AM_CONDITIONAL(HAVE_NOUVEAU, [test "x$NOUVEAU" = xyes])
Ben Skeggs7e5c5122009-02-11 14:18:03 +1000155
Dave Airlie2fa2db12009-06-17 17:47:42 +1000156AM_CONDITIONAL(HAVE_RADEON, [test "x$RADEON" = xyes])
157
Kristian Høgsberg7a389aa2009-02-03 15:03:41 -0500158PKG_CHECK_MODULES(CAIRO, cairo, [HAVE_CAIRO=yes], [HAVE_CAIRO=no])
159if test "x$HAVE_CAIRO" = xyes; then
160 AC_DEFINE(HAVE_CAIRO, 1, [Have cairo support])
161fi
162AM_CONDITIONAL(HAVE_CAIRO, [test "x$HAVE_CAIRO" = xyes])
163
Kristian Høgsberge9d61162009-04-06 17:13:01 -0400164# For enumerating devices in test case
165PKG_CHECK_MODULES(LIBUDEV, libudev, [HAVE_LIBUDEV=yes], [HAVE_LIBUDEV=no])
166if test "x$HAVE_LIBUDEV" = xyes; then
167 AC_DEFINE(HAVE_LIBUDEV, 1, [Have libudev support])
168fi
169AM_CONDITIONAL(HAVE_LIBUDEV, [test "x$HAVE_LIBUDEV" = xyes])
170
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100171if test "x$INTEL" != "xno"; then
Chris Wilsonab3300c2009-10-03 22:56:04 +0100172 # Check for atomic intrinsics
173 AC_CACHE_CHECK([for native atomic primitives], drm_cv_atomic_primitives,
174 [
175 drm_cv_atomic_primitives="none"
176
177 AC_TRY_LINK([
178 int atomic_add(int i) { return __sync_fetch_and_add (&i, 1); }
179 int atomic_cmpxchg(int i, int j, int k) { return __sync_val_compare_and_swap (&i, j, k); }
180 ], [],
181 drm_cv_atomic_primitives="Intel"
182 )
Chris Wilson901bacd2009-10-13 15:13:00 +0100183
184 if test "x$drm_cv_atomic_primitives" = "xnone"; then
185 AC_CHECK_HEADER([atomic_ops.h], drm_cv_atomic_primitives="libatomic-ops")
186 fi
187
Chris Wilsonab3300c2009-10-03 22:56:04 +0100188 ])
189 if test "x$drm_cv_atomic_primitives" = xIntel; then
190 AC_DEFINE(HAVE_INTEL_ATOMIC_PRIMITIVES, 1,
191 [Enable if your compiler supports the Intel __sync_* atomic primitives])
192 fi
Chris Wilson901bacd2009-10-13 15:13:00 +0100193 if test "x$drm_cv_atomic_primitives" = "xlibatomic-ops"; then
194 AC_DEFINE(HAVE_LIB_ATOMIC_OPS, 1, [Enable if you have libatomic-ops-dev installed])
195 fi
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100196
197 if test "x$drm_cv_atomic_primitives" = "xnone"; then
198 if test "x$INTEL" != "xauto"; then
Chris Wilson901bacd2009-10-13 15:13:00 +0100199 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 +0100200 else
201 INTEL=no
202 fi
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500203 else
204 INTEL=yes
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100205 fi
Chris Wilson04495ee2009-10-02 04:39:22 +0100206fi
207
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100208AM_CONDITIONAL(HAVE_INTEL, [test "x$INTEL" != "xno"])
209
Kristian Høgsberga9968032009-11-17 09:23:52 -0500210AC_ARG_WITH([kernel-source],
211 [AS_HELP_STRING([--with-kernel-source],
212 [specify path to linux kernel source])],
213 [kernel_source="$with_kernel_source"])
214AC_SUBST(kernel_source)
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100215
Eric Anholtc4857422008-06-03 10:20:49 -0700216AC_SUBST(WARN_CFLAGS)
Eric Anholtd7cf2982007-07-19 04:59:59 -0700217AC_OUTPUT([
218 Makefile
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100219 libkms/Makefile
220 libkms/libkms.pc
Kristian Høgsberg4f57abf2009-11-17 11:14:54 -0500221 intel/Makefile
222 intel/libdrm_intel.pc
223 radeon/Makefile
224 radeon/libdrm_radeon.pc
225 nouveau/Makefile
226 nouveau/libdrm_nouveau.pc
Eric Anholtd7cf2982007-07-19 04:59:59 -0700227 tests/Makefile
Eric Anholt06ab2f62008-12-17 10:41:21 -0800228 tests/modeprint/Makefile
229 tests/modetest/Makefile
Jakob Bornecrantzd207a382010-01-08 15:34:44 +0000230 tests/kmstest/Makefile
Kristian Høgsberg4f070d52009-11-20 19:42:59 -0500231 include/Makefile
232 include/drm/Makefile
Julien Cristau89cc98c2009-10-31 02:25:44 +0100233 libdrm.pc])
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500234
235echo ""
236echo "$PACKAGE_STRING will be compiled with:"
237echo ""
Jakob Bornecrantz8c0571a2009-11-24 17:54:10 +0100238echo " libkms $LIBKMS"
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500239echo " Intel API $INTEL"
Jakob Bornecrantz6d3b8bb2010-01-05 19:53:10 +0100240echo " vmwgfx API $VMWGFX"
Kristian Høgsberg863e39b2009-11-23 12:38:40 -0500241echo " Radeon API $RADEON"
Kristian Høgsberg696fdb12009-11-23 11:41:15 -0500242echo " Nouveau API $NOUVEAU"
243echo ""