summaryrefslogtreecommitdiff
path: root/gcc/config
diff options
context:
space:
mode:
authorgeoffk <geoffk@138bc75d-0d04-0410-961f-82ee72b054a4>2007-06-07 18:56:51 +0000
committergeoffk <geoffk@138bc75d-0d04-0410-961f-82ee72b054a4>2007-06-07 18:56:51 +0000
commita9540fb6339b347020db311b6b57b3640e7e0c43 (patch)
treed9d864d915cd9c3d17707352d3bf0704f21f26ab /gcc/config
parentb88bcfca21583d6fcac8cfd8d09f468dd20151e3 (diff)
downloadgcc-a9540fb6339b347020db311b6b57b3640e7e0c43.tar.gz
Index: ChangeLog
2007-06-06 Geoffrey Keating <geoffk@apple.com> Hui-May Chang <hm.chang@apple.com> * doc/invoke.texi (Darwin Options): Update documentation for -mmacosx-version-min. * config.gcc (*-*-darwin*): Set extra_gcc_objs. * config/darwin-driver.c: New file. * config/darwin.h (GCC_DRIVER_HOST_INITIALIZATION): New. * config/t-darwin (darwin-driver.o): New rule. * config/darwin-c.c (version_as_macro): Ignore low digit. Index: testsuite/ChangeLog 2007-06-06 Geoffrey Keating <geoffk@apple.com> * gcc.dg/darwin-minversion-3.c: New. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@125537 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/config')
-rw-r--r--gcc/config/darwin-c.c19
-rw-r--r--gcc/config/darwin-driver.c160
-rw-r--r--gcc/config/darwin.h6
-rw-r--r--gcc/config/t-darwin5
4 files changed, 176 insertions, 14 deletions
diff --git a/gcc/config/darwin-c.c b/gcc/config/darwin-c.c
index 0b3e8200f72..04f5ada00bc 100644
--- a/gcc/config/darwin-c.c
+++ b/gcc/config/darwin-c.c
@@ -567,8 +567,8 @@ find_subframework_header (cpp_reader *pfile, const char *header, cpp_dir **dirp)
/* Return the value of darwin_macosx_version_min suitable for the
__ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ macro,
- so '10.4.2' becomes 1042.
- Print a warning if the version number is not known. */
+ so '10.4.2' becomes 1040. The lowest digit is always zero.
+ Print a warning if the version number can't be understood. */
static const char *
version_as_macro (void)
{
@@ -579,18 +579,9 @@ version_as_macro (void)
if (! ISDIGIT (darwin_macosx_version_min[3]))
goto fail;
result[2] = darwin_macosx_version_min[3];
- if (darwin_macosx_version_min[4] != '\0')
- {
- if (darwin_macosx_version_min[4] != '.')
- goto fail;
- if (! ISDIGIT (darwin_macosx_version_min[5]))
- goto fail;
- if (darwin_macosx_version_min[6] != '\0')
- goto fail;
- result[3] = darwin_macosx_version_min[5];
- }
- else
- result[3] = '0';
+ if (darwin_macosx_version_min[4] != '\0'
+ && darwin_macosx_version_min[4] != '.')
+ goto fail;
return result;
diff --git a/gcc/config/darwin-driver.c b/gcc/config/darwin-driver.c
new file mode 100644
index 00000000000..2f7e09d14c6
--- /dev/null
+++ b/gcc/config/darwin-driver.c
@@ -0,0 +1,160 @@
+/* Additional functions for the GCC driver on Darwin native.
+ Copyright (C) 2006, 2007 Free Software Foundation, Inc.
+ Contributed by Apple Computer Inc.
+
+This file is part of GCC.
+
+GCC is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation; either version 2, or (at your option)
+any later version.
+
+GCC is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+GNU General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with GCC; see the file COPYING. If not, write to
+the Free Software Foundation, 51 Franklin Street, Fifth Floor,
+Boston, MA 02110-1301, USA. */
+
+#ifndef CROSS_DIRECTORY_STRUCTURE
+#include "config.h"
+#include "system.h"
+#include "coretypes.h"
+#include "tm.h"
+#include "gcc.h"
+#include <sys/sysctl.h>
+#include "xregex.h"
+
+#ifndef SWITCH_TAKES_ARG
+#define SWITCH_TAKES_ARG(CHAR) DEFAULT_SWITCH_TAKES_ARG(CHAR)
+#endif
+
+#ifndef WORD_SWITCH_TAKES_ARG
+#define WORD_SWITCH_TAKES_ARG(STR) DEFAULT_WORD_SWITCH_TAKES_ARG (STR)
+#endif
+
+/* When running on a Darwin system and using that system's headers and
+ libraries, default the -mmacosx-version-min flag to be the version
+ of the system on which the compiler is running. */
+
+void
+darwin_default_min_version (int * argc_p, char *** argv_p)
+{
+ const int argc = *argc_p;
+ char ** const argv = *argv_p;
+ int i;
+ char osversion[32];
+ size_t osversion_len = sizeof (osversion) - 1;
+ static int osversion_name[2] = { CTL_KERN, KERN_OSRELEASE };
+ char * version_p;
+ char * version_pend;
+ int major_vers;
+ char minor_vers[6];
+ static char new_flag[sizeof ("-mmacosx-version-min=10.0.0") + 6];
+
+ /* If the command-line is empty, just return. */
+ if (argc <= 1)
+ return;
+ /* Don't do this if the user has specified -b or -V at the start
+ of the command-line. */
+ if (argv[1][0] == '-'
+ && (argv[1][1] == 'V' ||
+ ((argv[1][1] == 'b') && (NULL != strchr(argv[1] + 2,'-')))))
+ return;
+
+ /* Don't do this if the user specified -mmacosx-version-min= or
+ -mno-macosx-version-min. */
+ for (i = 1; i < argc; i++)
+ if (argv[i][0] == '-')
+ {
+ const char * const p = argv[i];
+ if (strncmp (p, "-mno-macosx-version-min", 23) == 0
+ || strncmp (p, "-mmacosx-version-min", 20) == 0)
+ return;
+
+ /* It doesn't count if it's an argument to a different switch. */
+ if (p[0] == '-'
+ && ((SWITCH_TAKES_ARG (p[1]) > (p[2] != 0))
+ || WORD_SWITCH_TAKES_ARG (p + 1)))
+ i++;
+ }
+
+ /* Retrieve the deployment target from the environment and insert
+ it as a flag. */
+ {
+ const char * macosx_deployment_target;
+ macosx_deployment_target = getenv ("MACOSX_DEPLOYMENT_TARGET");
+ if (macosx_deployment_target
+ /* Apparently, an empty string for MACOSX_DEPLOYMENT_TARGET means
+ "use the default". Or, possibly "use 10.1". We choose
+ to ignore the environment variable, as if it was never set. */
+ && macosx_deployment_target[0])
+ {
+ ++*argc_p;
+ *argv_p = xmalloc (sizeof (char *) * *argc_p);
+ (*argv_p)[0] = argv[0];
+ (*argv_p)[1] = concat ("-mmacosx-version-min=",
+ macosx_deployment_target, NULL);
+ memcpy (*argv_p + 2, argv + 1, (argc - 1) * sizeof (char *));
+ return;
+ }
+ }
+
+ /* Determine the version of the running OS. If we can't, warn user,
+ and do nothing. */
+ if (sysctl (osversion_name, ARRAY_SIZE (osversion_name), osversion,
+ &osversion_len, NULL, 0) == -1)
+ {
+ fprintf (stderr, "sysctl for kern.osversion failed: %s\n",
+ xstrerror (errno));
+ return;
+ }
+
+ /* Try to parse the first two parts of the OS version number. Warn
+ user and return if it doesn't make sense. */
+ if (! ISDIGIT (osversion[0]))
+ goto parse_failed;
+ major_vers = osversion[0] - '0';
+ version_p = osversion + 1;
+ if (ISDIGIT (*version_p))
+ major_vers = major_vers * 10 + (*version_p++ - '0');
+ if (major_vers > 4 + 9)
+ goto parse_failed;
+ if (*version_p++ != '.')
+ goto parse_failed;
+ version_pend = strchr(version_p, '.');
+ if (!version_pend)
+ goto parse_failed;
+ if (! ISDIGIT (*version_p))
+ goto parse_failed;
+ strncpy(minor_vers, version_p, version_pend - version_p);
+ minor_vers[version_pend - version_p] = '\0';
+
+ /* The major kernel version number is 4 plus the second OS version
+ component. */
+ if (major_vers - 4 <= 4)
+ /* On 10.4 and earlier, the old linker is used which does not
+ support three-component system versions. */
+ sprintf (new_flag, "-mmacosx-version-min=10.%d", major_vers - 4);
+ else
+ sprintf (new_flag, "-mmacosx-version-min=10.%d.%s", major_vers - 4,
+ minor_vers);
+
+ /* Add the new flag. */
+ ++*argc_p;
+ *argv_p = xmalloc (sizeof (char *) * *argc_p);
+ (*argv_p)[0] = argv[0];
+ (*argv_p)[1] = new_flag;
+ memcpy (*argv_p + 2, argv + 1, (argc - 1) * sizeof (char *));
+ return;
+
+ parse_failed:
+ fprintf (stderr, "couldn't understand kern.osversion `%.*s'\n",
+ (int) osversion_len, osversion);
+ return;
+}
+
+#endif /* CROSS_DIRECTORY_STRUCTURE */
diff --git a/gcc/config/darwin.h b/gcc/config/darwin.h
index 9d7fdb1d7e6..e135191c3fc 100644
--- a/gcc/config/darwin.h
+++ b/gcc/config/darwin.h
@@ -986,4 +986,10 @@ extern int flag_apple_kext;
#define TARGET_HAS_TARGETCM 1
+#ifndef CROSS_DIRECTORY_STRUCTURE
+extern void darwin_default_min_version (int * argc, char *** argv);
+#define GCC_DRIVER_HOST_INITIALIZATION \
+ darwin_default_min_version (&argc, &argv)
+#endif /* CROSS_DIRECTORY_STRUCTURE */
+
#endif /* CONFIG_DARWIN_H */
diff --git a/gcc/config/t-darwin b/gcc/config/t-darwin
index 8ab072f53dd..2949e6baad0 100644
--- a/gcc/config/t-darwin
+++ b/gcc/config/t-darwin
@@ -12,6 +12,11 @@ darwin-c.o: $(srcdir)/config/darwin-c.c $(CONFIG_H) $(SYSTEM_H) coretypes.h \
gt-darwin.h : s-gtype ; @true
+darwin-driver.o: $(srcdir)/config/darwin-driver.c \
+ $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(GCC_H)
+ $(CC) -c $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
+ $(srcdir)/config/darwin-driver.c
+
# How to build crt3.o
EXTRA_MULTILIB_PARTS=crt3.o
# Pass -fno-tree-dominator-opts to work around bug 26840.