From 6fb4469588ba37ace4794b354c9fd30d18b5c9ff Mon Sep 17 00:00:00 2001 From: Jason Ekstrand Date: Mon, 19 Oct 2015 20:21:45 -0700 Subject: [PATCH] anv: Move the brw_compiler from anv_compiler to physical_device --- src/vulkan/anv_compiler.cpp | 2 +- src/vulkan/anv_device.c | 13 +++++++++++++ src/vulkan/anv_private.h | 1 + 3 files changed, 15 insertions(+), 1 deletion(-) diff --git a/src/vulkan/anv_compiler.cpp b/src/vulkan/anv_compiler.cpp index 5d74f0f131e..1ecd88a0331 100644 --- a/src/vulkan/anv_compiler.cpp +++ b/src/vulkan/anv_compiler.cpp @@ -460,7 +460,7 @@ anv_compiler_create(struct anv_device *device) brw_process_intel_debug_variable(); - compiler->screen->compiler = brw_compiler_create(compiler, &device->info); + compiler->screen->compiler = device->instance->physicalDevice.compiler; ctx = &compiler->brw->ctx; _mesa_init_shader_object_functions(&ctx->Driver); diff --git a/src/vulkan/anv_device.c b/src/vulkan/anv_device.c index 75fbe691c5f..e0bb7f6e4bc 100644 --- a/src/vulkan/anv_device.c +++ b/src/vulkan/anv_device.c @@ -91,6 +91,12 @@ anv_physical_device_init(struct anv_physical_device *device, close(fd); + device->compiler = brw_compiler_create(NULL, device->info); + if (device->compiler == NULL) { + result = vk_error(VK_ERROR_OUT_OF_HOST_MEMORY); + goto fail; + } + return VK_SUCCESS; fail: @@ -98,6 +104,12 @@ fail: return result; } +static void +anv_physical_device_finish(struct anv_physical_device *device) +{ + ralloc_free(device->compiler); +} + static void *default_alloc( void* pUserData, size_t size, @@ -193,6 +205,7 @@ void anv_DestroyInstance( { ANV_FROM_HANDLE(anv_instance, instance, _instance); + anv_physical_device_finish(&instance->physicalDevice); anv_finish_wsi(instance); VG(VALGRIND_DESTROY_MEMPOOL(instance)); diff --git a/src/vulkan/anv_private.h b/src/vulkan/anv_private.h index c0d9373b643..8c48a9c2b0a 100644 --- a/src/vulkan/anv_private.h +++ b/src/vulkan/anv_private.h @@ -427,6 +427,7 @@ struct anv_physical_device { const char * name; const struct brw_device_info * info; uint64_t aperture_size; + struct brw_compiler * compiler; }; struct anv_instance { -- 2.30.2