From: Marek Olšák Date: Wed, 6 Sep 2017 21:09:41 +0000 (+0200) Subject: disk_cache: make the thread queue resizable and low priority X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=7b4b8f6373a960e8996169a5b7fadd6bcca42d94;p=mesa.git disk_cache: make the thread queue resizable and low priority Acked-by: Timothy Arceri Reviewed-by: Nicolai Hähnle --- diff --git a/src/util/disk_cache.c b/src/util/disk_cache.c index b789a454eb0..33e4dc8e7df 100644 --- a/src/util/disk_cache.c +++ b/src/util/disk_cache.c @@ -358,13 +358,15 @@ disk_cache_create(const char *gpu_name, const char *timestamp, cache->max_size = max_size; - /* A limit of 32 jobs was choosen as observations of Deus Ex start-up times - * showed that we reached at most 11 jobs on an Intel i5-6400 CPU@2.70GHz - * (a fairly modest desktop CPU). 1 thread was chosen because we don't - * really care about getting things to disk quickly just that it's not - * blocking other tasks. + /* 1 thread was chosen because we don't really care about getting things + * to disk quickly just that it's not blocking other tasks. + * + * The queue will resize automatically when it's full, so adding new jobs + * doesn't stall. */ - util_queue_init(&cache->cache_queue, "disk_cache", 32, 1, 0); + util_queue_init(&cache->cache_queue, "disk_cache", 32, 1, + UTIL_QUEUE_INIT_RESIZE_IF_FULL | + UTIL_QUEUE_INIT_USE_MINIMUM_PRIORITY); uint8_t cache_version = CACHE_VERSION; size_t cv_size = sizeof(cache_version);