blob: be2fbbfb2a7c97ab0f46e08d0ba7af7e0e663054 [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
Jesse Barnes07646002009-04-10 15:34:24 -070021AC_PREREQ(2.57)
Keith Packardf57d7f42009-05-14 16:58:14 -070022AC_INIT([libdrm], 2.4.11, [dri-devel@lists.sourceforge.net], libdrm)
Adam Jackson07d23f92005-07-10 22:42:42 +000023AC_CONFIG_SRCDIR([Makefile.am])
24AM_INIT_AUTOMAKE([dist-bzip2])
25
26AM_CONFIG_HEADER([libdrm/config.h])
27
Adam Jackson56b07332006-06-27 21:04:50 +000028AC_DISABLE_STATIC
Adam Jackson07d23f92005-07-10 22:42:42 +000029AC_PROG_LIBTOOL
30AC_PROG_CC
31
32AC_HEADER_STDC
Thomas Hellstromeacedf42006-10-02 15:06:35 +020033AC_SYS_LARGEFILE
Adam Jackson07d23f92005-07-10 22:42:42 +000034
Eric Anholt6df7b072008-06-12 23:22:26 -070035PKG_CHECK_MODULES(PTHREADSTUBS, pthread-stubs)
36AC_SUBST(PTHREADSTUBS_CFLAGS)
37AC_SUBST(PTHREADSTUBS_LIBS)
38
Adam Jackson5a5478d2005-07-13 00:13:12 +000039pkgconfigdir=${libdir}/pkgconfig
Adam Jackson07d23f92005-07-10 22:42:42 +000040AC_SUBST(pkgconfigdir)
Dave Airlie9101a022008-08-24 16:54:43 +100041AC_ARG_ENABLE(udev, AS_HELP_STRING([--enable-udev],
42 [Enable support for using udev instead of mknod (default: disabled)]),
43 [UDEV=$enableval], [UDEV=no])
Adam Jackson07d23f92005-07-10 22:42:42 +000044
Ben Skeggs7e5c5122009-02-11 14:18:03 +100045AC_ARG_ENABLE(nouveau-experimental-api,
46 AS_HELP_STRING([--enable-nouveau-experimental-api],
47 [Enable support for nouveau's experimental API (default: disabled)]),
48 [NOUVEAU=$enableval], [NOUVEAU=no])
Eric Anholtc4857422008-06-03 10:20:49 -070049
Dave Airlie2fa2db12009-06-17 17:47:42 +100050AC_ARG_ENABLE(radeon-experimental-api,
51 AS_HELP_STRING([--enable-radeon-experimental-api],
52 [Enable support for radeon's KMS API (default: disabled)]),
53 [RADEON=$enableval], [RADEON=no])
54
Eric Anholtc4857422008-06-03 10:20:49 -070055dnl ===========================================================================
56dnl check compiler flags
57AC_DEFUN([LIBDRM_CC_TRY_FLAG], [
58 AC_MSG_CHECKING([whether $CC supports $1])
59
60 libdrm_save_CFLAGS="$CFLAGS"
61 CFLAGS="$CFLAGS $1"
62
63 AC_COMPILE_IFELSE([ ], [libdrm_cc_flag=yes], [libdrm_cc_flag=no])
64 CFLAGS="$libdrm_save_CFLAGS"
65
66 if test "x$libdrm_cc_flag" = "xyes"; then
67 ifelse([$2], , :, [$2])
68 else
69 ifelse([$3], , :, [$3])
70 fi
71 AC_MSG_RESULT([$libdrm_cc_flag])
72])
73
Jesse Barnesbadc6342009-01-07 11:47:52 -080074dnl We use clock_gettime to check for timeouts in drmWaitVBlank
75
76AC_CHECK_FUNCS([clock_gettime], [CLOCK_LIB=],
77 [AC_CHECK_LIB([rt], [clock_gettime], [CLOCK_LIB=-lrt],
78 [AC_MSG_ERROR([Couldn't find clock_gettime])])])
79AC_SUBST([CLOCK_LIB])
80
Eric Anholtc4857422008-06-03 10:20:49 -070081dnl Use lots of warning flags with with gcc and compatible compilers
82
83dnl Note: if you change the following variable, the cache is automatically
84dnl skipped and all flags rechecked. So there's no need to do anything
85dnl else. If for any reason you need to force a recheck, just change
86dnl MAYBE_WARN in an ignorable way (like adding whitespace)
87
88MAYBE_WARN="-Wall -Wextra \
89-Wsign-compare -Werror-implicit-function-declaration \
90-Wpointer-arith -Wwrite-strings -Wstrict-prototypes \
91-Wmissing-prototypes -Wmissing-declarations -Wnested-externs \
92-Wpacked -Wswitch-enum -Wmissing-format-attribute \
93-Wstrict-aliasing=2 -Winit-self -Wunsafe-loop-optimizations \
94-Wdeclaration-after-statement -Wold-style-definition \
95-Wno-missing-field-initializers -Wno-unused-parameter \
96-Wno-attributes -Wno-long-long -Winline"
97
98# invalidate cached value if MAYBE_WARN has changed
99if test "x$libdrm_cv_warn_maybe" != "x$MAYBE_WARN"; then
100 unset libdrm_cv_warn_cflags
101fi
102AC_CACHE_CHECK([for supported warning flags], libdrm_cv_warn_cflags, [
103 echo
104 WARN_CFLAGS=""
105
106 # Some warning options are not supported by all versions of
107 # gcc, so test all desired options against the current
108 # compiler.
109 #
110 # Note that there are some order dependencies
111 # here. Specifically, an option that disables a warning will
112 # have no net effect if a later option then enables that
113 # warnings, (perhaps implicitly). So we put some grouped
114 # options (-Wall and -Wextra) up front and the -Wno options
115 # last.
116
117 for W in $MAYBE_WARN; do
118 LIBDRM_CC_TRY_FLAG([$W], [WARN_CFLAGS="$WARN_CFLAGS $W"])
119 done
120
121 libdrm_cv_warn_cflags=$WARN_CFLAGS
122 libdrm_cv_warn_maybe=$MAYBE_WARN
123
124 AC_MSG_CHECKING([which warning flags were supported])])
125WARN_CFLAGS="$libdrm_cv_warn_cflags"
126
Dave Airlie9101a022008-08-24 16:54:43 +1000127if test "x$UDEV" = xyes; then
128 AC_DEFINE(UDEV, 1, [Have UDEV support])
129fi
130
Pekka Paalanen4a0d19e2009-02-22 12:40:47 +0200131AM_CONDITIONAL(HAVE_NOUVEAU, [test "x$NOUVEAU" = xyes])
Ben Skeggs7e5c5122009-02-11 14:18:03 +1000132
Dave Airlie2fa2db12009-06-17 17:47:42 +1000133AM_CONDITIONAL(HAVE_RADEON, [test "x$RADEON" = xyes])
134
Kristian Høgsberg7a389aa2009-02-03 15:03:41 -0500135PKG_CHECK_MODULES(CAIRO, cairo, [HAVE_CAIRO=yes], [HAVE_CAIRO=no])
136if test "x$HAVE_CAIRO" = xyes; then
137 AC_DEFINE(HAVE_CAIRO, 1, [Have cairo support])
138fi
139AM_CONDITIONAL(HAVE_CAIRO, [test "x$HAVE_CAIRO" = xyes])
140
Kristian Høgsberge9d61162009-04-06 17:13:01 -0400141# For enumerating devices in test case
142PKG_CHECK_MODULES(LIBUDEV, libudev, [HAVE_LIBUDEV=yes], [HAVE_LIBUDEV=no])
143if test "x$HAVE_LIBUDEV" = xyes; then
144 AC_DEFINE(HAVE_LIBUDEV, 1, [Have libudev support])
145fi
146AM_CONDITIONAL(HAVE_LIBUDEV, [test "x$HAVE_LIBUDEV" = xyes])
147
Kristian Høgsberg7a389aa2009-02-03 15:03:41 -0500148
Eric Anholtc4857422008-06-03 10:20:49 -0700149AC_SUBST(WARN_CFLAGS)
Eric Anholtd7cf2982007-07-19 04:59:59 -0700150AC_OUTPUT([
151 Makefile
152 libdrm/Makefile
Eric Anholtc4857422008-06-03 10:20:49 -0700153 libdrm/intel/Makefile
Dave Airlie2fa2db12009-06-17 17:47:42 +1000154 libdrm/radeon/Makefile
155 libdrm/radeon/libdrm_radeon.pc
Ben Skeggs225e7e22009-01-30 11:25:35 +1000156 libdrm/nouveau/Makefile
157 libdrm/nouveau/libdrm_nouveau.pc
Eric Anholtd7cf2982007-07-19 04:59:59 -0700158 shared-core/Makefile
159 tests/Makefile
Eric Anholt06ab2f62008-12-17 10:41:21 -0800160 tests/modeprint/Makefile
161 tests/modetest/Makefile
Eric Anholta773ce12009-02-23 13:30:20 -0800162 libdrm.pc
163 libdrm_intel.pc])