blob: 0c216cea5c0569315490595fc4ecc9046b428cbd [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
27AM_CONFIG_HEADER([libdrm/config.h])
28
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 )
166 ])
167 if test "x$drm_cv_atomic_primitives" = xIntel; then
168 AC_DEFINE(HAVE_INTEL_ATOMIC_PRIMITIVES, 1,
169 [Enable if your compiler supports the Intel __sync_* atomic primitives])
170 fi
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100171
172 if test "x$drm_cv_atomic_primitives" = "xnone"; then
173 if test "x$INTEL" != "xauto"; then
174 AC_MSG_ERROR([libdrm_intel depends upon atomic operations, which were not found for your compiler/cpu. Try compiling with -march=native, or disable support for Intel GPUs by passing --disable-intel to ./configue])
175 else
176 INTEL=no
177 fi
178 fi
Chris Wilson04495ee2009-10-02 04:39:22 +0100179fi
180
Chris Wilsonfc8f6be2009-10-12 23:58:47 +0100181AM_CONDITIONAL(HAVE_INTEL, [test "x$INTEL" != "xno"])
182
183
Eric Anholtc4857422008-06-03 10:20:49 -0700184AC_SUBST(WARN_CFLAGS)
Eric Anholtd7cf2982007-07-19 04:59:59 -0700185AC_OUTPUT([
186 Makefile
187 libdrm/Makefile
Eric Anholtc4857422008-06-03 10:20:49 -0700188 libdrm/intel/Makefile
Dave Airlie2fa2db12009-06-17 17:47:42 +1000189 libdrm/radeon/Makefile
190 libdrm/radeon/libdrm_radeon.pc
Ben Skeggs225e7e22009-01-30 11:25:35 +1000191 libdrm/nouveau/Makefile
192 libdrm/nouveau/libdrm_nouveau.pc
Eric Anholtd7cf2982007-07-19 04:59:59 -0700193 shared-core/Makefile
194 tests/Makefile
Eric Anholt06ab2f62008-12-17 10:41:21 -0800195 tests/modeprint/Makefile
196 tests/modetest/Makefile
Eric Anholta773ce12009-02-23 13:30:20 -0800197 libdrm.pc
198 libdrm_intel.pc])