vulkan_test2

changeset 17:f8bd29f124a8 tip

foo
author John Tsiombikas <nuclear@member.fsf.org>
date Wed, 27 Jun 2018 01:57:55 +0300 (2018-06-26)
parents 236f923a00a3
children
files sdr/pixel.glsl sdr/vertex.glsl src/main.c src/vkgl.c src/vkpipe.c src/vku.c src/vku.h src/wsys.h src/wsys_x11.c vk_layer_settings.txt
diffstat 10 files changed, 231 insertions(+), 85 deletions(-) [+]
line diff
     1.1 --- a/sdr/pixel.glsl	Tue Jun 26 08:42:12 2018 +0300
     1.2 +++ b/sdr/pixel.glsl	Wed Jun 27 01:57:55 2018 +0300
     1.3 @@ -5,5 +5,5 @@
     1.4  
     1.5  void main()
     1.6  {
     1.7 -	outcolor = vec4(1.0, 0.0, 0.0, 1.0);
     1.8 +	outcolor = vec4(0.8, 0.2, 0.1, 1.0);
     1.9  }
     2.1 --- a/sdr/vertex.glsl	Tue Jun 26 08:42:12 2018 +0300
     2.2 +++ b/sdr/vertex.glsl	Wed Jun 27 01:57:55 2018 +0300
     2.3 @@ -1,8 +1,6 @@
     2.4  #version 450
     2.5  #extension GL_ARB_separate_shader_objects: enable
     2.6  
     2.7 -layout(location = 0) out vec4 outpos;
     2.8 -
     2.9  const vec3 vdata[] = vec3[](
    2.10  	vec3(-0.5, -0.5, 0.0),
    2.11  	vec3(0.5, -0.5, 0.0),
    2.12 @@ -10,5 +8,5 @@
    2.13  
    2.14  void main()
    2.15  {
    2.16 -	outpos = vec4(vdata[gl_VertexIndex], 1.0);
    2.17 +	gl_Position = vec4(vdata[gl_VertexIndex], 1.0);
    2.18  }
     3.1 --- a/src/main.c	Tue Jun 26 08:42:12 2018 +0300
     3.2 +++ b/src/main.c	Wed Jun 27 01:57:55 2018 +0300
     3.3 @@ -10,6 +10,8 @@
     3.4  
     3.5  static struct vku_pipeline pipeline;
     3.6  static VkShaderModule vsdr, psdr;
     3.7 +static VkSemaphore sem_draw_done;
     3.8 +static VkFence fence_draw_done;
     3.9  
    3.10  int main(void)
    3.11  {
    3.12 @@ -26,8 +28,6 @@
    3.13  	wsys_reshape_callback(reshape);
    3.14  	wsys_keyboard_callback(keyboard);
    3.15  
    3.16 -	wsys_process_events(WSYS_NONBLOCK);
    3.17 -
    3.18  	if(!(vsdr = vku_load_shader("sdr/vertex.spv")) ||
    3.19  			!(psdr = vku_load_shader("sdr/pixel.spv"))) {
    3.20  		return 1;
    3.21 @@ -37,14 +37,23 @@
    3.22  	vku_pipeline_shader(&pipeline, vsdr, VK_SHADER_STAGE_VERTEX_BIT);
    3.23  	vku_pipeline_shader(&pipeline, psdr, VK_SHADER_STAGE_FRAGMENT_BIT);
    3.24  	vku_pipeline_viewport(&pipeline, 0, 0, 800, 600);
    3.25 +	vku_pipeline_scissor(&pipeline, 0, 0, 800, 600);
    3.26  	vku_pipeline_renderpass(&pipeline, vkrpass);
    3.27  	if(!vku_create_pipeline(&pipeline)) {
    3.28  		return 1;
    3.29  	}
    3.30  
    3.31 +	sem_draw_done = vku_create_semaphore();
    3.32 +	fence_draw_done = vku_create_fence();
    3.33  
    3.34  	while(wsys_process_events(WSYS_BLOCKING) != -1);
    3.35  
    3.36 +	vku_destroy_fence(fence_draw_done);
    3.37 +	vku_destroy_semaphore(sem_draw_done);
    3.38 +	vku_destroy_pipeline(&pipeline);
    3.39 +	vku_destroy_shader(vsdr);
    3.40 +	vku_destroy_shader(psdr);
    3.41 +
    3.42  	wsys_destroy_window();
    3.43  	vku_cleanup();
    3.44  	return 0;
    3.45 @@ -52,10 +61,10 @@
    3.46  
    3.47  static void display(void)
    3.48  {
    3.49 -	vkgl_clear_color(1, 0, 0, 1);
    3.50 +	vku_begin_cmdbuf(vkcmdbuf, VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT);
    3.51 +	vkgl_clear_color(0.2, 0.2, 0.3, 1);
    3.52  	vkgl_clear(VKGL_COLOR_BUFFER_BIT);
    3.53  
    3.54 -	vku_begin_cmdbuf(vkcmdbuf, VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT);
    3.55  	vku_begin_renderpass(vkcmdbuf, vkrpass, swapchain_framebuf[next_swapchain_image],
    3.56  			VK_SUBPASS_CONTENTS_INLINE);
    3.57  	vkCmdBindPipeline(vkcmdbuf, VK_PIPELINE_BIND_POINT_GRAPHICS, pipeline.pipeline);
    3.58 @@ -63,9 +72,10 @@
    3.59  	vku_end_renderpass(vkcmdbuf);
    3.60  	vku_end_cmdbuf(vkcmdbuf);
    3.61  
    3.62 -	vku_submit_cmdbuf(vkq, vkcmdbuf, 0);
    3.63 +	vku_submit_cmdbuf(vkq, vkcmdbuf, swapchain_getimg_sem, sem_draw_done, fence_draw_done);
    3.64  
    3.65 -	wsys_swap_buffers();
    3.66 +	wsys_swap_buffers(sem_draw_done);
    3.67 +	vku_wait_fence(fence_draw_done);
    3.68  }
    3.69  
    3.70  static void reshape(int x, int y)
     4.1 --- a/src/vkgl.c	Tue Jun 26 08:42:12 2018 +0300
     4.2 +++ b/src/vkgl.c	Wed Jun 27 01:57:55 2018 +0300
     4.3 @@ -27,7 +27,7 @@
     4.4  void vkgl_clear(unsigned int flags)
     4.5  {
     4.6  	VkImageSubresourceRange wtf;
     4.7 -	VkSubmitInfo si;
     4.8 +	//VkSubmitInfo si;
     4.9  
    4.10  	memset(&wtf, 0, sizeof wtf);
    4.11  
    4.12 @@ -43,7 +43,7 @@
    4.13  	wtf.levelCount = 1;
    4.14  	wtf.layerCount = 1;
    4.15  
    4.16 -	vku_begin_cmdbuf(vkcmdbuf, VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT);
    4.17 +	//vku_begin_cmdbuf(vkcmdbuf, VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT);
    4.18  	if(flags & VKGL_COLOR_BUFFER_BIT) {
    4.19  		vkCmdClearColorImage(vkcmdbuf, swapchain_images[next_swapchain_image],
    4.20  				VK_IMAGE_LAYOUT_GENERAL, &st.clear.color, 1, &wtf);
    4.21 @@ -52,12 +52,14 @@
    4.22  		vkCmdClearDepthStencilImage(vkcmdbuf, swapchain_images[next_swapchain_image],
    4.23  				VK_IMAGE_LAYOUT_GENERAL, &st.clear.depthStencil, 1, &wtf);
    4.24  	}
    4.25 -	vku_end_cmdbuf(vkcmdbuf);
    4.26 +	//vku_end_cmdbuf(vkcmdbuf);
    4.27  
    4.28 +	/*
    4.29  	memset(&si, 0, sizeof si);
    4.30  	si.sType = VK_STRUCTURE_TYPE_SUBMIT_INFO;
    4.31  	si.commandBufferCount = 1;
    4.32  	si.pCommandBuffers = &vkcmdbuf;
    4.33  
    4.34  	vkQueueSubmit(vkq, 1, &si, 0);
    4.35 +	*/
    4.36  }
     5.1 --- a/src/vkpipe.c	Tue Jun 26 08:42:12 2018 +0300
     5.2 +++ b/src/vkpipe.c	Wed Jun 27 01:57:55 2018 +0300
     5.3 @@ -30,6 +30,8 @@
     5.4  	st->vport_data.minDepth = 0.0f;
     5.5  	st->vport_data.maxDepth = 1.0f;
     5.6  
     5.7 +	st->msaa.rasterizationSamples = 1;
     5.8 +
     5.9  	st->blend.logicOp = VK_LOGIC_OP_COPY;
    5.10  	st->blend.attachmentCount = 1;
    5.11  	st->blend.pAttachments = &st->atblend;
     6.1 --- a/src/vku.c	Tue Jun 26 08:42:12 2018 +0300
     6.2 +++ b/src/vku.c	Wed Jun 27 01:57:55 2018 +0300
     6.3 @@ -27,9 +27,8 @@
     6.4  static uint32_t vkext_count, vkdevext_count;
     6.5  
     6.6  static VkDebugReportCallbackEXT debug_callback_obj;
     6.7 -static VkResult (*vk_create_debug_report_callback)(VkInstance,
     6.8 -		const VkDebugReportCallbackCreateInfoEXT*, const VkAllocationCallbacks*,
     6.9 -		VkDebugReportCallbackEXT*);
    6.10 +static PFN_vkCreateDebugReportCallbackEXT vk_create_debug_report_callback;
    6.11 +static PFN_vkDestroyDebugReportCallbackEXT vk_destroy_debug_report_callback;
    6.12  static void (*user_dbg_callback)(const char*, void*);
    6.13  static void *user_dbg_callback_data;
    6.14  
    6.15 @@ -137,7 +136,8 @@
    6.16  	static const char *layer_names[] = {
    6.17  		"VK_LAYER_LUNARG_standard_validation",
    6.18  		"VK_LAYER_LUNARG_parameter_validation",
    6.19 -		"VK_LAYER_LUNARG_core_validation"
    6.20 +		"VK_LAYER_LUNARG_core_validation",
    6.21 +		"VK_LAYER_LUNARG_image"
    6.22  	};
    6.23  
    6.24  	sel_dev = -1;
    6.25 @@ -177,6 +177,7 @@
    6.26  		fprintf(stderr, "FUCK EVERYTHING\n");
    6.27  		return -1;
    6.28  	}
    6.29 +	vk_destroy_debug_report_callback = (PFN_vkDestroyDebugReportCallbackEXT)vkGetInstanceProcAddr(vk, "vkDestroyDebugReportCallbackEXT");
    6.30  	vku_set_debug_callback(user_dbg_callback, user_dbg_callback_data);	/* set debug callback */
    6.31  
    6.32  
    6.33 @@ -289,11 +290,20 @@
    6.34  		return -1;
    6.35  	}
    6.36  
    6.37 -	if(!(vkcmdbuf = vku_alloc_cmdbuf(vkcmdpool, VK_COMMAND_BUFFER_LEVEL_PRIMARY))) {
    6.38 -		fprintf(stderr, "failed to create primary command buffer\n");
    6.39 +	/* XXX hardcoded 2 command buffers for a swapchain with 2 images */
    6.40 +	if(!(swapchain_cmdbuf = malloc(2 * sizeof *swapchain_cmdbuf))) {
    6.41 +		fprintf(stderr, "failed to allocate command buffer array\n");
    6.42  		return -1;
    6.43  	}
    6.44  
    6.45 +	for(i=0; i<2; i++) {
    6.46 +		if(!(swapchain_cmdbuf[i] = vku_alloc_cmdbuf(vkcmdpool, VK_COMMAND_BUFFER_LEVEL_PRIMARY))) {
    6.47 +			fprintf(stderr, "failed to create primary command buffer\n");
    6.48 +			return -1;
    6.49 +		}
    6.50 +	}
    6.51 +	vkcmdbuf = swapchain_cmdbuf[0];
    6.52 +
    6.53  	return 0;
    6.54  }
    6.55  
    6.56 @@ -303,6 +313,7 @@
    6.57  		vkDeviceWaitIdle(vkdev);
    6.58  		vkDestroyCommandPool(vkdev, vkcmdpool, 0);
    6.59  		vkDestroyDevice(vkdev, 0);
    6.60 +		vk_destroy_debug_report_callback(vk, debug_callback_obj, 0);
    6.61  		vkDestroyInstance(vk, 0);
    6.62  		vk = 0;
    6.63  	}
    6.64 @@ -355,7 +366,8 @@
    6.65  	vkResetCommandBuffer(buf, 0);
    6.66  }
    6.67  
    6.68 -void vku_submit_cmdbuf(VkQueue q, VkCommandBuffer buf, VkFence done_fence)
    6.69 +void vku_submit_cmdbuf(VkQueue q, VkCommandBuffer buf, VkSemaphore sem_wait,
    6.70 +		VkSemaphore sem_done, VkFence done_fence)
    6.71  {
    6.72  	VkSubmitInfo info;
    6.73  
    6.74 @@ -363,6 +375,14 @@
    6.75  	info.sType = VK_STRUCTURE_TYPE_SUBMIT_INFO;
    6.76  	info.commandBufferCount = 1;
    6.77  	info.pCommandBuffers = &buf;
    6.78 +	if(sem_wait) {
    6.79 +		info.pWaitSemaphores = &sem_wait;
    6.80 +		info.waitSemaphoreCount = 1;
    6.81 +	}
    6.82 +	if(sem_done) {
    6.83 +		info.pSignalSemaphores = &sem_done;
    6.84 +		info.signalSemaphoreCount = 1;
    6.85 +	}
    6.86  
    6.87  	vkQueueSubmit(q, 1, &info, done_fence);
    6.88  }
    6.89 @@ -412,13 +432,14 @@
    6.90  	return images;
    6.91  }
    6.92  
    6.93 -int vku_get_next_image(VkSwapchainKHR sc)
    6.94 +int vku_get_next_image(VkSwapchainKHR sc, VkSemaphore semdone)
    6.95  {
    6.96  	uint32_t next;
    6.97  
    6.98 -	if(vkAcquireNextImageKHR(vkdev, sc, UINT64_MAX, 0, 0, &next) != 0) {
    6.99 +	if(vkAcquireNextImageKHR(vkdev, sc, UINT64_MAX, semdone, 0, &next) != 0) {
   6.100  		return -1;
   6.101  	}
   6.102 +	vkcmdbuf = swapchain_cmdbuf[next];
   6.103  	return (int)next;
   6.104  }
   6.105  
   6.106 @@ -478,7 +499,7 @@
   6.107  	vkDestroyFramebuffer(vkdev, fb, 0);
   6.108  }
   6.109  
   6.110 -void vku_present(VkSwapchainKHR sc, int img_idx)
   6.111 +void vku_present(VkSwapchainKHR sc, int img_idx, VkSemaphore sem_wait)
   6.112  {
   6.113  	VkPresentInfoKHR inf;
   6.114  	VkResult res;
   6.115 @@ -490,6 +511,10 @@
   6.116  	inf.pSwapchains = &sc;
   6.117  	inf.pImageIndices = &index;
   6.118  	inf.pResults = &res;
   6.119 +	if(sem_wait) {
   6.120 +		inf.pWaitSemaphores = &sem_wait;
   6.121 +		inf.waitSemaphoreCount = 1;
   6.122 +	}
   6.123  
   6.124  	vkQueuePresentKHR(vkq, &inf);
   6.125  }
   6.126 @@ -622,6 +647,53 @@
   6.127  	vkCmdEndRenderPass(cmdbuf);
   6.128  }
   6.129  
   6.130 +VkSemaphore vku_create_semaphore(void)
   6.131 +{
   6.132 +	VkSemaphore s;
   6.133 +	VkSemaphoreCreateInfo sinf;
   6.134 +
   6.135 +	memset(&sinf, 0, sizeof sinf);
   6.136 +	sinf.sType = VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO;
   6.137 +
   6.138 +	if(vkCreateSemaphore(vkdev, &sinf, 0, &s) != 0) {
   6.139 +		fprintf(stderr, "vku_create_semaphore failed\n");
   6.140 +		return 0;
   6.141 +	}
   6.142 +	return s;
   6.143 +}
   6.144 +
   6.145 +void vku_destroy_semaphore(VkSemaphore s)
   6.146 +{
   6.147 +	vkDestroySemaphore(vkdev, s, 0);
   6.148 +}
   6.149 +
   6.150 +VkFence vku_create_fence(void)
   6.151 +{
   6.152 +	VkFence f;
   6.153 +	VkFenceCreateInfo finf;
   6.154 +
   6.155 +	memset(&finf, 0, sizeof finf);
   6.156 +	finf.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO;
   6.157 +
   6.158 +	if(vkCreateFence(vkdev, &finf, 0, &f) != 0) {
   6.159 +		fprintf(stderr, "vku_create_fence failed\n");
   6.160 +		return 0;
   6.161 +	}
   6.162 +	return f;
   6.163 +}
   6.164 +
   6.165 +void vku_destroy_fence(VkFence f)
   6.166 +{
   6.167 +	vkDestroyFence(vkdev, f, 0);
   6.168 +}
   6.169 +
   6.170 +void vku_wait_fence(VkFence f)
   6.171 +{
   6.172 +	vkWaitForFences(vkdev, 1, &f, VK_TRUE, UINT64_MAX);
   6.173 +	vkResetFences(vkdev, 1, &f);
   6.174 +}
   6.175 +
   6.176 +
   6.177  #ifdef VK_USE_PLATFORM_XLIB_KHR
   6.178  int vku_xlib_usable_visual(Display *dpy, VisualID vid)
   6.179  {
     7.1 --- a/src/vku.h	Tue Jun 26 08:42:12 2018 +0300
     7.2 +++ b/src/vku.h	Wed Jun 27 01:57:55 2018 +0300
     7.3 @@ -19,6 +19,8 @@
     7.4  VkImageView *swapchain_views;
     7.5  int next_swapchain_image;
     7.6  VkFramebuffer *swapchain_framebuf;
     7.7 +VkSemaphore swapchain_getimg_sem;
     7.8 +VkCommandBuffer *swapchain_cmdbuf;
     7.9  
    7.10  VkViewport vkvport;
    7.11  VkRenderPass vkrpass;
    7.12 @@ -45,13 +47,14 @@
    7.13  void vku_end_cmdbuf(VkCommandBuffer buf);
    7.14  void vku_reset_cmdbuf(VkCommandBuffer buf);
    7.15  
    7.16 -void vku_submit_cmdbuf(VkQueue q, VkCommandBuffer buf, VkFence done_fence);
    7.17 +void vku_submit_cmdbuf(VkQueue q, VkCommandBuffer buf, VkSemaphore sem_wait,
    7.18 +		VkSemaphore sem_done, VkFence done_fence);
    7.19  
    7.20  VkSwapchainKHR vku_create_swapchain(VkSurfaceKHR surf, int xsz, int ysz, int n,
    7.21  		VkFormat fmt, VkPresentModeKHR pmode, VkSwapchainKHR prev);
    7.22  VkImage *vku_get_swapchain_images(VkSwapchainKHR sc, int *count);
    7.23 -int vku_get_next_image(VkSwapchainKHR sc);
    7.24 -void vku_present(VkSwapchainKHR sc, int img_idx);
    7.25 +int vku_get_next_image(VkSwapchainKHR sc, VkSemaphore semdone);
    7.26 +void vku_present(VkSwapchainKHR sc, int img_idx, VkSemaphore sem_wait);
    7.27  
    7.28  VkImageView vku_create_view(VkImage img, VkFormat fmt);
    7.29  void vku_destroy_view(VkImageView view);
    7.30 @@ -71,6 +74,13 @@
    7.31  		VkSubpassContents cont);
    7.32  void vku_end_renderpass(VkCommandBuffer cmdbuf);
    7.33  
    7.34 +VkSemaphore vku_create_semaphore(void);
    7.35 +void vku_destroy_semaphore(VkSemaphore s);
    7.36 +
    7.37 +VkFence vku_create_fence(void);
    7.38 +void vku_destroy_fence(VkFence f);
    7.39 +void vku_wait_fence(VkFence f);
    7.40 +
    7.41  /* platform-specific */
    7.42  #ifdef VK_USE_PLATFORM_XLIB_KHR
    7.43  #include <X11/Xlib.h>
     8.1 --- a/src/wsys.h	Tue Jun 26 08:42:12 2018 +0300
     8.2 +++ b/src/wsys.h	Wed Jun 27 01:57:55 2018 +0300
     8.3 @@ -1,6 +1,8 @@
     8.4  #ifndef WSYS_H_
     8.5  #define WSYS_H_
     8.6  
     8.7 +#include <vulkan/vulkan.h>
     8.8 +
     8.9  /* pass to wsys_process_events */
    8.10  enum {
    8.11  	WSYS_BLOCKING = 0,
    8.12 @@ -20,7 +22,7 @@
    8.13  void wsys_motion_callback(void (*func)(int, int));
    8.14  void wsys_passive_motion_callback(void (*func)(int, int));
    8.15  
    8.16 -void wsys_swap_buffers(void);
    8.17 +void wsys_swap_buffers(VkSemaphore sem_wait);
    8.18  void wsys_redisplay(void);
    8.19  void wsys_quit(void);
    8.20  
     9.1 --- a/src/wsys_x11.c	Tue Jun 26 08:42:12 2018 +0300
     9.2 +++ b/src/wsys_x11.c	Wed Jun 27 01:57:55 2018 +0300
     9.3 @@ -20,6 +20,7 @@
     9.4  	REDISPLAY = 4
     9.5  };
     9.6  
     9.7 +static int reshape(int x, int y);
     9.8  static void proc_event(XEvent *ev);
     9.9  
    9.10  static Display *dpy;
    9.11 @@ -102,7 +103,14 @@
    9.12  
    9.13  	win_width = xsz;
    9.14  	win_height = ysz;
    9.15 -	pending = RESHAPE | REDISPLAY;
    9.16 +
    9.17 +	if(reshape(xsz, ysz) == -1) {
    9.18 +		XDestroyWindow(dpy, win);
    9.19 +		XCloseDisplay(dpy);
    9.20 +		return -1;
    9.21 +	}
    9.22 +
    9.23 +	pending = REDISPLAY;
    9.24  
    9.25  	return 0;
    9.26  }
    9.27 @@ -196,10 +204,10 @@
    9.28  	}
    9.29  }
    9.30  
    9.31 -void wsys_swap_buffers(void)
    9.32 +void wsys_swap_buffers(VkSemaphore sem_wait)
    9.33  {
    9.34 -	vku_present(swapchain, next_swapchain_image);
    9.35 -	next_swapchain_image = vku_get_next_image(swapchain);
    9.36 +	vku_present(swapchain, next_swapchain_image, sem_wait);
    9.37 +	next_swapchain_image = vku_get_next_image(swapchain, swapchain_getimg_sem);
    9.38  }
    9.39  
    9.40  void wsys_redisplay(void)
    9.41 @@ -212,67 +220,74 @@
    9.42  	pending |= QUIT;
    9.43  }
    9.44  
    9.45 +static int reshape(int x, int y)
    9.46 +{
    9.47 +	int i;
    9.48 +	VkSwapchainKHR sc;
    9.49 +	VkFormat fmt = VK_FORMAT_B8G8R8A8_UNORM;	/* TODO enumerate and choose */
    9.50 +
    9.51 +	printf("DBG reshape\n");
    9.52 +
    9.53 +	if(!vkrpass) {
    9.54 +		if(!(vkrpass = vku_create_renderpass(fmt, VK_FORMAT_UNDEFINED))) {
    9.55 +			abort();
    9.56 +		}
    9.57 +	}
    9.58 +
    9.59 +	if(!(sc = vku_create_swapchain(surf, x, y, 2, fmt,
    9.60 +					VK_PRESENT_MODE_FIFO_KHR, swapchain))) {
    9.61 +		fprintf(stderr, "Failed to create %dx%d double-buffered swapchain\n", x, y);
    9.62 +		return -1;
    9.63 +	}
    9.64 +	swapchain = sc;
    9.65 +
    9.66 +	free(swapchain_images);
    9.67 +	swapchain_size = 2;
    9.68 +	swapchain_images = vku_get_swapchain_images(sc, 0);
    9.69 +	next_swapchain_image = vku_get_next_image(swapchain, swapchain_getimg_sem);
    9.70 +
    9.71 +	if(!swapchain_views) {
    9.72 +		if(!(swapchain_views = calloc(swapchain_size, sizeof *swapchain_views))) {
    9.73 +			fprintf(stderr, "Failed to allocate image views\n");
    9.74 +			return -1;
    9.75 +		}
    9.76 +	}
    9.77 +
    9.78 +	for(i=0; i<swapchain_size; i++) {
    9.79 +		if(swapchain_views[i]) {
    9.80 +			vku_destroy_view(swapchain_views[i]);
    9.81 +		}
    9.82 +		swapchain_views[i] = vku_create_view(swapchain_images[i], fmt);
    9.83 +	}
    9.84 +
    9.85 +	if(!swapchain_framebuf) {
    9.86 +		if(!(swapchain_framebuf = calloc(swapchain_size, sizeof *swapchain_framebuf))) {
    9.87 +			fprintf(stderr, "Failed to allocate framebuffers\n");
    9.88 +			return -1;
    9.89 +		}
    9.90 +	}
    9.91 +
    9.92 +	for(i=0; i<swapchain_size; i++) {
    9.93 +		if(swapchain_framebuf[i]) {
    9.94 +			vku_destroy_framebuffer(swapchain_framebuf[i]);
    9.95 +		}
    9.96 +		swapchain_framebuf[i] = vku_create_framebuffer(swapchain_views[i], x, y, vkrpass);
    9.97 +	}
    9.98 +
    9.99 +	if(cb.reshape) {
   9.100 +		cb.reshape(x, y);
   9.101 +	}
   9.102 +	return 0;
   9.103 +}
   9.104 +
   9.105  int wsys_process_events(int mode)
   9.106  {
   9.107 -	int i;
   9.108  	XEvent xev;
   9.109  
   9.110  	if(pending & RESHAPE) {
   9.111 -		VkSwapchainKHR sc;
   9.112 -		VkFormat fmt = VK_FORMAT_B8G8R8A8_UNORM;	/* TODO enumerate and choose */
   9.113 -
   9.114 -		printf("DBG reshape\n");
   9.115 -
   9.116 -		if(!vkrpass) {
   9.117 -			if(!(vkrpass = vku_create_renderpass(fmt, VK_FORMAT_UNDEFINED))) {
   9.118 -				abort();
   9.119 -			}
   9.120 -		}
   9.121 -
   9.122 -		if(!(sc = vku_create_swapchain(surf, win_width, win_height, 2, fmt,
   9.123 -						VK_PRESENT_MODE_FIFO_KHR, swapchain))) {
   9.124 -			fprintf(stderr, "Failed to create %dx%d double-buffered swapchain\n", win_width, win_height);
   9.125 +		if(reshape(win_width, win_height) == -1) {
   9.126  			return -1;
   9.127  		}
   9.128 -		swapchain = sc;
   9.129 -
   9.130 -		free(swapchain_images);
   9.131 -		swapchain_size = 2;
   9.132 -		swapchain_images = vku_get_swapchain_images(sc, 0);
   9.133 -		next_swapchain_image = vku_get_next_image(swapchain);
   9.134 -
   9.135 -		if(!swapchain_views) {
   9.136 -			if(!(swapchain_views = calloc(swapchain_size, sizeof *swapchain_views))) {
   9.137 -				fprintf(stderr, "Failed to allocate image views\n");
   9.138 -				return -1;
   9.139 -			}
   9.140 -		}
   9.141 -
   9.142 -		for(i=0; i<swapchain_size; i++) {
   9.143 -			if(swapchain_views[i]) {
   9.144 -				vku_destroy_view(swapchain_views[i]);
   9.145 -			}
   9.146 -			swapchain_views[i] = vku_create_view(swapchain_images[i], fmt);
   9.147 -		}
   9.148 -
   9.149 -		if(!swapchain_framebuf) {
   9.150 -			if(!(swapchain_framebuf = calloc(swapchain_size, sizeof *swapchain_framebuf))) {
   9.151 -				fprintf(stderr, "Failed to allocate framebuffers\n");
   9.152 -				return -1;
   9.153 -			}
   9.154 -		}
   9.155 -
   9.156 -		for(i=0; i<swapchain_size; i++) {
   9.157 -			if(swapchain_framebuf[i]) {
   9.158 -				vku_destroy_framebuffer(swapchain_framebuf[i]);
   9.159 -			}
   9.160 -			swapchain_framebuf[i] = vku_create_framebuffer(swapchain_views[i],
   9.161 -					win_width, win_height, vkrpass);
   9.162 -		}
   9.163 -
   9.164 -		if(cb.reshape) {
   9.165 -			cb.reshape(win_width, win_height);
   9.166 -		}
   9.167  		pending &= ~RESHAPE;
   9.168  	}
   9.169  
    10.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
    10.2 +++ b/vk_layer_settings.txt	Wed Jun 27 01:57:55 2018 +0300
    10.3 @@ -0,0 +1,35 @@
    10.4 +# VK_LAYER_LUNARG_device_limits Settings
    10.5 +lunarg_device_limits.debug_action = VK_DBG_LAYER_ACTION_LOG_MSG
    10.6 +lunarg_device_limits.report_flags = error,warn,perf
    10.7 +lunarg_device_limits.log_filename = vkdebug.log
    10.8 +
    10.9 +# VK_LAYER_LUNARG_core_validation Settings
   10.10 +lunarg_core_validation.debug_action = VK_DBG_LAYER_ACTION_LOG_MSG
   10.11 +lunarg_core_validation.report_flags = error,warn,perf
   10.12 +lunarg_core_validation.log_filename = vkdebug.log
   10.13 +
   10.14 +# VK_LAYER_LUNARG_image Settings
   10.15 +lunarg_image.debug_action = VK_DBG_LAYER_ACTION_LOG_MSG
   10.16 +lunarg_image.report_flags = error,warn,perf
   10.17 +lunarg_image.log_filename = vkdebug.log
   10.18 +
   10.19 +# VK_LAYER_LUNARG_object_tracker Settings
   10.20 +lunarg_object_tracker.debug_action = VK_DBG_LAYER_ACTION_LOG_MSG
   10.21 +lunarg_object_tracker.report_flags = error,warn,perf
   10.22 +lunarg_object_tracker.log_filename = vkdebug.log
   10.23 +
   10.24 +# VK_LAYER_LUNARG_parameter_validation Settings
   10.25 +lunarg_parameter_validation.debug_action = VK_DBG_LAYER_ACTION_LOG_MSG
   10.26 +lunarg_parameter_validation.report_flags = error,warn,perf
   10.27 +lunarg_parameter_validation.log_filename = vkdebug.log
   10.28 +
   10.29 +# VK_LAYER_LUNARG_swapchain Settings
   10.30 +lunarg_swapchain.debug_action = VK_DBG_LAYER_ACTION_LOG_MSG
   10.31 +lunarg_swapchain.report_flags = error,warn,perf
   10.32 +lunarg_swapchain.log_filename = vkdebug.log
   10.33 +
   10.34 +# VK_LAYER_GOOGLE_threading Settings
   10.35 +google_threading.debug_action = VK_DBG_LAYER_ACTION_LOG_MSG
   10.36 +google_threading.report_flags = error,warn,perf
   10.37 +google_threading.log_filename = vkdebug.log
   10.38 +