vulkan_test2
changeset 3:68e1c437343f
more vulkan
author | John Tsiombikas <nuclear@member.fsf.org> |
---|---|
date | Fri, 22 Sep 2017 01:01:10 +0300 (2017-09-21) |
parents | 5b2ae06283aa |
children | c31c4115d44a |
files | Makefile main.c src/main.c src/vku.c src/vku.h |
diffstat | 5 files changed, 320 insertions(+), 226 deletions(-) [+] |
line diff
1.1 --- a/Makefile Sun Dec 18 09:15:16 2016 +0200 1.2 +++ b/Makefile Fri Sep 22 01:01:10 2017 +0300 1.3 @@ -1,4 +1,5 @@ 1.4 -obj = main.o 1.5 +src = $(wildcard src/*.c) 1.6 +obj = $(src:.c=.o) 1.7 bin = test 1.8 1.9 CFLAGS = -pedantic -Wall -g
2.1 --- a/main.c Sun Dec 18 09:15:16 2016 +0200 2.2 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 2.3 @@ -1,225 +0,0 @@ 2.4 -#include <stdio.h> 2.5 -#include <stdlib.h> 2.6 -#include <string.h> 2.7 -#include <alloca.h> 2.8 -#include <vulkan/vulkan.h> 2.9 - 2.10 -const char *get_device_name(VkPhysicalDeviceType type); 2.11 -const char *get_mem_prop_flag_string(VkMemoryPropertyFlags flags); 2.12 -const char *get_queue_flag_string(VkQueueFlagBits flags); 2.13 -int ver_major(uint32_t ver); 2.14 -int ver_minor(uint32_t ver); 2.15 -int ver_patch(uint32_t ver); 2.16 -const char *mem_size_str(long sz); 2.17 - 2.18 -int main(void) 2.19 -{ 2.20 - int i, j; 2.21 - VkInstance vk; 2.22 - VkInstanceCreateInfo inst_info; 2.23 - VkPhysicalDevice *devices; 2.24 - VkDevice vkdev; 2.25 - VkDeviceCreateInfo dev_info; 2.26 - VkDeviceQueueCreateInfo queue_info; 2.27 - uint32_t num_devices; 2.28 - int sel_dev = -1; 2.29 - int sel_qfamily = -1; 2.30 - float qprio = 0.0f; 2.31 - 2.32 - memset(&inst_info, 0, sizeof inst_info); 2.33 - inst_info.sType = VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO; 2.34 - 2.35 - if(vkCreateInstance(&inst_info, 0, &vk) != 0) { 2.36 - fprintf(stderr, "failed to create vulkan instance\n"); 2.37 - return 1; 2.38 - } 2.39 - printf("created vulkan instance\n"); 2.40 - 2.41 - if(vkEnumeratePhysicalDevices(vk, &num_devices, 0) != 0) { 2.42 - fprintf(stderr, "failed to enumerate vulkan physical devices\n"); 2.43 - return 1; 2.44 - } 2.45 - devices = alloca(num_devices * sizeof *devices); 2.46 - if(vkEnumeratePhysicalDevices(vk, &num_devices, devices) != 0) { 2.47 - fprintf(stderr, "failed to enumerate vulkan physical devices\n"); 2.48 - return 1; 2.49 - } 2.50 - printf("found %u physical device(s)\n", (unsigned int)num_devices); 2.51 - 2.52 - for(i=0; i<(int)num_devices; i++) { 2.53 - VkPhysicalDeviceProperties dev_prop; 2.54 - VkPhysicalDeviceMemoryProperties mem_prop; 2.55 - VkQueueFamilyProperties *qprop; 2.56 - uint32_t qprop_count; 2.57 - 2.58 - vkGetPhysicalDeviceProperties(devices[i], &dev_prop); 2.59 - 2.60 - printf("Device %d: %s\n", i, dev_prop.deviceName); 2.61 - printf(" type: %s\n", get_device_name(dev_prop.deviceType)); 2.62 - printf(" API version: %d.%d.%d\n", ver_major(dev_prop.apiVersion), ver_minor(dev_prop.apiVersion), 2.63 - ver_patch(dev_prop.apiVersion)); 2.64 - printf(" driver version: %d.%d.%d\n", ver_major(dev_prop.driverVersion), ver_minor(dev_prop.driverVersion), 2.65 - ver_patch(dev_prop.driverVersion)); 2.66 - printf(" vendor id: %x device id: %x\n", dev_prop.vendorID, dev_prop.deviceID); 2.67 - 2.68 - 2.69 - vkGetPhysicalDeviceMemoryProperties(devices[i], &mem_prop); 2.70 - printf(" %d memory heaps:\n", mem_prop.memoryHeapCount); 2.71 - for(j=0; j<mem_prop.memoryHeapCount; j++) { 2.72 - VkMemoryHeap heap = mem_prop.memoryHeaps[j]; 2.73 - printf(" Heap %d - size: %s, flags: %s\n", j, mem_size_str(heap.size), 2.74 - heap.flags & VK_MEMORY_HEAP_DEVICE_LOCAL_BIT ? "device-local" : "-"); 2.75 - } 2.76 - printf(" %d memory types:\n", mem_prop.memoryTypeCount); 2.77 - for(j=0; j<mem_prop.memoryTypeCount; j++) { 2.78 - VkMemoryType type = mem_prop.memoryTypes[j]; 2.79 - printf(" Type %d - heap: %d, flags: %s\n", j, type.heapIndex, 2.80 - get_mem_prop_flag_string(type.propertyFlags)); 2.81 - } 2.82 - 2.83 - vkGetPhysicalDeviceQueueFamilyProperties(devices[i], &qprop_count, 0); 2.84 - if(qprop_count <= 0) { 2.85 - continue; 2.86 - } 2.87 - qprop = malloc(qprop_count * sizeof *qprop); 2.88 - vkGetPhysicalDeviceQueueFamilyProperties(devices[i], &qprop_count, qprop); 2.89 - 2.90 - for(j=0; j<qprop_count; j++) { 2.91 - printf(" Queue family %d:\n", j); 2.92 - printf(" flags: %s\n", get_queue_flag_string(qprop[j].queueFlags)); 2.93 - printf(" num queues: %u\n", qprop[j].queueCount); 2.94 - 2.95 - if(qprop[j].queueFlags & VK_QUEUE_GRAPHICS_BIT) { 2.96 - sel_dev = i; 2.97 - sel_qfamily = j; 2.98 - } 2.99 - } 2.100 - free(qprop); 2.101 - } 2.102 - 2.103 - if(sel_dev < 0 || sel_qfamily < 0) { 2.104 - fprintf(stderr, "failed to find any device with a graphics-capable command queue\n"); 2.105 - vkDestroyDevice(vkdev, 0); 2.106 - return 1; 2.107 - } 2.108 - 2.109 - // create device & command queue 2.110 - memset(&queue_info, 0, sizeof queue_info); 2.111 - queue_info.sType = VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO; 2.112 - queue_info.queueFamilyIndex = sel_qfamily; 2.113 - queue_info.queueCount = 1; 2.114 - queue_info.pQueuePriorities = &qprio; 2.115 - 2.116 - memset(&dev_info, 0, sizeof dev_info); 2.117 - dev_info.sType = VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO; 2.118 - dev_info.queueCreateInfoCount = 1; 2.119 - dev_info.pQueueCreateInfos = &queue_info; 2.120 - 2.121 - if(vkCreateDevice(devices[sel_dev], &dev_info, 0, &vkdev) != 0) { 2.122 - fprintf(stderr, "failed to create device %d\n", sel_dev); 2.123 - return 1; 2.124 - } 2.125 - printf("created device %d\n", sel_dev); 2.126 - 2.127 - vkDestroyDevice(vkdev, 0); 2.128 - vkDestroyInstance(vk, 0); 2.129 - return 0; 2.130 -} 2.131 - 2.132 - 2.133 -const char *get_device_name(VkPhysicalDeviceType type) 2.134 -{ 2.135 - switch(type) { 2.136 - case VK_PHYSICAL_DEVICE_TYPE_INTEGRATED_GPU: 2.137 - return "integrated GPU"; 2.138 - case VK_PHYSICAL_DEVICE_TYPE_DISCRETE_GPU: 2.139 - return "discrete GPU"; 2.140 - case VK_PHYSICAL_DEVICE_TYPE_VIRTUAL_GPU: 2.141 - return "virtual GPU"; 2.142 - case VK_PHYSICAL_DEVICE_TYPE_CPU: 2.143 - return "CPU"; 2.144 - default: 2.145 - break; 2.146 - } 2.147 - return "unknown"; 2.148 -} 2.149 - 2.150 -const char *get_mem_prop_flag_string(VkMemoryPropertyFlags flags) 2.151 -{ 2.152 - static char str[128]; 2.153 - 2.154 - str[0] = 0; 2.155 - if(flags & VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT) { 2.156 - strcat(str, "device-local "); 2.157 - } 2.158 - if(flags & VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT) { 2.159 - strcat(str, "host-visible "); 2.160 - } 2.161 - if(flags & VK_MEMORY_PROPERTY_HOST_COHERENT_BIT) { 2.162 - strcat(str, "host-coherent "); 2.163 - } 2.164 - if(flags & VK_MEMORY_PROPERTY_HOST_CACHED_BIT) { 2.165 - strcat(str, "host-cached "); 2.166 - } 2.167 - if(flags & VK_MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT) { 2.168 - strcat(str, "lazily-allocated "); 2.169 - } 2.170 - 2.171 - if(!*str) { 2.172 - strcat(str, "-"); 2.173 - } 2.174 - return str; 2.175 -} 2.176 - 2.177 -const char *get_queue_flag_string(VkQueueFlagBits flags) 2.178 -{ 2.179 - static char str[128]; 2.180 - 2.181 - str[0] = 0; 2.182 - if(flags & VK_QUEUE_GRAPHICS_BIT) { 2.183 - strcat(str, "graphics "); 2.184 - } 2.185 - if(flags & VK_QUEUE_COMPUTE_BIT) { 2.186 - strcat(str, "compute "); 2.187 - } 2.188 - if(flags & VK_QUEUE_TRANSFER_BIT) { 2.189 - strcat(str, "transfer "); 2.190 - } 2.191 - if(flags & VK_QUEUE_SPARSE_BINDING_BIT) { 2.192 - strcat(str, "sparse-binding "); 2.193 - } 2.194 - if(!*str) { 2.195 - strcat(str, "-"); 2.196 - } 2.197 - return str; 2.198 -} 2.199 - 2.200 -int ver_major(uint32_t ver) 2.201 -{ 2.202 - return (ver >> 22) & 0x3ff; 2.203 -} 2.204 - 2.205 -int ver_minor(uint32_t ver) 2.206 -{ 2.207 - return (ver >> 12) & 0x3ff; 2.208 -} 2.209 - 2.210 -int ver_patch(uint32_t ver) 2.211 -{ 2.212 - return ver & 0xfff; 2.213 -} 2.214 - 2.215 -const char *mem_size_str(long sz) 2.216 -{ 2.217 - static char str[64]; 2.218 - static const char *unitstr[] = { "bytes", "KB", "MB", "GB", "TB", "PB", 0 }; 2.219 - int uidx = 0; 2.220 - sz *= 10; 2.221 - 2.222 - while(sz >= 10240 && unitstr[uidx + 1]) { 2.223 - sz /= 1024; 2.224 - ++uidx; 2.225 - } 2.226 - sprintf(str, "%ld.%ld %s", sz / 10, sz % 10, unitstr[uidx]); 2.227 - return str; 2.228 -}
3.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 3.2 +++ b/src/main.c Fri Sep 22 01:01:10 2017 +0300 3.3 @@ -0,0 +1,13 @@ 3.4 +#include <stdio.h> 3.5 +#include <vulkan/vulkan.h> 3.6 +#include "vku.h" 3.7 + 3.8 +int main(void) 3.9 +{ 3.10 + if(vku_create_dev() == -1) { 3.11 + return -1; 3.12 + } 3.13 + 3.14 + vku_cleanup(); 3.15 + return 0; 3.16 +}
4.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 4.2 +++ b/src/vku.c Fri Sep 22 01:01:10 2017 +0300 4.3 @@ -0,0 +1,281 @@ 4.4 +#include <stdio.h> 4.5 +#include <stdlib.h> 4.6 +#include <string.h> 4.7 +#include <alloca.h> 4.8 +#include "vku.h" 4.9 + 4.10 +static const char *get_device_name(VkPhysicalDeviceType type); 4.11 +static const char *get_mem_prop_flag_string(VkMemoryPropertyFlags flags); 4.12 +static const char *get_queue_flag_string(VkQueueFlagBits flags); 4.13 +static int ver_major(uint32_t ver); 4.14 +static int ver_minor(uint32_t ver); 4.15 +static int ver_patch(uint32_t ver); 4.16 +static const char *mem_size_str(long sz); 4.17 + 4.18 + 4.19 +VkInstance vk; 4.20 +VkDevice vkdev; 4.21 +VkQueue vkq; 4.22 + 4.23 +int vku_create_dev(void) 4.24 +{ 4.25 + int i, j; 4.26 + VkInstanceCreateInfo inst_info; 4.27 + VkPhysicalDevice *devices; 4.28 + VkDeviceCreateInfo dev_info; 4.29 + VkDeviceQueueCreateInfo queue_info; 4.30 + VkCommandPoolCreateInfo cmdpool_info; 4.31 + uint32_t num_devices; 4.32 + int sel_dev = -1; 4.33 + int sel_qfamily = -1; 4.34 + float qprio = 0.0f; 4.35 + 4.36 + memset(&inst_info, 0, sizeof inst_info); 4.37 + inst_info.sType = VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO; 4.38 + 4.39 + if(vkCreateInstance(&inst_info, 0, &vk) != 0) { 4.40 + fprintf(stderr, "failed to create vulkan instance\n"); 4.41 + return -1; 4.42 + } 4.43 + printf("created vulkan instance\n"); 4.44 + 4.45 + if(vkEnumeratePhysicalDevices(vk, &num_devices, 0) != 0) { 4.46 + fprintf(stderr, "failed to enumerate vulkan physical devices\n"); 4.47 + return -1; 4.48 + } 4.49 + devices = alloca(num_devices * sizeof *devices); 4.50 + if(vkEnumeratePhysicalDevices(vk, &num_devices, devices) != 0) { 4.51 + fprintf(stderr, "failed to enumerate vulkan physical devices\n"); 4.52 + return -1; 4.53 + } 4.54 + printf("found %u physical device(s)\n", (unsigned int)num_devices); 4.55 + 4.56 + for(i=0; i<(int)num_devices; i++) { 4.57 + VkPhysicalDeviceProperties dev_prop; 4.58 + VkPhysicalDeviceMemoryProperties mem_prop; 4.59 + VkQueueFamilyProperties *qprop; 4.60 + uint32_t qprop_count; 4.61 + 4.62 + vkGetPhysicalDeviceProperties(devices[i], &dev_prop); 4.63 + 4.64 + printf("Device %d: %s\n", i, dev_prop.deviceName); 4.65 + printf(" type: %s\n", get_device_name(dev_prop.deviceType)); 4.66 + printf(" API version: %d.%d.%d\n", ver_major(dev_prop.apiVersion), ver_minor(dev_prop.apiVersion), 4.67 + ver_patch(dev_prop.apiVersion)); 4.68 + printf(" driver version: %d.%d.%d\n", ver_major(dev_prop.driverVersion), ver_minor(dev_prop.driverVersion), 4.69 + ver_patch(dev_prop.driverVersion)); 4.70 + printf(" vendor id: %x device id: %x\n", dev_prop.vendorID, dev_prop.deviceID); 4.71 + 4.72 + 4.73 + vkGetPhysicalDeviceMemoryProperties(devices[i], &mem_prop); 4.74 + printf(" %d memory heaps:\n", mem_prop.memoryHeapCount); 4.75 + for(j=0; j<mem_prop.memoryHeapCount; j++) { 4.76 + VkMemoryHeap heap = mem_prop.memoryHeaps[j]; 4.77 + printf(" Heap %d - size: %s, flags: %s\n", j, mem_size_str(heap.size), 4.78 + heap.flags & VK_MEMORY_HEAP_DEVICE_LOCAL_BIT ? "device-local" : "-"); 4.79 + } 4.80 + printf(" %d memory types:\n", mem_prop.memoryTypeCount); 4.81 + for(j=0; j<mem_prop.memoryTypeCount; j++) { 4.82 + VkMemoryType type = mem_prop.memoryTypes[j]; 4.83 + printf(" Type %d - heap: %d, flags: %s\n", j, type.heapIndex, 4.84 + get_mem_prop_flag_string(type.propertyFlags)); 4.85 + } 4.86 + 4.87 + vkGetPhysicalDeviceQueueFamilyProperties(devices[i], &qprop_count, 0); 4.88 + if(qprop_count <= 0) { 4.89 + continue; 4.90 + } 4.91 + qprop = malloc(qprop_count * sizeof *qprop); 4.92 + vkGetPhysicalDeviceQueueFamilyProperties(devices[i], &qprop_count, qprop); 4.93 + 4.94 + for(j=0; j<qprop_count; j++) { 4.95 + printf(" Queue family %d:\n", j); 4.96 + printf(" flags: %s\n", get_queue_flag_string(qprop[j].queueFlags)); 4.97 + printf(" num queues: %u\n", qprop[j].queueCount); 4.98 + 4.99 + if(qprop[j].queueFlags & VK_QUEUE_GRAPHICS_BIT) { 4.100 + sel_dev = i; 4.101 + sel_qfamily = j; 4.102 + } 4.103 + } 4.104 + free(qprop); 4.105 + } 4.106 + 4.107 + if(sel_dev < 0 || sel_qfamily < 0) { 4.108 + fprintf(stderr, "failed to find any device with a graphics-capable command queue\n"); 4.109 + vkDestroyDevice(vkdev, 0); 4.110 + return -1; 4.111 + } 4.112 + 4.113 + /* create device & command queue */ 4.114 + memset(&queue_info, 0, sizeof queue_info); 4.115 + queue_info.sType = VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO; 4.116 + queue_info.queueFamilyIndex = sel_qfamily; 4.117 + queue_info.queueCount = 1; 4.118 + queue_info.pQueuePriorities = &qprio; 4.119 + 4.120 + memset(&dev_info, 0, sizeof dev_info); 4.121 + dev_info.sType = VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO; 4.122 + dev_info.queueCreateInfoCount = 1; 4.123 + dev_info.pQueueCreateInfos = &queue_info; 4.124 + 4.125 + if(vkCreateDevice(devices[sel_dev], &dev_info, 0, &vkdev) != 0) { 4.126 + fprintf(stderr, "failed to create device %d\n", sel_dev); 4.127 + return -1; 4.128 + } 4.129 + printf("created device %d\n", sel_dev); 4.130 + 4.131 + vkGetDeviceQueue(vkdev, sel_qfamily, 0, &vkq); 4.132 + 4.133 + /* create command buffer pool */ 4.134 + memset(&cmdpool_info, 0, sizeof cmdpool_info); 4.135 + cmdpool_info.sType = VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO; 4.136 + cmdpool_info.flags = VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT; 4.137 + cmdpool_info.queueFamilyIndex = sel_qfamily; 4.138 + 4.139 + if(vkCreateCommandPool(vkdev, &cmdpool_info, 0, &vkcmdpool) != 0) { 4.140 + fprintf(stderr, "failed to get command quque!\n"); 4.141 + return -1; 4.142 + } 4.143 + 4.144 + return 0; 4.145 +} 4.146 + 4.147 +void vku_cleanup(void) 4.148 +{ 4.149 + if(vk) { 4.150 + vkDeviceWaitIdle(vkdev); 4.151 + vkDestroyDevice(vkdev, 0); 4.152 + vkDestroyInstance(vk, 0); 4.153 + vk = 0; 4.154 + } 4.155 +} 4.156 + 4.157 +struct vk_buffer *vku_create_buffer(int sz, unsigned int usage) 4.158 +{ 4.159 + struct vk_buffer *buf; 4.160 + VkBufferCreateInfo binfo; 4.161 + 4.162 + if(!(buf = malloc(sizeof *buf))) { 4.163 + perror("failed to allocate vk_buffer structure"); 4.164 + return 0; 4.165 + } 4.166 + 4.167 + memset(&binfo, 0, sizeof binfo); 4.168 + binfo.sType = VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO; 4.169 + binfo.size = sz; 4.170 + binfo.usage = usage; 4.171 + binfo.sharingMode = VK_SHARING_MODE_EXCLUSIVE; 4.172 + 4.173 + if(vkCreateBuffer(vkdev, &binfo, 0, &buf->buf) != 0) { 4.174 + fprintf(stderr, "failed to create %d byte buffer (usage: %x)\n", sz, usage); 4.175 + return 0; 4.176 + } 4.177 + // TODO back with memory 4.178 + return buf; 4.179 +} 4.180 + 4.181 +void vku_destroy_buffer(struct vk_buffer *buf) 4.182 +{ 4.183 + if(buf) { 4.184 + vkDestroyBuffer(vkdev, buf->buf, 0); 4.185 + free(buf); 4.186 + } 4.187 +} 4.188 + 4.189 +static const char *get_device_name(VkPhysicalDeviceType type) 4.190 +{ 4.191 + switch(type) { 4.192 + case VK_PHYSICAL_DEVICE_TYPE_INTEGRATED_GPU: 4.193 + return "integrated GPU"; 4.194 + case VK_PHYSICAL_DEVICE_TYPE_DISCRETE_GPU: 4.195 + return "discrete GPU"; 4.196 + case VK_PHYSICAL_DEVICE_TYPE_VIRTUAL_GPU: 4.197 + return "virtual GPU"; 4.198 + case VK_PHYSICAL_DEVICE_TYPE_CPU: 4.199 + return "CPU"; 4.200 + default: 4.201 + break; 4.202 + } 4.203 + return "unknown"; 4.204 +} 4.205 + 4.206 +static const char *get_mem_prop_flag_string(VkMemoryPropertyFlags flags) 4.207 +{ 4.208 + static char str[128]; 4.209 + 4.210 + str[0] = 0; 4.211 + if(flags & VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT) { 4.212 + strcat(str, "device-local "); 4.213 + } 4.214 + if(flags & VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT) { 4.215 + strcat(str, "host-visible "); 4.216 + } 4.217 + if(flags & VK_MEMORY_PROPERTY_HOST_COHERENT_BIT) { 4.218 + strcat(str, "host-coherent "); 4.219 + } 4.220 + if(flags & VK_MEMORY_PROPERTY_HOST_CACHED_BIT) { 4.221 + strcat(str, "host-cached "); 4.222 + } 4.223 + if(flags & VK_MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT) { 4.224 + strcat(str, "lazily-allocated "); 4.225 + } 4.226 + 4.227 + if(!*str) { 4.228 + strcat(str, "-"); 4.229 + } 4.230 + return str; 4.231 +} 4.232 + 4.233 +static const char *get_queue_flag_string(VkQueueFlagBits flags) 4.234 +{ 4.235 + static char str[128]; 4.236 + 4.237 + str[0] = 0; 4.238 + if(flags & VK_QUEUE_GRAPHICS_BIT) { 4.239 + strcat(str, "graphics "); 4.240 + } 4.241 + if(flags & VK_QUEUE_COMPUTE_BIT) { 4.242 + strcat(str, "compute "); 4.243 + } 4.244 + if(flags & VK_QUEUE_TRANSFER_BIT) { 4.245 + strcat(str, "transfer "); 4.246 + } 4.247 + if(flags & VK_QUEUE_SPARSE_BINDING_BIT) { 4.248 + strcat(str, "sparse-binding "); 4.249 + } 4.250 + if(!*str) { 4.251 + strcat(str, "-"); 4.252 + } 4.253 + return str; 4.254 +} 4.255 + 4.256 +static int ver_major(uint32_t ver) 4.257 +{ 4.258 + return (ver >> 22) & 0x3ff; 4.259 +} 4.260 + 4.261 +static int ver_minor(uint32_t ver) 4.262 +{ 4.263 + return (ver >> 12) & 0x3ff; 4.264 +} 4.265 + 4.266 +static int ver_patch(uint32_t ver) 4.267 +{ 4.268 + return ver & 0xfff; 4.269 +} 4.270 + 4.271 +static const char *mem_size_str(long sz) 4.272 +{ 4.273 + static char str[64]; 4.274 + static const char *unitstr[] = { "bytes", "KB", "MB", "GB", "TB", "PB", 0 }; 4.275 + int uidx = 0; 4.276 + sz *= 10; 4.277 + 4.278 + while(sz >= 10240 && unitstr[uidx + 1]) { 4.279 + sz /= 1024; 4.280 + ++uidx; 4.281 + } 4.282 + sprintf(str, "%ld.%ld %s", sz / 10, sz % 10, unitstr[uidx]); 4.283 + return str; 4.284 +}
5.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 5.2 +++ b/src/vku.h Fri Sep 22 01:01:10 2017 +0300 5.3 @@ -0,0 +1,24 @@ 5.4 +#ifndef VKU_H_ 5.5 +#define VKU_H_ 5.6 + 5.7 +#include <vulkan/vulkan.h> 5.8 + 5.9 +VkInstance vk; 5.10 +VkDevice vkdev; 5.11 +VkQueue vkq; 5.12 +VkCommandPool vkcmdpool; 5.13 + 5.14 +struct vk_buffer { 5.15 + VkBuffer buf; 5.16 + VkDeviceMemory mem_pool; 5.17 + int mem_start, mem_size; 5.18 +}; 5.19 + 5.20 +int vku_create_dev(void); 5.21 +void vku_cleanup(void); 5.22 + 5.23 + 5.24 +struct vk_buffer *vku_create_buffer(int sz, unsigned int usage); 5.25 +void vku_destroy_buffer(struct vk_buffer *buf); 5.26 + 5.27 +#endif /* VKU_H_ */