+++ /dev/null
-/* { dg-do compile } */
-/* { dg-additional-options "-O3 --param vect-partial-vector-usage=1" } */
-/* { dg-additional-options "-march=x86-64-v4" { target avx512f } } */
-
-typedef struct {
- long left, right, top, bottom;
-} MngBox;
-typedef struct {
- MngBox object_clip[6];
- char exists[256], frozen[];
-} MngReadInfo;
-MngReadInfo mng_info;
-
-long ReadMNGImage_i;
-
-void ReadMNGImage(int ReadMNGImage_i)
-{
- for (; ReadMNGImage_i < 256; ReadMNGImage_i++)
- if (mng_info.exists[ReadMNGImage_i] && mng_info.frozen[ReadMNGImage_i])
- mng_info.object_clip[ReadMNGImage_i].left =
- mng_info.object_clip[ReadMNGImage_i].right =
- mng_info.object_clip[ReadMNGImage_i].top =
- mng_info.object_clip[ReadMNGImage_i].bottom = 0;
-}
LOOP_VINFO_CAN_USE_PARTIAL_VECTORS_P (loop_vinfo) = false;
}
}
- else if (loop_vinfo
- && LOOP_VINFO_CAN_USE_PARTIAL_VECTORS_P (loop_vinfo)
- && code == BIT_AND_EXPR
- && VECTOR_BOOLEAN_TYPE_P (vectype)
- /* We cannot always record a mask since that will disable
- len-based partial vectors, but there should be already
- one mask producer stmt which should require loop
- masking. */
- && !masks->is_empty ())
- vect_record_loop_mask (loop_vinfo, masks, vec_num, vectype, NULL);
/* Put types on constant and invariant SLP children. */
if (!vect_maybe_update_slp_op_vectype (slp_op0, vectype)