blob: 35a9bee03411fdbfd5c1563eacd71f1291b7b934 [file] [log] [blame]
; 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
}