102 lines
4.2 KiB
LLVM
102 lines
4.2 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py UTC_ARGS: --version 2
|
|
; RUN: opt -mtriple=riscv32 -mattr=+v -passes="print<cost-model>" 2>&1 -disable-output < %s \
|
|
; RUN: | FileCheck %s
|
|
; RUN: opt -mtriple=riscv64 -mattr=+v -passes="print<cost-model>" 2>&1 -disable-output < %s \
|
|
; RUN: | FileCheck %s
|
|
|
|
; These GEPs should all cost zero becuase all the indices operands are zero, so
|
|
; no computation actually needs to happen.
|
|
|
|
define ptr @zero_indices_i8(ptr %p) {
|
|
; CHECK-LABEL: 'zero_indices_i8'
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: %x = getelementptr i8, ptr %p, i32 0
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret ptr %x
|
|
;
|
|
%x = getelementptr i8, ptr %p, i32 0
|
|
ret ptr %x
|
|
}
|
|
|
|
define ptr @zero_indices_i16(ptr %p) {
|
|
; CHECK-LABEL: 'zero_indices_i16'
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: %x = getelementptr i16, ptr %p, i32 0
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret ptr %x
|
|
;
|
|
%x = getelementptr i16, ptr %p, i32 0
|
|
ret ptr %x
|
|
}
|
|
|
|
define ptr @zero_indices_i32(ptr %p) {
|
|
; CHECK-LABEL: 'zero_indices_i32'
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: %x = getelementptr i32, ptr %p, i32 0
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret ptr %x
|
|
;
|
|
%x = getelementptr i32, ptr %p, i32 0
|
|
ret ptr %x
|
|
}
|
|
|
|
define ptr @zero_indices_i64(ptr %p) {
|
|
; CHECK-LABEL: 'zero_indices_i64'
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: %x = getelementptr i64, ptr %p, i32 0
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret ptr %x
|
|
;
|
|
%x = getelementptr i64, ptr %p, i32 0
|
|
ret ptr %x
|
|
}
|
|
|
|
define ptr @zero_indices_array(ptr %p) {
|
|
; CHECK-LABEL: 'zero_indices_array'
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: %x = getelementptr [42 x i64], ptr %p, i32 0, i32 0
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret ptr %x
|
|
;
|
|
%x = getelementptr [42 x i64], ptr %p, i32 0, i32 0
|
|
ret ptr %x
|
|
}
|
|
|
|
%struct = type { %struct.inner }
|
|
%struct.inner = type { %struct.inner.inner }
|
|
%struct.inner.inner = type { i32 }
|
|
|
|
define ptr @zero_indices_struct(ptr %p) {
|
|
; CHECK-LABEL: 'zero_indices_struct'
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: %x = getelementptr %struct, ptr %p, i32 0, i32 0, i32 0
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret ptr %x
|
|
;
|
|
%x = getelementptr %struct, ptr %p, i32 0, i32 0, i32 0
|
|
ret ptr %x
|
|
}
|
|
|
|
define <4 x ptr> @zero_indices_v4i32(<4 x ptr> %p) {
|
|
; CHECK-LABEL: 'zero_indices_v4i32'
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: %x = getelementptr i32, <4 x ptr> %p, <4 x i32> zeroinitializer
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret <4 x ptr> %x
|
|
;
|
|
%x = getelementptr i32, <4 x ptr> %p, <4 x i32> zeroinitializer
|
|
ret <4 x ptr> %x
|
|
}
|
|
|
|
define <16 x ptr> @zero_indices_v16i32(<16 x ptr> %p) {
|
|
; CHECK-LABEL: 'zero_indices_v16i32'
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: %x = getelementptr i32, <16 x ptr> %p, <16 x i32> zeroinitializer
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret <16 x ptr> %x
|
|
;
|
|
%x = getelementptr i32, <16 x ptr> %p, <16 x i32> zeroinitializer
|
|
ret <16 x ptr> %x
|
|
}
|
|
|
|
define <4 x ptr> @zero_indices_v4f32(<4 x ptr> %p) {
|
|
; CHECK-LABEL: 'zero_indices_v4f32'
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: %x = getelementptr float, <4 x ptr> %p, <4 x i32> zeroinitializer
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret <4 x ptr> %x
|
|
;
|
|
%x = getelementptr float, <4 x ptr> %p, <4 x i32> zeroinitializer
|
|
ret <4 x ptr> %x
|
|
}
|
|
|
|
define <4 x ptr> @zero_indices_v4v4i32(<4 x ptr> %p) {
|
|
; CHECK-LABEL: 'zero_indices_v4v4i32'
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: %x = getelementptr <32 x i32>, <4 x ptr> %p, <4 x i32> zeroinitializer, <4 x i32> zeroinitializer
|
|
; CHECK-NEXT: Cost Model: Found an estimated cost of 0 for instruction: ret <4 x ptr> %x
|
|
;
|
|
%x = getelementptr <32 x i32>, <4 x ptr> %p, <4 x i32> zeroinitializer, <4 x i32> zeroinitializer
|
|
ret <4 x ptr> %x
|
|
}
|