51 lines
2.3 KiB
LLVM
51 lines
2.3 KiB
LLVM
; RUN: opt -loop-versioning -S < %s | FileCheck %s
|
|
|
|
; NB: addrspaces 10-13 are non-integral
|
|
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128-ni:10:11:12:13"
|
|
|
|
%jl_value_t = type opaque
|
|
%jl_array_t = type { i8 addrspace(13)*, i64, i16, i16, i32 }
|
|
|
|
define void @"japi1_permutedims!_33509"(%jl_value_t addrspace(10)**) {
|
|
; CHECK: [[CMP:%[^ ]*]] = icmp ult double addrspace(13)* [[A:%[^ ]*]], [[B:%[^ ]*]]
|
|
; CHECK: [[SELECT:%[^ ]*]] = select i1 %18, double addrspace(13)* [[A]], double addrspace(13)* [[B]]
|
|
top:
|
|
%1 = alloca [3 x i64], align 8
|
|
%2 = load %jl_value_t addrspace(10)*, %jl_value_t addrspace(10)** %0, align 8
|
|
%3 = getelementptr inbounds %jl_value_t addrspace(10)*, %jl_value_t addrspace(10)** %0, i64 1
|
|
%4 = load %jl_value_t addrspace(10)*, %jl_value_t addrspace(10)** %3, align 8
|
|
%5 = getelementptr inbounds [3 x i64], [3 x i64]* %1, i64 0, i64 0
|
|
store i64 1, i64* %5, align 8
|
|
%6 = getelementptr inbounds [3 x i64], [3 x i64]* %1, i64 0, i64 1
|
|
%7 = load i64, i64* inttoptr (i64 24 to i64*), align 8
|
|
%8 = addrspacecast %jl_value_t addrspace(10)* %4 to %jl_value_t addrspace(11)*
|
|
%9 = bitcast %jl_value_t addrspace(11)* %8 to double addrspace(13)* addrspace(11)*
|
|
%10 = load double addrspace(13)*, double addrspace(13)* addrspace(11)* %9, align 8
|
|
%11 = addrspacecast %jl_value_t addrspace(10)* %2 to %jl_value_t addrspace(11)*
|
|
%12 = bitcast %jl_value_t addrspace(11)* %11 to double addrspace(13)* addrspace(11)*
|
|
%13 = load double addrspace(13)*, double addrspace(13)* addrspace(11)* %12, align 8
|
|
%14 = load i64, i64* %6, align 8
|
|
br label %L74
|
|
|
|
L74:
|
|
%value_phi20 = phi i64 [ 1, %top ], [ %22, %L74 ]
|
|
%value_phi21 = phi i64 [ 1, %top ], [ %23, %L74 ]
|
|
%value_phi22 = phi i64 [ 1, %top ], [ %25, %L74 ]
|
|
%15 = add i64 %value_phi21, -1
|
|
%16 = getelementptr inbounds double, double addrspace(13)* %10, i64 %15
|
|
%17 = bitcast double addrspace(13)* %16 to i64 addrspace(13)*
|
|
%18 = load i64, i64 addrspace(13)* %17, align 8
|
|
%19 = add i64 %value_phi20, -1
|
|
%20 = getelementptr inbounds double, double addrspace(13)* %13, i64 %19
|
|
%21 = bitcast double addrspace(13)* %20 to i64 addrspace(13)*
|
|
store i64 %18, i64 addrspace(13)* %21, align 8
|
|
%22 = add i64 %value_phi20, 1
|
|
%23 = add i64 %14, %value_phi21
|
|
%24 = icmp eq i64 %value_phi22, %7
|
|
%25 = add i64 %value_phi22, 1
|
|
br i1 %24, label %L94, label %L74
|
|
|
|
L94:
|
|
ret void
|
|
}
|