46 lines
1.7 KiB
LLVM
46 lines
1.7 KiB
LLVM
; RUN: opt -S -loop-reduce < %s | FileCheck %s
|
|
|
|
; Address Space 10 is non-integral. The optimizer is not allowed to use
|
|
; ptrtoint/inttoptr instructions. Make sure that this doesn't happen
|
|
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128-ni:10:11:12"
|
|
target triple = "x86_64-unknown-linux-gnu"
|
|
|
|
define void @japi1__unsafe_getindex_65028(i64 addrspace(10)* %arg) {
|
|
; CHECK-NOT: inttoptr
|
|
; CHECK-NOT: ptrtoint
|
|
; How exactly SCEV chooses to materialize isn't all that important, as
|
|
; long as it doesn't try to round-trip through integers. As of this writing,
|
|
; it emits a byte-wise gep, which is fine.
|
|
; CHECK: getelementptr i64, i64 addrspace(10)* {{.*}}, i64 {{.*}}
|
|
top:
|
|
br label %L86
|
|
|
|
L86: ; preds = %L86, %top
|
|
%i.0 = phi i64 [ 0, %top ], [ %tmp, %L86 ]
|
|
%tmp = add i64 %i.0, 1
|
|
br i1 undef, label %L86, label %if29
|
|
|
|
if29: ; preds = %L86
|
|
%tmp1 = shl i64 %tmp, 1
|
|
%tmp2 = add i64 %tmp1, -2
|
|
br label %if31
|
|
|
|
if31: ; preds = %if38, %if29
|
|
%"#temp#1.sroa.0.022" = phi i64 [ 0, %if29 ], [ %tmp3, %if38 ]
|
|
br label %L119
|
|
|
|
L119: ; preds = %L119, %if31
|
|
%i5.0 = phi i64 [ %"#temp#1.sroa.0.022", %if31 ], [ %tmp3, %L119 ]
|
|
%tmp3 = add i64 %i5.0, 1
|
|
br i1 undef, label %L119, label %if38
|
|
|
|
if38: ; preds = %L119
|
|
%tmp4 = add i64 %tmp2, %i5.0
|
|
%tmp5 = getelementptr i64, i64 addrspace(10)* %arg, i64 %tmp4
|
|
%tmp6 = load i64, i64 addrspace(10)* %tmp5
|
|
br i1 undef, label %done, label %if31
|
|
|
|
done: ; preds = %if38
|
|
ret void
|
|
}
|