From c8ae061371b68ca6a1887f502f3ebebee28ff64f Mon Sep 17 00:00:00 2001 From: Sebastian Pop Date: Fri, 8 Jan 2010 16:07:18 +0000 Subject: [PATCH] Remove COMPONENT_REF limitation in SCoP detection. 2010-01-08 Sebastian Pop * graphite-scop-detection.c (exclude_component_ref): Removed. (is_simple_operand): Removed. (stmt_simple_for_scop_p): Remove use of is_simple_operand. From-SVN: r155739 --- gcc/ChangeLog.graphite | 6 +++ gcc/graphite-scop-detection.c | 71 +---------------------------------- 2 files changed, 7 insertions(+), 70 deletions(-) diff --git a/gcc/ChangeLog.graphite b/gcc/ChangeLog.graphite index b093edd8d52..cca61189e0f 100644 --- a/gcc/ChangeLog.graphite +++ b/gcc/ChangeLog.graphite @@ -1,3 +1,9 @@ +2010-01-08 Sebastian Pop + + * graphite-scop-detection.c (exclude_component_ref): Removed. + (is_simple_operand): Removed. + (stmt_simple_for_scop_p): Remove use of is_simple_operand. + 2010-01-07 Sebastian Pop PR middle-end/42221 diff --git a/gcc/graphite-scop-detection.c b/gcc/graphite-scop-detection.c index e30554f2799..8fd7b54ef07 100644 --- a/gcc/graphite-scop-detection.c +++ b/gcc/graphite-scop-detection.c @@ -297,41 +297,6 @@ stmt_has_simple_data_refs_p (loop_p outermost_loop, gimple stmt) return res; } -/* Return false if the TREE_CODE of the operand OP or any of its operands - is a COMPONENT_REF. */ - -static bool -exclude_component_ref (tree op) -{ - int i; - int len; - - if (!op) - return true; - - if (TREE_CODE (op) == COMPONENT_REF) - return false; - - len = TREE_OPERAND_LENGTH (op); - for (i = 0; i < len; ++i) - if (!exclude_component_ref (TREE_OPERAND (op, i))) - return false; - - return true; -} - -/* Return true if the operand OP used in STMT is simple in regards to - OUTERMOST_LOOP. */ - -static inline bool -is_simple_operand (tree op) -{ - /* It is not a simple operand when it is a declaration or a - structure. */ - return !DECL_P (op) && !AGGREGATE_TYPE_P (TREE_TYPE (op)) - && exclude_component_ref (op); -} - /* Return true only when STMT is simple enough for being handled by Graphite. This depends on SCOP_ENTRY, as the parameters are initialized relatively to this basic block, the linear functions @@ -395,42 +360,8 @@ stmt_simple_for_scop_p (basic_block scop_entry, loop_p outermost_loop, } case GIMPLE_ASSIGN: - { - enum tree_code code = gimple_assign_rhs_code (stmt); - - switch (get_gimple_rhs_class (code)) - { - case GIMPLE_UNARY_RHS: - case GIMPLE_SINGLE_RHS: - return (is_simple_operand (gimple_assign_lhs (stmt)) - && is_simple_operand (gimple_assign_rhs1 (stmt))); - - case GIMPLE_BINARY_RHS: - return (is_simple_operand (gimple_assign_lhs (stmt)) - && is_simple_operand (gimple_assign_rhs1 (stmt)) - && is_simple_operand (gimple_assign_rhs2 (stmt))); - - case GIMPLE_INVALID_RHS: - default: - gcc_unreachable (); - } - } - case GIMPLE_CALL: - { - size_t i; - size_t n = gimple_call_num_args (stmt); - tree lhs = gimple_call_lhs (stmt); - - if (lhs && !is_simple_operand (lhs)) - return false; - - for (i = 0; i < n; i++) - if (!is_simple_operand (gimple_call_arg (stmt, i))) - return false; - - return true; - } + return true; default: /* These nodes cut a new scope. */