Hi Richard,

Unfortunately this broke the Power builds:

/home/wschmidt/gcc/gcc-mainline-base/gcc/config/rs6000/constraints.md:211: 
reference to unknown predicate 'mem_operand_gpr'
/home/wschmidt/gcc/gcc-mainline-base/gcc/config/rs6000/constraints.md:242: 
reference to unknown predicate 'small_data_operand'

I haven't had time to investigate further -- will be in meetings most of
the morning.

Thanks,
Bill

On Fri, 2015-05-22 at 16:42 +0100, Richard Sandiford wrote:
> This patch adjusts the fix for PR target/65689 along the lines suggested
> in https://gcc.gnu.org/ml/gcc-patches/2015-04/msg01559.html.  The idea
> is to reuse the existing gensupport.c routine to work out the codes
> accepted by constraints.
> 
> I'd originally done this with an eye to using compute_test_codes for
> the problem that Andreas found on s390.  I don't think it's going to
> be useful for that after all, but it seems worth having for its on sake.
> 
> Bootstrapped & regression-tested on x86_64-linux-gnu.  OK to install?
> 
> Thanks,
> Richard
> 
> 
> gcc/
>       * gensupport.h (compute_test_codes): Declare.
>       * gensupport.c (compute_predicate_codes): Rename to...
>       (compute_test_codes): ...this.  Generalize error message.
>       (process_define_predicate): Update accordingly.
>       * genpreds.c (compute_maybe_allows): Delete.
>       (add_constraint): Use compute_test_codes to determine whether
>       something can accept a SUBREG, REG or MEM.
> 
> Index: gcc/gensupport.h
> ===================================================================
> --- gcc/gensupport.h  2015-05-21 08:45:32.663464769 +0100
> +++ gcc/gensupport.h  2015-05-21 08:45:33.015460604 +0100
> @@ -109,5 +109,6 @@ struct pattern_stats
>  };
>  
>  extern void get_pattern_stats (struct pattern_stats *ranges, rtvec vec);
> +extern void compute_test_codes (rtx, int, char *);
>  
>  #endif /* GCC_GENSUPPORT_H */
> Index: gcc/gensupport.c
> ===================================================================
> --- gcc/gensupport.c  2015-05-21 08:45:32.663464769 +0100
> +++ gcc/gensupport.c  2015-05-21 08:51:12.667438995 +0100
> @@ -204,8 +204,8 @@ #define TRISTATE_NOT(a)                           \
>     predicate expression EXP, writing the result to CODES.  LINENO is
>     the line number on which the directive containing EXP appeared.  */
>  
> -static void
> -compute_predicate_codes (rtx exp, int lineno, char codes[NUM_RTX_CODE])
> +void
> +compute_test_codes (rtx exp, int lineno, char *codes)
>  {
>    char op0_codes[NUM_RTX_CODE];
>    char op1_codes[NUM_RTX_CODE];
> @@ -215,29 +215,29 @@ compute_predicate_codes (rtx exp, int li
>    switch (GET_CODE (exp))
>      {
>      case AND:
> -      compute_predicate_codes (XEXP (exp, 0), lineno, op0_codes);
> -      compute_predicate_codes (XEXP (exp, 1), lineno, op1_codes);
> +      compute_test_codes (XEXP (exp, 0), lineno, op0_codes);
> +      compute_test_codes (XEXP (exp, 1), lineno, op1_codes);
>        for (i = 0; i < NUM_RTX_CODE; i++)
>       codes[i] = TRISTATE_AND (op0_codes[i], op1_codes[i]);
>        break;
>  
>      case IOR:
> -      compute_predicate_codes (XEXP (exp, 0), lineno, op0_codes);
> -      compute_predicate_codes (XEXP (exp, 1), lineno, op1_codes);
> +      compute_test_codes (XEXP (exp, 0), lineno, op0_codes);
> +      compute_test_codes (XEXP (exp, 1), lineno, op1_codes);
>        for (i = 0; i < NUM_RTX_CODE; i++)
>       codes[i] = TRISTATE_OR (op0_codes[i], op1_codes[i]);
>        break;
>      case NOT:
> -      compute_predicate_codes (XEXP (exp, 0), lineno, op0_codes);
> +      compute_test_codes (XEXP (exp, 0), lineno, op0_codes);
>        for (i = 0; i < NUM_RTX_CODE; i++)
>       codes[i] = TRISTATE_NOT (op0_codes[i]);
>        break;
>  
>      case IF_THEN_ELSE:
>        /* a ? b : c  accepts the same codes as (a & b) | (!a & c).  */
> -      compute_predicate_codes (XEXP (exp, 0), lineno, op0_codes);
> -      compute_predicate_codes (XEXP (exp, 1), lineno, op1_codes);
> -      compute_predicate_codes (XEXP (exp, 2), lineno, op2_codes);
> +      compute_test_codes (XEXP (exp, 0), lineno, op0_codes);
> +      compute_test_codes (XEXP (exp, 1), lineno, op1_codes);
> +      compute_test_codes (XEXP (exp, 2), lineno, op2_codes);
>        for (i = 0; i < NUM_RTX_CODE; i++)
>       codes[i] = TRISTATE_OR (TRISTATE_AND (op0_codes[i], op1_codes[i]),
>                               TRISTATE_AND (TRISTATE_NOT (op0_codes[i]),
> @@ -321,7 +321,7 @@ compute_predicate_codes (rtx exp, int li
>  
>      default:
>        error_with_line (lineno,
> -                    "'%s' cannot be used in a define_predicate expression",
> +                    "'%s' cannot be used in predicates or constraints",
>                      GET_RTX_NAME (GET_CODE (exp)));
>        memset (codes, I, NUM_RTX_CODE);
>        break;
> @@ -373,7 +373,7 @@ process_define_predicate (rtx desc, int
>    if (GET_CODE (desc) == DEFINE_SPECIAL_PREDICATE)
>      pred->special = true;
>  
> -  compute_predicate_codes (XEXP (desc, 1), lineno, codes);
> +  compute_test_codes (XEXP (desc, 1), lineno, codes);
>  
>    for (i = 0; i < NUM_RTX_CODE; i++)
>      if (codes[i] != N)
> Index: gcc/genpreds.c
> ===================================================================
> --- gcc/genpreds.c    2015-05-21 08:45:32.663464769 +0100
> +++ gcc/genpreds.c    2015-05-21 08:45:33.015460604 +0100
> @@ -716,34 +716,6 @@ mangle (const char *name)
>    return XOBFINISH (rtl_obstack, const char *);
>  }
>  
> -/* Return a bitmask, bit 1 if EXP maybe allows a REG/SUBREG, 2 if EXP
> -   maybe allows a MEM.  Bits should be clear only when we are sure it
> -   will not allow a REG/SUBREG or a MEM.  */
> -static int
> -compute_maybe_allows (rtx exp)
> -{
> -  switch (GET_CODE (exp))
> -    {
> -    case IF_THEN_ELSE:
> -      /* Conservative answer is like IOR, of the THEN and ELSE branches.  */
> -      return compute_maybe_allows (XEXP (exp, 1))
> -          | compute_maybe_allows (XEXP (exp, 2));
> -    case AND:
> -      return compute_maybe_allows (XEXP (exp, 0))
> -          & compute_maybe_allows (XEXP (exp, 1));
> -    case IOR:
> -      return compute_maybe_allows (XEXP (exp, 0))
> -          | compute_maybe_allows (XEXP (exp, 1));
> -    case MATCH_CODE:
> -      if (*XSTR (exp, 1) == '\0')
> -     return (strstr (XSTR (exp, 0), "reg") != NULL ? 1 : 0)
> -            | (strstr (XSTR (exp, 0), "mem") != NULL ? 2 : 0);
> -      /* FALLTHRU */
> -    default:
> -      return 3;
> -    }
> -}
> -
>  /* Add one constraint, of any sort, to the tables.  NAME is its name;
>     REGCLASS is the register class, if any; EXP is the expression to
>     test, if any;  IS_MEMORY and IS_ADDRESS indicate memory and address
> @@ -899,12 +871,17 @@ add_constraint (const char *name, const
>    c->is_extra = !(regclass || is_const_int || is_const_dbl);
>    c->is_memory = is_memory;
>    c->is_address = is_address;
> -  int maybe_allows = 3;
> +  c->maybe_allows_reg = true;
> +  c->maybe_allows_mem = true;
>    if (exp)
> -    maybe_allows = compute_maybe_allows (exp);
> -  c->maybe_allows_reg = (maybe_allows & 1) != 0;
> -  c->maybe_allows_mem = (maybe_allows & 2) != 0;
> -
> +    {
> +      char codes[NUM_RTX_CODE];
> +      compute_test_codes (exp, lineno, codes);
> +      if (!codes[REG] && !codes[SUBREG])
> +     c->maybe_allows_reg = false;
> +      if (!codes[MEM])
> +     c->maybe_allows_mem = false;
> +    }
>    c->next_this_letter = *slot;
>    *slot = c;
>  
> 


Reply via email to