158 lines
5.2 KiB
C++
158 lines
5.2 KiB
C++
/*
|
|
* Copyright (c) 2015-2016 The Khronos Group Inc.
|
|
* Copyright (c) 2015-2016 Valve Corporation
|
|
* Copyright (c) 2015-2016 LunarG, Inc.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*
|
|
* Author: Chia-I Wu <olvaffe@gmail.com>
|
|
* Author: Chris Forbes <chrisf@ijw.co.nz>
|
|
* Author: Courtney Goeltzenleuchter <courtney@LunarG.com>
|
|
* Author: Mark Lobodzinski <mark@lunarg.com>
|
|
* Author: Mike Stroyan <mike@LunarG.com>
|
|
* Author: Tobin Ehlis <tobine@google.com>
|
|
* Author: Tony Barbour <tony@LunarG.com>
|
|
*/
|
|
|
|
#include "test_common.h"
|
|
#include "test_environment.h"
|
|
|
|
#if defined(NDEBUG) && defined(__GNUC__)
|
|
#define U_ASSERT_ONLY __attribute__((unused))
|
|
#else
|
|
#define U_ASSERT_ONLY
|
|
#endif
|
|
|
|
#define ARRAY_SIZE(a) (sizeof(a) / sizeof(a[0]))
|
|
|
|
namespace vk_testing {
|
|
|
|
Environment::Environment() : default_dev_(0) {
|
|
app_.sType = VK_STRUCTURE_TYPE_APPLICATION_INFO;
|
|
app_.pApplicationName = "vk_testing";
|
|
app_.applicationVersion = 1;
|
|
app_.pEngineName = "vk_testing";
|
|
app_.engineVersion = 1;
|
|
app_.apiVersion = VK_API_VERSION_1_0;
|
|
app_.pNext = NULL;
|
|
}
|
|
|
|
bool Environment::parse_args(int argc, char **argv) {
|
|
int i;
|
|
|
|
for (i = 1; i < argc; i++) {
|
|
#define ARG(name) (strcmp(argv[i], name) == 0)
|
|
#define ARG_P(name) (i < argc - 1 && ARG(name))
|
|
if (ARG_P("--gpu")) {
|
|
default_dev_ = atoi(argv[++i]);
|
|
} else {
|
|
break;
|
|
}
|
|
#undef ARG
|
|
#undef ARG_P
|
|
}
|
|
|
|
if (i < argc) {
|
|
std::cout << "invalid argument: " << argv[i] << "\n\n"
|
|
<< "Usage: " << argv[0] << " <options>\n\n"
|
|
<< "Options:\n"
|
|
" --gpu <n> Use GPU<n> as the default GPU\n";
|
|
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
void Environment::SetUp() {
|
|
uint32_t count;
|
|
VkResult U_ASSERT_ONLY err;
|
|
VkInstanceCreateInfo inst_info = {};
|
|
std::vector<VkExtensionProperties> instance_extensions;
|
|
std::vector<VkExtensionProperties> device_extensions;
|
|
|
|
std::vector<const char *> instance_extension_names;
|
|
std::vector<const char *> device_extension_names;
|
|
|
|
instance_extension_names.push_back(VK_KHR_SURFACE_EXTENSION_NAME);
|
|
device_extension_names.push_back(VK_KHR_SWAPCHAIN_EXTENSION_NAME);
|
|
#ifdef _WIN32
|
|
instance_extension_names.push_back(VK_KHR_WIN32_SURFACE_EXTENSION_NAME);
|
|
#endif
|
|
#ifdef VK_USE_PLATFORM_XCB_KHR
|
|
instance_extension_names.push_back(VK_KHR_XCB_SURFACE_EXTENSION_NAME);
|
|
#endif
|
|
|
|
VkBool32 extFound;
|
|
|
|
instance_extensions = vk_testing::GetGlobalExtensions();
|
|
|
|
for (uint32_t i = 0; i < instance_extension_names.size(); i++) {
|
|
extFound = 0;
|
|
for (uint32_t j = 0; j < instance_extensions.size(); j++) {
|
|
if (!strcmp(instance_extension_names[i], instance_extensions[j].extensionName)) {
|
|
extFound = 1;
|
|
}
|
|
}
|
|
ASSERT_EQ(extFound, 1) << "ERROR: Cannot find extension named " << instance_extension_names[i]
|
|
<< " which is necessary to pass this test";
|
|
}
|
|
inst_info.sType = VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO;
|
|
inst_info.pNext = NULL;
|
|
inst_info.pApplicationInfo = &app_;
|
|
inst_info.enabledExtensionCount = instance_extension_names.size();
|
|
inst_info.ppEnabledExtensionNames = (instance_extension_names.size()) ? &instance_extension_names[0] : NULL;
|
|
inst_info.enabledLayerCount = 0;
|
|
inst_info.ppEnabledLayerNames = NULL;
|
|
err = vkCreateInstance(&inst_info, NULL, &inst);
|
|
ASSERT_EQ(VK_SUCCESS, err);
|
|
err = vkEnumeratePhysicalDevices(inst, &count, NULL);
|
|
ASSERT_EQ(VK_SUCCESS, err);
|
|
ASSERT_LE(count, ARRAY_SIZE(gpus));
|
|
err = vkEnumeratePhysicalDevices(inst, &count, gpus);
|
|
ASSERT_EQ(VK_SUCCESS, err);
|
|
ASSERT_GT(count, default_dev_);
|
|
|
|
vk_testing::PhysicalDevice phys_dev(gpus[0]);
|
|
device_extensions = phys_dev.extensions();
|
|
|
|
for (uint32_t i = 0; i < device_extension_names.size(); i++) {
|
|
extFound = 0;
|
|
for (uint32_t j = 0; j < device_extensions.size(); j++) {
|
|
if (!strcmp(device_extension_names[i], device_extensions[j].extensionName)) {
|
|
extFound = 1;
|
|
}
|
|
}
|
|
ASSERT_EQ(extFound, 1) << "ERROR: Cannot find extension named " << device_extension_names[i]
|
|
<< " which is necessary to pass this test";
|
|
}
|
|
|
|
devs_.reserve(count);
|
|
for (uint32_t i = 0; i < count; i++) {
|
|
devs_.push_back(new Device(gpus[i]));
|
|
if (i == default_dev_) {
|
|
devs_[i]->init(device_extension_names);
|
|
ASSERT_NE(true, devs_[i]->graphics_queues().empty());
|
|
}
|
|
}
|
|
}
|
|
|
|
void Environment::TearDown() {
|
|
// destroy devices first
|
|
for (std::vector<Device *>::iterator it = devs_.begin(); it != devs_.end(); it++) delete *it;
|
|
devs_.clear();
|
|
|
|
if (inst) vkDestroyInstance(inst, NULL);
|
|
}
|
|
} // namespace vk_testing
|