• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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 #include "harness/testHarness.h"
17 #include "harness/kernelHelpers.h"
18 #include "harness/errorHelpers.h"
19 #include "harness/conversions.h"
20 #include "harness/mt19937.h"
21 
22 #define kVectorSizeCount 5
23 #define kStrangeVectorSizeCount 1
24 #define kTotalVecCount (kVectorSizeCount + kStrangeVectorSizeCount)
25 
26 extern int g_arrVecSizes[kVectorSizeCount + kStrangeVectorSizeCount];
27 // int g_arrStrangeVectorSizes[kStrangeVectorSizeCount] = {3};
28 
29 extern int        test_clamp(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
30 extern int        test_degrees(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
31 extern int        test_fmax(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
32 extern int        test_fmaxf(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
33 extern int        test_fmin(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
34 extern int        test_fminf(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
35 extern int        test_max(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
36 extern int        test_maxf(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
37 extern int        test_min(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
38 extern int        test_minf(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
39 extern int        test_mix(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
40 extern int        test_radians(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
41 extern int        test_step(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
42 extern int        test_stepf(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
43 extern int        test_smoothstep(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
44 extern int        test_smoothstepf(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
45 extern int        test_sign(cl_device_id device, cl_context context, cl_command_queue queue, int num_elements);
46 
47 typedef int     (*binary_verify_float_fn)( float *x, float *y, float *out, int numElements, int vecSize );
48 typedef int     (*binary_verify_double_fn)( double *x, double *y, double *out, int numElements, int vecSize );
49 
50 extern int      test_binary_fn( cl_device_id device, cl_context context, cl_command_queue queue, int n_elems,
51                            const char *fnName, bool vectorSecondParam,
52                            binary_verify_float_fn floatVerifyFn, binary_verify_double_fn doubleVerifyFn );
53 
54 
55