1 // 2 // Copyright (c) 2017 The Khronos Group Inc. 3 // 4 // Licensed under the Apache License, Version 2.0 (the "License"); 5 // you may not use this file except in compliance with the License. 6 // You may obtain a copy of the License at 7 // 8 // http://www.apache.org/licenses/LICENSE-2.0 9 // 10 // Unless required by applicable law or agreed to in writing, software 11 // distributed under the License is distributed on an "AS IS" BASIS, 12 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 // See the License for the specific language governing permissions and 14 // limitations under the License. 15 // 16 #ifndef FUNCTION_LIST_H 17 #define FUNCTION_LIST_H 18 19 #include "harness/compat.h" 20 21 #ifndef WIN32 22 #include <unistd.h> 23 #endif 24 25 #if defined(__APPLE__) 26 #include <OpenCL/opencl.h> 27 #else 28 #include <CL/cl.h> 29 #endif 30 31 #include "harness/mt19937.h" 32 33 typedef union fptr { 34 void *p; 35 double (*f_f)(double); 36 double (*f_u)(cl_uint); 37 int (*i_f)(double); 38 int (*i_f_f)(float); 39 float (*f_ff_f)(float, float); 40 double (*f_ff)(double, double); 41 int (*i_ff)(double, double); 42 double (*f_fi)(double, int); 43 double (*f_fpf)(double, double *); 44 double (*f_fpI)(double, int *); 45 double (*f_ffpI)(double, double, int *); 46 double (*f_fff)(double, double, double); 47 float (*f_fma)(float, float, float, int); 48 } fptr; 49 50 typedef union dptr { 51 void *p; 52 long double (*f_f)(long double); 53 long double (*f_u)(cl_ulong); 54 int (*i_f)(long double); 55 long double (*f_ff)(long double, long double); 56 int (*i_ff)(long double, long double); 57 long double (*f_fi)(long double, int); 58 long double (*f_fpf)(long double, long double *); 59 long double (*f_fpI)(long double, int *); 60 long double (*f_ffpI)(long double, long double, int *); 61 long double (*f_fff)(long double, long double, long double); 62 } dptr; 63 64 struct Func; 65 66 typedef struct vtbl 67 { 68 const char *type_name; 69 int (*TestFunc)(const struct Func *, MTdata, bool); 70 int (*DoubleTestFunc)( 71 const struct Func *, MTdata, 72 bool); // may be NULL if function is single precision only 73 } vtbl; 74 75 typedef struct Func 76 { 77 const char *name; // common name, to be used as an argument in the shell 78 const char *nameInCode; // name as it appears in the __kernel, usually the 79 // same as name, but different for multiplication 80 fptr func; 81 dptr dfunc; 82 fptr rfunc; 83 float float_ulps; 84 float double_ulps; 85 float float_embedded_ulps; 86 float relaxed_error; 87 float relaxed_embedded_error; 88 int ftz; 89 int relaxed; 90 const vtbl *vtbl_ptr; 91 } Func; 92 93 94 extern const Func functionList[]; 95 96 extern const size_t functionListCount; 97 98 #endif 99