2019-08-31 03:26:06 +08:00
|
|
|
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
|
|
|
; RUN: llc < %s -mtriple=x86_64-pc-linux -mattr=avx512vl | FileCheck %s
|
|
|
|
|
|
|
|
; Test that we can unfold constant pool loads when we're using avx512's
|
|
|
|
; ability to fold a broadcast load into an operation.
|
|
|
|
|
|
|
|
define void @bcast_unfold_add_v16i32(i32* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_add_v16i32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpbroadcastd {{.*#+}} zmm0 = [2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB0_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpaddd 4096(%rdi,%rax), %zmm0, %zmm1
|
|
|
|
; CHECK-NEXT: vmovdqu64 %zmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB0_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i32, i32* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i32* %tmp3 to <16 x i32>*
|
|
|
|
%tmp5 = load <16 x i32>, <16 x i32>* %tmp4, align 4
|
|
|
|
%tmp6 = add nsw <16 x i32> %tmp5, <i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2>
|
|
|
|
%tmp7 = bitcast i32* %tmp3 to <16 x i32>*
|
|
|
|
store <16 x i32> %tmp6, <16 x i32>* %tmp7, align 4
|
|
|
|
%tmp8 = add i64 %tmp, 16
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_add_v8i32(i32* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_add_v8i32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpbroadcastd {{.*#+}} ymm0 = [2,2,2,2,2,2,2,2]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB1_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpaddd 4096(%rdi,%rax), %ymm0, %ymm1
|
|
|
|
; CHECK-NEXT: vmovdqu %ymm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB1_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i32, i32* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i32* %tmp3 to <8 x i32>*
|
|
|
|
%tmp5 = load <8 x i32>, <8 x i32>* %tmp4, align 4
|
|
|
|
%tmp6 = add nsw <8 x i32> %tmp5, <i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2>
|
|
|
|
%tmp7 = bitcast i32* %tmp3 to <8 x i32>*
|
|
|
|
store <8 x i32> %tmp6, <8 x i32>* %tmp7, align 4
|
|
|
|
%tmp8 = add i64 %tmp, 8
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_add_v4i32(i32* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_add_v4i32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpbroadcastd {{.*#+}} xmm0 = [2,2,2,2]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB2_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpaddd 4096(%rdi,%rax), %xmm0, %xmm1
|
|
|
|
; CHECK-NEXT: vmovdqu %xmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB2_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i32, i32* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i32* %tmp3 to <4 x i32>*
|
|
|
|
%tmp5 = load <4 x i32>, <4 x i32>* %tmp4, align 4
|
|
|
|
%tmp6 = add nsw <4 x i32> %tmp5, <i32 2, i32 2, i32 2, i32 2>
|
|
|
|
%tmp7 = bitcast i32* %tmp3 to <4 x i32>*
|
|
|
|
store <4 x i32> %tmp6, <4 x i32>* %tmp7, align 4
|
|
|
|
%tmp8 = add i64 %tmp, 4
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_add_v8i64(i64* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_add_v8i64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpbroadcastq {{.*#+}} zmm0 = [2,2,2,2,2,2,2,2]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB3_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpaddq 8192(%rdi,%rax), %zmm0, %zmm1
|
|
|
|
; CHECK-NEXT: vmovdqu64 %zmm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB3_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i64, i64* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i64* %tmp3 to <8 x i64>*
|
|
|
|
%tmp5 = load <8 x i64>, <8 x i64>* %tmp4, align 8
|
|
|
|
%tmp6 = add nsw <8 x i64> %tmp5, <i64 2, i64 2, i64 2, i64 2, i64 2, i64 2, i64 2, i64 2>
|
|
|
|
%tmp7 = bitcast i64* %tmp3 to <8 x i64>*
|
|
|
|
store <8 x i64> %tmp6, <8 x i64>* %tmp7, align 8
|
|
|
|
%tmp8 = add i64 %tmp, 8
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_add_v4i64(i64* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_add_v4i64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpbroadcastq {{.*#+}} ymm0 = [2,2,2,2]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB4_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpaddq 8192(%rdi,%rax), %ymm0, %ymm1
|
|
|
|
; CHECK-NEXT: vmovdqu %ymm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB4_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i64, i64* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i64* %tmp3 to <4 x i64>*
|
|
|
|
%tmp5 = load <4 x i64>, <4 x i64>* %tmp4, align 8
|
|
|
|
%tmp6 = add nsw <4 x i64> %tmp5, <i64 2, i64 2, i64 2, i64 2>
|
|
|
|
%tmp7 = bitcast i64* %tmp3 to <4 x i64>*
|
|
|
|
store <4 x i64> %tmp6, <4 x i64>* %tmp7, align 8
|
|
|
|
%tmp8 = add i64 %tmp, 4
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_add_v2i64(i64* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_add_v2i64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-08-31 03:42:48 +08:00
|
|
|
; CHECK-NEXT: vmovdqa {{.*#+}} xmm0 = [2,2]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB5_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-08-31 03:42:48 +08:00
|
|
|
; CHECK-NEXT: vpaddq 8192(%rdi,%rax), %xmm0, %xmm1
|
|
|
|
; CHECK-NEXT: vmovdqu %xmm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB5_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i64, i64* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i64* %tmp3 to <2 x i64>*
|
|
|
|
%tmp5 = load <2 x i64>, <2 x i64>* %tmp4, align 8
|
|
|
|
%tmp6 = add nsw <2 x i64> %tmp5, <i64 2, i64 2>
|
|
|
|
%tmp7 = bitcast i64* %tmp3 to <2 x i64>*
|
|
|
|
store <2 x i64> %tmp6, <2 x i64>* %tmp7, align 8
|
|
|
|
%tmp8 = add i64 %tmp, 2
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_mul_v16i32(i32* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_mul_v16i32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpbroadcastd {{.*#+}} zmm0 = [3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB6_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpmulld 4096(%rdi,%rax), %zmm0, %zmm1
|
|
|
|
; CHECK-NEXT: vmovdqu64 %zmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB6_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i32, i32* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i32* %tmp3 to <16 x i32>*
|
|
|
|
%tmp5 = load <16 x i32>, <16 x i32>* %tmp4, align 4
|
|
|
|
%tmp6 = mul nsw <16 x i32> %tmp5, <i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3>
|
|
|
|
%tmp7 = bitcast i32* %tmp3 to <16 x i32>*
|
|
|
|
store <16 x i32> %tmp6, <16 x i32>* %tmp7, align 4
|
|
|
|
%tmp8 = add i64 %tmp, 16
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_mul_v8i32(i32* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_mul_v8i32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpbroadcastd {{.*#+}} ymm0 = [3,3,3,3,3,3,3,3]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB7_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpmulld 4096(%rdi,%rax), %ymm0, %ymm1
|
|
|
|
; CHECK-NEXT: vmovdqu %ymm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB7_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i32, i32* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i32* %tmp3 to <8 x i32>*
|
|
|
|
%tmp5 = load <8 x i32>, <8 x i32>* %tmp4, align 4
|
|
|
|
%tmp6 = mul nsw <8 x i32> %tmp5, <i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3>
|
|
|
|
%tmp7 = bitcast i32* %tmp3 to <8 x i32>*
|
|
|
|
store <8 x i32> %tmp6, <8 x i32>* %tmp7, align 4
|
|
|
|
%tmp8 = add i64 %tmp, 8
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_mul_v4i32(i32* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_mul_v4i32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpbroadcastd {{.*#+}} xmm0 = [3,3,3,3]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB8_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpmulld 4096(%rdi,%rax), %xmm0, %xmm1
|
|
|
|
; CHECK-NEXT: vmovdqu %xmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB8_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i32, i32* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i32* %tmp3 to <4 x i32>*
|
|
|
|
%tmp5 = load <4 x i32>, <4 x i32>* %tmp4, align 4
|
|
|
|
%tmp6 = mul nsw <4 x i32> %tmp5, <i32 3, i32 3, i32 3, i32 3>
|
|
|
|
%tmp7 = bitcast i32* %tmp3 to <4 x i32>*
|
|
|
|
store <4 x i32> %tmp6, <4 x i32>* %tmp7, align 4
|
|
|
|
%tmp8 = add i64 %tmp, 4
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_mul_v8i64(i64* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_mul_v8i64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB9_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
|
|
|
; CHECK-NEXT: vmovdqu64 8192(%rdi,%rax), %zmm0
|
|
|
|
; CHECK-NEXT: vpaddq %zmm0, %zmm0, %zmm1
|
|
|
|
; CHECK-NEXT: vpaddq %zmm1, %zmm0, %zmm0
|
|
|
|
; CHECK-NEXT: vmovdqu64 %zmm0, 8192(%rdi,%rax)
|
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB9_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i64, i64* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i64* %tmp3 to <8 x i64>*
|
|
|
|
%tmp5 = load <8 x i64>, <8 x i64>* %tmp4, align 8
|
|
|
|
%tmp6 = mul nsw <8 x i64> %tmp5, <i64 3, i64 3, i64 3, i64 3, i64 3, i64 3, i64 3, i64 3>
|
|
|
|
%tmp7 = bitcast i64* %tmp3 to <8 x i64>*
|
|
|
|
store <8 x i64> %tmp6, <8 x i64>* %tmp7, align 8
|
|
|
|
%tmp8 = add i64 %tmp, 8
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_mul_v4i64(i64* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_mul_v4i64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB10_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
|
|
|
; CHECK-NEXT: vmovdqu 8192(%rdi,%rax), %ymm0
|
|
|
|
; CHECK-NEXT: vpaddq %ymm0, %ymm0, %ymm1
|
|
|
|
; CHECK-NEXT: vpaddq %ymm1, %ymm0, %ymm0
|
|
|
|
; CHECK-NEXT: vmovdqu %ymm0, 8192(%rdi,%rax)
|
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB10_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i64, i64* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i64* %tmp3 to <4 x i64>*
|
|
|
|
%tmp5 = load <4 x i64>, <4 x i64>* %tmp4, align 8
|
|
|
|
%tmp6 = mul nsw <4 x i64> %tmp5, <i64 3, i64 3, i64 3, i64 3>
|
|
|
|
%tmp7 = bitcast i64* %tmp3 to <4 x i64>*
|
|
|
|
store <4 x i64> %tmp6, <4 x i64>* %tmp7, align 8
|
|
|
|
%tmp8 = add i64 %tmp, 4
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_mul_v2i64(i64* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_mul_v2i64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB11_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
|
|
|
; CHECK-NEXT: vmovdqu 8192(%rdi,%rax), %xmm0
|
|
|
|
; CHECK-NEXT: vpaddq %xmm0, %xmm0, %xmm1
|
|
|
|
; CHECK-NEXT: vpaddq %xmm1, %xmm0, %xmm0
|
|
|
|
; CHECK-NEXT: vmovdqu %xmm0, 8192(%rdi,%rax)
|
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB11_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i64, i64* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i64* %tmp3 to <2 x i64>*
|
|
|
|
%tmp5 = load <2 x i64>, <2 x i64>* %tmp4, align 8
|
|
|
|
%tmp6 = mul nsw <2 x i64> %tmp5, <i64 3, i64 3>
|
|
|
|
%tmp7 = bitcast i64* %tmp3 to <2 x i64>*
|
|
|
|
store <2 x i64> %tmp6, <2 x i64>* %tmp7, align 8
|
|
|
|
%tmp8 = add i64 %tmp, 2
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_or_v16i32(i32* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_or_v16i32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpbroadcastd {{.*#+}} zmm0 = [3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB12_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpord 4096(%rdi,%rax), %zmm0, %zmm1
|
|
|
|
; CHECK-NEXT: vmovdqu64 %zmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB12_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i32, i32* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i32* %tmp3 to <16 x i32>*
|
|
|
|
%tmp5 = load <16 x i32>, <16 x i32>* %tmp4, align 4
|
|
|
|
%tmp6 = or <16 x i32> %tmp5, <i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3>
|
|
|
|
%tmp7 = bitcast i32* %tmp3 to <16 x i32>*
|
|
|
|
store <16 x i32> %tmp6, <16 x i32>* %tmp7, align 4
|
|
|
|
%tmp8 = add i64 %tmp, 16
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_or_v8i32(i32* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_or_v8i32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} ymm0 = [3,3,3,3,3,3,3,3]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB13_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vorps 4096(%rdi,%rax), %ymm0, %ymm1
|
|
|
|
; CHECK-NEXT: vmovups %ymm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB13_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i32, i32* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i32* %tmp3 to <8 x i32>*
|
|
|
|
%tmp5 = load <8 x i32>, <8 x i32>* %tmp4, align 4
|
|
|
|
%tmp6 = or <8 x i32> %tmp5, <i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3>
|
|
|
|
%tmp7 = bitcast i32* %tmp3 to <8 x i32>*
|
|
|
|
store <8 x i32> %tmp6, <8 x i32>* %tmp7, align 4
|
|
|
|
%tmp8 = add i64 %tmp, 8
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_or_v4i32(i32* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_or_v4i32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} xmm0 = [3,3,3,3]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB14_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vorps 4096(%rdi,%rax), %xmm0, %xmm1
|
|
|
|
; CHECK-NEXT: vmovups %xmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB14_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i32, i32* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i32* %tmp3 to <4 x i32>*
|
|
|
|
%tmp5 = load <4 x i32>, <4 x i32>* %tmp4, align 4
|
|
|
|
%tmp6 = or <4 x i32> %tmp5, <i32 3, i32 3, i32 3, i32 3>
|
|
|
|
%tmp7 = bitcast i32* %tmp3 to <4 x i32>*
|
|
|
|
store <4 x i32> %tmp6, <4 x i32>* %tmp7, align 4
|
|
|
|
%tmp8 = add i64 %tmp, 4
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_or_v8i64(i64* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_or_v8i64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpbroadcastq {{.*#+}} zmm0 = [3,3,3,3,3,3,3,3]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB15_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vporq 8192(%rdi,%rax), %zmm0, %zmm1
|
|
|
|
; CHECK-NEXT: vmovdqu64 %zmm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB15_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i64, i64* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i64* %tmp3 to <8 x i64>*
|
|
|
|
%tmp5 = load <8 x i64>, <8 x i64>* %tmp4, align 8
|
|
|
|
%tmp6 = or <8 x i64> %tmp5, <i64 3, i64 3, i64 3, i64 3, i64 3, i64 3, i64 3, i64 3>
|
|
|
|
%tmp7 = bitcast i64* %tmp3 to <8 x i64>*
|
|
|
|
store <8 x i64> %tmp6, <8 x i64>* %tmp7, align 8
|
|
|
|
%tmp8 = add i64 %tmp, 8
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_or_v4i64(i64* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_or_v4i64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastsd {{.*#+}} ymm0 = [3,3,3,3]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB16_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vorps 8192(%rdi,%rax), %ymm0, %ymm1
|
|
|
|
; CHECK-NEXT: vmovups %ymm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB16_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i64, i64* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i64* %tmp3 to <4 x i64>*
|
|
|
|
%tmp5 = load <4 x i64>, <4 x i64>* %tmp4, align 8
|
|
|
|
%tmp6 = or <4 x i64> %tmp5, <i64 3, i64 3, i64 3, i64 3>
|
|
|
|
%tmp7 = bitcast i64* %tmp3 to <4 x i64>*
|
|
|
|
store <4 x i64> %tmp6, <4 x i64>* %tmp7, align 8
|
|
|
|
%tmp8 = add i64 %tmp, 4
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_or_v2i64(i64* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_or_v2i64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-08-31 03:42:48 +08:00
|
|
|
; CHECK-NEXT: vmovaps {{.*#+}} xmm0 = [3,3]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB17_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-08-31 03:42:48 +08:00
|
|
|
; CHECK-NEXT: vorps 8192(%rdi,%rax), %xmm0, %xmm1
|
|
|
|
; CHECK-NEXT: vmovups %xmm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB17_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds i64, i64* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast i64* %tmp3 to <2 x i64>*
|
|
|
|
%tmp5 = load <2 x i64>, <2 x i64>* %tmp4, align 8
|
|
|
|
%tmp6 = or <2 x i64> %tmp5, <i64 3, i64 3>
|
|
|
|
%tmp7 = bitcast i64* %tmp3 to <2 x i64>*
|
|
|
|
store <2 x i64> %tmp6, <2 x i64>* %tmp7, align 8
|
|
|
|
%tmp8 = add i64 %tmp, 2
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb2
|
|
|
|
|
|
|
|
bb10: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fneg_v16f32(float* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fneg_v16f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpbroadcastd {{.*#+}} zmm0 = [-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB18_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpxord 4096(%rdi,%rax), %zmm0, %zmm1
|
|
|
|
; CHECK-NEXT: vmovdqu64 %zmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB18_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <16 x float>*
|
|
|
|
%tmp4 = load <16 x float>, <16 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = fneg <16 x float> %tmp4
|
|
|
|
%tmp6 = bitcast float* %tmp2 to <16 x float>*
|
|
|
|
store <16 x float> %tmp5, <16 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 16
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fneg_v8f32(float* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fneg_v8f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} ymm0 = [-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB19_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vxorps 4096(%rdi,%rax), %ymm0, %ymm1
|
|
|
|
; CHECK-NEXT: vmovups %ymm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB19_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <8 x float>*
|
|
|
|
%tmp4 = load <8 x float>, <8 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = fneg <8 x float> %tmp4
|
|
|
|
%tmp6 = bitcast float* %tmp2 to <8 x float>*
|
|
|
|
store <8 x float> %tmp5, <8 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 8
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fneg_v4f32(float* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fneg_v4f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} xmm0 = [-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB20_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vxorps 4096(%rdi,%rax), %xmm0, %xmm1
|
|
|
|
; CHECK-NEXT: vmovups %xmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB20_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <4 x float>*
|
|
|
|
%tmp4 = load <4 x float>, <4 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = fneg <4 x float> %tmp4
|
|
|
|
%tmp6 = bitcast float* %tmp2 to <4 x float>*
|
|
|
|
store <4 x float> %tmp5, <4 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 4
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fneg_v8f64(double* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fneg_v8f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpbroadcastq {{.*#+}} zmm0 = [-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB21_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpxorq 8192(%rdi,%rax), %zmm0, %zmm1
|
|
|
|
; CHECK-NEXT: vmovdqu64 %zmm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB21_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <8 x double>*
|
|
|
|
%tmp4 = load <8 x double>, <8 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = fneg <8 x double> %tmp4
|
|
|
|
%tmp6 = bitcast double* %tmp2 to <8 x double>*
|
|
|
|
store <8 x double> %tmp5, <8 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 8
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fneg_v4f64(double* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fneg_v4f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastsd {{.*#+}} ymm0 = [-0.0E+0,-0.0E+0,-0.0E+0,-0.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB22_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vxorps 8192(%rdi,%rax), %ymm0, %ymm1
|
|
|
|
; CHECK-NEXT: vmovups %ymm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB22_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <4 x double>*
|
|
|
|
%tmp4 = load <4 x double>, <4 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = fneg <4 x double> %tmp4
|
|
|
|
%tmp6 = bitcast double* %tmp2 to <4 x double>*
|
|
|
|
store <4 x double> %tmp5, <4 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 4
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fneg_v2f64(double* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fneg_v2f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-08-31 03:42:48 +08:00
|
|
|
; CHECK-NEXT: vmovaps {{.*#+}} xmm0 = [-0.0E+0,-0.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB23_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-08-31 03:42:48 +08:00
|
|
|
; CHECK-NEXT: vxorps 8192(%rdi,%rax), %xmm0, %xmm1
|
|
|
|
; CHECK-NEXT: vmovups %xmm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB23_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <2 x double>*
|
|
|
|
%tmp4 = load <2 x double>, <2 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = fneg <2 x double> %tmp4
|
|
|
|
%tmp6 = bitcast double* %tmp2 to <2 x double>*
|
|
|
|
store <2 x double> %tmp5, <2 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 2
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fabs_v16f32(float* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fabs_v16f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpbroadcastd {{.*#+}} zmm0 = [NaN,NaN,NaN,NaN,NaN,NaN,NaN,NaN,NaN,NaN,NaN,NaN,NaN,NaN,NaN,NaN]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB24_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpandd 4096(%rdi,%rax), %zmm0, %zmm1
|
|
|
|
; CHECK-NEXT: vmovdqu64 %zmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB24_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <16 x float>*
|
|
|
|
%tmp4 = load <16 x float>, <16 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = call <16 x float> @llvm.fabs.v16f32(<16 x float> %tmp4)
|
|
|
|
%tmp6 = bitcast float* %tmp2 to <16 x float>*
|
|
|
|
store <16 x float> %tmp5, <16 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 16
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; Function Attrs: nounwind readnone speculatable willreturn
|
|
|
|
declare <16 x float> @llvm.fabs.v16f32(<16 x float>) #0
|
|
|
|
|
|
|
|
define void @bcast_unfold_fabs_v8f32(float* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fabs_v8f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} ymm0 = [NaN,NaN,NaN,NaN,NaN,NaN,NaN,NaN]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB25_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vandps 4096(%rdi,%rax), %ymm0, %ymm1
|
|
|
|
; CHECK-NEXT: vmovups %ymm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB25_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <8 x float>*
|
|
|
|
%tmp4 = load <8 x float>, <8 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = call <8 x float> @llvm.fabs.v8f32(<8 x float> %tmp4)
|
|
|
|
%tmp6 = bitcast float* %tmp2 to <8 x float>*
|
|
|
|
store <8 x float> %tmp5, <8 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 8
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; Function Attrs: nounwind readnone speculatable willreturn
|
|
|
|
declare <8 x float> @llvm.fabs.v8f32(<8 x float>) #0
|
|
|
|
|
|
|
|
define void @bcast_unfold_fabs_v4f32(float* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fabs_v4f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} xmm0 = [NaN,NaN,NaN,NaN]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB26_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vandps 4096(%rdi,%rax), %xmm0, %xmm1
|
|
|
|
; CHECK-NEXT: vmovups %xmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB26_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <4 x float>*
|
|
|
|
%tmp4 = load <4 x float>, <4 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = call <4 x float> @llvm.fabs.v4f32(<4 x float> %tmp4)
|
|
|
|
%tmp6 = bitcast float* %tmp2 to <4 x float>*
|
|
|
|
store <4 x float> %tmp5, <4 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 4
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; Function Attrs: nounwind readnone speculatable willreturn
|
|
|
|
declare <4 x float> @llvm.fabs.v4f32(<4 x float>) #0
|
|
|
|
|
|
|
|
define void @bcast_unfold_fabs_v8f64(double* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fabs_v8f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpbroadcastq {{.*#+}} zmm0 = [NaN,NaN,NaN,NaN,NaN,NaN,NaN,NaN]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB27_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vpandq 8192(%rdi,%rax), %zmm0, %zmm1
|
|
|
|
; CHECK-NEXT: vmovdqu64 %zmm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB27_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <8 x double>*
|
|
|
|
%tmp4 = load <8 x double>, <8 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = call <8 x double> @llvm.fabs.v8f64(<8 x double> %tmp4)
|
|
|
|
%tmp6 = bitcast double* %tmp2 to <8 x double>*
|
|
|
|
store <8 x double> %tmp5, <8 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 8
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; Function Attrs: nounwind readnone speculatable willreturn
|
|
|
|
declare <8 x double> @llvm.fabs.v8f64(<8 x double>) #0
|
|
|
|
|
|
|
|
define void @bcast_unfold_fabs_v4f64(double* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fabs_v4f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastsd {{.*#+}} ymm0 = [NaN,NaN,NaN,NaN]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB28_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vandps 8192(%rdi,%rax), %ymm0, %ymm1
|
|
|
|
; CHECK-NEXT: vmovups %ymm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB28_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <4 x double>*
|
|
|
|
%tmp4 = load <4 x double>, <4 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = call <4 x double> @llvm.fabs.v4f64(<4 x double> %tmp4)
|
|
|
|
%tmp6 = bitcast double* %tmp2 to <4 x double>*
|
|
|
|
store <4 x double> %tmp5, <4 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 4
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; Function Attrs: nounwind readnone speculatable willreturn
|
|
|
|
declare <4 x double> @llvm.fabs.v4f64(<4 x double>) #0
|
|
|
|
|
|
|
|
define void @bcast_unfold_fabs_v2f64(double* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fabs_v2f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-08-31 03:42:48 +08:00
|
|
|
; CHECK-NEXT: vmovaps {{.*#+}} xmm0 = [NaN,NaN]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB29_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-08-31 03:42:48 +08:00
|
|
|
; CHECK-NEXT: vandps 8192(%rdi,%rax), %xmm0, %xmm1
|
|
|
|
; CHECK-NEXT: vmovups %xmm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB29_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <2 x double>*
|
|
|
|
%tmp4 = load <2 x double>, <2 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = call <2 x double> @llvm.fabs.v2f64(<2 x double> %tmp4)
|
|
|
|
%tmp6 = bitcast double* %tmp2 to <2 x double>*
|
|
|
|
store <2 x double> %tmp5, <2 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 2
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; Function Attrs: nounwind readnone speculatable willreturn
|
|
|
|
declare <2 x double> @llvm.fabs.v2f64(<2 x double>) #0
|
|
|
|
|
|
|
|
define void @bcast_unfold_fadd_v16f32(float* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fadd_v16f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} zmm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB30_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vaddps 4096(%rdi,%rax), %zmm0, %zmm1
|
|
|
|
; CHECK-NEXT: vmovups %zmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB30_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <16 x float>*
|
|
|
|
%tmp4 = load <16 x float>, <16 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = fadd <16 x float> %tmp4, <float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00>
|
|
|
|
%tmp6 = bitcast float* %tmp2 to <16 x float>*
|
|
|
|
store <16 x float> %tmp5, <16 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 16
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fadd_v8f32(float* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fadd_v8f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} ymm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB31_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vaddps 4096(%rdi,%rax), %ymm0, %ymm1
|
|
|
|
; CHECK-NEXT: vmovups %ymm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB31_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <8 x float>*
|
|
|
|
%tmp4 = load <8 x float>, <8 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = fadd <8 x float> %tmp4, <float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00>
|
|
|
|
%tmp6 = bitcast float* %tmp2 to <8 x float>*
|
|
|
|
store <8 x float> %tmp5, <8 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 8
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fadd_v4f32(float* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fadd_v4f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} xmm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB32_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vaddps 4096(%rdi,%rax), %xmm0, %xmm1
|
|
|
|
; CHECK-NEXT: vmovups %xmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB32_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <4 x float>*
|
|
|
|
%tmp4 = load <4 x float>, <4 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = fadd <4 x float> %tmp4, <float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00>
|
|
|
|
%tmp6 = bitcast float* %tmp2 to <4 x float>*
|
|
|
|
store <4 x float> %tmp5, <4 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 4
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fadd_v8f64(double* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fadd_v8f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastsd {{.*#+}} zmm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB33_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vaddpd 8192(%rdi,%rax), %zmm0, %zmm1
|
|
|
|
; CHECK-NEXT: vmovupd %zmm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB33_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <8 x double>*
|
|
|
|
%tmp4 = load <8 x double>, <8 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = fadd <8 x double> %tmp4, <double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00>
|
|
|
|
%tmp6 = bitcast double* %tmp2 to <8 x double>*
|
|
|
|
store <8 x double> %tmp5, <8 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 8
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fadd_v4f64(double* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fadd_v4f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastsd {{.*#+}} ymm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB34_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vaddpd 8192(%rdi,%rax), %ymm0, %ymm1
|
|
|
|
; CHECK-NEXT: vmovupd %ymm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB34_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <4 x double>*
|
|
|
|
%tmp4 = load <4 x double>, <4 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = fadd <4 x double> %tmp4, <double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00>
|
|
|
|
%tmp6 = bitcast double* %tmp2 to <4 x double>*
|
|
|
|
store <4 x double> %tmp5, <4 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 4
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fadd_v2f64(double* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fadd_v2f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-08-31 03:42:48 +08:00
|
|
|
; CHECK-NEXT: vmovapd {{.*#+}} xmm0 = [2.0E+0,2.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB35_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-08-31 03:42:48 +08:00
|
|
|
; CHECK-NEXT: vaddpd 8192(%rdi,%rax), %xmm0, %xmm1
|
|
|
|
; CHECK-NEXT: vmovupd %xmm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB35_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <2 x double>*
|
|
|
|
%tmp4 = load <2 x double>, <2 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = fadd <2 x double> %tmp4, <double 2.000000e+00, double 2.000000e+00>
|
|
|
|
%tmp6 = bitcast double* %tmp2 to <2 x double>*
|
|
|
|
store <2 x double> %tmp5, <2 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 2
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
2019-08-31 04:04:23 +08:00
|
|
|
define void @bcast_unfold_fmul_v16f32(float* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fmul_v16f32:
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} zmm0 = [3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB36_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vmulps 4096(%rdi,%rax), %zmm0, %zmm1
|
|
|
|
; CHECK-NEXT: vmovups %zmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB36_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <16 x float>*
|
|
|
|
%tmp4 = load <16 x float>, <16 x float>* %tmp3, align 4
|
2019-08-31 04:04:23 +08:00
|
|
|
%tmp5 = fmul <16 x float> %tmp4, <float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00>
|
2019-08-31 03:26:06 +08:00
|
|
|
%tmp6 = bitcast float* %tmp2 to <16 x float>*
|
|
|
|
store <16 x float> %tmp5, <16 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 16
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
2019-08-31 04:04:23 +08:00
|
|
|
define void @bcast_unfold_fmul_v8f32(float* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fmul_v8f32:
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} ymm0 = [3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB37_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vmulps 4096(%rdi,%rax), %ymm0, %ymm1
|
|
|
|
; CHECK-NEXT: vmovups %ymm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB37_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <8 x float>*
|
|
|
|
%tmp4 = load <8 x float>, <8 x float>* %tmp3, align 4
|
2019-08-31 04:04:23 +08:00
|
|
|
%tmp5 = fmul <8 x float> %tmp4, <float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00>
|
2019-08-31 03:26:06 +08:00
|
|
|
%tmp6 = bitcast float* %tmp2 to <8 x float>*
|
|
|
|
store <8 x float> %tmp5, <8 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 8
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
2019-08-31 04:04:23 +08:00
|
|
|
define void @bcast_unfold_fmul_v4f32(float* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fmul_v4f32:
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} xmm0 = [3.0E+0,3.0E+0,3.0E+0,3.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB38_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vmulps 4096(%rdi,%rax), %xmm0, %xmm1
|
|
|
|
; CHECK-NEXT: vmovups %xmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB38_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <4 x float>*
|
|
|
|
%tmp4 = load <4 x float>, <4 x float>* %tmp3, align 4
|
2019-08-31 04:04:23 +08:00
|
|
|
%tmp5 = fmul <4 x float> %tmp4, <float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00>
|
2019-08-31 03:26:06 +08:00
|
|
|
%tmp6 = bitcast float* %tmp2 to <4 x float>*
|
|
|
|
store <4 x float> %tmp5, <4 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 4
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
2019-08-31 04:04:23 +08:00
|
|
|
define void @bcast_unfold_fmul_v8f64(double* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fmul_v8f64:
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastsd {{.*#+}} zmm0 = [3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0,3.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB39_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vmulpd 8192(%rdi,%rax), %zmm0, %zmm1
|
|
|
|
; CHECK-NEXT: vmovupd %zmm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB39_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <8 x double>*
|
|
|
|
%tmp4 = load <8 x double>, <8 x double>* %tmp3, align 8
|
2019-08-31 04:04:23 +08:00
|
|
|
%tmp5 = fmul <8 x double> %tmp4, <double 3.000000e+00, double 3.000000e+00, double 3.000000e+00, double 3.000000e+00, double 3.000000e+00, double 3.000000e+00, double 3.000000e+00, double 3.000000e+00>
|
2019-08-31 03:26:06 +08:00
|
|
|
%tmp6 = bitcast double* %tmp2 to <8 x double>*
|
|
|
|
store <8 x double> %tmp5, <8 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 8
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
2019-08-31 04:04:23 +08:00
|
|
|
define void @bcast_unfold_fmul_v4f64(double* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fmul_v4f64:
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastsd {{.*#+}} ymm0 = [3.0E+0,3.0E+0,3.0E+0,3.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB40_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vmulpd 8192(%rdi,%rax), %ymm0, %ymm1
|
|
|
|
; CHECK-NEXT: vmovupd %ymm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB40_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <4 x double>*
|
|
|
|
%tmp4 = load <4 x double>, <4 x double>* %tmp3, align 8
|
2019-08-31 04:04:23 +08:00
|
|
|
%tmp5 = fmul <4 x double> %tmp4, <double 3.000000e+00, double 3.000000e+00, double 3.000000e+00, double 3.000000e+00>
|
2019-08-31 03:26:06 +08:00
|
|
|
%tmp6 = bitcast double* %tmp2 to <4 x double>*
|
|
|
|
store <4 x double> %tmp5, <4 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 4
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
2019-08-31 04:04:23 +08:00
|
|
|
define void @bcast_unfold_fmul_v2f64(double* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fmul_v2f64:
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-08-31 04:04:23 +08:00
|
|
|
; CHECK-NEXT: vmovapd {{.*#+}} xmm0 = [3.0E+0,3.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB41_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-08-31 04:04:23 +08:00
|
|
|
; CHECK-NEXT: vmulpd 8192(%rdi,%rax), %xmm0, %xmm1
|
2019-08-31 03:42:48 +08:00
|
|
|
; CHECK-NEXT: vmovupd %xmm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB41_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <2 x double>*
|
|
|
|
%tmp4 = load <2 x double>, <2 x double>* %tmp3, align 8
|
2019-08-31 04:04:23 +08:00
|
|
|
%tmp5 = fmul <2 x double> %tmp4, <double 3.000000e+00, double 3.000000e+00>
|
2019-08-31 03:26:06 +08:00
|
|
|
%tmp6 = bitcast double* %tmp2 to <2 x double>*
|
|
|
|
store <2 x double> %tmp5, <2 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 2
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fdiv_v16f32(float* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fdiv_v16f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} zmm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
2019-08-31 04:04:23 +08:00
|
|
|
; CHECK-NEXT: .LBB42_1: # %bb1
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vmovups 4096(%rdi,%rax), %zmm1
|
|
|
|
; CHECK-NEXT: vdivps %zmm0, %zmm1, %zmm1
|
|
|
|
; CHECK-NEXT: vmovups %zmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
2019-08-31 04:04:23 +08:00
|
|
|
; CHECK-NEXT: jne .LBB42_1
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <16 x float>*
|
|
|
|
%tmp4 = load <16 x float>, <16 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = fdiv <16 x float> %tmp4, <float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00>
|
|
|
|
%tmp6 = bitcast float* %tmp2 to <16 x float>*
|
|
|
|
store <16 x float> %tmp5, <16 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 16
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fdiv_v8f32(float* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fdiv_v8f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} ymm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
2019-08-31 04:04:23 +08:00
|
|
|
; CHECK-NEXT: .LBB43_1: # %bb1
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vmovups 4096(%rdi,%rax), %ymm1
|
|
|
|
; CHECK-NEXT: vdivps %ymm0, %ymm1, %ymm1
|
|
|
|
; CHECK-NEXT: vmovups %ymm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
2019-08-31 04:04:23 +08:00
|
|
|
; CHECK-NEXT: jne .LBB43_1
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <8 x float>*
|
|
|
|
%tmp4 = load <8 x float>, <8 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = fdiv <8 x float> %tmp4, <float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00>
|
|
|
|
%tmp6 = bitcast float* %tmp2 to <8 x float>*
|
|
|
|
store <8 x float> %tmp5, <8 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 8
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fdiv_v4f32(float* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fdiv_v4f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} xmm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
2019-08-31 04:04:23 +08:00
|
|
|
; CHECK-NEXT: .LBB44_1: # %bb1
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vmovups 4096(%rdi,%rax), %xmm1
|
|
|
|
; CHECK-NEXT: vdivps %xmm0, %xmm1, %xmm1
|
|
|
|
; CHECK-NEXT: vmovups %xmm1, 4096(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
2019-08-31 04:04:23 +08:00
|
|
|
; CHECK-NEXT: jne .LBB44_1
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <4 x float>*
|
|
|
|
%tmp4 = load <4 x float>, <4 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = fdiv <4 x float> %tmp4, <float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00>
|
|
|
|
%tmp6 = bitcast float* %tmp2 to <4 x float>*
|
|
|
|
store <4 x float> %tmp5, <4 x float>* %tmp6, align 4
|
|
|
|
%tmp7 = add i64 %tmp, 4
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fdiv_v8f64(double* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fdiv_v8f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastsd {{.*#+}} zmm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
2019-08-31 04:04:23 +08:00
|
|
|
; CHECK-NEXT: .LBB45_1: # %bb1
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vmovupd 8192(%rdi,%rax), %zmm1
|
|
|
|
; CHECK-NEXT: vdivpd %zmm0, %zmm1, %zmm1
|
|
|
|
; CHECK-NEXT: vmovupd %zmm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
2019-08-31 04:04:23 +08:00
|
|
|
; CHECK-NEXT: jne .LBB45_1
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <8 x double>*
|
|
|
|
%tmp4 = load <8 x double>, <8 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = fdiv <8 x double> %tmp4, <double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00>
|
|
|
|
%tmp6 = bitcast double* %tmp2 to <8 x double>*
|
|
|
|
store <8 x double> %tmp5, <8 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 8
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fdiv_v4f64(double* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fdiv_v4f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vbroadcastsd {{.*#+}} ymm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
2019-08-31 04:04:23 +08:00
|
|
|
; CHECK-NEXT: .LBB46_1: # %bb1
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-02 06:14:36 +08:00
|
|
|
; CHECK-NEXT: vmovupd 8192(%rdi,%rax), %ymm1
|
|
|
|
; CHECK-NEXT: vdivpd %ymm0, %ymm1, %ymm1
|
|
|
|
; CHECK-NEXT: vmovupd %ymm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
2019-08-31 04:04:23 +08:00
|
|
|
; CHECK-NEXT: jne .LBB46_1
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <4 x double>*
|
|
|
|
%tmp4 = load <4 x double>, <4 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = fdiv <4 x double> %tmp4, <double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00>
|
|
|
|
%tmp6 = bitcast double* %tmp2 to <4 x double>*
|
|
|
|
store <4 x double> %tmp5, <4 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 4
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fdiv_v2f64(double* nocapture %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fdiv_v2f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-08-31 03:42:48 +08:00
|
|
|
; CHECK-NEXT: vmovapd {{.*#+}} xmm0 = [2.0E+0,2.0E+0]
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
2019-08-31 04:04:23 +08:00
|
|
|
; CHECK-NEXT: .LBB47_1: # %bb1
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-08-31 03:42:48 +08:00
|
|
|
; CHECK-NEXT: vmovupd 8192(%rdi,%rax), %xmm1
|
|
|
|
; CHECK-NEXT: vdivpd %xmm0, %xmm1, %xmm1
|
|
|
|
; CHECK-NEXT: vmovupd %xmm1, 8192(%rdi,%rax)
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
2019-08-31 04:04:23 +08:00
|
|
|
; CHECK-NEXT: jne .LBB47_1
|
2019-08-31 03:26:06 +08:00
|
|
|
; CHECK-NEXT: # %bb.2: # %bb9
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp7, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <2 x double>*
|
|
|
|
%tmp4 = load <2 x double>, <2 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = fdiv <2 x double> %tmp4, <double 2.000000e+00, double 2.000000e+00>
|
|
|
|
%tmp6 = bitcast double* %tmp2 to <2 x double>*
|
|
|
|
store <2 x double> %tmp5, <2 x double>* %tmp6, align 8
|
|
|
|
%tmp7 = add i64 %tmp, 2
|
|
|
|
%tmp8 = icmp eq i64 %tmp7, 1024
|
|
|
|
br i1 %tmp8, label %bb9, label %bb1
|
|
|
|
|
|
|
|
bb9: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
2019-09-08 05:54:36 +08:00
|
|
|
|
|
|
|
define void @bcast_unfold_fma213_v4f32(float* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fma213_v4f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} xmm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB48_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vmovups 4096(%rdi,%rax), %xmm1
|
|
|
|
; CHECK-NEXT: vfmadd213ps {{.*#+}} xmm1 = (xmm1 * xmm1) + xmm0
|
|
|
|
; CHECK-NEXT: vmovups %xmm1, 4096(%rdi,%rax)
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB48_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb11
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp9, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast float* %tmp3 to <4 x float>*
|
|
|
|
%tmp5 = load <4 x float>, <4 x float>* %tmp4, align 4
|
|
|
|
%tmp6 = fmul contract <4 x float> %tmp5, %tmp5
|
|
|
|
%tmp7 = fadd contract <4 x float> %tmp6, <float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00>
|
|
|
|
%tmp8 = bitcast float* %tmp3 to <4 x float>*
|
|
|
|
store <4 x float> %tmp7, <4 x float>* %tmp8, align 4
|
|
|
|
%tmp9 = add i64 %tmp, 4
|
|
|
|
%tmp10 = icmp eq i64 %tmp9, 1024
|
|
|
|
br i1 %tmp10, label %bb11, label %bb2
|
|
|
|
|
|
|
|
bb11: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fma231_v4f32(float* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fma231_v4f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} xmm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB49_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vmovups 4096(%rdi,%rax), %xmm1
|
|
|
|
; CHECK-NEXT: vfmadd231ps {{.*#+}} xmm1 = (xmm1 * xmm0) + xmm1
|
|
|
|
; CHECK-NEXT: vmovups %xmm1, 4096(%rdi,%rax)
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB49_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <4 x float>*
|
|
|
|
%tmp4 = load <4 x float>, <4 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = fmul contract <4 x float> %tmp4, <float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00>
|
|
|
|
%tmp6 = fadd contract <4 x float> %tmp4, %tmp5
|
|
|
|
%tmp7 = bitcast float* %tmp2 to <4 x float>*
|
|
|
|
store <4 x float> %tmp6, <4 x float>* %tmp7, align 4
|
|
|
|
%tmp8 = add i64 %tmp, 4
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb1
|
|
|
|
|
|
|
|
bb10: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fma213_v8f32(float* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fma213_v8f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} ymm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB50_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vmovups 4096(%rdi,%rax), %ymm1
|
|
|
|
; CHECK-NEXT: vfmadd213ps {{.*#+}} ymm1 = (ymm1 * ymm1) + ymm0
|
|
|
|
; CHECK-NEXT: vmovups %ymm1, 4096(%rdi,%rax)
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB50_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb11
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp9, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast float* %tmp3 to <8 x float>*
|
|
|
|
%tmp5 = load <8 x float>, <8 x float>* %tmp4, align 4
|
|
|
|
%tmp6 = fmul contract <8 x float> %tmp5, %tmp5
|
|
|
|
%tmp7 = fadd contract <8 x float> %tmp6, <float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00>
|
|
|
|
%tmp8 = bitcast float* %tmp3 to <8 x float>*
|
|
|
|
store <8 x float> %tmp7, <8 x float>* %tmp8, align 4
|
|
|
|
%tmp9 = add i64 %tmp, 8
|
|
|
|
%tmp10 = icmp eq i64 %tmp9, 1024
|
|
|
|
br i1 %tmp10, label %bb11, label %bb2
|
|
|
|
|
|
|
|
bb11: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fma231_v8f32(float* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fma231_v8f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} ymm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB51_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vmovups 4096(%rdi,%rax), %ymm1
|
|
|
|
; CHECK-NEXT: vfmadd231ps {{.*#+}} ymm1 = (ymm1 * ymm0) + ymm1
|
|
|
|
; CHECK-NEXT: vmovups %ymm1, 4096(%rdi,%rax)
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB51_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <8 x float>*
|
|
|
|
%tmp4 = load <8 x float>, <8 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = fmul contract <8 x float> %tmp4, <float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00>
|
|
|
|
%tmp6 = fadd contract <8 x float> %tmp4, %tmp5
|
|
|
|
%tmp7 = bitcast float* %tmp2 to <8 x float>*
|
|
|
|
store <8 x float> %tmp6, <8 x float>* %tmp7, align 4
|
|
|
|
%tmp8 = add i64 %tmp, 8
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb1
|
|
|
|
|
|
|
|
bb10: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fma213_v16f32(float* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fma213_v16f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} zmm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB52_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vmovups 4096(%rdi,%rax), %zmm1
|
|
|
|
; CHECK-NEXT: vfmadd213ps {{.*#+}} zmm1 = (zmm1 * zmm1) + zmm0
|
|
|
|
; CHECK-NEXT: vmovups %zmm1, 4096(%rdi,%rax)
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB52_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb11
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp9, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast float* %tmp3 to <16 x float>*
|
|
|
|
%tmp5 = load <16 x float>, <16 x float>* %tmp4, align 4
|
|
|
|
%tmp6 = fmul contract <16 x float> %tmp5, %tmp5
|
|
|
|
%tmp7 = fadd contract <16 x float> %tmp6, <float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00>
|
|
|
|
%tmp8 = bitcast float* %tmp3 to <16 x float>*
|
|
|
|
store <16 x float> %tmp7, <16 x float>* %tmp8, align 4
|
|
|
|
%tmp9 = add i64 %tmp, 16
|
|
|
|
%tmp10 = icmp eq i64 %tmp9, 1024
|
|
|
|
br i1 %tmp10, label %bb11, label %bb2
|
|
|
|
|
|
|
|
bb11: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fma231_v16f32(float* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fma231_v16f32:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-4096, %rax # imm = 0xF000
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vbroadcastss {{.*#+}} zmm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB53_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vmovups 4096(%rdi,%rax), %zmm1
|
|
|
|
; CHECK-NEXT: vfmadd231ps {{.*#+}} zmm1 = (zmm1 * zmm0) + zmm1
|
|
|
|
; CHECK-NEXT: vmovups %zmm1, 4096(%rdi,%rax)
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB53_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds float, float* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast float* %tmp2 to <16 x float>*
|
|
|
|
%tmp4 = load <16 x float>, <16 x float>* %tmp3, align 4
|
|
|
|
%tmp5 = fmul contract <16 x float> %tmp4, <float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00, float 2.000000e+00>
|
|
|
|
%tmp6 = fadd contract <16 x float> %tmp4, %tmp5
|
|
|
|
%tmp7 = bitcast float* %tmp2 to <16 x float>*
|
|
|
|
store <16 x float> %tmp6, <16 x float>* %tmp7, align 4
|
|
|
|
%tmp8 = add i64 %tmp, 16
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb1
|
|
|
|
|
|
|
|
bb10: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fma213_v2f64(double* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fma213_v2f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
|
|
|
; CHECK-NEXT: vmovapd {{.*#+}} xmm0 = [2.0E+0,2.0E+0]
|
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB54_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
|
|
|
; CHECK-NEXT: vmovupd 8192(%rdi,%rax), %xmm1
|
|
|
|
; CHECK-NEXT: vfmadd213pd {{.*#+}} xmm1 = (xmm1 * xmm1) + xmm0
|
|
|
|
; CHECK-NEXT: vmovupd %xmm1, 8192(%rdi,%rax)
|
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB54_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb11
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp9, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast double* %tmp3 to <2 x double>*
|
|
|
|
%tmp5 = load <2 x double>, <2 x double>* %tmp4, align 4
|
|
|
|
%tmp6 = fmul contract <2 x double> %tmp5, %tmp5
|
|
|
|
%tmp7 = fadd contract <2 x double> %tmp6, <double 2.000000e+00, double 2.000000e+00>
|
|
|
|
%tmp8 = bitcast double* %tmp3 to <2 x double>*
|
|
|
|
store <2 x double> %tmp7, <2 x double>* %tmp8, align 8
|
|
|
|
%tmp9 = add i64 %tmp, 2
|
|
|
|
%tmp10 = icmp eq i64 %tmp9, 1024
|
|
|
|
br i1 %tmp10, label %bb11, label %bb2
|
|
|
|
|
|
|
|
bb11: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fma231_v2f64(double* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fma231_v2f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
|
|
|
; CHECK-NEXT: vmovapd {{.*#+}} xmm0 = [2.0E+0,2.0E+0]
|
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB55_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
|
|
|
; CHECK-NEXT: vmovupd 8192(%rdi,%rax), %xmm1
|
|
|
|
; CHECK-NEXT: vfmadd231pd {{.*#+}} xmm1 = (xmm1 * xmm0) + xmm1
|
|
|
|
; CHECK-NEXT: vmovupd %xmm1, 8192(%rdi,%rax)
|
|
|
|
; CHECK-NEXT: addq $16, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB55_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <2 x double>*
|
|
|
|
%tmp4 = load <2 x double>, <2 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = fmul contract <2 x double> %tmp4, <double 2.000000e+00, double 2.000000e+00>
|
|
|
|
%tmp6 = fadd contract <2 x double> %tmp4, %tmp5
|
|
|
|
%tmp7 = bitcast double* %tmp2 to <2 x double>*
|
|
|
|
store <2 x double> %tmp6, <2 x double>* %tmp7, align 8
|
|
|
|
%tmp8 = add i64 %tmp, 2
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb1
|
|
|
|
|
|
|
|
bb10: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fma213_v4f64(double* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fma213_v4f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vbroadcastsd {{.*#+}} ymm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB56_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vmovupd 8192(%rdi,%rax), %ymm1
|
|
|
|
; CHECK-NEXT: vfmadd213pd {{.*#+}} ymm1 = (ymm1 * ymm1) + ymm0
|
|
|
|
; CHECK-NEXT: vmovupd %ymm1, 8192(%rdi,%rax)
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB56_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb11
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp9, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast double* %tmp3 to <4 x double>*
|
|
|
|
%tmp5 = load <4 x double>, <4 x double>* %tmp4, align 8
|
|
|
|
%tmp6 = fmul contract <4 x double> %tmp5, %tmp5
|
|
|
|
%tmp7 = fadd contract <4 x double> %tmp6, <double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00>
|
|
|
|
%tmp8 = bitcast double* %tmp3 to <4 x double>*
|
|
|
|
store <4 x double> %tmp7, <4 x double>* %tmp8, align 8
|
|
|
|
%tmp9 = add i64 %tmp, 4
|
|
|
|
%tmp10 = icmp eq i64 %tmp9, 1024
|
|
|
|
br i1 %tmp10, label %bb11, label %bb2
|
|
|
|
|
|
|
|
bb11: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fma231_v4f64(double* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fma231_v4f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vbroadcastsd {{.*#+}} ymm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB57_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vmovupd 8192(%rdi,%rax), %ymm1
|
|
|
|
; CHECK-NEXT: vfmadd231pd {{.*#+}} ymm1 = (ymm1 * ymm0) + ymm1
|
|
|
|
; CHECK-NEXT: vmovupd %ymm1, 8192(%rdi,%rax)
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: addq $32, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB57_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <4 x double>*
|
|
|
|
%tmp4 = load <4 x double>, <4 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = fmul contract <4 x double> %tmp4, <double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00>
|
|
|
|
%tmp6 = fadd contract <4 x double> %tmp4, %tmp5
|
|
|
|
%tmp7 = bitcast double* %tmp2 to <4 x double>*
|
|
|
|
store <4 x double> %tmp6, <4 x double>* %tmp7, align 8
|
|
|
|
%tmp8 = add i64 %tmp, 4
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb1
|
|
|
|
|
|
|
|
bb10: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fma213_v8f64(double* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fma213_v8f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vbroadcastsd {{.*#+}} zmm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB58_1: # %bb2
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vmovupd 8192(%rdi,%rax), %zmm1
|
|
|
|
; CHECK-NEXT: vfmadd213pd {{.*#+}} zmm1 = (zmm1 * zmm1) + zmm0
|
|
|
|
; CHECK-NEXT: vmovupd %zmm1, 8192(%rdi,%rax)
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB58_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb11
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb2
|
|
|
|
|
|
|
|
bb2: ; preds = %bb2, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp9, %bb2 ]
|
|
|
|
%tmp3 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp4 = bitcast double* %tmp3 to <8 x double>*
|
|
|
|
%tmp5 = load <8 x double>, <8 x double>* %tmp4, align 8
|
|
|
|
%tmp6 = fmul contract <8 x double> %tmp5, %tmp5
|
|
|
|
%tmp7 = fadd contract <8 x double> %tmp6, <double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00>
|
|
|
|
%tmp8 = bitcast double* %tmp3 to <8 x double>*
|
|
|
|
store <8 x double> %tmp7, <8 x double>* %tmp8, align 8
|
|
|
|
%tmp9 = add i64 %tmp, 8
|
|
|
|
%tmp10 = icmp eq i64 %tmp9, 1024
|
|
|
|
br i1 %tmp10, label %bb11, label %bb2
|
|
|
|
|
|
|
|
bb11: ; preds = %bb2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bcast_unfold_fma231_v8f64(double* %arg) {
|
|
|
|
; CHECK-LABEL: bcast_unfold_fma231_v8f64:
|
|
|
|
; CHECK: # %bb.0: # %bb
|
|
|
|
; CHECK-NEXT: movq $-8192, %rax # imm = 0xE000
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vbroadcastsd {{.*#+}} zmm0 = [2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0,2.0E+0]
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: .p2align 4, 0x90
|
|
|
|
; CHECK-NEXT: .LBB59_1: # %bb1
|
|
|
|
; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
|
2019-09-08 05:54:40 +08:00
|
|
|
; CHECK-NEXT: vmovupd 8192(%rdi,%rax), %zmm1
|
|
|
|
; CHECK-NEXT: vfmadd231pd {{.*#+}} zmm1 = (zmm1 * zmm0) + zmm1
|
|
|
|
; CHECK-NEXT: vmovupd %zmm1, 8192(%rdi,%rax)
|
2019-09-08 05:54:36 +08:00
|
|
|
; CHECK-NEXT: addq $64, %rax
|
|
|
|
; CHECK-NEXT: jne .LBB59_1
|
|
|
|
; CHECK-NEXT: # %bb.2: # %bb10
|
|
|
|
; CHECK-NEXT: vzeroupper
|
|
|
|
; CHECK-NEXT: retq
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1: ; preds = %bb1, %bb
|
|
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb1 ]
|
|
|
|
%tmp2 = getelementptr inbounds double, double* %arg, i64 %tmp
|
|
|
|
%tmp3 = bitcast double* %tmp2 to <8 x double>*
|
|
|
|
%tmp4 = load <8 x double>, <8 x double>* %tmp3, align 8
|
|
|
|
%tmp5 = fmul contract <8 x double> %tmp4, <double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00, double 2.000000e+00>
|
|
|
|
%tmp6 = fadd contract <8 x double> %tmp4, %tmp5
|
|
|
|
%tmp7 = bitcast double* %tmp2 to <8 x double>*
|
|
|
|
store <8 x double> %tmp6, <8 x double>* %tmp7, align 8
|
|
|
|
%tmp8 = add i64 %tmp, 8
|
|
|
|
%tmp9 = icmp eq i64 %tmp8, 1024
|
|
|
|
br i1 %tmp9, label %bb10, label %bb1
|
|
|
|
|
|
|
|
bb10: ; preds = %bb1
|
|
|
|
ret void
|
|
|
|
}
|