Don't check/change generic/i686 tuning
authorH.J. Lu <hongjiu.lu@intel.com>
Thu, 26 Dec 2013 16:10:55 +0000 (16:10 +0000)
committerH.J. Lu <hjl@gcc.gnu.org>
Thu, 26 Dec 2013 16:10:55 +0000 (08:10 -0800)
gcc/

PR target/59588
* config/i386/i386.c (ix86_option_override_internal): Don't
check generic tuning.  Don't change i686 tuning.

gcc/testsuite/

PR target/59588
* gcc.target/i386/pr59588-1.c: New file.
* gcc.target/i386/pr59588-2.c: Likewise.

From-SVN: r206213

gcc/ChangeLog
gcc/config/i386/i386.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/i386/pr59588-1.c [new file with mode: 0644]
gcc/testsuite/gcc.target/i386/pr59588-2.c [new file with mode: 0644]

index 186fa1c..d8c272a 100644 (file)
@@ -1,5 +1,11 @@
 2013-12-26   H.J. Lu  <hongjiu.lu@intel.com>
 
+       PR target/59588
+       * config/i386/i386.c (ix86_option_override_internal): Don't
+       check generic tuning.  Don't change i686 tuning.
+
+2013-12-26   H.J. Lu  <hongjiu.lu@intel.com>
+
        PR target/59601
        * config/i386/i386.c (get_builtin_code_for_version): Map
        PROCESSOR_NEHALEM to "corei7".
index 71063bb..0cf0a9d 100644 (file)
@@ -3283,23 +3283,13 @@ ix86_option_override_internal (bool main_args_p,
   /* Need to check -mtune=generic first.  */
   if (opts->x_ix86_tune_string)
     {
-      if (!strcmp (opts->x_ix86_tune_string, "generic")
-         || !strcmp (opts->x_ix86_tune_string, "i686")
-         /* As special support for cross compilers we read -mtune=native
+      /* As special support for cross compilers we read -mtune=native
             as -mtune=generic.  With native compilers we won't see the
             -mtune=native, as it was changed by the driver.  */
-         || !strcmp (opts->x_ix86_tune_string, "native"))
+      if (!strcmp (opts->x_ix86_tune_string, "native"))
        {
          opts->x_ix86_tune_string = "generic";
        }
-      /* If this call is for setting the option attribute, allow the
-        generic that was previously set.  */
-      else if (!main_args_p
-              && !strcmp (opts->x_ix86_tune_string, "generic"))
-       ;
-      else if (!strncmp (opts->x_ix86_tune_string, "generic", 7))
-        error ("bad value (%s) for %stune=%s %s",
-              opts->x_ix86_tune_string, prefix, suffix, sw);
       else if (!strcmp (opts->x_ix86_tune_string, "x86-64"))
         warning (OPT_Wdeprecated, "%stune=x86-64%s is deprecated; use "
                  "%stune=k8%s or %stune=generic%s instead as appropriate",
@@ -3318,9 +3308,7 @@ ix86_option_override_internal (bool main_args_p,
 
       /* opts->x_ix86_tune_string is set to opts->x_ix86_arch_string
         or defaulted.  We need to use a sensible tune option.  */
-      if (!strcmp (opts->x_ix86_tune_string, "generic")
-         || !strcmp (opts->x_ix86_tune_string, "x86-64")
-         || !strcmp (opts->x_ix86_tune_string, "i686"))
+      if (!strcmp (opts->x_ix86_tune_string, "x86-64"))
        {
          opts->x_ix86_tune_string = "generic";
        }
@@ -3600,7 +3588,7 @@ ix86_option_override_internal (bool main_args_p,
   else if (!strcmp (opts->x_ix86_arch_string, "intel"))
     error ("intel CPU can be used only for %stune=%s %s",
           prefix, suffix, sw);
-  else if (!strncmp (opts->x_ix86_arch_string, "generic", 7) || i == pta_size)
+  else if (i == pta_size)
     error ("bad value (%s) for %sarch=%s %s",
           opts->x_ix86_arch_string, prefix, suffix, sw);
 
index 51be98c..c64a552 100644 (file)
@@ -1,3 +1,9 @@
+2013-12-26   H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR target/59588
+       * gcc.target/i386/pr59588-1.c: New file.
+       * gcc.target/i386/pr59588-2.c: Likewise.
+
 2013-12-26   Uros Bizjak  <ubizjak@gmail.com>
             H.J. Lu  <hongjiu.lu@intel.com>
 
diff --git a/gcc/testsuite/gcc.target/i386/pr59588-1.c b/gcc/testsuite/gcc.target/i386/pr59588-1.c
new file mode 100644 (file)
index 0000000..6f5fb72
--- /dev/null
@@ -0,0 +1,7 @@
+/* { dg-do preprocess } */
+/* { dg-require-effective-target ia32 } */
+/* { dg-options "-march=i686" } */
+
+#ifndef __tune_i686__
+#error "__tune_i686__ should be defined for this test"
+#endif
diff --git a/gcc/testsuite/gcc.target/i386/pr59588-2.c b/gcc/testsuite/gcc.target/i386/pr59588-2.c
new file mode 100644 (file)
index 0000000..7c427e3
--- /dev/null
@@ -0,0 +1,7 @@
+/* { dg-do preprocess } */
+/* { dg-require-effective-target ia32 } */
+/* { dg-options "-mtune=i686" } */
+
+#ifndef __tune_i686__
+#error "__tune_i686__ should be defined for this test"
+#endif