Ben Elliston | bce1b48 | 1998-09-30 02:13:15 +0000 | [diff] [blame] | 1 | # Process this file with autoconf to produce a configure script. |
Jakub Jelinek | 85ec4fe | 2018-01-03 11:03:58 +0100 | [diff] [blame] | 2 | # Copyright (C) 1994-2018 Free Software Foundation, Inc. |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 3 | # Originally contributed by Dave Love (d.love@dl.ac.uk). |
Ben Elliston | bce1b48 | 1998-09-30 02:13:15 +0000 | [diff] [blame] | 4 | # |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 5 | #This file is part of GCC. |
Ben Elliston | bce1b48 | 1998-09-30 02:13:15 +0000 | [diff] [blame] | 6 | # |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 7 | #GCC is free software; you can redistribute it and/or modify |
Ben Elliston | bce1b48 | 1998-09-30 02:13:15 +0000 | [diff] [blame] | 8 | #it under the terms of the GNU General Public License as published by |
Jakub Jelinek | 748086b | 2009-04-09 17:00:19 +0200 | [diff] [blame] | 9 | #the Free Software Foundation; either version 3, or (at your option) |
Ben Elliston | bce1b48 | 1998-09-30 02:13:15 +0000 | [diff] [blame] | 10 | #any later version. |
| 11 | # |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 12 | #GCC is distributed in the hope that it will be useful, |
Ben Elliston | bce1b48 | 1998-09-30 02:13:15 +0000 | [diff] [blame] | 13 | #but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 14 | #MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 15 | #GNU General Public License for more details. |
| 16 | # |
| 17 | #You should have received a copy of the GNU General Public License |
Jakub Jelinek | 748086b | 2009-04-09 17:00:19 +0200 | [diff] [blame] | 18 | #along with GCC; see the file COPYING3. If not see |
| 19 | #<http://www.gnu.org/licenses/>. |
Ben Elliston | bce1b48 | 1998-09-30 02:13:15 +0000 | [diff] [blame] | 20 | |
Ralf Wildenhues | df58e64 | 2009-08-24 19:08:51 +0000 | [diff] [blame] | 21 | AC_PREREQ(2.64) |
Andrew Pinski | 684c64b | 2004-06-11 20:11:12 +0000 | [diff] [blame] | 22 | AC_INIT(package-unused, version-unused,, libobjc) |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 23 | AC_CONFIG_SRCDIR([objc/objc.h]) |
Paolo Bonzini | 215c351 | 2005-02-28 13:26:36 +0000 | [diff] [blame] | 24 | GCC_TOPLEV_SUBDIRS |
Ben Elliston | bce1b48 | 1998-09-30 02:13:15 +0000 | [diff] [blame] | 25 | |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 26 | # We need the following definitions because AC_PROG_LIBTOOL relies on them |
Nathanael Nerode | 1fcfac9 | 2004-04-09 11:50:51 +0000 | [diff] [blame] | 27 | PACKAGE=libobjc |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 28 | # Version is pulled out to make it a bit easier to change using sed. |
Nicola Pero | c7907a5 | 2011-06-08 08:24:15 +0000 | [diff] [blame] | 29 | VERSION=4:0:0 |
Nathanael Nerode | 1fcfac9 | 2004-04-09 11:50:51 +0000 | [diff] [blame] | 30 | AC_SUBST(VERSION) |
| 31 | |
Alexandre Oliva | 6706f11 | 2002-05-08 04:38:00 +0000 | [diff] [blame] | 32 | # This works around the fact that libtool configuration may change LD |
| 33 | # for this particular configuration, but some shells, instead of |
| 34 | # keeping the changes in LD private, export them just because LD is |
| 35 | # exported. |
| 36 | ORIGINAL_LD_FOR_MULTILIBS=$LD |
| 37 | |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 38 | # ------- |
| 39 | # Options |
| 40 | # ------- |
| 41 | |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 42 | # We use these options to decide which functions to include. |
| 43 | AC_ARG_WITH(target-subdir, |
| 44 | [ --with-target-subdir=SUBDIR |
| 45 | configuring in a subdirectory]) |
| 46 | AC_ARG_WITH(cross-host, |
| 47 | [ --with-cross-host=HOST configuring with a cross compiler]) |
| 48 | |
| 49 | AC_MSG_CHECKING([for --enable-version-specific-runtime-libs]) |
| 50 | AC_ARG_ENABLE(version-specific-runtime-libs, |
| 51 | [ --enable-version-specific-runtime-libs Specify that runtime libraries should be installed in a compiler-specific directory ], |
| 52 | [case "$enableval" in |
| 53 | yes) version_specific_libs=yes ;; |
| 54 | no) version_specific_libs=no ;; |
| 55 | *) AC_MSG_ERROR([Unknown argument to enable/disable version-specific libs]);; |
| 56 | esac], |
| 57 | [version_specific_libs=no]) |
| 58 | AC_MSG_RESULT($version_specific_libs) |
| 59 | |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 60 | # ----------- |
| 61 | # Directories |
| 62 | # ----------- |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 63 | |
Geoffrey Keating | 5b043f0 | 2006-10-15 07:42:57 +0000 | [diff] [blame] | 64 | # Find the rest of the source tree framework. |
| 65 | AM_ENABLE_MULTILIB(, ..) |
DJ Delorie | aebb8c2 | 2002-06-25 23:53:45 -0400 | [diff] [blame] | 66 | |
Franz Sirl | b150efe | 2002-02-11 18:10:05 +0000 | [diff] [blame] | 67 | AC_CANONICAL_SYSTEM |
Nathanael Nerode | 1506eac | 2004-08-28 11:18:12 +0000 | [diff] [blame] | 68 | ACX_NONCANONICAL_TARGET |
Franz Sirl | b150efe | 2002-02-11 18:10:05 +0000 | [diff] [blame] | 69 | |
Nathanael Nerode | af0c82b | 2004-04-09 12:49:16 +0000 | [diff] [blame] | 70 | # Export source directory. |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 71 | # These need to be absolute paths, yet at the same time need to |
| 72 | # canonicalize only relative paths, because then amd will not unmount |
| 73 | # drives. Thus the use of PWDCMD: set it to 'pawd' or 'amq -w' if using amd. |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 74 | case $srcdir in |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 75 | [\\/$]* | ?:[\\/]*) glibcpp_srcdir=${srcdir} ;; |
| 76 | *) glibcpp_srcdir=`cd "$srcdir" && ${PWDCMD-pwd} || echo "$srcdir"` ;; |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 77 | esac |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 78 | AC_SUBST(glibcpp_srcdir) |
| 79 | |
Nathanael Nerode | 608e1e0 | 2004-04-09 13:08:31 +0000 | [diff] [blame] | 80 | # Calculate toolexeclibdir |
Nathanael Nerode | a42a57c | 2004-04-14 20:08:02 +0000 | [diff] [blame] | 81 | # Also toolexecdir, though it's only used in toolexeclibdir |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 82 | case ${version_specific_libs} in |
| 83 | yes) |
| 84 | # Need the gcc compiler version to know where to install libraries |
| 85 | # and header files if --enable-version-specific-runtime-libs option |
| 86 | # is selected. |
Nathanael Nerode | a42a57c | 2004-04-14 20:08:02 +0000 | [diff] [blame] | 87 | toolexecdir='$(libdir)/gcc/$(target_noncanonical)' |
Zack Weinberg | 2b37e3d | 2005-03-21 17:42:26 +0000 | [diff] [blame] | 88 | toolexeclibdir='$(toolexecdir)/$(gcc_version)$(MULTISUBDIR)' |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 89 | ;; |
| 90 | no) |
| 91 | if test -n "$with_cross_host" && |
| 92 | test x"$with_cross_host" != x"no"; then |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 93 | # Install a library built with a cross compiler in tooldir, not libdir. |
Nathanael Nerode | a42a57c | 2004-04-14 20:08:02 +0000 | [diff] [blame] | 94 | toolexecdir='$(exec_prefix)/$(target_noncanonical)' |
Nathanael Nerode | 608e1e0 | 2004-04-09 13:08:31 +0000 | [diff] [blame] | 95 | toolexeclibdir='$(toolexecdir)/lib' |
| 96 | else |
Nathanael Nerode | a42a57c | 2004-04-14 20:08:02 +0000 | [diff] [blame] | 97 | toolexecdir='$(libdir)/gcc-lib/$(target_noncanonical)' |
Nathanael Nerode | 608e1e0 | 2004-04-09 13:08:31 +0000 | [diff] [blame] | 98 | toolexeclibdir='$(libdir)' |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 99 | fi |
| 100 | multi_os_directory=`$CC -print-multi-os-directory` |
| 101 | case $multi_os_directory in |
| 102 | .) ;; # Avoid trailing /. |
Nathanael Nerode | 608e1e0 | 2004-04-09 13:08:31 +0000 | [diff] [blame] | 103 | *) toolexeclibdir=$toolexeclibdir/$multi_os_directory ;; |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 104 | esac |
| 105 | ;; |
| 106 | esac |
Nathanael Nerode | a42a57c | 2004-04-14 20:08:02 +0000 | [diff] [blame] | 107 | AC_SUBST(toolexecdir) |
Nathanael Nerode | 608e1e0 | 2004-04-09 13:08:31 +0000 | [diff] [blame] | 108 | AC_SUBST(toolexeclibdir) |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 109 | |
Andrew Pinski | ff65de7 | 2004-05-25 22:39:02 +0000 | [diff] [blame] | 110 | # Figure out if we want to name the include directory and the |
| 111 | # library name changes differently. |
Andrew Pinski | 7d34a5a | 2004-05-26 01:21:46 +0000 | [diff] [blame] | 112 | includedirname=include |
Andrew Pinski | 45d5f86 | 2007-06-02 01:35:59 +0000 | [diff] [blame] | 113 | libsuffix= |
Andrew Pinski | ff65de7 | 2004-05-25 22:39:02 +0000 | [diff] [blame] | 114 | case "${host}" in |
| 115 | *-darwin*) |
| 116 | # Darwin is the only target so far that needs a different include directory. |
Andrew Pinski | 7d34a5a | 2004-05-26 01:21:46 +0000 | [diff] [blame] | 117 | includedirname=include-gnu-runtime |
Andrew Pinski | af333b9 | 2007-06-03 20:38:37 +0000 | [diff] [blame] | 118 | libsuffix=-gnu |
Andrew Pinski | ff65de7 | 2004-05-25 22:39:02 +0000 | [diff] [blame] | 119 | ;; |
| 120 | esac |
Andrew Pinski | 7d34a5a | 2004-05-26 01:21:46 +0000 | [diff] [blame] | 121 | AC_SUBST(includedirname) |
H.J. Lu | 4620d81 | 2007-06-02 16:15:04 +0000 | [diff] [blame] | 122 | AC_SUBST(libsuffix) |
Andrew Pinski | ff65de7 | 2004-05-25 22:39:02 +0000 | [diff] [blame] | 123 | |
Andrew Pinski | 049bc40 | 2004-10-01 03:46:39 +0000 | [diff] [blame] | 124 | AC_CONFIG_HEADERS(config.h) |
| 125 | |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 126 | # -------- |
| 127 | # Programs |
| 128 | # -------- |
| 129 | |
| 130 | GCC_NO_EXECUTABLES |
Nathanael Nerode | db7f3c6 | 2004-04-15 17:05:36 +0000 | [diff] [blame] | 131 | |
| 132 | # We must force CC to /not/ be a precious variable; otherwise |
| 133 | # the wrong, non-multilib-adjusted value will be used in multilibs. |
| 134 | # As a side effect, we have to subst CFLAGS ourselves. |
| 135 | m4_rename([_AC_ARG_VAR_PRECIOUS],[real_PRECIOUS]) |
| 136 | m4_define([_AC_ARG_VAR_PRECIOUS],[]) |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 137 | AC_PROG_CC |
Ralf Wildenhues | 1b3b24c | 2009-07-30 19:41:13 +0000 | [diff] [blame] | 138 | m4_rename_force([real_PRECIOUS],[_AC_ARG_VAR_PRECIOUS]) |
Nathanael Nerode | db7f3c6 | 2004-04-15 17:05:36 +0000 | [diff] [blame] | 139 | |
Andrew Pinski | a5a813f | 2005-08-13 23:44:14 +0000 | [diff] [blame] | 140 | # extra LD Flags which are required for targets |
Dave Korn | 7de6ba7 | 2010-12-06 00:50:04 +0000 | [diff] [blame] | 141 | ACX_LT_HOST_FLAGS |
Andrew Pinski | a5a813f | 2005-08-13 23:44:14 +0000 | [diff] [blame] | 142 | case "${host}" in |
| 143 | *-darwin*) |
| 144 | # Darwin needs -single_module when linking libobjc |
Dave Korn | 7de6ba7 | 2010-12-06 00:50:04 +0000 | [diff] [blame] | 145 | extra_ldflags_libobjc='$(lt_host_flags) -Wl,-single_module' |
Andrew Pinski | a5a813f | 2005-08-13 23:44:14 +0000 | [diff] [blame] | 146 | ;; |
Dave Korn | 1922295 | 2010-03-23 05:05:35 +0000 | [diff] [blame] | 147 | *-cygwin*|*-mingw*) |
| 148 | # Tell libtool to build DLLs on Windows |
Dave Korn | 7de6ba7 | 2010-12-06 00:50:04 +0000 | [diff] [blame] | 149 | extra_ldflags_libobjc='$(lt_host_flags)' |
Dave Korn | 1922295 | 2010-03-23 05:05:35 +0000 | [diff] [blame] | 150 | ;; |
Andrew Pinski | a5a813f | 2005-08-13 23:44:14 +0000 | [diff] [blame] | 151 | esac |
| 152 | AC_SUBST(extra_ldflags_libobjc) |
| 153 | |
Igor Tsimbalist | 7b7168c | 2017-11-17 23:48:36 +0100 | [diff] [blame] | 154 | # Add CET specific flags if CET is enabled |
| 155 | GCC_CET_FLAGS(CET_FLAGS) |
| 156 | XCFLAGS="$XCFLAGS $CET_FLAGS" |
| 157 | |
Nathanael Nerode | db7f3c6 | 2004-04-15 17:05:36 +0000 | [diff] [blame] | 158 | AC_SUBST(CFLAGS) |
Igor Tsimbalist | 7b7168c | 2017-11-17 23:48:36 +0100 | [diff] [blame] | 159 | AC_SUBST(XCFLAGS) |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 160 | |
| 161 | AC_CHECK_TOOL(AS, as) |
| 162 | AC_CHECK_TOOL(AR, ar) |
| 163 | AC_CHECK_TOOL(RANLIB, ranlib, :) |
| 164 | AC_PROG_INSTALL |
Geoffrey Keating | 7c6b0e9 | 2001-02-09 07:14:35 +0000 | [diff] [blame] | 165 | |
Mike Stump | dd36515 | 2004-10-20 01:26:37 +0000 | [diff] [blame] | 166 | AM_MAINTAINER_MODE |
| 167 | |
Nathanael Nerode | 9c01f39 | 2004-04-09 11:43:02 +0000 | [diff] [blame] | 168 | # Enable Win32 DLL on MS Windows - FIXME |
| 169 | AC_LIBTOOL_WIN32_DLL |
Geoffrey Keating | 7c6b0e9 | 2001-02-09 07:14:35 +0000 | [diff] [blame] | 170 | |
Franz Sirl | b150efe | 2002-02-11 18:10:05 +0000 | [diff] [blame] | 171 | AC_PROG_LIBTOOL |
Ben Elliston | bce1b48 | 1998-09-30 02:13:15 +0000 | [diff] [blame] | 172 | |
Mike Stump | dd36515 | 2004-10-20 01:26:37 +0000 | [diff] [blame] | 173 | AM_PROG_CC_C_O |
| 174 | |
Franz Sirl | b150efe | 2002-02-11 18:10:05 +0000 | [diff] [blame] | 175 | AC_PROG_MAKE_SET |
Ben Elliston | bce1b48 | 1998-09-30 02:13:15 +0000 | [diff] [blame] | 176 | |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 177 | # ------- |
| 178 | # Headers |
| 179 | # ------- |
| 180 | |
Ben Elliston | bce1b48 | 1998-09-30 02:13:15 +0000 | [diff] [blame] | 181 | # Sanity check for the cross-compilation case: |
| 182 | AC_CHECK_HEADER(stdio.h,:, |
| 183 | [AC_MSG_ERROR([Can't find stdio.h. |
| 184 | You must have a usable C system for the target already installed, at least |
| 185 | including headers and, preferably, the library, before you can configure |
| 186 | the Objective C runtime system. If necessary, install gcc now with |
| 187 | \`LANGUAGES=c', then the target library, then build with \`LANGUAGES=objc'.])]) |
| 188 | |
| 189 | AC_HEADER_STDC |
| 190 | |
Ovidiu Predescu | d972a4c | 2000-08-15 07:38:04 +0000 | [diff] [blame] | 191 | AC_CHECK_HEADERS(sched.h) |
| 192 | |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 193 | # ----------- |
| 194 | # Miscellanea |
| 195 | # ----------- |
| 196 | |
Nicola Pero | fd31253 | 2010-09-14 10:23:37 +0000 | [diff] [blame] | 197 | # Check if we have thread-local storage |
| 198 | GCC_CHECK_TLS |
Ben Elliston | bce1b48 | 1998-09-30 02:13:15 +0000 | [diff] [blame] | 199 | |
Trevor Saunders | 539280a | 2015-05-02 04:11:07 +0000 | [diff] [blame] | 200 | gt_BITFIELD_TYPE_MATTERS |
| 201 | |
Matthias Klose | 114bf3f | 2016-11-30 00:12:45 +0000 | [diff] [blame] | 202 | # ----------- |
| 203 | # boehm-gc |
| 204 | # ----------- |
| 205 | |
| 206 | AC_ARG_ENABLE(objc-gc, |
| 207 | [AS_HELP_STRING([--enable-objc-gc], |
| 208 | [enable use of Boehm's garbage collector with the |
Jakub Jelinek | ac02e9a | 2016-11-30 12:42:04 +0100 | [diff] [blame] | 209 | GNU Objective-C runtime])],,enable_objc_gc=no) |
Matthias Klose | 114bf3f | 2016-11-30 00:12:45 +0000 | [diff] [blame] | 210 | AC_ARG_WITH([target-bdw-gc], |
| 211 | [AS_HELP_STRING([--with-target-bdw-gc=PATHLIST], |
| 212 | [specify prefix directory for installed bdw-gc package. |
| 213 | Equivalent to --with-target-bdw-gc-include=PATH/include |
| 214 | plus --with-target-bdw-gc-lib=PATH/lib])]) |
| 215 | AC_ARG_WITH([target-bdw-gc-include], |
| 216 | [AS_HELP_STRING([--with-target-bdw-gc-include=PATHLIST], |
| 217 | [specify directories for installed bdw-gc include files])]) |
| 218 | AC_ARG_WITH([target-bdw-gc-lib], |
| 219 | [AS_HELP_STRING([--with-target-bdw-gc-lib=PATHLIST], |
| 220 | [specify directories for installed bdw-gc library])]) |
| 221 | |
| 222 | case "$enable_objc_gc" in |
| 223 | no) |
| 224 | use_bdw_gc=no |
| 225 | ;; |
| 226 | *) |
| 227 | AC_MSG_CHECKING([for bdw garbage collector]) |
| 228 | if test "x$with_target_bdw_gc$with_target_bdw_gc_include$with_target_bdw_gc_lib" = x; then |
Matthias Klose | 825fba5 | 2016-12-01 12:31:49 +0000 | [diff] [blame] | 229 | dnl no bdw-gw options, assuming bdw-gc in default locations |
| 230 | BDW_GC_CFLAGS= |
| 231 | BDW_GC_LIBS="-lgc" |
Matthias Klose | 114bf3f | 2016-11-30 00:12:45 +0000 | [diff] [blame] | 232 | else |
| 233 | dnl bdw-gw options passed by configure flags |
| 234 | if test "x$with_target_bdw_gc_include" = x && test "x$with_target_bdw_gc_lib" != x; then |
| 235 | AC_MSG_ERROR([found --with-target-bdw-gc-lib but --with-target-bdw-gc-include missing]) |
| 236 | elif test "x$with_target_bdw_gc_include" != x && test "x$with_target_bdw_gc_lib" = x; then |
| 237 | AC_MSG_ERROR([found --with-target-bdw-gc-include but --with-target-bdw-gc-lib missing]) |
| 238 | else |
| 239 | AC_MSG_RESULT([using paths configured with --with-target-bdw-gc options]) |
| 240 | fi |
| 241 | mldir=`${CC-gcc} --print-multi-directory 2>/dev/null` |
| 242 | bdw_val= |
| 243 | if test "x$with_target_bdw_gc" != x; then |
| 244 | for i in `echo $with_target_bdw_gc | tr ',' ' '`; do |
| 245 | case "$i" in |
| 246 | *=*) sd=${i%%=*}; d=${i#*=} ;; |
| 247 | *) sd=.; d=$i ;; |
| 248 | esac |
| 249 | if test "$mldir" = "$sd"; then |
| 250 | bdw_val=$d |
| 251 | fi |
| 252 | done |
| 253 | if test "x$bdw_val" = x; then |
| 254 | AC_MSG_ERROR([no multilib path ($mldir) found in --with-target-bdw-gc]) |
| 255 | fi |
| 256 | bdw_inc_dir="$bdw_val/include" |
| 257 | bdw_lib_dir="$bdw_val/lib" |
| 258 | fi |
| 259 | bdw_val= |
| 260 | if test "x$with_target_bdw_gc_include" != x; then |
| 261 | for i in `echo $with_target_bdw_gc_include | tr ',' ' '`; do |
| 262 | case "$i" in |
| 263 | *=*) sd=${i%%=*}; d=${i#*=} ;; |
Matthias Klose | 8465132 | 2017-01-18 15:48:54 +0000 | [diff] [blame] | 264 | *) sd=.; d=$i; fallback=$i ;; |
Matthias Klose | 114bf3f | 2016-11-30 00:12:45 +0000 | [diff] [blame] | 265 | esac |
| 266 | if test "$mldir" = "$sd"; then |
| 267 | bdw_val=$d |
| 268 | fi |
| 269 | done |
Matthias Klose | 8465132 | 2017-01-18 15:48:54 +0000 | [diff] [blame] | 270 | if test "x$bdw_val" = x && test "x$bdw_inc_dir" = x && test "x$fallback" != x; then |
| 271 | bdw_inc_dir="$fallback" |
| 272 | elif test "x$bdw_val" = x; then |
Matthias Klose | 114bf3f | 2016-11-30 00:12:45 +0000 | [diff] [blame] | 273 | AC_MSG_ERROR([no multilib path ($mldir) found in --with-target-bdw-gc-include]) |
Matthias Klose | 8465132 | 2017-01-18 15:48:54 +0000 | [diff] [blame] | 274 | else |
| 275 | bdw_inc_dir="$bdw_val" |
Matthias Klose | 114bf3f | 2016-11-30 00:12:45 +0000 | [diff] [blame] | 276 | fi |
Matthias Klose | 114bf3f | 2016-11-30 00:12:45 +0000 | [diff] [blame] | 277 | fi |
| 278 | bdw_val= |
| 279 | if test "x$with_target_bdw_gc_lib" != x; then |
| 280 | for i in `echo $with_target_bdw_gc_lib | tr ',' ' '`; do |
| 281 | case "$i" in |
| 282 | *=*) sd=${i%%=*}; d=${i#*=} ;; |
| 283 | *) sd=.; d=$i ;; |
| 284 | esac |
| 285 | if test "$mldir" = "$sd"; then |
| 286 | bdw_val=$d |
| 287 | fi |
| 288 | done |
| 289 | if test "x$bdw_val" = x; then |
| 290 | AC_MSG_ERROR([no multilib path ($mldir) found in --with-target-bdw-gc-lib]) |
| 291 | fi |
| 292 | bdw_lib_dir="$bdw_val" |
| 293 | fi |
| 294 | if test "x$bdw_inc_dir" = x; then |
| 295 | AC_MSG_ERROR([no multilib path ($mldir) found in --with-target-bdw-gc-include]) |
| 296 | fi |
| 297 | if test "x$bdw_lib_dir" = x; then |
| 298 | AC_MSG_ERROR([no multilib path ($mldir) found in --with-target-bdw-gc-lib]) |
| 299 | fi |
| 300 | BDW_GC_CFLAGS="-I$bdw_inc_dir" |
Matthias Klose | 8465132 | 2017-01-18 15:48:54 +0000 | [diff] [blame] | 301 | if test -f $bdw_lib_dir/libgc.la; then |
| 302 | BDW_GC_LIBS="$bdw_lib_dir/libgc.la" |
| 303 | else |
| 304 | BDW_GC_LIBS="-L$bdw_lib_dir -lgc" |
| 305 | fi |
Matthias Klose | 114bf3f | 2016-11-30 00:12:45 +0000 | [diff] [blame] | 306 | AC_MSG_RESULT([found]) |
| 307 | fi |
| 308 | |
Matthias Klose | 8465132 | 2017-01-18 15:48:54 +0000 | [diff] [blame] | 309 | case "$BDW_GC_LIBS" in |
| 310 | *libgc.la) |
Matthias Klose | 114bf3f | 2016-11-30 00:12:45 +0000 | [diff] [blame] | 311 | use_bdw_gc=yes |
Matthias Klose | 8465132 | 2017-01-18 15:48:54 +0000 | [diff] [blame] | 312 | ;; |
| 313 | *) |
| 314 | AC_MSG_CHECKING([for system boehm-gc]) |
| 315 | save_CFLAGS=$CFLAGS |
| 316 | save_LIBS=$LIBS |
| 317 | CFLAGS="$CFLAGS $BDW_GC_CFLAGS" |
| 318 | LIBS="$LIBS $BDW_GC_LIBS" |
| 319 | dnl the link test is not good enough for ARM32 multilib detection, |
| 320 | dnl first check to link, then to run |
| 321 | AC_LINK_IFELSE( |
| 322 | [AC_LANG_PROGRAM([#include <gc/gc.h>],[GC_init()])], |
| 323 | [ |
| 324 | AC_RUN_IFELSE([AC_LANG_SOURCE([[ |
| 325 | #include <gc/gc.h> |
| 326 | int main() { |
| 327 | GC_init(); |
| 328 | return 0; |
| 329 | } |
| 330 | ]])], |
| 331 | [system_bdw_gc_found=yes], |
| 332 | [system_bdw_gc_found=no], |
| 333 | dnl assume no system boehm-gc for cross builds ... |
| 334 | [system_bdw_gc_found=no] |
| 335 | ) |
| 336 | ], |
| 337 | [system_bdw_gc_found=no]) |
| 338 | CFLAGS=$save_CFLAGS |
| 339 | LIBS=$save_LIBS |
| 340 | if test x$enable_objc_gc = xauto && test x$system_bdw_gc_found = xno; then |
| 341 | AC_MSG_WARN([system bdw-gc not found, not building libobjc_gc]) |
| 342 | use_bdw_gc=no |
| 343 | elif test x$enable_objc_gc = xyes && test x$system_bdw_gc_found = xno; then |
| 344 | AC_MSG_ERROR([system bdw-gc required but not found]) |
| 345 | else |
| 346 | use_bdw_gc=yes |
| 347 | AC_MSG_RESULT([found]) |
| 348 | fi |
| 349 | esac |
Matthias Klose | 114bf3f | 2016-11-30 00:12:45 +0000 | [diff] [blame] | 350 | esac |
| 351 | |
| 352 | if test "$use_bdw_gc" = no; then |
| 353 | OBJC_GCFLAGS='' |
| 354 | OBJC_BOEHM_GC='' |
| 355 | OBJC_BOEHM_GC_INCLUDES='' |
| 356 | OBJC_BOEHM_GC_LIBS='' |
| 357 | else |
| 358 | OBJC_GCFLAGS='-DOBJC_WITH_GC=1' |
| 359 | OBJC_BOEHM_GC='libobjc_gc$(libsuffix).la' |
| 360 | OBJC_BOEHM_GC_INCLUDES=$BDW_GC_CFLAGS |
| 361 | OBJC_BOEHM_GC_LIBS=$BDW_GC_LIBS |
| 362 | fi |
| 363 | AC_SUBST(OBJC_GCFLAGS) |
| 364 | AC_SUBST(OBJC_BOEHM_GC) |
| 365 | AC_SUBST(OBJC_BOEHM_GC_INCLUDES) |
| 366 | AC_SUBST(OBJC_BOEHM_GC_LIBS) |
| 367 | |
Jakub Jelinek | 3c36aa6 | 2017-01-17 10:38:48 +0100 | [diff] [blame] | 368 | # Determine what GCC version number to use in filesystem paths. |
| 369 | GCC_BASE_VER |
| 370 | |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 371 | # ------ |
| 372 | # Output |
| 373 | # ------ |
Ben Elliston | bce1b48 | 1998-09-30 02:13:15 +0000 | [diff] [blame] | 374 | |
H.J. Lu | 2c88848 | 2007-10-14 18:17:14 +0000 | [diff] [blame] | 375 | if test ${multilib} = yes; then |
| 376 | multilib_arg="--enable-multilib" |
| 377 | else |
| 378 | multilib_arg= |
| 379 | fi |
| 380 | |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 381 | AC_CONFIG_FILES([Makefile]) |
Nathanael Nerode | 252dde6 | 2004-04-09 12:40:59 +0000 | [diff] [blame] | 382 | AC_OUTPUT |