canonicalized as bitwise and of a mask. */
(if (GIMPLE /* PR70366: doing this in GENERIC breaks -Wconversion. */
&& final_int && inter_int && inside_int
- && final_prec == inside_prec
- && final_prec > inter_prec
+ && final_prec >= inside_prec
+ && inside_prec > inter_prec
&& inter_unsignedp)
(convert (bit_and @0 { wide_int_to_tree
(inside_type,
--- /dev/null
+// { dg-do compile }
+// { dg-require-effective-target vect_int }
+
+// PR tree-optimization/117776
+
+typedef __SIZE_TYPE__ size_t;
+typedef unsigned int u32;
+typedef unsigned char u8;
+
+static inline const bool
+is_even_bool(u8 n)
+{
+ return n % 2 == 0;
+}
+
+static inline const u32
+is_even_u32(u8 n)
+{
+ return n % 2 == 0;
+}
+
+static inline
+const u32 is_even_convert(u8 n)
+{
+ return is_even_bool(n);
+}
+
+u32 count_even_v1(u8 *data, size_t len)
+{
+ u32 ret = 0;
+ for (size_t i = 0; i < len; i++)
+ ret += is_even_bool(data[i]);
+ return ret;
+}
+
+u32 count_even_v2(u8 *data, size_t len)
+{
+ u32 ret = 0;
+ for (size_t i = 0; i < len; i++)
+ ret += is_even_u32(data[i]);
+ return ret;
+}
+
+u32 count_even_v3(u8 *data, size_t len)
+{
+ u32 ret = 0;
+ for (size_t i = 0; i < len; i++)
+ ret += is_even_convert(data[i]);
+ return ret;
+}
+
+u32 count_even_v4(u8 *data, size_t len)
+{
+ u32 ret = 0;
+ for (size_t i = 0; i < len; i++)
+ ret += static_cast<u32>(is_even_bool(data[i]));
+ return ret;
+}
+
+// All 4 count_even_v functions should be vectorized
+
+// { dg-final { scan-tree-dump-times "LOOP VECTORIZED" 4 "vect" } }
--- /dev/null
+/* { dg-do compile } */
+/* { dg-options "-O2 -fdump-tree-optimized" } */
+
+/* PR tree-optimization/117776 */
+
+/* These 2 functions should be optimized to just `return 1;`
+ as `(int)(unsigned smaller)medium` is the same as
+ `(int)medium&smaller_mask` where smaller_mask in this case is
+ either `1` (_Bool) or `0xff` (char). */
+int f(unsigned char a)
+{
+ _Bool odd = (a & 1) != 0;
+ int odd1 = (a & 1) != 0;
+ return odd == odd1;
+}
+int g(unsigned short a)
+{
+ unsigned char b = a;
+ int d = b;
+ unsigned short c = a&0xff;
+ int e = c;
+ return d == e;
+}
+
+/* { dg-final { scan-tree-dump-times "return 1" 2 "optimized" } } */