Aaron Ballman | eda0373 | 2014-11-26 16:17:20 +0000 | [diff] [blame] | 1 | // RUN: %clang_cc1 %s -triple x86_64-unknown-linux-gnu -O0 -ffake-address-space-map -cl-std=CL2.0 -emit-llvm -o - | FileCheck %s |
Yaxun Liu | b7b6d0f | 2016-04-12 19:03:49 +0000 | [diff] [blame] | 2 | // RUN: %clang_cc1 %s -triple x86_64-unknown-linux-gnu -O0 -cl-std=CL2.0 -emit-llvm -o - | FileCheck --check-prefix=CHECK-NOFAKE %s |
| 3 | // When -ffake-address-space-map is not used, all addr space mapped to 0 for x86_64. |
Anastasia Stulova | 5d8ad8a | 2014-11-26 15:36:41 +0000 | [diff] [blame] | 4 | |
| 5 | // test that we generate address space casts everywhere we need conversions of |
| 6 | // pointers to different address spaces |
| 7 | |
| 8 | void test(global int *arg_glob, generic int *arg_gen) { |
| 9 | int var_priv; |
| 10 | arg_gen = arg_glob; // implicit cast global -> generic |
| 11 | // CHECK: %{{[0-9]+}} = addrspacecast i32 addrspace(1)* %{{[0-9]+}} to i32 addrspace(4)* |
Yaxun Liu | b7b6d0f | 2016-04-12 19:03:49 +0000 | [diff] [blame] | 12 | // CHECK-NOFAKE-NOT: addrspacecast |
Yaxun Liu | c5cec39 | 2016-04-12 15:46:24 +0000 | [diff] [blame] | 13 | |
Anastasia Stulova | 5d8ad8a | 2014-11-26 15:36:41 +0000 | [diff] [blame] | 14 | arg_gen = &var_priv; // implicit cast with obtaining adr, private -> generic |
| 15 | // CHECK: %{{[0-9]+}} = addrspacecast i32* %var_priv to i32 addrspace(4)* |
Yaxun Liu | b7b6d0f | 2016-04-12 19:03:49 +0000 | [diff] [blame] | 16 | // CHECK-NOFAKE-NOT: addrspacecast |
| 17 | |
Anastasia Stulova | 5d8ad8a | 2014-11-26 15:36:41 +0000 | [diff] [blame] | 18 | arg_glob = (global int *)arg_gen; // explicit cast |
| 19 | // CHECK: %{{[0-9]+}} = addrspacecast i32 addrspace(4)* %{{[0-9]+}} to i32 addrspace(1)* |
Yaxun Liu | b7b6d0f | 2016-04-12 19:03:49 +0000 | [diff] [blame] | 20 | // CHECK-NOFAKE-NOT: addrspacecast |
| 21 | |
Anastasia Stulova | 5d8ad8a | 2014-11-26 15:36:41 +0000 | [diff] [blame] | 22 | global int *var_glob = |
| 23 | (global int *)arg_glob; // explicit cast in the same address space |
| 24 | // CHECK-NOT: %{{[0-9]+}} = addrspacecast i32 addrspace(1)* %{{[0-9]+}} to i32 addrspace(1)* |
Yaxun Liu | b7b6d0f | 2016-04-12 19:03:49 +0000 | [diff] [blame] | 25 | // CHECK-NOFAKE-NOT: addrspacecast |
| 26 | |
Anastasia Stulova | 5d8ad8a | 2014-11-26 15:36:41 +0000 | [diff] [blame] | 27 | var_priv = arg_gen - arg_glob; // arithmetic operation |
Tim Northover | 8603941 | 2014-11-26 22:33:04 +0000 | [diff] [blame] | 28 | // CHECK: %{{.*}} = ptrtoint i32 addrspace(4)* %{{.*}} to i64 |
| 29 | // CHECK: %{{.*}} = ptrtoint i32 addrspace(1)* %{{.*}} to i64 |
Yaxun Liu | b7b6d0f | 2016-04-12 19:03:49 +0000 | [diff] [blame] | 30 | // CHECK-NOFAKE: %{{.*}} = ptrtoint i32* %{{.*}} to i64 |
| 31 | // CHECK-NOFAKE: %{{.*}} = ptrtoint i32* %{{.*}} to i64 |
| 32 | |
Anastasia Stulova | 5d8ad8a | 2014-11-26 15:36:41 +0000 | [diff] [blame] | 33 | var_priv = arg_gen > arg_glob; // comparison |
| 34 | // CHECK: %{{[0-9]+}} = addrspacecast i32 addrspace(1)* %{{[0-9]+}} to i32 addrspace(4)* |
Yaxun Liu | b7b6d0f | 2016-04-12 19:03:49 +0000 | [diff] [blame] | 35 | |
| 36 | generic void *var_gen_v = arg_glob; |
| 37 | // CHECK: addrspacecast |
| 38 | // CHECK-NOT: bitcast |
| 39 | // CHECK-NOFAKE: bitcast |
| 40 | // CHECK-NOFAKE-NOT: addrspacecast |
Anastasia Stulova | 5d8ad8a | 2014-11-26 15:36:41 +0000 | [diff] [blame] | 41 | } |