diff options
author | Richard Henderson <rth@redhat.com> | 2005-01-03 11:41:06 -0800 |
---|---|---|
committer | Richard Henderson <rth@gcc.gnu.org> | 2005-01-03 11:41:06 -0800 |
commit | 3198b947a84e0db7870158c7cd357396a91c2b30 (patch) | |
tree | 547100dbbf027f84c7bcd3cfd648ba2e4d3f7248 /gcc | |
parent | cde7853d20991c6fd1d5294ebf7b5b524df25608 (diff) | |
download | gcc-3198b947a84e0db7870158c7cd357396a91c2b30.zip gcc-3198b947a84e0db7870158c7cd357396a91c2b30.tar.gz gcc-3198b947a84e0db7870158c7cd357396a91c2b30.tar.bz2 |
* simplify-rtx.c (simplify_binary_operation): Handle VEC_CONCAT.
From-SVN: r92861
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/simplify-rtx.c | 44 |
2 files changed, 42 insertions, 7 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index e3e4db4..ec06ccb 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2005-01-03 Richard Henderson <rth@redhat.com> + + * simplify-rtx.c (simplify_binary_operation): Handle VEC_CONCAT. + 2005-01-03 Uros Bizjak <uros@kss-loka.si> PR target/19236 @@ -5,7 +9,6 @@ to SFmode. (log1pdf2): Change mode of operands[0,1] to DFmode. - 2005-01-03 Eric Botcazou <ebotcazou@libertysurf.fr> * config/sparc/sparc.h (SPARC_RELAXED_ORDERING): Define to false. diff --git a/gcc/simplify-rtx.c b/gcc/simplify-rtx.c index 34b0ab8..6525e16 100644 --- a/gcc/simplify-rtx.c +++ b/gcc/simplify-rtx.c @@ -1190,14 +1190,11 @@ simplify_binary_operation (enum rtx_code code, enum machine_mode mode, && GET_CODE (trueop0) == CONST_VECTOR && GET_CODE (trueop1) == CONST_VECTOR) { - int elt_size = GET_MODE_SIZE (GET_MODE_INNER (mode)); - unsigned n_elts = (GET_MODE_SIZE (mode) / elt_size); + unsigned n_elts = GET_MODE_NUNITS (mode); enum machine_mode op0mode = GET_MODE (trueop0); - int op0_elt_size = GET_MODE_SIZE (GET_MODE_INNER (op0mode)); - unsigned op0_n_elts = (GET_MODE_SIZE (op0mode) / op0_elt_size); + unsigned op0_n_elts = GET_MODE_NUNITS (op0mode); enum machine_mode op1mode = GET_MODE (trueop1); - int op1_elt_size = GET_MODE_SIZE (GET_MODE_INNER (op1mode)); - unsigned op1_n_elts = (GET_MODE_SIZE (op1mode) / op1_elt_size); + unsigned op1_n_elts = GET_MODE_NUNITS (op1mode); rtvec v = rtvec_alloc (n_elts); unsigned int i; @@ -1216,6 +1213,41 @@ simplify_binary_operation (enum rtx_code code, enum machine_mode mode, return gen_rtx_CONST_VECTOR (mode, v); } + if (VECTOR_MODE_P (mode) + && code == VEC_CONCAT + && CONSTANT_P (trueop0) && CONSTANT_P (trueop1)) + { + unsigned n_elts = GET_MODE_NUNITS (mode); + rtvec v = rtvec_alloc (n_elts); + + gcc_assert (n_elts >= 2); + if (n_elts == 2) + { + gcc_assert (GET_CODE (trueop0) != CONST_VECTOR); + gcc_assert (GET_CODE (trueop1) != CONST_VECTOR); + + RTVEC_ELT (v, 0) = trueop0; + RTVEC_ELT (v, 1) = trueop1; + } + else + { + unsigned op0_n_elts = GET_MODE_NUNITS (GET_MODE (trueop0)); + unsigned op1_n_elts = GET_MODE_NUNITS (GET_MODE (trueop1)); + unsigned i; + + gcc_assert (GET_CODE (trueop0) == CONST_VECTOR); + gcc_assert (GET_CODE (trueop1) == CONST_VECTOR); + gcc_assert (op0_n_elts + op1_n_elts == n_elts); + + for (i = 0; i < op0_n_elts; ++i) + RTVEC_ELT (v, i) = XVECEXP (trueop0, 0, i); + for (i = 0; i < op1_n_elts; ++i) + RTVEC_ELT (v, op0_n_elts+i) = XVECEXP (trueop1, 0, i); + } + + return gen_rtx_CONST_VECTOR (mode, v); + } + if (GET_MODE_CLASS (mode) == MODE_FLOAT && GET_CODE (trueop0) == CONST_DOUBLE && GET_CODE (trueop1) == CONST_DOUBLE |