2012-12-26 02:51:18 +08:00
|
|
|
target datalayout = "E-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v128:128:128-n32:64"
|
|
|
|
target triple = "powerpc64-unknown-linux-gnu"
|
2016-08-04 02:17:35 +08:00
|
|
|
; RUN: llc -verify-machineinstrs -mcpu=a2 -enable-misched -enable-aa-sched-mi < %s | FileCheck %s
|
2012-12-26 02:51:18 +08:00
|
|
|
|
|
|
|
define i8 @test1(i8* noalias %a, i8* noalias %b, i8* noalias %c) nounwind {
|
|
|
|
entry:
|
2015-02-28 05:17:42 +08:00
|
|
|
%q = load i8, i8* %b
|
2012-12-26 02:51:18 +08:00
|
|
|
call void @llvm.prefetch(i8* %a, i32 0, i32 3, i32 1)
|
2015-02-28 05:17:42 +08:00
|
|
|
%r = load i8, i8* %c
|
2012-12-26 02:51:18 +08:00
|
|
|
%s = add i8 %q, %r
|
|
|
|
ret i8 %s
|
|
|
|
}
|
|
|
|
|
|
|
|
declare void @llvm.prefetch(i8*, i32, i32, i32)
|
|
|
|
|
|
|
|
; Test that we've moved the second load to before the dcbt to better
|
|
|
|
; hide its latency.
|
|
|
|
; CHECK: @test1
|
|
|
|
; CHECK: lbz
|
|
|
|
; CHECK: lbz
|
|
|
|
; CHECK: dcbt
|
|
|
|
|