summaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorjiez <jiez@138bc75d-0d04-0410-961f-82ee72b054a4>2010-03-29 13:06:50 +0000
committerjiez <jiez@138bc75d-0d04-0410-961f-82ee72b054a4>2010-03-29 13:06:50 +0000
commit1da234593cd89d22d1661961d223518d07b73012 (patch)
tree7acf3831a61124e3544b15880d258d529a66dc1c /gcc
parent35a97371b55873aa3ab63f4b80578249723e4147 (diff)
downloadgcc-1da234593cd89d22d1661961d223518d07b73012.tar.gz
PR 43564
* toplev.c (process_options): Set optimization_default_node and optimization_current_node. * opts.c (decode_options): Don't set optimization_default_node and optimization_current_node. testsuite/ PR 43564 * gcc.dg/pr43564.c: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@157795 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog8
-rw-r--r--gcc/opts.c8
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/pr43564.c16
-rw-r--r--gcc/toplev.c4
5 files changed, 34 insertions, 7 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 9d2dd62ba5e..f3b75676a02 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,11 @@
+2010-03-29 Jie Zhang <jie@codesourcery.com>
+
+ PR 43564
+ * toplev.c (process_options): Set optimization_default_node
+ and optimization_current_node.
+ * opts.c (decode_options): Don't set optimization_default_node
+ and optimization_current_node.
+
2010-03-29 Ralf Corsépius <ralf.corsepius@rtems.org>
* config/rtems.h: Abandon -qrtems_debug.
diff --git a/gcc/opts.c b/gcc/opts.c
index df78027d1e9..139cd269416 100644
--- a/gcc/opts.c
+++ b/gcc/opts.c
@@ -1034,6 +1034,7 @@ decode_options (unsigned int argc, const char **argv)
flag_pic = flag_pie;
if (flag_pic && !flag_pie)
flag_shlib = 1;
+ first_time_p = false;
}
if (optimize == 0)
@@ -1112,13 +1113,6 @@ decode_options (unsigned int argc, const char **argv)
flag_ira_algorithm = IRA_ALGORITHM_PRIORITY;
}
- /* Save the current optimization options if this is the first call. */
- if (first_time_p)
- {
- optimization_default_node = build_optimization_node ();
- optimization_current_node = optimization_default_node;
- first_time_p = false;
- }
if (flag_conserve_stack)
{
if (!PARAM_SET_P (PARAM_LARGE_STACK_FRAME))
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index b23124664e3..e429f264eb1 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2010-03-29 Jie Zhang <jie@codesourcery.com>
+
+ PR 43564
+ * gcc.dg/pr43564.c: New test.
+
2010-03-29 Tobias Burnus <burnus@net-b.de>
PR fortran/43551
diff --git a/gcc/testsuite/gcc.dg/pr43564.c b/gcc/testsuite/gcc.dg/pr43564.c
new file mode 100644
index 00000000000..39e0f3ac3ed
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr43564.c
@@ -0,0 +1,16 @@
+/* { dg-options "-O0" } */
+/* { dg-do compile } */
+
+static inline __attribute__ ((__always_inline__))
+unsigned __clz (unsigned input)
+{
+ unsigned output;
+ __asm__ __volatile__ ("clz %0, %1":"=r" (output):"r" (input));
+}
+__attribute__ ((optimize ("O2")))
+void foo ()
+{
+ unsigned a;
+ unsigned b;
+ a = __clz (b);
+}
diff --git a/gcc/toplev.c b/gcc/toplev.c
index fb3c4b26063..a789383cfdc 100644
--- a/gcc/toplev.c
+++ b/gcc/toplev.c
@@ -2148,6 +2148,10 @@ process_options (void)
"for correctness");
flag_omit_frame_pointer = 0;
}
+
+ /* Save the current optimization options. */
+ optimization_default_node = build_optimization_node ();
+ optimization_current_node = optimization_default_node;
}
/* This function can be called multiple times to reinitialize the compiler