1 /******************************************************************
2 Copyright (c) 2016 The Khronos Group Inc. All Rights Reserved.
3
4 This code is protected by copyright laws and contains material proprietary to
5 the Khronos Group, Inc. This is UNPUBLISHED PROPRIETARY SOURCE CODE that may not
6 be disclosed in whole or in part to third parties, and may not be reproduced,
7 republished, distributed, transmitted, displayed, broadcast or otherwise
8 exploited in any manner without the express prior written permission of Khronos
9 Group. The receipt or possession of this code does not convey any rights to
10 reproduce, disclose, or distribute its contents, or to manufacture, use, or sell
11 anything that it may describe, in whole or in part other than under the terms of
12 the Khronos Adopters Agreement or Khronos Conformance Test Source License
13 Agreement as executed between Khronos and the recipient.
14 ******************************************************************/
15
16 #pragma once
17
18 #include "harness/errorHelpers.h"
19 #include "harness/kernelHelpers.h"
20 #include "harness/typeWrappers.h"
21 #include "harness/conversions.h"
22 #include "harness/mt19937.h"
23 #include "harness/compat.h"
24 #include "harness/testHarness.h"
25 #include "harness/parseParameters.h"
26
27 #include <vector>
28
29 #define SPIRV_CHECK_ERROR(err, fmt, ...) \
30 do \
31 { \
32 if (err == CL_SUCCESS) break; \
33 log_error("%s(%d): Error %d\n" fmt "\n", __FILE__, __LINE__, err, \
34 ##__VA_ARGS__); \
35 return -1; \
36 } while (0)
37
38
39 class baseTestClass {
40 public:
baseTestClass()41 baseTestClass() {}
42 virtual basefn getFunction() = 0;
43 };
44
45 class spirvTestsRegistry {
46 private:
47 std::vector<baseTestClass *> testClasses;
48 std::vector<test_definition> testDefinitions;
49
50 public:
51 static spirvTestsRegistry &getInstance();
52
53 test_definition *getTestDefinitions();
54
55 size_t getNumTests();
56
57 void addTestClass(baseTestClass *test, const char *testName,
58 Version version);
spirvTestsRegistry()59 spirvTestsRegistry() {}
60 };
61
createAndRegister(const char * name,Version version)62 template <typename T> T *createAndRegister(const char *name, Version version)
63 {
64 T *testClass = new T();
65 spirvTestsRegistry::getInstance().addTestClass((baseTestClass *)testClass,
66 name, version);
67 return testClass;
68 }
69
70 #define TEST_SPIRV_FUNC_VERSION(name, version) \
71 extern int test_##name(cl_device_id deviceID, cl_context context, \
72 cl_command_queue queue, int num_elements); \
73 class test_##name##_class : public baseTestClass { \
74 private: \
75 basefn fn; \
76 \
77 public: \
78 test_##name##_class(): fn(test_##name) {} \
79 basefn getFunction() { return fn; } \
80 }; \
81 test_##name##_class *var_##name = \
82 createAndRegister<test_##name##_class>(#name, version); \
83 int test_##name(cl_device_id deviceID, cl_context context, \
84 cl_command_queue queue, int num_elements)
85
86 #define TEST_SPIRV_FUNC(name) TEST_SPIRV_FUNC_VERSION(name, Version(1, 2))
87
88 struct spec_const
89 {
90 spec_const(cl_int id = 0, size_t sizet = 0, const void *value = NULL)
spec_idspec_const91 : spec_id(id), spec_size(sizet), spec_value(value){};
92 cl_int spec_id;
93 size_t spec_size;
94 const void *spec_value;
95 };
96
97 int get_program_with_il(clProgramWrapper &prog, const cl_device_id deviceID,
98 const cl_context context, const char *prog_name,
99 spec_const spec_const_def = spec_const());
100 std::vector<unsigned char> readSPIRV(const char *file_name);