aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-vect-generic.c
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2020-09-03 12:44:40 +0200
committerRichard Biener <rguenther@suse.de>2020-09-03 12:47:59 +0200
commitb246f5272eb7242a9cefe5b4e7220be9d86ea512 (patch)
tree1f7a696836df0185d80f2ec8e97961107f414ea1 /gcc/tree-vect-generic.c
parent3cc3a373fe5ceb66839daca6861188d04c98362e (diff)
downloadgcc-b246f5272eb7242a9cefe5b4e7220be9d86ea512.zip
gcc-b246f5272eb7242a9cefe5b4e7220be9d86ea512.tar.gz
gcc-b246f5272eb7242a9cefe5b4e7220be9d86ea512.tar.bz2
Improve constant folding of vector lowering with vector bools
This improves the situation somewhat when vector lowering tries to access vector bools as seen in PR96814. 2020-09-03 Richard Biener <rguenther@suse.de> * tree-vect-generic.c (tree_vec_extract): Remove odd special-casing of boolean vectors. * fold-const.c (fold_ternary_loc): Handle boolean vector type BIT_FIELD_REFs.
Diffstat (limited to 'gcc/tree-vect-generic.c')
-rw-r--r--gcc/tree-vect-generic.c14
1 files changed, 1 insertions, 13 deletions
diff --git a/gcc/tree-vect-generic.c b/gcc/tree-vect-generic.c
index 6d5d651..d7bafa7 100644
--- a/gcc/tree-vect-generic.c
+++ b/gcc/tree-vect-generic.c
@@ -136,19 +136,7 @@ tree_vec_extract (gimple_stmt_iterator *gsi, tree type,
t = gimple_assign_rhs1 (def_stmt);
}
if (bitpos)
- {
- if (TREE_CODE (type) == BOOLEAN_TYPE)
- {
- tree itype
- = build_nonstandard_integer_type (tree_to_uhwi (bitsize), 0);
- tree field = gimplify_build3 (gsi, BIT_FIELD_REF, itype, t,
- bitsize, bitpos);
- return gimplify_build2 (gsi, NE_EXPR, type, field,
- build_zero_cst (itype));
- }
- else
- return gimplify_build3 (gsi, BIT_FIELD_REF, type, t, bitsize, bitpos);
- }
+ return gimplify_build3 (gsi, BIT_FIELD_REF, type, t, bitsize, bitpos);
else
return gimplify_build1 (gsi, VIEW_CONVERT_EXPR, type, t);
}