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
|
;=========================== begin_copyright_notice ============================
;
; Copyright (C) 2020-2025 Intel Corporation
;
; SPDX-License-Identifier: MIT
;
;============================ end_copyright_notice =============================
; RUN: %opt_typed_ptrs %use_old_pass_manager% -CMABILegacy -march=genx64 -mcpu=XeHPG -S < %s | FileCheck %s --check-prefixes=CHECK,CHECK-TYPED-PTRS
; RUN: %opt_opaque_ptrs %use_old_pass_manager% -CMABILegacy -march=genx64 -mcpu=XeHPG -S < %s | FileCheck %s --check-prefixes=CHECK,CHECK-OPAQUE-PTRS
; RUN: %opt_new_pm_typed -passes=CMABI -march=genx64 -mcpu=XeHPG -S < %s | FileCheck %s --check-prefixes=CHECK,CHECK-TYPED-PTRS
; RUN: %opt_new_pm_opaque -passes=CMABI -march=genx64 -mcpu=XeHPG -S < %s | FileCheck %s --check-prefixes=CHECK,CHECK-OPAQUE-PTRS
target datalayout = "e-p:64:64-i64:64-n8:16:32"
@simple_global_array = internal global [8 x i32] [i32 42, i32 43, i32 44, i32 45, i32 46, i32 47, i32 48, i32 49], align 4
; Function Attrs: noinline nounwind
define internal spir_func i32 @bar(i64 %passed.offset) {
; CHECK-TYPED-PTRS: define internal spir_func i32 @bar(i64 %passed.offset, [8 x i32]* %simple_global_array.in) {
; CHECK-OPAQUE-PTRS: define internal spir_func i32 @bar(i64 %passed.offset, ptr %simple_global_array.in) {
%elem.ptr = getelementptr inbounds [8 x i32], [8 x i32]* @simple_global_array, i64 0, i64 %passed.offset
; CHECK-TYPED-PTRS: %elem.ptr = getelementptr inbounds [8 x i32], [8 x i32]* %simple_global_array.in, i64 0, i64 %passed.offset
; CHECK-OPAQUE-PTRS: %elem.ptr = getelementptr inbounds [8 x i32], ptr %simple_global_array.in, i64 0, i64 %passed.offset
%elem = load i32, i32* %elem.ptr, align 4
ret i32 %elem
}
; Function Attrs: noinline nounwind
define dllexport void @foo_kernel(i64 %offset) {
; CHECK: %simple_global_array.local = alloca [8 x i32], align 4
; CHECK-TYPED-PTRS: store [8 x i32] [i32 42, i32 43, i32 44, i32 45, i32 46, i32 47, i32 48, i32 49], [8 x i32]* %simple_global_array.local
; CHECK-OPAQUE-PTRS: store [8 x i32] [i32 42, i32 43, i32 44, i32 45, i32 46, i32 47, i32 48, i32 49], ptr %simple_global_array.local
%ret.val = call spir_func i32 @bar(i64 %offset)
; CHECK-TYPED-PTRS: %ret.val = call spir_func i32 @bar(i64 %offset, [8 x i32]* %simple_global_array.local)
; CHECK-OPAQUE-PTRS: %ret.val = call spir_func i32 @bar(i64 %offset, ptr %simple_global_array.local)
%just.use = add nsw i32 %ret.val, 1
ret void
}
!genx.kernels = !{!0}
!0 = !{void (i64)* @foo_kernel}
|