annotate clang/test/CodeGenOpenCL/printf.cl @ 236:c4bab56944e8 llvm-original

LLVM 16
author kono
date Wed, 09 Nov 2022 17:45:10 +0900
parents 79ff65ed7e25
children 1f2b6ac9f198
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
1 // RUN: %clang_cc1 -no-opaque-pointers -no-enable-noundef-analysis -cl-std=CL1.2 -cl-ext=-+cl_khr_fp64 -triple spir-unknown-unknown -disable-llvm-passes -emit-llvm -o - %s | FileCheck -check-prefixes=FP64,ALL %s
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
2 // RUN: %clang_cc1 -no-opaque-pointers -no-enable-noundef-analysis -cl-std=CL1.2 -cl-ext=-cl_khr_fp64 -triple spir-unknown-unknown -disable-llvm-passes -emit-llvm -o - %s | FileCheck -check-prefixes=NOFP64,ALL %s
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
3 // RUN: %clang_cc1 -no-opaque-pointers -no-enable-noundef-analysis -cl-std=CL3.0 -cl-ext=+__opencl_c_fp64,+cl_khr_fp64 -triple spir-unknown-unknown -disable-llvm-passes -emit-llvm -o - %s | FileCheck -check-prefixes=FP64,ALL %s
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
4 // RUN: %clang_cc1 -no-opaque-pointers -no-enable-noundef-analysis -cl-std=CL3.0 -cl-ext=-__opencl_c_fp64,-cl_khr_fp64 -triple spir-unknown-unknown -disable-llvm-passes -emit-llvm -o - %s | FileCheck -check-prefixes=NOFP64,ALL %s
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
5 // RUN: %clang_cc1 -no-opaque-pointers -no-enable-noundef-analysis -cl-std=clc++2021 -cl-ext=+__opencl_c_fp64,+cl_khr_fp64 -triple spir-unknown-unknown -disable-llvm-passes -emit-llvm -o - %s | FileCheck -check-prefixes=FP64,ALL %s
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
6 // RUN: %clang_cc1 -no-opaque-pointers -no-enable-noundef-analysis -cl-std=clc++2021 -cl-ext=-__opencl_c_fp64,-cl_khr_fp64 -triple spir-unknown-unknown -disable-llvm-passes -emit-llvm -o - %s | FileCheck -check-prefixes=NOFP64,ALL %s
150
anatofuz
parents:
diff changeset
7
anatofuz
parents:
diff changeset
8 typedef __attribute__((ext_vector_type(2))) float float2;
anatofuz
parents:
diff changeset
9 typedef __attribute__((ext_vector_type(2))) half half2;
anatofuz
parents:
diff changeset
10
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
11 #if defined(cl_khr_fp64) || defined(__opencl_c_fp64)
150
anatofuz
parents:
diff changeset
12 typedef __attribute__((ext_vector_type(2))) double double2;
anatofuz
parents:
diff changeset
13 #endif
anatofuz
parents:
diff changeset
14
anatofuz
parents:
diff changeset
15 int printf(__constant const char* st, ...) __attribute__((format(printf, 1, 2)));
anatofuz
parents:
diff changeset
16
anatofuz
parents:
diff changeset
17
anatofuz
parents:
diff changeset
18 // ALL-LABEL: @test_printf_float2(
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
19 // FP64: %call = call spir_func i32 (i8 addrspace(2)*, ...) @{{.*}}printf{{.*}}(i8 addrspace(2)* getelementptr inbounds ([7 x i8], [7 x i8] addrspace(2)* @.str, i32 0, i32 0), <2 x float> %0)
150
anatofuz
parents:
diff changeset
20
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
21 // NOFP64: call spir_func i32 (i8 addrspace(2)*, ...) @{{.*}}printf{{.*}}(i8 addrspace(2)* getelementptr inbounds ([7 x i8], [7 x i8] addrspace(2)* @.str, i32 0, i32 0), <2 x float> %0)
150
anatofuz
parents:
diff changeset
22 kernel void test_printf_float2(float2 arg) {
anatofuz
parents:
diff changeset
23 printf("%v2hlf", arg);
anatofuz
parents:
diff changeset
24 }
anatofuz
parents:
diff changeset
25
anatofuz
parents:
diff changeset
26 // ALL-LABEL: @test_printf_half2(
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
27 // FP64: %call = call spir_func i32 (i8 addrspace(2)*, ...) @{{.*}}printf{{.*}}(i8 addrspace(2)* getelementptr inbounds ([6 x i8], [6 x i8] addrspace(2)* @.str.1, i32 0, i32 0), <2 x half> %0)
150
anatofuz
parents:
diff changeset
28
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
29 // NOFP64: %call = call spir_func i32 (i8 addrspace(2)*, ...) @{{.*}}printf{{.*}}(i8 addrspace(2)* getelementptr inbounds ([6 x i8], [6 x i8] addrspace(2)* @.str.1, i32 0, i32 0), <2 x half> %0)
150
anatofuz
parents:
diff changeset
30 kernel void test_printf_half2(half2 arg) {
anatofuz
parents:
diff changeset
31 printf("%v2hf", arg);
anatofuz
parents:
diff changeset
32 }
anatofuz
parents:
diff changeset
33
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
34 #if defined(cl_khr_fp64) || defined(__opencl_c_fp64)
150
anatofuz
parents:
diff changeset
35 // FP64-LABEL: @test_printf_double2(
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
36 // FP64: call spir_func i32 (i8 addrspace(2)*, ...) @{{.*}}printf{{.*}}(i8 addrspace(2)* getelementptr inbounds ([6 x i8], [6 x i8] addrspace(2)* @.str.2, i32 0, i32 0), <2 x double> %0)
150
anatofuz
parents:
diff changeset
37 kernel void test_printf_double2(double2 arg) {
anatofuz
parents:
diff changeset
38 printf("%v2lf", arg);
anatofuz
parents:
diff changeset
39 }
anatofuz
parents:
diff changeset
40 #endif