; RUN: opt < %s -passes="print<cost-model>" 2>&1 -disable-output | FileCheck %s
; The cost model does not have any target information so it just makes boring
; assumptions.
; -- No triple in this module --
; CHECK-LABEL: function 'no_info'
; CHECK: cost of 1 {{.*}} add
; CHECK: cost of 1 {{.*}} ret
define i32 @no_info(i32 %arg) {
%e = add i32 %arg, %arg
ret i32 %e
}
define i8 @addressing_mode_reg_reg(ptr %a, i32 %b) {
; CHECK-LABEL: function 'addressing_mode_reg_reg'
%p = getelementptr i8, ptr %a, i32 %b ; NoTTI accepts reg+reg addressing.
; CHECK: cost of 0 {{.*}} getelementptr
%v = load i8, ptr %p
ret i8 %v
}
; CHECK-LABEL: function 'addressing_mode_scaled_reg'
define i32 @addressing_mode_scaled_reg(ptr %a, i32 %b) {
; NoTTI rejects reg+scale*reg addressing.
%p = getelementptr i32, ptr %a, i32 %b
; CHECK: cost of 1 {{.*}} getelementptr
%v = load i32, ptr %p
ret i32 %v
}