| ; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py UTC_ARGS: --version 3 |
| ; RUN: opt -passes="print<cost-model>" 2>&1 -disable-output -mtriple=riscv32 -mattr=+f,+d,+zfh < %s | FileCheck %s --check-prefixes=RV32 |
| ; RUN: opt -passes="print<cost-model>" 2>&1 -disable-output -mtriple=riscv64 -mattr=+f,+d,+zfh < %s | FileCheck %s --check-prefixes=RV64 |
| |
| define void @insertelement_int(i32 %x) { |
| ; RV32-LABEL: 'insertelement_int' |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %v2i8 = insertelement <2 x i8> undef, i8 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %v4i8 = insertelement <4 x i8> undef, i8 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 17 for instruction: %v8i8 = insertelement <8 x i8> undef, i8 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 33 for instruction: %v16i8 = insertelement <16 x i8> undef, i8 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Invalid cost for instruction: %nxv16i8 = insertelement <vscale x 16 x i8> undef, i8 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %v2i16 = insertelement <2 x i16> undef, i16 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %v4i16 = insertelement <4 x i16> undef, i16 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 17 for instruction: %v8i16 = insertelement <8 x i16> undef, i16 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 33 for instruction: %v16i16 = insertelement <16 x i16> undef, i16 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Invalid cost for instruction: %nxv16i16 = insertelement <vscale x 16 x i16> undef, i16 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %v2i32 = insertelement <2 x i32> undef, i32 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %v4i32 = insertelement <4 x i32> undef, i32 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 17 for instruction: %v8i32 = insertelement <8 x i32> undef, i32 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 33 for instruction: %v16i32 = insertelement <16 x i32> undef, i32 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Invalid cost for instruction: %nxv16i32 = insertelement <vscale x 16 x i32> undef, i32 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 10 for instruction: %v2i64 = insertelement <2 x i64> undef, i64 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 18 for instruction: %v4i64 = insertelement <4 x i64> undef, i64 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 34 for instruction: %v8i64 = insertelement <8 x i64> undef, i64 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 66 for instruction: %v16i64 = insertelement <16 x i64> undef, i64 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Invalid cost for instruction: %nxv16i64 = insertelement <vscale x 16 x i64> undef, i64 undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret void |
| ; |
| ; RV64-LABEL: 'insertelement_int' |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %v2i8 = insertelement <2 x i8> undef, i8 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %v4i8 = insertelement <4 x i8> undef, i8 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 17 for instruction: %v8i8 = insertelement <8 x i8> undef, i8 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 33 for instruction: %v16i8 = insertelement <16 x i8> undef, i8 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Invalid cost for instruction: %nxv16i8 = insertelement <vscale x 16 x i8> undef, i8 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %v2i16 = insertelement <2 x i16> undef, i16 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %v4i16 = insertelement <4 x i16> undef, i16 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 17 for instruction: %v8i16 = insertelement <8 x i16> undef, i16 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 33 for instruction: %v16i16 = insertelement <16 x i16> undef, i16 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Invalid cost for instruction: %nxv16i16 = insertelement <vscale x 16 x i16> undef, i16 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %v2i32 = insertelement <2 x i32> undef, i32 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %v4i32 = insertelement <4 x i32> undef, i32 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 17 for instruction: %v8i32 = insertelement <8 x i32> undef, i32 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 33 for instruction: %v16i32 = insertelement <16 x i32> undef, i32 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Invalid cost for instruction: %nxv16i32 = insertelement <vscale x 16 x i32> undef, i32 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %v2i64 = insertelement <2 x i64> undef, i64 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %v4i64 = insertelement <4 x i64> undef, i64 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 17 for instruction: %v8i64 = insertelement <8 x i64> undef, i64 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 33 for instruction: %v16i64 = insertelement <16 x i64> undef, i64 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Invalid cost for instruction: %nxv16i64 = insertelement <vscale x 16 x i64> undef, i64 undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret void |
| ; |
| %v2i8 = insertelement <2 x i8> undef, i8 undef, i32 %x |
| %v4i8 = insertelement <4 x i8> undef, i8 undef, i32 %x |
| %v8i8 = insertelement <8 x i8> undef, i8 undef, i32 %x |
| %v16i8 = insertelement <16 x i8> undef, i8 undef, i32 %x |
| %nxv16i8 = insertelement <vscale x 16 x i8> undef, i8 undef, i32 %x |
| |
| %v2i16 = insertelement <2 x i16> undef, i16 undef, i32 %x |
| %v4i16 = insertelement <4 x i16> undef, i16 undef, i32 %x |
| %v8i16 = insertelement <8 x i16> undef, i16 undef, i32 %x |
| %v16i16 = insertelement <16 x i16> undef, i16 undef, i32 %x |
| %nxv16i16 = insertelement <vscale x 16 x i16> undef, i16 undef, i32 %x |
| |
| %v2i32 = insertelement <2 x i32> undef, i32 undef, i32 %x |
| %v4i32 = insertelement <4 x i32> undef, i32 undef, i32 %x |
| %v8i32 = insertelement <8 x i32> undef, i32 undef, i32 %x |
| %v16i32 = insertelement <16 x i32> undef, i32 undef, i32 %x |
| %nxv16i32 = insertelement <vscale x 16 x i32> undef, i32 undef, i32 %x |
| |
| %v2i64 = insertelement <2 x i64> undef, i64 undef, i32 %x |
| %v4i64 = insertelement <4 x i64> undef, i64 undef, i32 %x |
| %v8i64 = insertelement <8 x i64> undef, i64 undef, i32 %x |
| %v16i64 = insertelement <16 x i64> undef, i64 undef, i32 %x |
| %nxv16i64 = insertelement <vscale x 16 x i64> undef, i64 undef, i32 %x |
| |
| ret void |
| } |
| |
| define void @insertelement_fp(i32 %x) { |
| ; RV32-LABEL: 'insertelement_fp' |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %v2f16 = insertelement <2 x half> undef, half undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %v4f16 = insertelement <4 x half> undef, half undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 17 for instruction: %v8f16 = insertelement <8 x half> undef, half undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 33 for instruction: %v16f16 = insertelement <16 x half> undef, half undef, i32 %x |
| ; RV32-NEXT: Cost Model: Invalid cost for instruction: %nxv16f16 = insertelement <vscale x 16 x half> undef, half undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %v2f32 = insertelement <2 x float> undef, float undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %v4f32 = insertelement <4 x float> undef, float undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 17 for instruction: %v8f32 = insertelement <8 x float> undef, float undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 33 for instruction: %v16f32 = insertelement <16 x float> undef, float undef, i32 %x |
| ; RV32-NEXT: Cost Model: Invalid cost for instruction: %nxv16f32 = insertelement <vscale x 16 x float> undef, float undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %v2f64 = insertelement <2 x double> undef, double undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %v4f64 = insertelement <4 x double> undef, double undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 17 for instruction: %v8f64 = insertelement <8 x double> undef, double undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 33 for instruction: %v16f64 = insertelement <16 x double> undef, double undef, i32 %x |
| ; RV32-NEXT: Cost Model: Invalid cost for instruction: %nxv16f64 = insertelement <vscale x 16 x double> undef, double undef, i32 %x |
| ; RV32-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret void |
| ; |
| ; RV64-LABEL: 'insertelement_fp' |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %v2f16 = insertelement <2 x half> undef, half undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %v4f16 = insertelement <4 x half> undef, half undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 17 for instruction: %v8f16 = insertelement <8 x half> undef, half undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 33 for instruction: %v16f16 = insertelement <16 x half> undef, half undef, i32 %x |
| ; RV64-NEXT: Cost Model: Invalid cost for instruction: %nxv16f16 = insertelement <vscale x 16 x half> undef, half undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %v2f32 = insertelement <2 x float> undef, float undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %v4f32 = insertelement <4 x float> undef, float undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 17 for instruction: %v8f32 = insertelement <8 x float> undef, float undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 33 for instruction: %v16f32 = insertelement <16 x float> undef, float undef, i32 %x |
| ; RV64-NEXT: Cost Model: Invalid cost for instruction: %nxv16f32 = insertelement <vscale x 16 x float> undef, float undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 5 for instruction: %v2f64 = insertelement <2 x double> undef, double undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 9 for instruction: %v4f64 = insertelement <4 x double> undef, double undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 17 for instruction: %v8f64 = insertelement <8 x double> undef, double undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 33 for instruction: %v16f64 = insertelement <16 x double> undef, double undef, i32 %x |
| ; RV64-NEXT: Cost Model: Invalid cost for instruction: %nxv16f64 = insertelement <vscale x 16 x double> undef, double undef, i32 %x |
| ; RV64-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret void |
| ; |
| %v2f16 = insertelement <2 x half> undef, half undef, i32 %x |
| %v4f16 = insertelement <4 x half> undef, half undef, i32 %x |
| %v8f16 = insertelement <8 x half> undef, half undef, i32 %x |
| %v16f16 = insertelement <16 x half> undef, half undef, i32 %x |
| %nxv16f16 = insertelement <vscale x 16 x half> undef, half undef, i32 %x |
| |
| %v2f32 = insertelement <2 x float> undef, float undef, i32 %x |
| %v4f32 = insertelement <4 x float> undef, float undef, i32 %x |
| %v8f32 = insertelement <8 x float> undef, float undef, i32 %x |
| %v16f32 = insertelement <16 x float> undef, float undef, i32 %x |
| %nxv16f32 = insertelement <vscale x 16 x float> undef, float undef, i32 %x |
| |
| %v2f64 = insertelement <2 x double> undef, double undef, i32 %x |
| %v4f64 = insertelement <4 x double> undef, double undef, i32 %x |
| %v8f64 = insertelement <8 x double> undef, double undef, i32 %x |
| %v16f64 = insertelement <16 x double> undef, double undef, i32 %x |
| %nxv16f64 = insertelement <vscale x 16 x double> undef, double undef, i32 %x |
| |
| ret void |
| } |