; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py UTC_ARGS: --version 5 ; RUN: opt < %s -mtriple=riscv32 -mattr=+v,+zvl128b -passes="print" -cost-kind=throughput 2>&1 -disable-output \ ; RUN: | FileCheck %s --check-prefixes=THROUGHPUT,THROUGHPUT-VL128B ; RUN: opt < %s -mtriple=riscv64 -mattr=+v,+zvl128b -passes="print" -cost-kind=throughput 2>&1 -disable-output \ ; RUN: | FileCheck %s --check-prefixes=THROUGHPUT,THROUGHPUT-VL128B ; RUN: opt < %s -mtriple=riscv32 -mattr=+v,+zvl256b -passes="print" -cost-kind=throughput 2>&1 -disable-output \ ; RUN: | FileCheck %s --check-prefixes=THROUGHPUT,THROUGHPUT-VL256B ; RUN: opt < %s -mtriple=riscv64 -mattr=+v,+zvl256b -passes="print" -cost-kind=throughput 2>&1 -disable-output \ ; RUN: | FileCheck %s --check-prefixes=THROUGHPUT,THROUGHPUT-VL256B ; RUN: opt < %s -mtriple=riscv32 -mattr=+v,+zvl512b -passes="print" -cost-kind=throughput 2>&1 -disable-output \ ; RUN: | FileCheck %s --check-prefixes=THROUGHPUT,THROUGHPUT-VL512B ; RUN: opt < %s -mtriple=riscv64 -mattr=+v,+zvl512b -passes="print" -cost-kind=throughput 2>&1 -disable-output \ ; RUN: | FileCheck %s --check-prefixes=THROUGHPUT,THROUGHPUT-VL512B ; RUN: opt < %s -mtriple=riscv32 -mattr=+v,+zvl1024b -passes="print" -cost-kind=throughput 2>&1 -disable-output \ ; RUN: | FileCheck %s --check-prefixes=THROUGHPUT,THROUGHPUT-VL1024B ; RUN: opt < %s -mtriple=riscv64 -mattr=+v,+zvl1024b -passes="print" -cost-kind=throughput 2>&1 -disable-output \ ; RUN: | FileCheck %s --check-prefixes=THROUGHPUT,THROUGHPUT-VL1024B define zeroext i1 @vreduce_and_v1i1(<1 x i1> %v) { ; THROUGHPUT-LABEL: 'vreduce_and_v1i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 2 for instruction: %red = call i1 @llvm.vector.reduce.and.v1i1(<1 x i1> %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.v1i1(<1 x i1> %v) ret i1 %red } define zeroext i1 @vreduce_and_v2i1(<2 x i1> %v) { ; THROUGHPUT-LABEL: 'vreduce_and_v2i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.v2i1(<2 x i1> %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.v2i1(<2 x i1> %v) ret i1 %red } define zeroext i1 @vreduce_and_v4i1(<4 x i1> %v) { ; THROUGHPUT-LABEL: 'vreduce_and_v4i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.v4i1(<4 x i1> %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.v4i1(<4 x i1> %v) ret i1 %red } define zeroext i1 @vreduce_and_v8i1(<8 x i1> %v) { ; THROUGHPUT-LABEL: 'vreduce_and_v8i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.v8i1(<8 x i1> %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.v8i1(<8 x i1> %v) ret i1 %red } define zeroext i1 @vreduce_and_v16i1(<16 x i1> %v) { ; THROUGHPUT-LABEL: 'vreduce_and_v16i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.v16i1(<16 x i1> %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.v16i1(<16 x i1> %v) ret i1 %red } define zeroext i1 @vreduce_and_v32i1(<32 x i1> %v) { ; THROUGHPUT-LABEL: 'vreduce_and_v32i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.v32i1(<32 x i1> %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.v32i1(<32 x i1> %v) ret i1 %red } define zeroext i1 @vreduce_and_v64i1(<64 x i1> %v) { ; THROUGHPUT-LABEL: 'vreduce_and_v64i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.v64i1(<64 x i1> %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.v64i1(<64 x i1> %v) ret i1 %red } define zeroext i1 @vreduce_and_v128i1(<128 x i1> %v) { ; THROUGHPUT-LABEL: 'vreduce_and_v128i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.v128i1(<128 x i1> %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.v128i1(<128 x i1> %v) ret i1 %red } define zeroext i1 @vreduce_and_v256i1(<256 x i1> %v) { ; THROUGHPUT-LABEL: 'vreduce_and_v256i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.v256i1(<256 x i1> %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.v256i1(<256 x i1> %v) ret i1 %red } define zeroext i1 @vreduce_and_v512i1(<512 x i1> %v) { ; THROUGHPUT-VL128B-LABEL: 'vreduce_and_v512i1' ; THROUGHPUT-VL128B-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %red = call i1 @llvm.vector.reduce.and.v512i1(<512 x i1> %v) ; THROUGHPUT-VL128B-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; ; THROUGHPUT-VL256B-LABEL: 'vreduce_and_v512i1' ; THROUGHPUT-VL256B-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.v512i1(<512 x i1> %v) ; THROUGHPUT-VL256B-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; ; THROUGHPUT-VL512B-LABEL: 'vreduce_and_v512i1' ; THROUGHPUT-VL512B-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.v512i1(<512 x i1> %v) ; THROUGHPUT-VL512B-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; ; THROUGHPUT-VL1024B-LABEL: 'vreduce_and_v512i1' ; THROUGHPUT-VL1024B-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.v512i1(<512 x i1> %v) ; THROUGHPUT-VL1024B-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.v512i1(<512 x i1> %v) ret i1 %red } define zeroext i1 @vreduce_and_v1024i1(<1024 x i1> %v) { ; THROUGHPUT-VL128B-LABEL: 'vreduce_and_v1024i1' ; THROUGHPUT-VL128B-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %red = call i1 @llvm.vector.reduce.and.v1024i1(<1024 x i1> %v) ; THROUGHPUT-VL128B-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; ; THROUGHPUT-VL256B-LABEL: 'vreduce_and_v1024i1' ; THROUGHPUT-VL256B-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %red = call i1 @llvm.vector.reduce.and.v1024i1(<1024 x i1> %v) ; THROUGHPUT-VL256B-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; ; THROUGHPUT-VL512B-LABEL: 'vreduce_and_v1024i1' ; THROUGHPUT-VL512B-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.v1024i1(<1024 x i1> %v) ; THROUGHPUT-VL512B-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; ; THROUGHPUT-VL1024B-LABEL: 'vreduce_and_v1024i1' ; THROUGHPUT-VL1024B-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.v1024i1(<1024 x i1> %v) ; THROUGHPUT-VL1024B-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.v1024i1(<1024 x i1> %v) ret i1 %red } define zeroext i1 @vreduce_and_nxv1i1( %v) { ; THROUGHPUT-LABEL: 'vreduce_and_nxv1i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.nxv1i1( %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.nxv1i1( %v) ret i1 %red } define zeroext i1 @vreduce_and_nxv2i1( %v) { ; THROUGHPUT-LABEL: 'vreduce_and_nxv2i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.nxv2i1( %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.nxv2i1( %v) ret i1 %red } define zeroext i1 @vreduce_and_nxv4i1( %v) { ; THROUGHPUT-LABEL: 'vreduce_and_nxv4i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.nxv4i1( %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.nxv4i1( %v) ret i1 %red } define zeroext i1 @vreduce_and_nxv8i1( %v) { ; THROUGHPUT-LABEL: 'vreduce_and_nxv8i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.nxv8i1( %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.nxv8i1( %v) ret i1 %red } define zeroext i1 @vreduce_and_nxv16i1( %v) { ; THROUGHPUT-LABEL: 'vreduce_and_nxv16i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.nxv16i1( %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.nxv16i1( %v) ret i1 %red } define zeroext i1 @vreduce_and_nxv32i1( %v) { ; THROUGHPUT-LABEL: 'vreduce_and_nxv32i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.nxv32i1( %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.nxv32i1( %v) ret i1 %red } define zeroext i1 @vreduce_and_nxv64i1( %v) { ; THROUGHPUT-LABEL: 'vreduce_and_nxv64i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.nxv64i1( %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.nxv64i1( %v) ret i1 %red } define zeroext i1 @vreduce_and_nxv128i1( %v) { ; THROUGHPUT-LABEL: 'vreduce_and_nxv128i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 3 for instruction: %red = call i1 @llvm.vector.reduce.and.nxv128i1( %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.nxv128i1( %v) ret i1 %red } define zeroext i1 @vreduce_and_nxv256i1( %v) { ; THROUGHPUT-LABEL: 'vreduce_and_nxv256i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %red = call i1 @llvm.vector.reduce.and.nxv256i1( %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.nxv256i1( %v) ret i1 %red } define zeroext i1 @vreduce_and_nxv512i1( %v) { ; THROUGHPUT-LABEL: 'vreduce_and_nxv512i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %red = call i1 @llvm.vector.reduce.and.nxv512i1( %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.nxv512i1( %v) ret i1 %red } define zeroext i1 @vreduce_and_nxv1024i1( %v) { ; THROUGHPUT-LABEL: 'vreduce_and_nxv1024i1' ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 17 for instruction: %red = call i1 @llvm.vector.reduce.and.nxv1024i1( %v) ; THROUGHPUT-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret i1 %red ; %red = call i1 @llvm.vector.reduce.and.nxv1024i1( %v) ret i1 %red }