1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
|
; RUN: opt -S -mtriple=amdgcn-- -passes=amdgpu-lower-ctor-dtor < %s | FileCheck %s
; RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx700 -filetype=obj -o - < %s | llvm-readelf -s - 2>&1 | FileCheck %s -check-prefix=CHECK-VIS
; Make sure there's no crash or error if amdgcn.device.init or
; amdgcn.device.fini already exist.
@llvm.global_ctors = appending addrspace(1) global [1 x { i32, ptr, ptr }] [{ i32, ptr, ptr } { i32 1, ptr @foo, ptr null }]
@llvm.global_dtors = appending addrspace(1) global [1 x { i32, ptr, ptr }] [{ i32, ptr, ptr } { i32 1, ptr @bar, ptr null }]
; CHECK-NOT: @llvm.global_ctors
; CHECK-NOT: @llvm.global_dtors
; CHECK-LABEL: amdgpu_kernel void @amdgcn.device.init() #0
; CHECK-NEXT: store
; CHECK-NEXT: ret void
; CHECK-LABEL: amdgpu_kernel void @amdgcn.device.fini() #1
; CHECK-NEXT: store
; CHECK-NEXT: ret void
; CHECK-LABEL: amdgpu_kernel void @amdgcn.device.init.1() #0
; CHECK-NEXT: call void @foo
; CHECK-NEXT: ret void
; CHECK-LABEL: amdgpu_kernel void @amdgcn.device.fini.2() #1
; CHECK-NEXT: call void @bar
; CHECK-NEXT: ret void
; CHECK-NOT: amdgcn.device.
; CHECK-VIS: FUNC GLOBAL PROTECTED {{.*}} amdgcn.device.init{{$}}
; CHECK-VIS: OBJECT GLOBAL DEFAULT {{.*}} amdgcn.device.init.kd{{$}}
; CHECK-VIS: FUNC GLOBAL PROTECTED {{.*}} amdgcn.device.fini{{$}}
; CHECK-VIS: OBJECT GLOBAL DEFAULT {{.*}} amdgcn.device.fini.kd{{$}}
; CHECK-VIS: FUNC GLOBAL PROTECTED {{.*}} amdgcn.device.init.1{{$}}
; CHECK-VIS: OBJECT GLOBAL DEFAULT {{.*}} amdgcn.device.init.1.kd{{$}}
; CHECK-VIS: FUNC GLOBAL PROTECTED {{.*}} amdgcn.device.fini.2{{$}}
; CHECK-VIS: OBJECT GLOBAL DEFAULT {{.*}} amdgcn.device.fini.2.kd{{$}}
define internal void @foo() {
ret void
}
define internal void @bar() {
ret void
}
define amdgpu_kernel void @amdgcn.device.init() #0 {
store volatile i32 1, ptr addrspace(1) null
ret void
}
define amdgpu_kernel void @amdgcn.device.fini() #1 {
store volatile i32 0, ptr addrspace(1) null
ret void
}
attributes #0 = { "device-init" }
attributes #1 = { "device-fini" }
; CHECK: attributes #0 = { "device-init" }
; CHECK: attributes #1 = { "device-fini" }
|