xref: /aosp_15_r20/external/deqp/external/vulkancts/modules/vulkan/spirv_assembly/vktSpvAsmSignedOpTests.cpp (revision 35238bce31c2a825756842865a792f8cf7f89930)
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  * \file
22  * \brief SPIR-V signed instruction tests
23  *//*--------------------------------------------------------------------*/
24 
25 #include <string>
26 
27 #include "vktTestGroupUtil.hpp"
28 #include "vktAmberTestCase.hpp"
29 #include "vktSpvAsmSignedIntCompareTests.hpp"
30 
31 namespace vkt
32 {
33 namespace SpirVAssembly
34 {
35 namespace
36 {
37 
createSignedOpTests(tcu::TestCaseGroup * tests,const char * data_dir)38 void createSignedOpTests(tcu::TestCaseGroup *tests, const char *data_dir)
39 {
40 #ifndef CTS_USES_VULKANSC
41     tcu::TestContext &testCtx = tests->getTestContext();
42 
43     // Shader test files are saved in <path>/external/vulkancts/data/vulkan/amber/<data_dir>/<basename>.amber
44     struct Case
45     {
46         const char *basename;
47         const char *description;
48     };
49     const Case cases[] = {
50         {"glsl_int_findumsb", "32bit signed int with FindUMsb"},
51         {"glsl_int_uclamp", "32bit signed int with UClamp"},
52         {"glsl_int_umax", "32bit signed int with UMax"},
53         {"glsl_int_umin", "32bit signed int with UMin"},
54         {"glsl_uint_findsmsb", "32bit unsigned int with FindSMsb"},
55         {"glsl_uint_sabs", "32bit unsigned int with SAbs"},
56         {"glsl_uint_sclamp", "32bit unsigned int with SClamp"},
57         {"glsl_uint_smax", "32bit unsigned int with SMax"},
58         {"glsl_uint_smin", "32bit unsigned int with SMin"},
59         {"glsl_uint_ssign", "32bit unsigned int with SSign"},
60         {"int_atomicumax", "32bit unsigned int with UMax"},
61         {"int_atomicumin", "32bit unsigned int with UMin"},
62         {"int_ugreaterthan", "32bit unsigned int with UGreaterThanEqual"},
63         {"int_ugreaterthanequal", "32bit unsigned int with UGreaterThanEqual"},
64         {"int_ulessthan", "32bit unsigned int with ULessThan"},
65         {"int_ulessthanequal", "32bit unsigned int with ULessThanEqual"},
66         {"uint_atomicsmax", "32bit unsigned int with SMax"},
67         {"uint_atomicsmin", "32bit unsigned int with SMin"},
68         {"uint_sdiv", "32bit unsigned int with UMax"},
69         {"uint_smulextended", "32bit unsigned int with SMulExtended"},
70         {"uint_snegate", "32bit unsigned int with SNegate"},
71     };
72 
73     for (unsigned i = 0; i < sizeof(cases) / sizeof(cases[0]); ++i)
74     {
75         std::string file = std::string(cases[i].basename) + ".amber";
76         cts_amber::AmberTestCase *testCase =
77             cts_amber::createAmberTestCase(testCtx, cases[i].basename, cases[i].description, data_dir, file);
78 
79         tests->addChild(testCase);
80     }
81 #else
82     DE_UNREF(tests);
83     DE_UNREF(data_dir);
84 #endif
85 }
86 
87 } // namespace
88 
createSignedOpTestsGroup(tcu::TestContext & testCtx)89 tcu::TestCaseGroup *createSignedOpTestsGroup(tcu::TestContext &testCtx)
90 {
91     // Location of the Amber script files under the data/vulkan/amber source tree.
92     const char *data_dir = "spirv_assembly/instruction/compute/signed_op";
93     return createTestGroup(testCtx, "signed_op", createSignedOpTests, data_dir);
94 }
95 
96 } // namespace SpirVAssembly
97 } // namespace vkt
98