mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 11:13:28 +01:00
91cf96359e
r243250 appeared to break clang/test/Analysis/dead-store.c on one of the build slaves, but I couldn't reproduce this failure locally. Probably a false positive as I saw this test was broken by r243246 or r243247 too but passed later without people fixing anything. llvm-svn: 243253
32 lines
883 B
LLVM
32 lines
883 B
LLVM
; RUN: opt < %s -cost-model -analyze | 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(i8* %a, i32 %b) {
|
|
; CHECK-LABEL: function 'addressing_mode_reg_reg'
|
|
%p = getelementptr i8, i8* %a, i32 %b ; NoTTI accepts reg+reg addressing.
|
|
; CHECK: cost of 0 {{.*}} getelementptr
|
|
%v = load i8, i8* %p
|
|
ret i8 %v
|
|
}
|
|
|
|
; CHECK-LABEL: function 'addressing_mode_scaled_reg'
|
|
define i32 @addressing_mode_scaled_reg(i32* %a, i32 %b) {
|
|
; NoTTI rejects reg+scale*reg addressing.
|
|
%p = getelementptr i32, i32* %a, i32 %b
|
|
; CHECK: cost of 1 {{.*}} getelementptr
|
|
%v = load i32, i32* %p
|
|
ret i32 %v
|
|
}
|