OSDN Git Service

* config/i386/i386.c (ix86_option_override_internal): Enable flag_ree
authoruros <uros@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 21 Dec 2011 20:56:30 +0000 (20:56 +0000)
committeruros <uros@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 21 Dec 2011 20:56:30 +0000 (20:56 +0000)
also for 32bit targets.

testsuite/ChangeLog:

* gcc.dg/pr50038.c: Move to ...
* gcc.target/i386/pr50038.c: ... here.  Test on all targets.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@182605 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/config/i386/i386.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/i386/pr50038.c [moved from gcc/testsuite/gcc.dg/pr50038.c with 61% similarity]

index 31210c0..df31988 100644 (file)
@@ -1,3 +1,8 @@
+2011-12-21  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (ix86_option_override_internal): Enable flag_ree
+       also for 32bit targets.
+
 2011-12-21  Richard Henderson  <rth@redhat.com>
 
        PR target/51552
index c913c13..af07524 100644 (file)
@@ -3445,12 +3445,14 @@ ix86_option_override_internal (bool main_args_p)
 #define USE_X86_64_FRAME_POINTER 0
 #endif
 
+  /* Enable redundant extension instructions removal at -O2 and higher.  */
+  if (optimize >= 2 && !global_options_set.x_flag_ree)
+    flag_ree = 1;
+
   /* Set the default values for switches whose default depends on TARGET_64BIT
      in case they weren't overwritten by command line options.  */
   if (TARGET_64BIT)
     {
-      if (optimize > 1 && !global_options_set.x_flag_ree)
-       flag_ree = 1;
       if (optimize >= 1 && !global_options_set.x_flag_omit_frame_pointer)
        flag_omit_frame_pointer = !USE_X86_64_FRAME_POINTER;
       if (flag_asynchronous_unwind_tables == 2)
index 1592e13..492a0c3 100644 (file)
@@ -1,3 +1,8 @@
+2011-12-21  Uros Bizjak  <ubizjak@gmail.com>
+
+       * gcc.dg/pr50038.c: Move to ...
+       * gcc.target/i386/pr50038.c: ... here.  Test on all targets.
+
 2011-12-21  Jason Merrill  <jason@redhat.com>
 
        PR c++/51611
similarity index 61%
rename from gcc/testsuite/gcc.dg/pr50038.c
rename to gcc/testsuite/gcc.target/i386/pr50038.c
index 4d1c8f7..e111574 100644 (file)
@@ -1,8 +1,8 @@
 /* PR target/50038 */
-/* { dg-do compile { target x86_64-*-* } } */
 /* { dg-options "-O2" } */
 
-void pr50038(int len, unsigned char *in, unsigned char *out)
+void
+test (int len, unsigned char *in, unsigned char *out)
 {
   int i;
   unsigned char xr, xg;
@@ -11,7 +11,7 @@ void pr50038(int len, unsigned char *in, unsigned char *out)
     {
       xr = *in++;
       xg = *in++;
-      xy = (unsigned char) ((19595*xr + 38470*xg) >> 16);
+      xy = (unsigned char) ((19595 * xr + 38470 * xg) >> 16);
 
       *out++ = xy;
     }