|
| 1 | +; Ensure assertion is not hit when folding concat of two contiguous extract_subvector operations |
| 2 | +; from a source with a non-power-of-two vector length. |
| 3 | +; RUN: llc -mattr=+avx2 < %s |
| 4 | + |
| 5 | +source_filename = "foo.c" |
| 6 | +target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-i128:128-f80:128-n8:16:32:64-S128" |
| 7 | +target triple = "x86_64-unknown-linux-gnu" |
| 8 | + |
| 9 | +define void @foo(ptr noundef %pDst, ptr noundef %pSrc) { |
| 10 | +bb0: |
| 11 | + %sptr1 = getelementptr i8, ptr %pSrc, i64 32 |
| 12 | + %load598 = load <12 x float>, ptr %sptr1, align 1 |
| 13 | + br label %bb1 |
| 14 | +bb1: |
| 15 | + %sptr0 = getelementptr i8, ptr %pSrc, i64 16 |
| 16 | + %load617 = load <12 x float>, ptr %sptr0, align 1 |
| 17 | + %42 = fsub contract <12 x float> %load617, %load598 |
| 18 | + %43 = shufflevector <12 x float> %42, <12 x float> poison, <4 x i32> <i32 0, i32 1, i32 2, i32 3> |
| 19 | + %44 = fsub contract <12 x float> %load617, %load598 |
| 20 | + %45 = shufflevector <12 x float> %44, <12 x float> poison, <4 x i32> <i32 4, i32 5, i32 6, i32 7> |
| 21 | + %46 = fsub contract <12 x float> %load617, %load598 |
| 22 | + %47 = shufflevector <12 x float> %46, <12 x float> poison, <4 x i32> <i32 8, i32 9, i32 10, i32 11> |
| 23 | + %dptr0 = getelementptr i8, ptr %pDst, i64 16 |
| 24 | + %dptr1 = getelementptr i8, ptr %pDst, i64 32 |
| 25 | + %dptr2 = getelementptr i8, ptr %pDst, i64 48 |
| 26 | + store <4 x float> %43, ptr %dptr0, align 1 |
| 27 | + store <4 x float> %45, ptr %dptr1, align 1 |
| 28 | + store <4 x float> %47, ptr %dptr2, align 1 |
| 29 | + ret void |
| 30 | +} |
0 commit comments