xref: /llvm-project/clang/test/CodeGenOpenCL/kernel-param-alignment.cl (revision 29441e4f5fa5f5c7709f7cf180815ba97f611297)
1aae20a74SNikita Popov// RUN: %clang_cc1 %s -cl-std=CL1.2 -emit-llvm -triple x86_64-unknown-unknown -o - | FileCheck %s
218834dcaSNikita Popov
318834dcaSNikita Popov// Test that pointer arguments to kernels are assumed to be ABI aligned.
418834dcaSNikita Popov
518834dcaSNikita Popovstruct __attribute__((packed, aligned(1))) packed {
618834dcaSNikita Popov  int i32;
718834dcaSNikita Popov};
818834dcaSNikita Popov
918834dcaSNikita Popovtypedef __attribute__((ext_vector_type(4))) int int4;
1018834dcaSNikita Popovtypedef __attribute__((ext_vector_type(2))) float float2;
1118834dcaSNikita Popov
1218834dcaSNikita Popovkernel void test(
1318834dcaSNikita Popov    global int *i32,
1418834dcaSNikita Popov    global long *i64,
1518834dcaSNikita Popov    global int4 *v4i32,
1618834dcaSNikita Popov    global float2 *v2f32,
1718834dcaSNikita Popov    global void *v,
1818834dcaSNikita Popov    global struct packed *p) {
1918834dcaSNikita Popov// CHECK-LABEL: spir_kernel void @test(
20*29441e4fSNikita Popov// CHECK-SAME: ptr noundef readnone align 4 captures(none) %i32,
21*29441e4fSNikita Popov// CHECK-SAME: ptr noundef readnone align 8 captures(none) %i64,
22*29441e4fSNikita Popov// CHECK-SAME: ptr noundef readnone align 16 captures(none) %v4i32,
23*29441e4fSNikita Popov// CHECK-SAME: ptr noundef readnone align 8 captures(none) %v2f32,
24*29441e4fSNikita Popov// CHECK-SAME: ptr noundef readnone captures(none) %v,
25*29441e4fSNikita Popov// CHECK-SAME: ptr noundef readnone align 1 captures(none) %p)
2618834dcaSNikita Popov}
27