aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog12
-rw-r--r--gcc/ipa-param-manipulation.c12
-rw-r--r--gcc/ipa-param-manipulation.h3
-rw-r--r--gcc/ipa-prop.c37
-rw-r--r--gcc/ipa-prop.h1
-rw-r--r--gcc/testsuite/ChangeLog7
-rw-r--r--gcc/testsuite/gcc.dg/ipa/ipa-bit-cp-1.c16
-rw-r--r--gcc/testsuite/gcc.dg/ipa/ipa-bit-cp-2.c19
-rw-r--r--gcc/testsuite/gcc.dg/ipa/ipa-bit-cp.c16
-rw-r--r--gcc/tree-ssa-ccp.c24
10 files changed, 145 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index eb5264dc..198aa78 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,15 @@
+2019-12-17 Jan Hubicka <hubicka@ucw.cz>
+ Martin Jambor <mjambor@suse.cz>
+
+ * ipa-param-manipulation.h (get_original_index): Declare.
+ * ipa-param-manipulation.c (ipa_param_adjustments::get_original_index):
+ New member function.
+ * ipa-prop.c (ipcp_get_parm_bits): New function.
+ * ipa-prop.h (ipcp_get_parm_bits): Declare.
+ * tree-ssa-ccp.c: Include cgraph.h, alloc-pool.h, symbol-summary.h,
+ ipa-utils.h and ipa-prop.h
+ (get_default_value): Use ipcp_get_parm_bits.
+
2019-12-18 Jakub Jelinek <jakub@redhat.com>
PR lto/92972
diff --git a/gcc/ipa-param-manipulation.c b/gcc/ipa-param-manipulation.c
index 28ac2b8..b756b5d 100644
--- a/gcc/ipa-param-manipulation.c
+++ b/gcc/ipa-param-manipulation.c
@@ -324,6 +324,18 @@ ipa_param_adjustments::get_updated_indices (vec<int> *new_indices)
}
}
+/* Return the original index for the given new parameter index. Return a
+ negative number if not available. */
+
+int
+ipa_param_adjustments::get_original_index (int newidx)
+{
+ const ipa_adjusted_param *adj = &(*m_adj_params)[newidx];
+ if (adj->op != IPA_PARAM_OP_COPY)
+ return -1;
+ return adj->base_index;
+}
+
/* Return true if the first parameter (assuming there was one) survives the
transformation intact and remains the first one. */
diff --git a/gcc/ipa-param-manipulation.h b/gcc/ipa-param-manipulation.h
index 8e95545..5d7278e 100644
--- a/gcc/ipa-param-manipulation.h
+++ b/gcc/ipa-param-manipulation.h
@@ -258,6 +258,9 @@ public:
void get_surviving_params (vec<bool> *surviving_params);
/* Fill a vector with new indices of surviving original parameters. */
void get_updated_indices (vec<int> *new_indices);
+ /* Return the original index for the given new parameter index. Return a
+ negative number if not available. */
+ int get_original_index (int newidx);
void dump (FILE *f);
void debug ();
diff --git a/gcc/ipa-prop.c b/gcc/ipa-prop.c
index 1a59c35..c9c6a82 100644
--- a/gcc/ipa-prop.c
+++ b/gcc/ipa-prop.c
@@ -5480,6 +5480,43 @@ ipcp_modif_dom_walker::before_dom_children (basic_block bb)
return NULL;
}
+/* Return true if we have recorded VALUE and MASK about PARM.
+ Set VALUE and MASk accordingly. */
+
+bool
+ipcp_get_parm_bits (tree parm, tree *value, widest_int *mask)
+{
+ cgraph_node *cnode = cgraph_node::get (current_function_decl);
+ ipcp_transformation *ts = ipcp_get_transformation_summary (cnode);
+ if (!ts || vec_safe_length (ts->bits) == 0)
+ return false;
+
+ int i = 0;
+ for (tree p = DECL_ARGUMENTS (current_function_decl);
+ p != parm; p = DECL_CHAIN (p))
+ {
+ i++;
+ /* Ignore static chain. */
+ if (!p)
+ return false;
+ }
+
+ if (cnode->clone.param_adjustments)
+ {
+ i = cnode->clone.param_adjustments->get_original_index (i);
+ if (i < 0)
+ return false;
+ }
+
+ vec<ipa_bits *, va_gc> &bits = *ts->bits;
+ if (!bits[i])
+ return false;
+ *mask = bits[i]->mask;
+ *value = wide_int_to_tree (TREE_TYPE (parm), bits[i]->value);
+ return true;
+}
+
+
/* Update bits info of formal parameters as described in
ipcp_transformation. */
diff --git a/gcc/ipa-prop.h b/gcc/ipa-prop.h
index 1958e1e..4ce367a 100644
--- a/gcc/ipa-prop.h
+++ b/gcc/ipa-prop.h
@@ -1041,6 +1041,7 @@ ipa_agg_value_set ipa_agg_value_set_from_jfunc (ipa_node_params *,
void ipa_dump_param (FILE *, class ipa_node_params *info, int i);
void ipa_release_body_info (struct ipa_func_body_info *);
tree ipa_get_callee_param_type (struct cgraph_edge *e, int i);
+bool ipcp_get_parm_bits (tree, tree *, widest_int *);
/* From tree-sra.c: */
tree build_ref_for_offset (location_t, tree, poly_int64, bool, tree,
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 5dcd460..bcdfaa8 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,10 @@
+2019-12-17 Jan Hubicka <hubicka@ucw.cz>
+ Martin Jambor <mjambor@suse.cz>
+
+ * gcc.dg/ipa/ipa-bit-cp.c: New testcase.
+ * gcc.dg/ipa/ipa-bit-cp-1.c: New testcase.
+ * gcc.dg/ipa/ipa-bit-cp-2.c: New testcase.
+
2019-12-18 Andrew Stubbs <ams@codesourcery.com>
* gcc.dg/vect/pr65947-8.c: Change pass conditions for amdgcn.
diff --git a/gcc/testsuite/gcc.dg/ipa/ipa-bit-cp-1.c b/gcc/testsuite/gcc.dg/ipa/ipa-bit-cp-1.c
new file mode 100644
index 0000000..2ec5fe5
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/ipa/ipa-bit-cp-1.c
@@ -0,0 +1,16 @@
+/* { dg-do run } */
+/* { dg-options "-O2 -w -fipa-bit-cp" } */
+static int
+__attribute__ ((noinline))
+test (int a)
+{
+ if (!(a&2))
+ link_error ();
+}
+main()
+{
+ test (2);
+ test (3);
+ test (6);
+ return 0;
+}
diff --git a/gcc/testsuite/gcc.dg/ipa/ipa-bit-cp-2.c b/gcc/testsuite/gcc.dg/ipa/ipa-bit-cp-2.c
new file mode 100644
index 0000000..42ce346
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/ipa/ipa-bit-cp-2.c
@@ -0,0 +1,19 @@
+/* { dg-do run } */
+/* { dg-options "-O2 -w -fipa-bit-cp" } */
+static int
+__attribute__ ((noinline))
+test (int __attribute__((unused)) b, int a)
+{
+ if (!(a&2))
+ link_error ();
+}
+
+extern int __attribute__((const)) getint ();
+
+main()
+{
+ test (getint(), 2);
+ test (getint(), 3);
+ test (getint(), 6);
+ return 0;
+}
diff --git a/gcc/testsuite/gcc.dg/ipa/ipa-bit-cp.c b/gcc/testsuite/gcc.dg/ipa/ipa-bit-cp.c
new file mode 100644
index 0000000..2ec5fe5
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/ipa/ipa-bit-cp.c
@@ -0,0 +1,16 @@
+/* { dg-do run } */
+/* { dg-options "-O2 -w -fipa-bit-cp" } */
+static int
+__attribute__ ((noinline))
+test (int a)
+{
+ if (!(a&2))
+ link_error ();
+}
+main()
+{
+ test (2);
+ test (3);
+ test (6);
+ return 0;
+}
diff --git a/gcc/tree-ssa-ccp.c b/gcc/tree-ssa-ccp.c
index 72e15b1..a77c036 100644
--- a/gcc/tree-ssa-ccp.c
+++ b/gcc/tree-ssa-ccp.c
@@ -146,6 +146,11 @@ along with GCC; see the file COPYING3. If not see
#include "stringpool.h"
#include "attribs.h"
#include "tree-vector-builder.h"
+#include "cgraph.h"
+#include "alloc-pool.h"
+#include "symbol-summary.h"
+#include "ipa-utils.h"
+#include "ipa-prop.h"
/* Possible lattice values. */
typedef enum
@@ -292,11 +297,26 @@ get_default_value (tree var)
if (flag_tree_bit_ccp)
{
wide_int nonzero_bits = get_nonzero_bits (var);
- if (nonzero_bits != -1)
+ tree value;
+ widest_int mask;
+
+ if (SSA_NAME_VAR (var)
+ && TREE_CODE (SSA_NAME_VAR (var)) == PARM_DECL
+ && ipcp_get_parm_bits (SSA_NAME_VAR (var), &value, &mask))
+ {
+ val.lattice_val = CONSTANT;
+ val.value = value;
+ val.mask = mask;
+ if (nonzero_bits != -1)
+ val.mask &= extend_mask (nonzero_bits,
+ TYPE_SIGN (TREE_TYPE (var)));
+ }
+ else if (nonzero_bits != -1)
{
val.lattice_val = CONSTANT;
val.value = build_zero_cst (TREE_TYPE (var));
- val.mask = extend_mask (nonzero_bits, TYPE_SIGN (TREE_TYPE (var)));
+ val.mask = extend_mask (nonzero_bits,
+ TYPE_SIGN (TREE_TYPE (var)));
}
}
}