mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-27 00:56:06 +00:00

Currently, for AMDGPU, when compiling for OpenCL, we unconditionally use `private` as the default address space. This is wrong for cases where the `generic` address space is available, and is corrected via this patch. In general, this AS map abuse is a bad hack and we should re-work it altogether, but at least after this patch we will stop being incorrect for e.g. OpenCL 2.0.
566 lines
36 KiB
Common Lisp
566 lines
36 KiB
Common Lisp
// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py UTC_ARGS: --version 5
|
|
// RUN: %clang_cc1 %s -O0 -triple amdgcn-amd-amdhsa -cl-std=CL1.2 \
|
|
// RUN: -emit-llvm -o - | FileCheck --check-prefixes=OPENCL12 %s
|
|
// RUN: %clang_cc1 %s -O0 -triple amdgcn-amd-amdhsa -cl-std=CL2.0 \
|
|
// RUN: -emit-llvm -o - | FileCheck --check-prefixes=OPENCL20 %s
|
|
// RUN: %clang_cc1 %s -O0 -triple amdgcn-amd-amdhsa -cl-std=CL3.0 \
|
|
// RUN: -emit-llvm -o - | FileCheck --check-prefixes=OPENCL30 %s
|
|
// RUN: %clang_cc1 %s -O0 -triple amdgcn-amd-amdhsa -cl-std=CL3.0 -cl-ext=+__opencl_c_generic_address_space \
|
|
// RUN: -emit-llvm -o - | FileCheck --check-prefixes=OPENCL30GAS %s
|
|
|
|
// OPENCL-LABEL: define dso_local void @test1_builtin_alloca(
|
|
// OPENCL-SAME: i32 noundef [[N:%.*]]) #[[ATTR0:[0-9]+]] {
|
|
// OPENCL-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL-NEXT: [[ALLOC_PTR:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 8, addrspace(5)
|
|
// OPENCL-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR]], align 4
|
|
// OPENCL-NEXT: ret void
|
|
// OPENCL12-LABEL: define dso_local void @test1_builtin_alloca(
|
|
// OPENCL12-SAME: i32 noundef [[N:%.*]]) #[[ATTR0:[0-9]+]] {
|
|
// OPENCL12-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL12-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL12-NEXT: [[ALLOC_PTR:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL12-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL12-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL12-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 8, addrspace(5)
|
|
// OPENCL12-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR]], align 4
|
|
// OPENCL12-NEXT: ret void
|
|
//
|
|
// OPENCL20-LABEL: define dso_local void @test1_builtin_alloca(
|
|
// OPENCL20-SAME: i32 noundef [[N:%.*]]) #[[ATTR0:[0-9]+]] {
|
|
// OPENCL20-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL20-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[ALLOC_PTR:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL20-NEXT: [[ALLOC_PTR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR]] to ptr
|
|
// OPENCL20-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL20-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL20-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 8, addrspace(5)
|
|
// OPENCL20-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: ret void
|
|
//
|
|
// OPENCL30-LABEL: define dso_local void @test1_builtin_alloca(
|
|
// OPENCL30-SAME: i32 noundef [[N:%.*]]) #[[ATTR0:[0-9]+]] {
|
|
// OPENCL30-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30-NEXT: [[ALLOC_PTR:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL30-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 8, addrspace(5)
|
|
// OPENCL30-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR]], align 4
|
|
// OPENCL30-NEXT: ret void
|
|
//
|
|
// OPENCL30GAS-LABEL: define dso_local void @test1_builtin_alloca(
|
|
// OPENCL30GAS-SAME: i32 noundef [[N:%.*]]) #[[ATTR0:[0-9]+]] {
|
|
// OPENCL30GAS-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30GAS-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR]] to ptr
|
|
// OPENCL30GAS-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30GAS-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL30GAS-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 8, addrspace(5)
|
|
// OPENCL30GAS-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: ret void
|
|
//
|
|
void test1_builtin_alloca(unsigned n) {
|
|
__private float* alloc_ptr = (__private float*)__builtin_alloca(n*sizeof(int));
|
|
}
|
|
|
|
// OPENCL-LABEL: define dso_local void @test1_builtin_alloca_uninitialized(
|
|
// OPENCL-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL-NEXT: [[ALLOC_PTR_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 8, addrspace(5)
|
|
// OPENCL-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_UNINITIALIZED]], align 4
|
|
// OPENCL-NEXT: ret void
|
|
// OPENCL12-LABEL: define dso_local void @test1_builtin_alloca_uninitialized(
|
|
// OPENCL12-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL12-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL12-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL12-NEXT: [[ALLOC_PTR_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL12-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL12-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL12-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 8, addrspace(5)
|
|
// OPENCL12-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_UNINITIALIZED]], align 4
|
|
// OPENCL12-NEXT: ret void
|
|
//
|
|
// OPENCL20-LABEL: define dso_local void @test1_builtin_alloca_uninitialized(
|
|
// OPENCL20-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL20-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL20-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[ALLOC_PTR_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL20-NEXT: [[ALLOC_PTR_UNINITIALIZED_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR_UNINITIALIZED]] to ptr
|
|
// OPENCL20-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL20-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL20-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 8, addrspace(5)
|
|
// OPENCL20-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_UNINITIALIZED_ASCAST]], align 4
|
|
// OPENCL20-NEXT: ret void
|
|
//
|
|
// OPENCL30-LABEL: define dso_local void @test1_builtin_alloca_uninitialized(
|
|
// OPENCL30-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL30-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30-NEXT: [[ALLOC_PTR_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL30-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 8, addrspace(5)
|
|
// OPENCL30-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_UNINITIALIZED]], align 4
|
|
// OPENCL30-NEXT: ret void
|
|
//
|
|
// OPENCL30GAS-LABEL: define dso_local void @test1_builtin_alloca_uninitialized(
|
|
// OPENCL30GAS-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL30GAS-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30GAS-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR_UNINITIALIZED_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR_UNINITIALIZED]] to ptr
|
|
// OPENCL30GAS-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30GAS-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL30GAS-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 8, addrspace(5)
|
|
// OPENCL30GAS-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_UNINITIALIZED_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: ret void
|
|
//
|
|
void test1_builtin_alloca_uninitialized(unsigned n) {
|
|
__private float* alloc_ptr_uninitialized = (__private float*)__builtin_alloca_uninitialized(n*sizeof(int));
|
|
}
|
|
|
|
// OPENCL-LABEL: define dso_local void @test1_builtin_alloca_with_align(
|
|
// OPENCL-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL-NEXT: [[ALLOC_PTR_ALIGN:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 1, addrspace(5)
|
|
// OPENCL-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_ALIGN]], align 4
|
|
// OPENCL-NEXT: ret void
|
|
// OPENCL12-LABEL: define dso_local void @test1_builtin_alloca_with_align(
|
|
// OPENCL12-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL12-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL12-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL12-NEXT: [[ALLOC_PTR_ALIGN:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL12-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL12-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL12-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 1, addrspace(5)
|
|
// OPENCL12-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_ALIGN]], align 4
|
|
// OPENCL12-NEXT: ret void
|
|
//
|
|
// OPENCL20-LABEL: define dso_local void @test1_builtin_alloca_with_align(
|
|
// OPENCL20-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL20-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL20-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[ALLOC_PTR_ALIGN:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL20-NEXT: [[ALLOC_PTR_ALIGN_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR_ALIGN]] to ptr
|
|
// OPENCL20-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL20-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL20-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 1, addrspace(5)
|
|
// OPENCL20-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_ALIGN_ASCAST]], align 4
|
|
// OPENCL20-NEXT: ret void
|
|
//
|
|
// OPENCL30-LABEL: define dso_local void @test1_builtin_alloca_with_align(
|
|
// OPENCL30-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL30-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30-NEXT: [[ALLOC_PTR_ALIGN:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL30-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 1, addrspace(5)
|
|
// OPENCL30-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_ALIGN]], align 4
|
|
// OPENCL30-NEXT: ret void
|
|
//
|
|
// OPENCL30GAS-LABEL: define dso_local void @test1_builtin_alloca_with_align(
|
|
// OPENCL30GAS-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL30GAS-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30GAS-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR_ALIGN:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR_ALIGN_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR_ALIGN]] to ptr
|
|
// OPENCL30GAS-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30GAS-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL30GAS-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 1, addrspace(5)
|
|
// OPENCL30GAS-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_ALIGN_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: ret void
|
|
//
|
|
void test1_builtin_alloca_with_align(unsigned n) {
|
|
__private float* alloc_ptr_align = (__private float*)__builtin_alloca_with_align((n*sizeof(int)), 8);
|
|
}
|
|
|
|
// OPENCL-LABEL: define dso_local void @test1_builtin_alloca_with_align_uninitialized(
|
|
// OPENCL-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL-NEXT: [[ALLOC_PTR_ALIGN_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 1, addrspace(5)
|
|
// OPENCL-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_ALIGN_UNINITIALIZED]], align 4
|
|
// OPENCL-NEXT: ret void
|
|
// OPENCL12-LABEL: define dso_local void @test1_builtin_alloca_with_align_uninitialized(
|
|
// OPENCL12-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL12-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL12-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL12-NEXT: [[ALLOC_PTR_ALIGN_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL12-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL12-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL12-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 1, addrspace(5)
|
|
// OPENCL12-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_ALIGN_UNINITIALIZED]], align 4
|
|
// OPENCL12-NEXT: ret void
|
|
//
|
|
// OPENCL20-LABEL: define dso_local void @test1_builtin_alloca_with_align_uninitialized(
|
|
// OPENCL20-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL20-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL20-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[ALLOC_PTR_ALIGN_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL20-NEXT: [[ALLOC_PTR_ALIGN_UNINITIALIZED_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR_ALIGN_UNINITIALIZED]] to ptr
|
|
// OPENCL20-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL20-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL20-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 1, addrspace(5)
|
|
// OPENCL20-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_ALIGN_UNINITIALIZED_ASCAST]], align 4
|
|
// OPENCL20-NEXT: ret void
|
|
//
|
|
// OPENCL30-LABEL: define dso_local void @test1_builtin_alloca_with_align_uninitialized(
|
|
// OPENCL30-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL30-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30-NEXT: [[ALLOC_PTR_ALIGN_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL30-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 1, addrspace(5)
|
|
// OPENCL30-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_ALIGN_UNINITIALIZED]], align 4
|
|
// OPENCL30-NEXT: ret void
|
|
//
|
|
// OPENCL30GAS-LABEL: define dso_local void @test1_builtin_alloca_with_align_uninitialized(
|
|
// OPENCL30GAS-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL30GAS-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30GAS-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR_ALIGN_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR_ALIGN_UNINITIALIZED_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR_ALIGN_UNINITIALIZED]] to ptr
|
|
// OPENCL30GAS-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30GAS-NEXT: [[MUL:%.*]] = mul i64 [[CONV]], 4
|
|
// OPENCL30GAS-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[MUL]], align 1, addrspace(5)
|
|
// OPENCL30GAS-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_ALIGN_UNINITIALIZED_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: ret void
|
|
//
|
|
void test1_builtin_alloca_with_align_uninitialized(unsigned n) {
|
|
__private float* alloc_ptr_align_uninitialized = (__private float*)__builtin_alloca_with_align_uninitialized((n*sizeof(int)), 8);
|
|
}
|
|
|
|
// OPENCL-LABEL: define dso_local void @test2_builtin_alloca(
|
|
// OPENCL-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL-NEXT: [[ALLOC_PTR:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 8, addrspace(5)
|
|
// OPENCL-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR]], align 4
|
|
// OPENCL-NEXT: ret void
|
|
// OPENCL12-LABEL: define dso_local void @test2_builtin_alloca(
|
|
// OPENCL12-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL12-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL12-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL12-NEXT: [[ALLOC_PTR:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL12-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL12-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 8, addrspace(5)
|
|
// OPENCL12-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR]], align 4
|
|
// OPENCL12-NEXT: ret void
|
|
//
|
|
// OPENCL20-LABEL: define dso_local void @test2_builtin_alloca(
|
|
// OPENCL20-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL20-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL20-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[ALLOC_PTR:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL20-NEXT: [[ALLOC_PTR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR]] to ptr
|
|
// OPENCL20-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL20-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 8, addrspace(5)
|
|
// OPENCL20-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: ret void
|
|
//
|
|
// OPENCL30-LABEL: define dso_local void @test2_builtin_alloca(
|
|
// OPENCL30-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL30-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30-NEXT: [[ALLOC_PTR:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 8, addrspace(5)
|
|
// OPENCL30-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR]], align 4
|
|
// OPENCL30-NEXT: ret void
|
|
//
|
|
// OPENCL30GAS-LABEL: define dso_local void @test2_builtin_alloca(
|
|
// OPENCL30GAS-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL30GAS-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30GAS-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR]] to ptr
|
|
// OPENCL30GAS-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30GAS-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 8, addrspace(5)
|
|
// OPENCL30GAS-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: ret void
|
|
//
|
|
void test2_builtin_alloca(unsigned n) {
|
|
__private void *alloc_ptr = __builtin_alloca(n);
|
|
}
|
|
|
|
// OPENCL-LABEL: define dso_local void @test2_builtin_alloca_uninitialized(
|
|
// OPENCL-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL-NEXT: [[ALLOC_PTR_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 8, addrspace(5)
|
|
// OPENCL-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_UNINITIALIZED]], align 4
|
|
// OPENCL-NEXT: ret void
|
|
// OPENCL12-LABEL: define dso_local void @test2_builtin_alloca_uninitialized(
|
|
// OPENCL12-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL12-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL12-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL12-NEXT: [[ALLOC_PTR_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL12-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL12-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 8, addrspace(5)
|
|
// OPENCL12-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_UNINITIALIZED]], align 4
|
|
// OPENCL12-NEXT: ret void
|
|
//
|
|
// OPENCL20-LABEL: define dso_local void @test2_builtin_alloca_uninitialized(
|
|
// OPENCL20-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL20-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL20-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[ALLOC_PTR_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL20-NEXT: [[ALLOC_PTR_UNINITIALIZED_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR_UNINITIALIZED]] to ptr
|
|
// OPENCL20-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL20-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 8, addrspace(5)
|
|
// OPENCL20-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_UNINITIALIZED_ASCAST]], align 4
|
|
// OPENCL20-NEXT: ret void
|
|
//
|
|
// OPENCL30-LABEL: define dso_local void @test2_builtin_alloca_uninitialized(
|
|
// OPENCL30-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL30-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30-NEXT: [[ALLOC_PTR_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 8, addrspace(5)
|
|
// OPENCL30-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_UNINITIALIZED]], align 4
|
|
// OPENCL30-NEXT: ret void
|
|
//
|
|
// OPENCL30GAS-LABEL: define dso_local void @test2_builtin_alloca_uninitialized(
|
|
// OPENCL30GAS-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL30GAS-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30GAS-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR_UNINITIALIZED_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR_UNINITIALIZED]] to ptr
|
|
// OPENCL30GAS-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30GAS-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 8, addrspace(5)
|
|
// OPENCL30GAS-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_UNINITIALIZED_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: ret void
|
|
//
|
|
void test2_builtin_alloca_uninitialized(unsigned n) {
|
|
__private void *alloc_ptr_uninitialized = __builtin_alloca_uninitialized(n);
|
|
}
|
|
|
|
// OPENCL-LABEL: define dso_local void @test2_builtin_alloca_with_align(
|
|
// OPENCL-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL-NEXT: [[ALLOC_PTR_ALIGN:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 1, addrspace(5)
|
|
// OPENCL-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_ALIGN]], align 4
|
|
// OPENCL-NEXT: ret void
|
|
// OPENCL12-LABEL: define dso_local void @test2_builtin_alloca_with_align(
|
|
// OPENCL12-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL12-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL12-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL12-NEXT: [[ALLOC_PTR_ALIGN:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL12-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL12-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 1, addrspace(5)
|
|
// OPENCL12-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_ALIGN]], align 4
|
|
// OPENCL12-NEXT: ret void
|
|
//
|
|
// OPENCL20-LABEL: define dso_local void @test2_builtin_alloca_with_align(
|
|
// OPENCL20-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL20-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL20-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[ALLOC_PTR_ALIGN:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL20-NEXT: [[ALLOC_PTR_ALIGN_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR_ALIGN]] to ptr
|
|
// OPENCL20-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL20-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 1, addrspace(5)
|
|
// OPENCL20-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_ALIGN_ASCAST]], align 4
|
|
// OPENCL20-NEXT: ret void
|
|
//
|
|
// OPENCL30-LABEL: define dso_local void @test2_builtin_alloca_with_align(
|
|
// OPENCL30-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL30-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30-NEXT: [[ALLOC_PTR_ALIGN:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 1, addrspace(5)
|
|
// OPENCL30-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_ALIGN]], align 4
|
|
// OPENCL30-NEXT: ret void
|
|
//
|
|
// OPENCL30GAS-LABEL: define dso_local void @test2_builtin_alloca_with_align(
|
|
// OPENCL30GAS-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL30GAS-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30GAS-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR_ALIGN:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR_ALIGN_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR_ALIGN]] to ptr
|
|
// OPENCL30GAS-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30GAS-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 1, addrspace(5)
|
|
// OPENCL30GAS-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_ALIGN_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: ret void
|
|
//
|
|
void test2_builtin_alloca_with_align(unsigned n) {
|
|
__private void *alloc_ptr_align = __builtin_alloca_with_align(n, 8);
|
|
}
|
|
|
|
// OPENCL-LABEL: define dso_local void @test2_builtin_alloca_with_align_uninitialized(
|
|
// OPENCL-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL-NEXT: [[ALLOC_PTR_ALIGN_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 1, addrspace(5)
|
|
// OPENCL-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_ALIGN_UNINITIALIZED]], align 4
|
|
// OPENCL-NEXT: ret void
|
|
// OPENCL12-LABEL: define dso_local void @test2_builtin_alloca_with_align_uninitialized(
|
|
// OPENCL12-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL12-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL12-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL12-NEXT: [[ALLOC_PTR_ALIGN_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL12-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL12-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL12-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 1, addrspace(5)
|
|
// OPENCL12-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_ALIGN_UNINITIALIZED]], align 4
|
|
// OPENCL12-NEXT: ret void
|
|
//
|
|
// OPENCL20-LABEL: define dso_local void @test2_builtin_alloca_with_align_uninitialized(
|
|
// OPENCL20-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL20-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL20-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[ALLOC_PTR_ALIGN_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL20-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL20-NEXT: [[ALLOC_PTR_ALIGN_UNINITIALIZED_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR_ALIGN_UNINITIALIZED]] to ptr
|
|
// OPENCL20-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL20-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL20-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 1, addrspace(5)
|
|
// OPENCL20-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_ALIGN_UNINITIALIZED_ASCAST]], align 4
|
|
// OPENCL20-NEXT: ret void
|
|
//
|
|
// OPENCL30-LABEL: define dso_local void @test2_builtin_alloca_with_align_uninitialized(
|
|
// OPENCL30-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL30-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30-NEXT: [[ALLOC_PTR_ALIGN_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30-NEXT: store i32 [[N]], ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[TMP0:%.*]] = load i32, ptr addrspace(5) [[N_ADDR]], align 4
|
|
// OPENCL30-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 1, addrspace(5)
|
|
// OPENCL30-NEXT: store ptr addrspace(5) [[TMP1]], ptr addrspace(5) [[ALLOC_PTR_ALIGN_UNINITIALIZED]], align 4
|
|
// OPENCL30-NEXT: ret void
|
|
//
|
|
// OPENCL30GAS-LABEL: define dso_local void @test2_builtin_alloca_with_align_uninitialized(
|
|
// OPENCL30GAS-SAME: i32 noundef [[N:%.*]]) #[[ATTR0]] {
|
|
// OPENCL30GAS-NEXT: [[ENTRY:.*:]]
|
|
// OPENCL30GAS-NEXT: [[N_ADDR:%.*]] = alloca i32, align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR_ALIGN_UNINITIALIZED:%.*]] = alloca ptr addrspace(5), align 4, addrspace(5)
|
|
// OPENCL30GAS-NEXT: [[N_ADDR_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[N_ADDR]] to ptr
|
|
// OPENCL30GAS-NEXT: [[ALLOC_PTR_ALIGN_UNINITIALIZED_ASCAST:%.*]] = addrspacecast ptr addrspace(5) [[ALLOC_PTR_ALIGN_UNINITIALIZED]] to ptr
|
|
// OPENCL30GAS-NEXT: store i32 [[N]], ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[TMP0:%.*]] = load i32, ptr [[N_ADDR_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: [[CONV:%.*]] = zext i32 [[TMP0]] to i64
|
|
// OPENCL30GAS-NEXT: [[TMP1:%.*]] = alloca i8, i64 [[CONV]], align 1, addrspace(5)
|
|
// OPENCL30GAS-NEXT: store ptr addrspace(5) [[TMP1]], ptr [[ALLOC_PTR_ALIGN_UNINITIALIZED_ASCAST]], align 4
|
|
// OPENCL30GAS-NEXT: ret void
|
|
//
|
|
void test2_builtin_alloca_with_align_uninitialized(unsigned n) {
|
|
__private void *alloc_ptr_align_uninitialized = __builtin_alloca_with_align_uninitialized(n, 8);
|
|
}
|