OSDN Git Service

PR target/38056
authorsje <sje@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 13 Feb 2009 21:59:32 +0000 (21:59 +0000)
committersje <sje@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 13 Feb 2009 21:59:32 +0000 (21:59 +0000)
* config/ia64/ia64.c (ia64_function_ok_for_sibcall): Check
TARGET_CONST_GP.
* gcc.target/ia64/sibcall-opt-1.c: New test.
* gcc.target/ia64/sibcall-opt-2.c: New test.

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

gcc/ChangeLog
gcc/config/ia64/ia64.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/ia64/sibcall-opt-1.c [new file with mode: 0644]
gcc/testsuite/gcc.target/ia64/sibcall-opt-2.c [new file with mode: 0644]

index 5f8aac0..f4b29ef 100644 (file)
@@ -1,3 +1,9 @@
+2009-02-13  Steve Ellcey  <sje@cup.hp.com>
+
+       PR target/38056
+       * config/ia64/ia64.c (ia64_function_ok_for_sibcall): Check
+       TARGET_CONST_GP.
+
 2009-02-13  H.J. Lu  <hongjiu.lu@intel.com>
 
        PR target/39149
index 6c28801..495d943 100644 (file)
@@ -4365,8 +4365,9 @@ ia64_function_ok_for_sibcall (tree decl, tree exp ATTRIBUTE_UNUSED)
     return false;
 
   /* We must always return with our current GP.  This means we can
-     only sibcall to functions defined in the current module.  */
-  return decl && (*targetm.binds_local_p) (decl);
+     only sibcall to functions defined in the current module unless
+     TARGET_CONST_GP is set to true.  */
+  return (decl && (*targetm.binds_local_p) (decl)) || TARGET_CONST_GP;
 }
 \f
 
index a0f1650..ca7aece 100644 (file)
@@ -1,3 +1,9 @@
+2009-02-13  Steve Ellcey  <sje@cup.hp.com>
+
+       PR target/38056
+       * gcc.target/ia64/sibcall-opt-1.c: New test.
+       * gcc.target/ia64/sibcall-opt-2.c: New test.
+
 2009-02-13  Paul Thomas  <pault@gcc.gnu.org>
 
        PR fortran/36528
diff --git a/gcc/testsuite/gcc.target/ia64/sibcall-opt-1.c b/gcc/testsuite/gcc.target/ia64/sibcall-opt-1.c
new file mode 100644 (file)
index 0000000..6e8d1a2
--- /dev/null
@@ -0,0 +1,12 @@
+/* PR target/38056.  Do not do sibcall optimization across object file
+   boundery when -mconstant-gp is not used.  */
+/* { dg-do compile } */
+/* { dg-options "-O2" } */
+/* { dg-final { scan-assembler "br.call.*bar" } } */
+
+int bar(int x);
+
+int foo(int x)
+{
+  return (bar(x + 1));
+}
diff --git a/gcc/testsuite/gcc.target/ia64/sibcall-opt-2.c b/gcc/testsuite/gcc.target/ia64/sibcall-opt-2.c
new file mode 100644 (file)
index 0000000..d802b79
--- /dev/null
@@ -0,0 +1,12 @@
+/* PR target/38056.  Do sibcall optimization across object file
+   boundery when -mconstant-gp is used.  */
+/* { dg-do compile } */
+/* { dg-options "-O2 -mconstant-gp" } */
+/* { dg-final { scan-assembler-not "br.call.*bar" } } */
+
+int bar(int x);
+
+int foo(int x)
+{
+  return (bar(x + 1));
+}