From 070ef6f4c41ea9bf4de0fde93860d7e65d8a186c Mon Sep 17 00:00:00 2001 From: Richard Kenner Date: Fri, 18 May 2001 20:53:55 +0000 Subject: [PATCH] genrecog.c (enum decision_type): Add DT_elt_zero-wide_safe. * genrecog.c (enum decision_type): Add DT_elt_zero-wide_safe. (add_to_sequence): Make that decision type. (maybe_both_true_2, nodes_identical_1, factor_tests): Use it. (write_switch, write_cond, debug_decision_2): Likewise. From-SVN: r42285 --- gcc/ChangeLog | 5 +++++ gcc/genrecog.c | 39 +++++++++++++++++++++++++-------------- 2 files changed, 30 insertions(+), 14 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 1e54bf5bfd6..5ad0e4514e1 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,10 @@ Fri May 18 07:26:34 2001 Richard Kenner + * genrecog.c (enum decision_type): Add DT_elt_zero-wide_safe. + (add_to_sequence): Make that decision type. + (maybe_both_true_2, nodes_identical_1, factor_tests): Use it. + (write_switch, write_cond, debug_decision_2): Likewise. + * dbxout.c (dbxout_type): Use host_integerp and fix typo in testing for INTEGER_TYPE. (dbxout_symbol, case TYPE_DECL): Don't generate tag for records of diff --git a/gcc/genrecog.c b/gcc/genrecog.c index ba4043797d2..228a5701eb4 100644 --- a/gcc/genrecog.c +++ b/gcc/genrecog.c @@ -84,12 +84,13 @@ struct decision_test struct decision_test *next; /* These types are roughly in the order in which we'd like to test them. */ - enum decision_type { - DT_mode, DT_code, DT_veclen, - DT_elt_zero_int, DT_elt_one_int, DT_elt_zero_wide, - DT_veclen_ge, DT_dup, DT_pred, DT_c_test, - DT_accept_op, DT_accept_insn - } type; + enum decision_type + { + DT_mode, DT_code, DT_veclen, + DT_elt_zero_int, DT_elt_one_int, DT_elt_zero_wide, DT_elt_zero_wide_safe, + DT_veclen_ge, DT_dup, DT_pred, DT_c_test, + DT_accept_op, DT_accept_insn + } type; union { @@ -956,10 +957,16 @@ add_to_sequence (pattern, last, position, insn_type, top) } else if (fmt[i] == 'w') { + /* If this value actually fits in an int, we can use a switch + statement here, so indicate that. */ + enum decision_type type + = ((int) XWINT (pattern, i) == XWINT (pattern, i)) + ? DT_elt_zero_wide_safe : DT_elt_zero_wide; + if (i != 0) abort (); - test = new_decision_test (DT_elt_zero_wide, &place); + test = new_decision_test (type, &place); test->u.intval = XWINT (pattern, i); } else if (fmt[i] == 'E') @@ -1055,6 +1062,7 @@ maybe_both_true_2 (d1, d2) case DT_elt_zero_int: case DT_elt_one_int: case DT_elt_zero_wide: + case DT_elt_zero_wide_safe: return d1->u.intval == d2->u.intval; default: @@ -1278,6 +1286,7 @@ nodes_identical_1 (d1, d2) case DT_elt_zero_int: case DT_elt_one_int: case DT_elt_zero_wide: + case DT_elt_zero_wide_safe: return d1->u.intval == d2->u.intval; case DT_accept_op: @@ -1488,7 +1497,7 @@ factor_tests (head) && type != DT_veclen && type != DT_elt_zero_int && type != DT_elt_one_int - && type != DT_elt_zero_wide) + && type != DT_elt_zero_wide_safe) continue; /* If we'd been performing more than one test, create a new node @@ -1858,12 +1867,8 @@ write_switch (start, depth) || type == DT_veclen || type == DT_elt_zero_int || type == DT_elt_one_int - || type == DT_elt_zero_wide) + || type == DT_elt_zero_wide_safe) { - /* The argument is casted to int. In case HOST_WIDE_INT is more exact, - we can't safely construct switch statement over it. */ - if (type == DT_elt_zero_wide && HOST_BITS_PER_WIDE_INT > sizeof (int) * CHAR_BIT) - return p; printf (" switch ("); switch (type) { @@ -1879,7 +1884,7 @@ write_switch (start, depth) case DT_elt_one_int: printf ("XINT (x%d, 1)", depth); break; - case DT_elt_zero_wide: + case DT_elt_zero_wide_safe: /* Convert result of XWINT to int for portability since some C compilers won't do it and some will. */ printf ("(int) XWINT (x%d, 0)", depth); @@ -1914,6 +1919,7 @@ write_switch (start, depth) case DT_elt_zero_int: case DT_elt_one_int: case DT_elt_zero_wide: + case DT_elt_zero_wide_safe: printf (HOST_WIDE_INT_PRINT_DEC, p->tests->u.intval); break; default: @@ -1970,6 +1976,7 @@ write_cond (p, depth, subroutine_type) break; case DT_elt_zero_wide: + case DT_elt_zero_wide_safe: printf ("XWINT (x%d, 0) == ", depth); printf (HOST_WIDE_INT_PRINT_DEC, p->u.intval); break; @@ -2742,6 +2749,10 @@ debug_decision_2 (test) fprintf (stderr, "elt0_w="); fprintf (stderr, HOST_WIDE_INT_PRINT_DEC, test->u.intval); break; + case DT_elt_zero_wide_safe: + fprintf (stderr, "elt0_ws="); + fprintf (stderr, HOST_WIDE_INT_PRINT_DEC, test->u.intval); + break; case DT_veclen_ge: fprintf (stderr, "veclen>=%d", test->u.veclen); break; -- 2.30.2