]> gcc.gnu.org Git - gcc.git/commitdiff
gccspec.c (lang_specific_driver): If compiling ObjC, add -shared-libgcc when necessary.
authorFranz Sirl <Franz.Sirl-kernel@lauterbach.com>
Sat, 16 Jun 2001 16:33:28 +0000 (16:33 +0000)
committerFranz Sirl <sirl@gcc.gnu.org>
Sat, 16 Jun 2001 16:33:28 +0000 (16:33 +0000)
        2001-06-16  Franz Sirl  <Franz.Sirl-kernel@lauterbach.com>

        * gccspec.c (lang_specific_driver): If compiling ObjC, add
        -shared-libgcc when necessary.
        * Makefile.in (gccspec.o): Compile with DRIVER_DEFINES.

From-SVN: r43421

gcc/ChangeLog
gcc/Makefile.in
gcc/gccspec.c

index cd9d69dd23c40d32ddac60bd145d4912834c2154..65f241aac1aabcb7c69d8aa8414d4f7bda731225 100644 (file)
@@ -1,3 +1,9 @@
+2001-06-16  Franz Sirl  <Franz.Sirl-kernel@lauterbach.com>
+
+       * gccspec.c (lang_specific_driver): If compiling ObjC, add
+       -shared-libgcc when necessary.
+       * Makefile.in (gccspec.o): Compile with DRIVER_DEFINES.
+
 2001-06-16  Daniel Berlin  <dan@cgsoftware.com>
 
        * bitmap.h: Add dump_bitmap, bitmap_zero, bitmap_union_of_diffs,
index 2b41f3ebd96b1806f02014d7bba2c652494e4a78..6606cabfa758b505cbc849182e770c5cbdf5aefe 100644 (file)
@@ -1263,6 +1263,12 @@ gcc.o: gcc.c $(CONFIG_H) $(SYSTEM_H) intl.h multilib.h \
   -c $(srcdir)/gcc.c)
 
 gccspec.o: gccspec.c $(CONFIG_H) $(SYSTEM_H) $(GCC_H)
+       (SHLIB_LINK='$(SHLIB_LINK)' \
+       SHLIB_MULTILIB='$(SHLIB_MULTILIB)'; \
+       $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
+  $(DRIVER_DEFINES) \
+  -c $(srcdir)/gccspec.c)
+
 cppspec.o: cppspec.c $(CONFIG_H) $(SYSTEM_H) $(GCC_H)
 
 tree-check.h: s-check ; @true
index fcad38d9b52bd2a2d9759bc05c9bfb96ad0d7e83..8576ee0d603de55780d7c56d71d89781a55b20b1 100644 (file)
@@ -1,5 +1,5 @@
 /* Specific flags and argument handling of the C front-end.
-   Copyright (C) 1999 Free Software Foundation, Inc.
+   Copyright (C) 1999, 2001 Free Software Foundation, Inc.
 
 This file is part of GNU CC.
 
@@ -29,7 +29,67 @@ lang_specific_driver (in_argc, in_argv, in_added_libraries)
      const char *const **in_argv ATTRIBUTE_UNUSED;
      int *in_added_libraries ATTRIBUTE_UNUSED;
 {
-  return;  /* Not used for C. */
+#ifdef ENABLE_SHARED_LIBGCC
+  int i;
+
+  /* The new argument list will be contained in this.  */
+  const char **arglist;
+
+  /* True if we should add -shared-libgcc to the command-line.  */
+  int shared_libgcc = 0;
+
+  /* The total number of arguments with the new stuff.  */
+  int argc;
+
+  /* The argument list.  */
+  const char *const *argv;
+
+  argc = *in_argc;
+  argv = *in_argv;
+
+  for (i = 1; i < argc; i++)
+    {
+      if (argv[i][0] == '-')
+       {
+         if (strcmp (argv[i], "-static-libgcc") == 0
+             || strcmp (argv[i], "-static") == 0)
+           return;
+       }
+      else
+       {
+         int len; 
+
+         /* If the filename ends in .m or .mi, we are compiling ObjC
+            and want to pass -shared-libgcc.  */
+         len = strlen (argv[i]);
+         if ((len > 2 && argv[i][len - 2] == '.' && argv[i][len - 1] == 'm')
+             ||  (len > 3 && argv[i][len - 3] == '.' && argv[i][len - 2] == 'm'
+                  && argv[i][len - 1] == 'i'))
+           shared_libgcc = 1;
+       }
+    }
+
+  if  (shared_libgcc)
+    {
+      /* Make sure to have room for the trailing NULL argument.  */
+      arglist = (const char **) xmalloc ((argc+2) * sizeof (char *));
+
+      i = 0;
+      do
+       {
+         arglist[i] = argv[i];
+         i++;
+       }
+      while (i < argc);
+
+      arglist[i++] = "-shared-libgcc";
+
+      arglist[i] = NULL;
+
+      *in_argc = i;
+      *in_argv = arglist;
+    }
+#endif
 }
 
 /* Called before linking.  Returns 0 on success and -1 on failure. */
This page took 0.086227 seconds and 5 git commands to generate.