1 /*------------------------------------------------------------------------
2  * Vulkan Conformance Tests
3  * ------------------------
4  *
5  * Copyright (c) 2019 Google LLC
6  * Copyright (c) 2019 The Khronos Group Inc.
7  *
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  *
12  *      http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  *
20  *--------------------------------------------------------------------*/
21 
22 #include <string>
23 
24 #include "vktTestGroupUtil.hpp"
25 #include "vktAmberTestCase.hpp"
26 #include "vktSpvAsmVectorShuffleTests.hpp"
27 
28 namespace vkt
29 {
30 namespace SpirVAssembly
31 {
32 namespace
33 {
34 
createTests(tcu::TestCaseGroup * tests,const char * data_dir)35 void createTests (tcu::TestCaseGroup* tests, const char* data_dir)
36 {
37 	tcu::TestContext& testCtx = tests->getTestContext();
38 
39 	// Shader test files are saved in <path>/external/vulkancts/data/vulkan/amber/<data_dir>/<basename>.amber
40 	struct Case {
41 		const char*                    basename;
42 		const char*                    description;
43 		std::vector<std::string>       requirements;
44 	};
45 	const Case cases[] =
46 	{
47 		{ "vector_shuffle", "OpVectorShuffle with indices including -1" , { "VariablePointerFeatures.variablePointers" } },
48 	};
49 
50 	for (unsigned i = 0; i < sizeof(cases)/sizeof(cases[0]) ; ++i)
51 	{
52 		std::string					file		= std::string(cases[i].basename) + ".amber";
53 		cts_amber::AmberTestCase	*testCase	= cts_amber::createAmberTestCase(testCtx, cases[i].basename, cases[i].description, data_dir, file, cases[i].requirements);
54 
55 		tests->addChild(testCase);
56 	}
57 }
58 
59 } // anonymous
60 
createVectorShuffleGroup(tcu::TestContext & testCtx)61 tcu::TestCaseGroup* createVectorShuffleGroup (tcu::TestContext& testCtx)
62 {
63 	// Location of the Amber script files under the data/vulkan/amber source tree.
64 	const char* data_dir = "spirv_assembly/instruction/compute/vector_shuffle";
65 	return createTestGroup(testCtx, "vector_shuffle", "OpVectorShuffle edge cases", createTests, data_dir);
66 }
67 
68 } // SpirVAssembly
69 } // vkt
70