52 lines
1.9 KiB
LLVM
52 lines
1.9 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 6
|
|
; RUN: opt -S -mtriple=amdgcn-amd-amdhsa -amdgpu-lower-module-lds %s -o - | FileCheck %s
|
|
; RUN: opt -S -mtriple=amdgcn-amd-amdhsa -passes=amdgpu-lower-module-lds %s -o - | FileCheck %s
|
|
|
|
@lds = internal unnamed_addr addrspace(3) global [6144 x half] poison, align 2
|
|
|
|
define amdgpu_kernel void @test(ptr addrspace(1) %out) {
|
|
; CHECK-LABEL: define amdgpu_kernel void @test(
|
|
; CHECK-SAME: ptr addrspace(1) [[OUT:%.*]]) #[[ATTR0:[0-9]+]] {
|
|
; CHECK-NEXT: [[ENTRY:.*]]:
|
|
; CHECK-NEXT: switch i32 0, label %[[BB_3:.*]] [
|
|
; CHECK-NEXT: i32 18, label %[[BB_2:.*]]
|
|
; CHECK-NEXT: i32 1, label %[[BB_2]]
|
|
; CHECK-NEXT: i32 0, label %[[BB_3]]
|
|
; CHECK-NEXT: ]
|
|
; CHECK: [[BB_1:.*]]:
|
|
; CHECK-NEXT: [[TMP0:%.*]] = addrspacecast ptr addrspace(3) @llvm.amdgcn.kernel.test.lds to ptr
|
|
; CHECK-NEXT: [[TMP1:%.*]] = ptrtoint ptr [[TMP0]] to i64
|
|
; CHECK-NEXT: switch i32 0, label %[[BB_3]] [
|
|
; CHECK-NEXT: i32 18, label %[[BB_2]]
|
|
; CHECK-NEXT: i32 1, label %[[BB_2]]
|
|
; CHECK-NEXT: i32 0, label %[[BB_3]]
|
|
; CHECK-NEXT: ]
|
|
; CHECK: [[BB_2]]:
|
|
; CHECK-NEXT: [[PHI:%.*]] = phi i64 [ [[TMP1]], %[[BB_1]] ], [ [[TMP1]], %[[BB_1]] ], [ 10, %[[ENTRY]] ], [ 10, %[[ENTRY]] ]
|
|
; CHECK-NEXT: store i64 [[PHI]], ptr addrspace(1) [[OUT]], align 8
|
|
; CHECK-NEXT: br label %[[BB_3]]
|
|
; CHECK: [[BB_3]]:
|
|
; CHECK-NEXT: ret void
|
|
;
|
|
entry:
|
|
switch i32 0, label %bb.3 [
|
|
i32 18, label %bb.2
|
|
i32 1, label %bb.2
|
|
i32 0, label %bb.3
|
|
]
|
|
bb.1:
|
|
switch i32 0, label %bb.3 [
|
|
i32 18, label %bb.2
|
|
i32 1, label %bb.2
|
|
i32 0, label %bb.3
|
|
]
|
|
|
|
bb.2:
|
|
%phi = phi i64 [ ptrtoint (ptr addrspacecast (ptr addrspace(3) @lds to ptr) to i64), %bb.1 ], [ ptrtoint (ptr addrspacecast (ptr addrspace(3) @lds to ptr) to i64), %bb.1 ], [10, %entry], [10, %entry]
|
|
store i64 %phi, ptr addrspace(1) %out, align 8
|
|
br label %bb.3
|
|
|
|
bb.3:
|
|
ret void
|
|
}
|