Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(112)

Unified Diff: ui/vulkan/vulkan_implementation.cc

Issue 1726303002: Added initial Vulkan build files as well as a basic implementation file. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: ui/vulkan/vulkan_implementation.cc
diff --git a/ui/vulkan/vulkan_implementation.cc b/ui/vulkan/vulkan_implementation.cc
new file mode 100644
index 0000000000000000000000000000000000000000..94c660d564abc7ef913cb4ea5aa6a4f3c8915f88
--- /dev/null
+++ b/ui/vulkan/vulkan_implementation.cc
@@ -0,0 +1,101 @@
+// Copyright (c) 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "ui/vulkan/vulkan_implementation.h"
+
+#include <string>
+#include <vector>
+#include <vulkan/vulkan.h>
+
+#include "base/macros.h"
+
+namespace gfx {
+
+static VkInstance vk_instance;
+static VkDevice vk_device;
piman 2016/02/25 06:49:44 It would be nice to have these wrapped into an obj
David Yen 2016/03/01 19:54:09 Done.
+
+bool InitializeVulkan() {
+ // Initialize the Vulkan Instance.
+ VkApplicationInfo app_info = {};
+ app_info.sType = VK_STRUCTURE_TYPE_APPLICATION_INFO;
+ app_info.pApplicationName = "Chromium";
+ app_info.apiVersion = VK_MAKE_VERSION(1, 0, 2);
+
+ const char* instance_extensions[] = {VK_KHR_SURFACE_EXTENSION_NAME};
+
+ VkInstanceCreateInfo instance_create_info = {};
+ instance_create_info.sType = VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO;
+ instance_create_info.pApplicationInfo = &app_info;
+ instance_create_info.ppEnabledExtensionNames = instance_extensions;
+ instance_create_info.enabledExtensionCount = arraysize(instance_extensions);
+
+ VkResult status = VK_SUCCESS;
+ status = vkCreateInstance(&instance_create_info, nullptr, &vk_instance);
+ if (VK_SUCCESS != status)
+ return false;
+
+ // Initialize the Vulkan Device.
+ uint32_t device_count = 0;
+ status = vkEnumeratePhysicalDevices(vk_instance, &device_count, nullptr);
+ if (VK_SUCCESS != status || device_count == 0)
+ return false;
+
+ std::vector<VkPhysicalDevice> devices(device_count);
+ status =
+ vkEnumeratePhysicalDevices(vk_instance, &device_count, devices.data());
+ if (VK_SUCCESS != status)
+ return false;
+
sohanjg 2016/02/24 07:24:08 sorry for the intrusion, but do we not want any la
David Yen 2016/02/25 00:27:37 The intent of this first CL is to just get linking
+ int device_index = -1;
+ int queue_index = -1;
+ for (size_t i = 0; i < devices.size(); ++i) {
+ const VkPhysicalDevice& device = devices[i];
+ uint32_t queue_count = 0;
+ vkGetPhysicalDeviceQueueFamilyProperties(device, &queue_count, nullptr);
+ if (queue_count) {
+ std::vector<VkQueueFamilyProperties> queue_properties(queue_count);
+ vkGetPhysicalDeviceQueueFamilyProperties(device, &queue_count,
+ queue_properties.data());
+ for (size_t n = 0; n < queue_properties.size(); ++n) {
+ if (queue_properties[n].queueFlags & VK_QUEUE_GRAPHICS_BIT) {
piman 2016/02/24 01:52:13 We'll probably also want to pick a device that can
David Yen 2016/02/25 00:27:37 That would make it seem like the output surface wo
piman 2016/02/25 06:49:44 We wouldn't want a separate device per output surf
David Yen 2016/03/01 19:54:09 Done (although this currently crashes on my driver
+ queue_index = static_cast<int>(n);
Nico 2016/02/24 01:28:57 (nit: personally, i think this function could beco
David Yen 2016/02/25 00:27:37 Done.
+ break;
+ }
+ }
+
+ if (-1 != queue_index) {
+ device_index = static_cast<int>(i);
+ break;
+ }
+ }
+ }
+
+ if (queue_index == -1)
+ return false;
+
+ float queue_priority = 0.0f;
+ VkDeviceQueueCreateInfo queue_create_info = {};
+ queue_create_info.sType = VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO;
+ queue_create_info.queueFamilyIndex = queue_index;
+ queue_create_info.queueCount = 1;
+ queue_create_info.pQueuePriorities = &queue_priority;
+
+ const char* device_extensions[] = {VK_KHR_SWAPCHAIN_EXTENSION_NAME};
+
+ VkDeviceCreateInfo device_create_info = {};
+ device_create_info.sType = VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO;
+ device_create_info.queueCreateInfoCount = 1;
+ device_create_info.pQueueCreateInfos = &queue_create_info;
+ device_create_info.enabledExtensionCount = arraysize(device_extensions);
+ device_create_info.ppEnabledExtensionNames = device_extensions;
+
+ status = vkCreateDevice(devices[device_index], &device_create_info, nullptr,
+ &vk_device);
+ if (VK_SUCCESS != status)
+ return false;
+
+ return true;
+}
+
+} // namespace gfx

Powered by Google App Engine
This is Rietveld 408576698