Matt Arsenault | af07de4 | 2018-12-01 21:56:10 +0000 | [diff] [blame] | 1 | // RUN: %clang_cc1 -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 |
| 2 | // RUN: %clang_cc1 -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 |
| 3 | |
| 4 | typedef __attribute__((ext_vector_type(2))) float float2; |
| 5 | typedef __attribute__((ext_vector_type(2))) half half2; |
| 6 | |
| 7 | #ifdef cl_khr_fp64 |
| 8 | typedef __attribute__((ext_vector_type(2))) double double2; |
| 9 | #endif |
| 10 | |
| 11 | int printf(__constant const char* st, ...) __attribute__((format(printf, 1, 2))); |
| 12 | |
| 13 | |
| 14 | // ALL-LABEL: @test_printf_float2( |
Matt Arsenault | 297afb1 | 2019-01-29 20:49:47 +0000 | [diff] [blame] | 15 | // 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) |
Matt Arsenault | af07de4 | 2018-12-01 21:56:10 +0000 | [diff] [blame] | 16 | |
Matt Arsenault | 297afb1 | 2019-01-29 20:49:47 +0000 | [diff] [blame] | 17 | |
| 18 | // 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) |
Matt Arsenault | af07de4 | 2018-12-01 21:56:10 +0000 | [diff] [blame] | 19 | kernel void test_printf_float2(float2 arg) { |
Matt Arsenault | 297afb1 | 2019-01-29 20:49:47 +0000 | [diff] [blame] | 20 | printf("%v2hlf", arg); |
Matt Arsenault | af07de4 | 2018-12-01 21:56:10 +0000 | [diff] [blame] | 21 | } |
| 22 | |
| 23 | // ALL-LABEL: @test_printf_half2( |
Matt Arsenault | 297afb1 | 2019-01-29 20:49:47 +0000 | [diff] [blame] | 24 | // 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) |
Matt Arsenault | af07de4 | 2018-12-01 21:56:10 +0000 | [diff] [blame] | 25 | |
Matt Arsenault | 297afb1 | 2019-01-29 20:49:47 +0000 | [diff] [blame] | 26 | // 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) |
Matt Arsenault | af07de4 | 2018-12-01 21:56:10 +0000 | [diff] [blame] | 27 | kernel void test_printf_half2(half2 arg) { |
Matt Arsenault | 297afb1 | 2019-01-29 20:49:47 +0000 | [diff] [blame] | 28 | printf("%v2hf", arg); |
Matt Arsenault | af07de4 | 2018-12-01 21:56:10 +0000 | [diff] [blame] | 29 | } |
| 30 | |
| 31 | #ifdef cl_khr_fp64 |
| 32 | // FP64-LABEL: @test_printf_double2( |
Matt Arsenault | 297afb1 | 2019-01-29 20:49:47 +0000 | [diff] [blame] | 33 | // 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) |
Matt Arsenault | af07de4 | 2018-12-01 21:56:10 +0000 | [diff] [blame] | 34 | kernel void test_printf_double2(double2 arg) { |
Matt Arsenault | 297afb1 | 2019-01-29 20:49:47 +0000 | [diff] [blame] | 35 | printf("%v2lf", arg); |
Matt Arsenault | af07de4 | 2018-12-01 21:56:10 +0000 | [diff] [blame] | 36 | } |
| 37 | #endif |