| // RUN: %clang_cc1 %s -O0 -ffake-address-space-map -emit-llvm -o - | FileCheck %s --check-prefixes=CHECK,SPIR |
| // RUN: %clang_cc1 %s -O0 -DCL20 -cl-std=CL2.0 -ffake-address-space-map -emit-llvm -o - | FileCheck %s --check-prefixes=CL20,CL20SPIR |
| // RUN: %clang_cc1 %s -O0 -triple amdgcn-amd-amdhsa-opencl -emit-llvm -o - | FileCheck --check-prefixes=CHECK,SPIR %s |
| // RUN: %clang_cc1 %s -O0 -triple amdgcn-amd-amdhsa-opencl -DCL20 -cl-std=CL2.0 -emit-llvm -o - | FileCheck %s --check-prefixes=CL20,CL20SPIR |
| // RUN: %clang_cc1 %s -O0 -triple amdgcn-amd-amdhsa-amdgizcl -emit-llvm -o - | FileCheck %s -check-prefixes=CHECK,GIZ |
| // RUN: %clang_cc1 %s -O0 -triple amdgcn-amd-amdhsa-amdgizcl -DCL20 -cl-std=CL2.0 -emit-llvm -o - | FileCheck %s --check-prefixes=CL20,CL20GIZ |
| // RUN: %clang_cc1 %s -O0 -triple amdgcn-mesa-mesa3d -emit-llvm -o - | FileCheck --check-prefixes=CHECK,SPIR %s |
| // RUN: %clang_cc1 %s -O0 -triple r600-- -emit-llvm -o - | FileCheck --check-prefixes=CHECK,SPIR %s |
| |
| // SPIR: %struct.S = type { i32, i32, i32* } |
| // CL20SPIR: %struct.S = type { i32, i32, i32 addrspace(4)* } |
| struct S { |
| int x; |
| int y; |
| int *z; |
| }; |
| |
| // CL20-DAG: @g_extern_var = external addrspace(1) global float |
| // CL20-DAG: @l_extern_var = external addrspace(1) global float |
| // CL20-DAG: @test_static.l_static_var = internal addrspace(1) global float 0.000000e+00 |
| // CL20-DAG: @g_static_var = internal addrspace(1) global float 0.000000e+00 |
| |
| #ifdef CL20 |
| // CL20-DAG: @g_s = common addrspace(1) global %struct.S zeroinitializer |
| struct S g_s; |
| #endif |
| |
| // SPIR: i32* %arg |
| // GIZ: i32 addrspace(5)* %arg |
| void f__p(__private int *arg) {} |
| |
| // CHECK: i32 addrspace(1)* %arg |
| void f__g(__global int *arg) {} |
| |
| // CHECK: i32 addrspace(3)* %arg |
| void f__l(__local int *arg) {} |
| |
| // CHECK: i32 addrspace(2)* %arg |
| void f__c(__constant int *arg) {} |
| |
| // SPIR: i32* %arg |
| // GIZ: i32 addrspace(5)* %arg |
| void fp(private int *arg) {} |
| |
| // CHECK: i32 addrspace(1)* %arg |
| void fg(global int *arg) {} |
| |
| // CHECK: i32 addrspace(3)* %arg |
| void fl(local int *arg) {} |
| |
| // CHECK: i32 addrspace(2)* %arg |
| void fc(constant int *arg) {} |
| |
| #ifdef CL20 |
| int i; |
| // CL20-DAG: @i = common addrspace(1) global i32 0 |
| int *ptr; |
| // CL20SPIR-DAG: @ptr = common addrspace(1) global i32 addrspace(4)* null |
| // CL20GIZ-DAG: @ptr = common addrspace(1) global i32* null |
| #endif |
| |
| // SPIR: i32* %arg |
| // GIZ: i32 addrspace(5)* %arg |
| // CL20SPIR-DAG: i32 addrspace(4)* %arg |
| // CL20GIZ-DAG: i32* %arg |
| void f(int *arg) { |
| |
| int i; |
| // SPIR: %i = alloca i32, |
| // GIZ: %i = alloca i32{{.*}}addrspace(5) |
| // CL20SPIR-DAG: %i = alloca i32, |
| // CL20GIZ-DAG: %i = alloca i32{{.*}}addrspace(5) |
| |
| #ifdef CL20 |
| static int ii; |
| // CL20-DAG: @f.ii = internal addrspace(1) global i32 0 |
| #endif |
| } |
| |
| typedef int int_td; |
| typedef int *intp_td; |
| // SPIR: define void @test_typedef(i32 addrspace(1)* %x, i32 addrspace(2)* %y, i32* %z) |
| void test_typedef(global int_td *x, constant int_td *y, intp_td z) { |
| *x = *y; |
| *z = 0; |
| } |
| |
| // SPIR: define void @test_struct() |
| void test_struct() { |
| // SPIR: %ps = alloca %struct.S* |
| // CL20SPIR: %ps = alloca %struct.S addrspace(4)* |
| struct S *ps; |
| // SPIR: store i32 0, i32* %x |
| // CL20SPIR: store i32 0, i32 addrspace(4)* %x |
| ps->x = 0; |
| #ifdef CL20 |
| // CL20SPIR: store i32 0, i32 addrspace(1)* getelementptr inbounds (%struct.S, %struct.S addrspace(1)* @g_s, i32 0, i32 0) |
| g_s.x = 0; |
| #endif |
| } |
| |
| // SPIR-LABEL: define void @test_void_par() |
| void test_void_par(void) {} |
| |
| // On ppc64 returns signext i32. |
| // SPIR-LABEL: define{{.*}} i32 @test_func_return_type() |
| int test_func_return_type(void) { |
| return 0; |
| } |
| |
| #ifdef CL20 |
| extern float g_extern_var; |
| |
| // CL20-LABEL: define {{.*}}void @test_extern( |
| kernel void test_extern(global float *buf) { |
| extern float l_extern_var; |
| buf[0] += g_extern_var + l_extern_var; |
| } |
| |
| static float g_static_var; |
| |
| // CL20-LABEL: define {{.*}}void @test_static( |
| kernel void test_static(global float *buf) { |
| static float l_static_var; |
| buf[0] += g_static_var + l_static_var; |
| } |
| |
| #endif |