tm.texi (THREAD_MODEL_SPEC): Document it.
authorAlexandre Oliva <aoliva@redhat.com>
Sun, 13 May 2001 22:17:02 +0000 (22:17 +0000)
committerAlexandre Oliva <aoliva@gcc.gnu.org>
Sun, 13 May 2001 22:17:02 +0000 (22:17 +0000)
* tm.texi (THREAD_MODEL_SPEC): Document it.
* gcc.c (main): Use it.
* config/rs6000/aix43.h (THREAD_MODEL_SPEC): Define it.
* config/rs6000/aix51.h (THREAD_MODEL_SPEC): Likewise.

From-SVN: r42048

gcc/ChangeLog
gcc/config/rs6000/aix43.h
gcc/config/rs6000/aix51.h
gcc/gcc.c
gcc/tm.texi

index 6a7e6bc615e842b1691364ea3797049772fe66ec..22f729ffa1ebc3625fbf4ed59bd80dfa1a4b7097 100644 (file)
@@ -1,3 +1,10 @@
+2001-05-13  Alexandre Oliva  <aoliva@redhat.com>
+
+       * tm.texi (THREAD_MODEL_SPEC): Document it.
+       * gcc.c (main): Use it.
+       * config/rs6000/aix43.h (THREAD_MODEL_SPEC): Define it.
+       * config/rs6000/aix51.h (THREAD_MODEL_SPEC): Likewise.
+
 2001-05-13  Franz Sirl  <Franz.Sirl-kernel@lauterbach.com>
 
        * rtl.h (SYMBOL_REF_WEAK): New macro.
index 3f08e771fe27e6890f71dd71eb70795534e28236..78700eaa209cc55a0ac424425d5f70194f5d2251 100644 (file)
@@ -199,6 +199,10 @@ do {                                                                       \
        %{pthread:%{pg:gcrt0_r%O%s}%{!pg:%{p:mcrt0_r%O%s}%{!p:crt0_r%O%s}}}\
        %{!pthread:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}}}}"
 
+/* Since there are separate multilibs for pthreads, determine the
+   thread model based on the command-line arguments.  */
+#define THREAD_MODEL_SPEC "%{pthread:posix}%{!pthread:single}"
+
 /* AIX 4.3 typedefs ptrdiff_t as "long" while earlier releases used "int".  */
 
 #undef PTRDIFF_TYPE
index 5875956b7b748f690dc7d3ab194a828e2fbe86a4..a72d986cd1e232ec17d1f5ba1b483ca16d2324b1 100644 (file)
@@ -202,6 +202,10 @@ do {                                                                       \
        %{pthread:%{pg:gcrt0_r%O%s}%{!pg:%{p:mcrt0_r%O%s}%{!p:crt0_r%O%s}}}\
        %{!pthread:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}}}}"
 
+/* Since there are separate multilibs for pthreads, determine the
+   thread model based on the command-line arguments.  */
+#define THREAD_MODEL_SPEC "%{pthread:posix}%{!pthread:single}"
+
 /* AIX V5 typedefs ptrdiff_t as "long" while earlier releases used "int".  */
 
 #undef PTRDIFF_TYPE
index 34047e64422fa1adbfb4a2d635616e46218afb9d..1ba86eebc9d5a6e3b32da90ea8346cb2c767ae3c 100644 (file)
--- a/gcc/gcc.c
+++ b/gcc/gcc.c
@@ -5801,10 +5801,23 @@ main (argc, argv)
   if (verbose_flag)
     {
       int n;
+      const char *thrmod;
 
       notice ("Configured with: %s\n", configuration_arguments);
 
-      notice ("Thread model: %s\n", thread_model);
+#ifdef THREAD_MODEL_SPEC
+      /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
+        but there's no point in doing all this processing just to get
+        thread_model back.  */
+      obstack_init (&obstack);
+      do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
+      obstack_1grow (&obstack, '\0');
+      thrmod = obstack_finish (&obstack);
+#else
+      thrmod = thread_model;
+#endif
+
+      notice ("Thread model: %s\n", thrmod);
 
       /* compiler_version is truncated at the first space when initialized
         from version string, so truncate version_string at the first space
index 8f1c314d79056b53ec9a1568f2506d425259ed14..e777ea9a37b62af83d3f01ad3f33a9243b6b6b22 100644 (file)
@@ -248,6 +248,16 @@ the very end of the command given to the linker.
 
 Do not define this macro if it does not need to do anything.
 
+@findex THREAD_MODEL_SPEC
+@item THREAD_MODEL_SPEC
+GCC @code{-v} will print the thread model GCC was configured to use.
+However, this doesn't work on platforms that are multilibbed on thread
+models, such as AIX 4.3.  On such platforms, define
+@code{THREAD_MODEL_SPEC} such that it evaluates to a string without
+blanks that names one of the recognized thread models.  @code{%*}, the
+default value of this macro, will expand to the value of
+@code{thread_file} set in @file{config.gcc}.
+
 @findex EXTRA_SPECS
 @item EXTRA_SPECS
 Define this macro to provide additional specifications to put in the