From: Tapani Pälli Date: Wed, 17 Jan 2018 09:43:59 +0000 (+0200) Subject: i965: add __DRI2_BLOB support and set cache functions X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=9d322fde9781f9fc53c3baac6995ab1cbd8d6135;p=mesa.git i965: add __DRI2_BLOB support and set cache functions v2: adjust to change that moved cache from ctx to screen Signed-off-by: Tapani Pälli Reviewed-by: Jordan Justen Reviewed-by: Emil Velikov --- diff --git a/src/mesa/drivers/dri/i965/intel_screen.c b/src/mesa/drivers/dri/i965/intel_screen.c index 8c78b73b640..1f866cf8459 100644 --- a/src/mesa/drivers/dri/i965/intel_screen.c +++ b/src/mesa/drivers/dri/i965/intel_screen.c @@ -36,6 +36,7 @@ #include "main/version.h" #include "swrast/s_renderbuffer.h" #include "util/ralloc.h" +#include "util/disk_cache.h" #include "brw_defines.h" #include "brw_state.h" #include "compiler/nir/nir.h" @@ -1494,6 +1495,19 @@ brw_query_renderer_string(__DRIscreen *dri_screen, return -1; } +static void +brw_set_cache_funcs(__DRIscreen *dri_screen, + __DRIblobCacheSet set, __DRIblobCacheGet get) +{ + const struct intel_screen *const screen = + (struct intel_screen *) dri_screen->driverPrivate; + + if (!screen->disk_cache) + return; + + disk_cache_set_callbacks(screen->disk_cache, set, get); +} + static const __DRI2rendererQueryExtension intelRendererQueryExtension = { .base = { __DRI2_RENDERER_QUERY, 1 }, @@ -1505,6 +1519,11 @@ static const __DRIrobustnessExtension dri2Robustness = { .base = { __DRI2_ROBUSTNESS, 1 } }; +static const __DRI2blobExtension intelBlobExtension = { + .base = { __DRI2_BLOB, 1 }, + .set_cache_funcs = brw_set_cache_funcs +}; + static const __DRIextension *screenExtensions[] = { &intelTexBufferExtension.base, &intelFenceExtension.base, @@ -1513,6 +1532,7 @@ static const __DRIextension *screenExtensions[] = { &intelRendererQueryExtension.base, &dri2ConfigQueryExtension.base, &dri2NoErrorExtension.base, + &intelBlobExtension.base, NULL }; @@ -1525,6 +1545,7 @@ static const __DRIextension *intelRobustScreenExtensions[] = { &dri2ConfigQueryExtension.base, &dri2Robustness.base, &dri2NoErrorExtension.base, + &intelBlobExtension.base, NULL };