blob: 2852962e64c0a54a6ec08534cd48caa17288e3ca [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 Anholtac71f082009-09-21 15:29:58 -070022AC_INIT([libdrm], 2.4.14, [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
Ben Skeggs7e5c5122009-02-11 14:18:03 +100046AC_ARG_ENABLE(nouveau-experimental-api,
47 AS_HELP_STRING([--enable-nouveau-experimental-api],
48 [Enable support for nouveau's experimental API (default: disabled)]),
49 [NOUVEAU=$enableval], [NOUVEAU=no])
Eric Anholtc4857422008-06-03 10:20:49 -070050
Dave Airlie2fa2db12009-06-17 17:47:42 +100051AC_ARG_ENABLE(radeon-experimental-api,
52 AS_HELP_STRING([--enable-radeon-experimental-api],
53 [Enable support for radeon's KMS API (default: disabled)]),
54 [RADEON=$enableval], [RADEON=no])
55
Eric Anholtc4857422008-06-03 10:20:49 -070056dnl ===========================================================================
57dnl check compiler flags
58AC_DEFUN([LIBDRM_CC_TRY_FLAG], [
59 AC_MSG_CHECKING([whether $CC supports $1])
60
61 libdrm_save_CFLAGS="$CFLAGS"
62 CFLAGS="$CFLAGS $1"
63
64 AC_COMPILE_IFELSE([ ], [libdrm_cc_flag=yes], [libdrm_cc_flag=no])
65 CFLAGS="$libdrm_save_CFLAGS"
66
67 if test "x$libdrm_cc_flag" = "xyes"; then
68 ifelse([$2], , :, [$2])
69 else
70 ifelse([$3], , :, [$3])
71 fi
72 AC_MSG_RESULT([$libdrm_cc_flag])
73])
74
Jesse Barnesbadc6342009-01-07 11:47:52 -080075dnl We use clock_gettime to check for timeouts in drmWaitVBlank
76
77AC_CHECK_FUNCS([clock_gettime], [CLOCK_LIB=],
78 [AC_CHECK_LIB([rt], [clock_gettime], [CLOCK_LIB=-lrt],
79 [AC_MSG_ERROR([Couldn't find clock_gettime])])])
80AC_SUBST([CLOCK_LIB])
81
Eric Anholtc4857422008-06-03 10:20:49 -070082dnl Use lots of warning flags with with gcc and compatible compilers
83
84dnl Note: if you change the following variable, the cache is automatically
85dnl skipped and all flags rechecked. So there's no need to do anything
86dnl else. If for any reason you need to force a recheck, just change
87dnl MAYBE_WARN in an ignorable way (like adding whitespace)
88
89MAYBE_WARN="-Wall -Wextra \
90-Wsign-compare -Werror-implicit-function-declaration \
91-Wpointer-arith -Wwrite-strings -Wstrict-prototypes \
92-Wmissing-prototypes -Wmissing-declarations -Wnested-externs \
93-Wpacked -Wswitch-enum -Wmissing-format-attribute \
94-Wstrict-aliasing=2 -Winit-self -Wunsafe-loop-optimizations \
95-Wdeclaration-after-statement -Wold-style-definition \
96-Wno-missing-field-initializers -Wno-unused-parameter \
97-Wno-attributes -Wno-long-long -Winline"
98
99# invalidate cached value if MAYBE_WARN has changed
100if test "x$libdrm_cv_warn_maybe" != "x$MAYBE_WARN"; then
101 unset libdrm_cv_warn_cflags
102fi
103AC_CACHE_CHECK([for supported warning flags], libdrm_cv_warn_cflags, [
104 echo
105 WARN_CFLAGS=""
106
107 # Some warning options are not supported by all versions of
108 # gcc, so test all desired options against the current
109 # compiler.
110 #
111 # Note that there are some order dependencies
112 # here. Specifically, an option that disables a warning will
113 # have no net effect if a later option then enables that
114 # warnings, (perhaps implicitly). So we put some grouped
115 # options (-Wall and -Wextra) up front and the -Wno options
116 # last.
117
118 for W in $MAYBE_WARN; do
119 LIBDRM_CC_TRY_FLAG([$W], [WARN_CFLAGS="$WARN_CFLAGS $W"])
120 done
121
122 libdrm_cv_warn_cflags=$WARN_CFLAGS
123 libdrm_cv_warn_maybe=$MAYBE_WARN
124
125 AC_MSG_CHECKING([which warning flags were supported])])
126WARN_CFLAGS="$libdrm_cv_warn_cflags"
127
Dave Airlie9101a022008-08-24 16:54:43 +1000128if test "x$UDEV" = xyes; then
129 AC_DEFINE(UDEV, 1, [Have UDEV support])
130fi
131
Pekka Paalanen4a0d19e2009-02-22 12:40:47 +0200132AM_CONDITIONAL(HAVE_NOUVEAU, [test "x$NOUVEAU" = xyes])
Ben Skeggs7e5c5122009-02-11 14:18:03 +1000133
Dave Airlie2fa2db12009-06-17 17:47:42 +1000134AM_CONDITIONAL(HAVE_RADEON, [test "x$RADEON" = xyes])
135
Kristian Høgsberg7a389aa2009-02-03 15:03:41 -0500136PKG_CHECK_MODULES(CAIRO, cairo, [HAVE_CAIRO=yes], [HAVE_CAIRO=no])
137if test "x$HAVE_CAIRO" = xyes; then
138 AC_DEFINE(HAVE_CAIRO, 1, [Have cairo support])
139fi
140AM_CONDITIONAL(HAVE_CAIRO, [test "x$HAVE_CAIRO" = xyes])
141
Kristian Høgsberge9d61162009-04-06 17:13:01 -0400142# For enumerating devices in test case
143PKG_CHECK_MODULES(LIBUDEV, libudev, [HAVE_LIBUDEV=yes], [HAVE_LIBUDEV=no])
144if test "x$HAVE_LIBUDEV" = xyes; then
145 AC_DEFINE(HAVE_LIBUDEV, 1, [Have libudev support])
146fi
147AM_CONDITIONAL(HAVE_LIBUDEV, [test "x$HAVE_LIBUDEV" = xyes])
148
Chris Wilson04495ee2009-10-02 04:39:22 +0100149# Check for atomic intrinsics
150AC_CACHE_CHECK([for native atomic primitives], drm_cv_atomic_primitives,
151[
152 drm_cv_atomic_primitives="none"
153
154 AC_TRY_LINK([
155int atomic_add(int i) { return __sync_fetch_and_add (&i, 1); }
156int atomic_cmpxchg(int i, int j, int k) { return __sync_val_compare_and_swap (&i, j, k); }
157], [],
158 drm_cv_atomic_primitives="Intel"
159 )
160])
161if test "x$drm_cv_atomic_primitives" = xIntel; then
162 AC_DEFINE(HAVE_INTEL_ATOMIC_PRIMITIVES, 1,
163 [Enable if your compiler supports the Intel __sync_* atomic primitives])
164fi
165
Eric Anholtc4857422008-06-03 10:20:49 -0700166AC_SUBST(WARN_CFLAGS)
Eric Anholtd7cf2982007-07-19 04:59:59 -0700167AC_OUTPUT([
168 Makefile
169 libdrm/Makefile
Eric Anholtc4857422008-06-03 10:20:49 -0700170 libdrm/intel/Makefile
Dave Airlie2fa2db12009-06-17 17:47:42 +1000171 libdrm/radeon/Makefile
172 libdrm/radeon/libdrm_radeon.pc
Ben Skeggs225e7e22009-01-30 11:25:35 +1000173 libdrm/nouveau/Makefile
174 libdrm/nouveau/libdrm_nouveau.pc
Eric Anholtd7cf2982007-07-19 04:59:59 -0700175 shared-core/Makefile
176 tests/Makefile
Eric Anholt06ab2f62008-12-17 10:41:21 -0800177 tests/modeprint/Makefile
178 tests/modetest/Makefile
Eric Anholta773ce12009-02-23 13:30:20 -0800179 libdrm.pc
180 libdrm_intel.pc])